* pph-streamer.h (pph_output_tree_or_ref_1): New.
[official-gcc.git] / gcc / gcc.c
blob78eae57c526e7ba6fd86112b9de7704a06e16c33
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
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 "vec.h"
47 #include "filenames.h"
49 /* By default there is no special suffix for target executables. */
50 /* FIXME: when autoconf is fixed, remove the host check - dj */
51 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
52 #define HAVE_TARGET_EXECUTABLE_SUFFIX
53 #endif
55 /* By default there is no special suffix for host executables. */
56 #ifdef HOST_EXECUTABLE_SUFFIX
57 #define HAVE_HOST_EXECUTABLE_SUFFIX
58 #else
59 #define HOST_EXECUTABLE_SUFFIX ""
60 #endif
62 /* By default, the suffix for target object files is ".o". */
63 #ifdef TARGET_OBJECT_SUFFIX
64 #define HAVE_TARGET_OBJECT_SUFFIX
65 #else
66 #define TARGET_OBJECT_SUFFIX ".o"
67 #endif
69 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
71 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
72 #ifndef LIBRARY_PATH_ENV
73 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
74 #endif
76 /* If a stage of compilation returns an exit status >= 1,
77 compilation of that file ceases. */
79 #define MIN_FATAL_STATUS 1
81 /* Flag set by cppspec.c to 1. */
82 int is_cpp_driver;
84 /* Flag set to nonzero if an @file argument has been supplied to gcc. */
85 static bool at_file_supplied;
87 /* Definition of string containing the arguments given to configure. */
88 #include "configargs.h"
90 /* Flag saying to print the command line options understood by gcc and its
91 sub-processes. */
93 static int print_help_list;
95 /* Flag saying to print the version of gcc and its sub-processes. */
97 static int print_version;
99 /* Flag indicating whether we should ONLY print the command and
100 arguments (like verbose_flag) without executing the command.
101 Displayed arguments are quoted so that the generated command
102 line is suitable for execution. This is intended for use in
103 shell scripts to capture the driver-generated command line. */
104 static int verbose_only_flag;
106 /* Flag indicating how to print command line options of sub-processes. */
108 static int print_subprocess_help;
110 /* Whether we should report subprocess execution times to a file. */
112 FILE *report_times_to_file = NULL;
114 /* Nonzero means place this string before uses of /, so that include
115 and library files can be found in an alternate location. */
117 #ifdef TARGET_SYSTEM_ROOT
118 static const char *target_system_root = TARGET_SYSTEM_ROOT;
119 #else
120 static const char *target_system_root = 0;
121 #endif
123 /* Nonzero means pass the updated target_system_root to the compiler. */
125 static int target_system_root_changed;
127 /* Nonzero means append this string to target_system_root. */
129 static const char *target_sysroot_suffix = 0;
131 /* Nonzero means append this string to target_system_root for headers. */
133 static const char *target_sysroot_hdrs_suffix = 0;
135 /* Nonzero means write "temp" files in source directory
136 and use the source file's name in them, and don't delete them. */
138 static enum save_temps {
139 SAVE_TEMPS_NONE, /* no -save-temps */
140 SAVE_TEMPS_CWD, /* -save-temps in current directory */
141 SAVE_TEMPS_OBJ /* -save-temps in object directory */
142 } save_temps_flag;
144 /* Output file to use to get the object directory for -save-temps=obj */
145 static char *save_temps_prefix = 0;
146 static size_t save_temps_length = 0;
148 /* The compiler version. */
150 static const char *compiler_version;
152 /* The target version. */
154 static const char *const spec_version = DEFAULT_TARGET_VERSION;
156 /* The target machine. */
158 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
160 /* Nonzero if cross-compiling.
161 When -b is used, the value comes from the `specs' file. */
163 #ifdef CROSS_DIRECTORY_STRUCTURE
164 static const char *cross_compile = "1";
165 #else
166 static const char *cross_compile = "0";
167 #endif
169 /* Greatest exit code of sub-processes that has been encountered up to
170 now. */
171 static int greatest_status = 1;
173 /* This is the obstack which we use to allocate many strings. */
175 static struct obstack obstack;
177 /* This is the obstack to build an environment variable to pass to
178 collect2 that describes all of the relevant switches of what to
179 pass the compiler in building the list of pointers to constructors
180 and destructors. */
182 static struct obstack collect_obstack;
184 /* Forward declaration for prototypes. */
185 struct path_prefix;
186 struct prefix_list;
188 static void init_spec (void);
189 static void store_arg (const char *, int, int);
190 static void insert_wrapper (const char *);
191 static char *load_specs (const char *);
192 static void read_specs (const char *, int);
193 static void set_spec (const char *, const char *);
194 static struct compiler *lookup_compiler (const char *, size_t, const char *);
195 static char *build_search_list (const struct path_prefix *, const char *,
196 bool, bool);
197 static void xputenv (const char *);
198 static void putenv_from_prefixes (const struct path_prefix *, const char *,
199 bool);
200 static int access_check (const char *, int);
201 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
202 static void add_prefix (struct path_prefix *, const char *, const char *,
203 int, int, int);
204 static void add_sysrooted_prefix (struct path_prefix *, const char *,
205 const char *, int, int, int);
206 static char *skip_whitespace (char *);
207 static void delete_if_ordinary (const char *);
208 static void delete_temp_files (void);
209 static void delete_failure_queue (void);
210 static void clear_failure_queue (void);
211 static int check_live_switch (int, int);
212 static const char *handle_braces (const char *);
213 static inline bool input_suffix_matches (const char *, const char *);
214 static inline bool switch_matches (const char *, const char *, int);
215 static inline void mark_matching_switches (const char *, const char *, int);
216 static inline void process_marked_switches (void);
217 static const char *process_brace_body (const char *, const char *, const char *, int, int);
218 static const struct spec_function *lookup_spec_function (const char *);
219 static const char *eval_spec_function (const char *, const char *);
220 static const char *handle_spec_function (const char *);
221 static char *save_string (const char *, int);
222 static void set_collect_gcc_options (void);
223 static int do_spec_1 (const char *, int, const char *);
224 static int do_spec_2 (const char *);
225 static void do_option_spec (const char *, const char *);
226 static void do_self_spec (const char *);
227 static const char *find_file (const char *);
228 static int is_directory (const char *, bool);
229 static const char *validate_switches (const char *);
230 static void validate_all_switches (void);
231 static inline void validate_switches_from_spec (const char *);
232 static void give_switch (int, int);
233 static int used_arg (const char *, int);
234 static int default_arg (const char *, int);
235 static void set_multilib_dir (void);
236 static void print_multilib_info (void);
237 static void perror_with_name (const char *);
238 static void display_help (void);
239 static void add_preprocessor_option (const char *, int);
240 static void add_assembler_option (const char *, int);
241 static void add_linker_option (const char *, int);
242 static void process_command (unsigned int, struct cl_decoded_option *);
243 static int execute (void);
244 static void alloc_args (void);
245 static void clear_args (void);
246 static void fatal_signal (int);
247 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
248 static void init_gcc_specs (struct obstack *, const char *, const char *,
249 const char *);
250 #endif
251 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
252 static const char *convert_filename (const char *, int, int);
253 #endif
255 static const char *getenv_spec_function (int, const char **);
256 static const char *if_exists_spec_function (int, const char **);
257 static const char *if_exists_else_spec_function (int, const char **);
258 static const char *replace_outfile_spec_function (int, const char **);
259 static const char *remove_outfile_spec_function (int, const char **);
260 static const char *version_compare_spec_function (int, const char **);
261 static const char *include_spec_function (int, const char **);
262 static const char *find_file_spec_function (int, const char **);
263 static const char *find_plugindir_spec_function (int, const char **);
264 static const char *print_asm_header_spec_function (int, const char **);
265 static const char *compare_debug_dump_opt_spec_function (int, const char **);
266 static const char *compare_debug_self_opt_spec_function (int, const char **);
267 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
268 static const char *pass_through_libs_spec_func (int, const char **);
270 /* The Specs Language
272 Specs are strings containing lines, each of which (if not blank)
273 is made up of a program name, and arguments separated by spaces.
274 The program name must be exact and start from root, since no path
275 is searched and it is unreliable to depend on the current working directory.
276 Redirection of input or output is not supported; the subprograms must
277 accept filenames saying what files to read and write.
279 In addition, the specs can contain %-sequences to substitute variable text
280 or for conditional text. Here is a table of all defined %-sequences.
281 Note that spaces are not generated automatically around the results of
282 expanding these sequences; therefore, you can concatenate them together
283 or with constant text in a single argument.
285 %% substitute one % into the program name or argument.
286 %i substitute the name of the input file being processed.
287 %b substitute the basename of the input file being processed.
288 This is the substring up to (and not including) the last period
289 and not including the directory unless -save-temps was specified
290 to put temporaries in a different location.
291 %B same as %b, but include the file suffix (text after the last period).
292 %gSUFFIX
293 substitute a file name that has suffix SUFFIX and is chosen
294 once per compilation, and mark the argument a la %d. To reduce
295 exposure to denial-of-service attacks, the file name is now
296 chosen in a way that is hard to predict even when previously
297 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
298 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
299 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
300 had been pre-processed. Previously, %g was simply substituted
301 with a file name chosen once per compilation, without regard
302 to any appended suffix (which was therefore treated just like
303 ordinary text), making such attacks more likely to succeed.
304 %|SUFFIX
305 like %g, but if -pipe is in effect, expands simply to "-".
306 %mSUFFIX
307 like %g, but if -pipe is in effect, expands to nothing. (We have both
308 %| and %m to accommodate differences between system assemblers; see
309 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
310 %uSUFFIX
311 like %g, but generates a new temporary file name even if %uSUFFIX
312 was already seen.
313 %USUFFIX
314 substitutes the last file name generated with %uSUFFIX, generating a
315 new one if there is no such last file name. In the absence of any
316 %uSUFFIX, this is just like %gSUFFIX, except they don't share
317 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
318 would involve the generation of two distinct file names, one
319 for each `%g.s' and another for each `%U.s'. Previously, %U was
320 simply substituted with a file name chosen for the previous %u,
321 without regard to any appended suffix.
322 %jSUFFIX
323 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
324 writable, and if save-temps is off; otherwise, substitute the name
325 of a temporary file, just like %u. This temporary file is not
326 meant for communication between processes, but rather as a junk
327 disposal mechanism.
328 %.SUFFIX
329 substitutes .SUFFIX for the suffixes of a matched switch's args when
330 it is subsequently output with %*. SUFFIX is terminated by the next
331 space or %.
332 %d marks the argument containing or following the %d as a
333 temporary file name, so that that file will be deleted if GCC exits
334 successfully. Unlike %g, this contributes no text to the argument.
335 %w marks the argument containing or following the %w as the
336 "output file" of this compilation. This puts the argument
337 into the sequence of arguments that %o will substitute later.
338 %V indicates that this compilation produces no "output file".
339 %W{...}
340 like %{...} but mark last argument supplied within
341 as a file to be deleted on failure.
342 %o substitutes the names of all the output files, with spaces
343 automatically placed around them. You should write spaces
344 around the %o as well or the results are undefined.
345 %o is for use in the specs for running the linker.
346 Input files whose names have no recognized suffix are not compiled
347 at all, but they are included among the output files, so they will
348 be linked.
349 %O substitutes the suffix for object files. Note that this is
350 handled specially when it immediately follows %g, %u, or %U
351 (with or without a suffix argument) because of the need for
352 those to form complete file names. The handling is such that
353 %O is treated exactly as if it had already been substituted,
354 except that %g, %u, and %U do not currently support additional
355 SUFFIX characters following %O as they would following, for
356 example, `.o'.
357 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
358 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
359 and -B options) and -imultilib as necessary.
360 %s current argument is the name of a library or startup file of some sort.
361 Search for that file in a standard list of directories
362 and substitute the full name found.
363 %eSTR Print STR as an error message. STR is terminated by a newline.
364 Use this when inconsistent options are detected.
365 %nSTR Print STR as a notice. STR is terminated by a newline.
366 %x{OPTION} Accumulate an option for %X.
367 %X Output the accumulated linker options specified by compilations.
368 %Y Output the accumulated assembler options specified by compilations.
369 %Z Output the accumulated preprocessor options specified by compilations.
370 %a process ASM_SPEC as a spec.
371 This allows config.h to specify part of the spec for running as.
372 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
373 used here. This can be used to run a post-processor after the
374 assembler has done its job.
375 %D Dump out a -L option for each directory in startfile_prefixes.
376 If multilib_dir is set, extra entries are generated with it affixed.
377 %l process LINK_SPEC as a spec.
378 %L process LIB_SPEC as a spec.
379 %G process LIBGCC_SPEC as a spec.
380 %R Output the concatenation of target_system_root and
381 target_sysroot_suffix.
382 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
383 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
384 %C process CPP_SPEC as a spec.
385 %1 process CC1_SPEC as a spec.
386 %2 process CC1PLUS_SPEC as a spec.
387 %* substitute the variable part of a matched option. (See below.)
388 Note that each comma in the substituted string is replaced by
389 a single space.
390 %<S remove all occurrences of -S from the command line.
391 Note - this command is position dependent. % commands in the
392 spec string before this one will see -S, % commands in the
393 spec string after this one will not.
394 %>S Similar to "%<S", but keep it in the GCC command line.
395 %<S* remove all occurrences of all switches beginning with -S from the
396 command line.
397 %:function(args)
398 Call the named function FUNCTION, passing it ARGS. ARGS is
399 first processed as a nested spec string, then split into an
400 argument vector in the usual fashion. The function returns
401 a string which is processed as if it had appeared literally
402 as part of the current spec.
403 %{S} substitutes the -S switch, if that switch was given to GCC.
404 If that switch was not specified, this substitutes nothing.
405 Here S is a metasyntactic variable.
406 %{S*} substitutes all the switches specified to GCC whose names start
407 with -S. This is used for -o, -I, etc; switches that take
408 arguments. GCC considers `-o foo' as being one switch whose
409 name starts with `o'. %{o*} would substitute this text,
410 including the space; thus, two arguments would be generated.
411 %{S*&T*} likewise, but preserve order of S and T options (the order
412 of S and T in the spec is not significant). Can be any number
413 of ampersand-separated variables; for each the wild card is
414 optional. Useful for CPP as %{D*&U*&A*}.
416 %{S:X} substitutes X, if the -S switch was given to GCC.
417 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
418 %{S*:X} substitutes X if one or more switches whose names start
419 with -S was given to GCC. Normally X is substituted only
420 once, no matter how many such switches appeared. However,
421 if %* appears somewhere in X, then X will be substituted
422 once for each matching switch, with the %* replaced by the
423 part of that switch that matched the '*'.
424 %{.S:X} substitutes X, if processing a file with suffix S.
425 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
426 %{,S:X} substitutes X, if processing a file which will use spec S.
427 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
429 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
430 combined with '!', '.', ',', and '*' as above binding stronger
431 than the OR.
432 If %* appears in X, all of the alternatives must be starred, and
433 only the first matching alternative is substituted.
434 %{S:X; if S was given to GCC, substitutes X;
435 T:Y; else if T was given to GCC, substitutes Y;
436 :D} else substitutes D. There can be as many clauses as you need.
437 This may be combined with '.', '!', ',', '|', and '*' as above.
439 %(Spec) processes a specification defined in a specs file as *Spec:
440 %[Spec] as above, but put __ around -D arguments
442 The conditional text X in a %{S:X} or similar construct may contain
443 other nested % constructs or spaces, or even newlines. They are
444 processed as usual, as described above. Trailing white space in X is
445 ignored. White space may also appear anywhere on the left side of the
446 colon in these constructs, except between . or * and the corresponding
447 word.
449 The -O, -f, -m, and -W switches are handled specifically in these
450 constructs. If another value of -O or the negated form of a -f, -m, or
451 -W switch is found later in the command line, the earlier switch
452 value is ignored, except with {S*} where S is just one letter; this
453 passes all matching options.
455 The character | at the beginning of the predicate text is used to indicate
456 that a command should be piped to the following command, but only if -pipe
457 is specified.
459 Note that it is built into GCC which switches take arguments and which
460 do not. You might think it would be useful to generalize this to
461 allow each compiler's spec to say which switches take arguments. But
462 this cannot be done in a consistent fashion. GCC cannot even decide
463 which input files have been specified without knowing which switches
464 take arguments, and it must know which input files to compile in order
465 to tell which compilers to run.
467 GCC also knows implicitly that arguments starting in `-l' are to be
468 treated as compiler output files, and passed to the linker in their
469 proper position among the other output files. */
471 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
473 /* config.h can define ASM_SPEC to provide extra args to the assembler
474 or extra switch-translations. */
475 #ifndef ASM_SPEC
476 #define ASM_SPEC ""
477 #endif
479 /* config.h can define ASM_FINAL_SPEC to run a post processor after
480 the assembler has run. */
481 #ifndef ASM_FINAL_SPEC
482 #define ASM_FINAL_SPEC ""
483 #endif
485 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
486 or extra switch-translations. */
487 #ifndef CPP_SPEC
488 #define CPP_SPEC ""
489 #endif
491 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
492 or extra switch-translations. */
493 #ifndef CC1_SPEC
494 #define CC1_SPEC ""
495 #endif
497 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
498 or extra switch-translations. */
499 #ifndef CC1PLUS_SPEC
500 #define CC1PLUS_SPEC ""
501 #endif
503 /* config.h can define LINK_SPEC to provide extra args to the linker
504 or extra switch-translations. */
505 #ifndef LINK_SPEC
506 #define LINK_SPEC ""
507 #endif
509 /* config.h can define LIB_SPEC to override the default libraries. */
510 #ifndef LIB_SPEC
511 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
512 #endif
514 /* mudflap specs */
515 #ifndef MFWRAP_SPEC
516 /* XXX: valid only for GNU ld */
517 /* XXX: should exactly match hooks provided by libmudflap.a */
518 #define MFWRAP_SPEC " %{static: %{fmudflap|fmudflapth: \
519 --wrap=malloc --wrap=free --wrap=calloc --wrap=realloc\
520 --wrap=mmap --wrap=munmap --wrap=alloca\
521 } %{fmudflapth: --wrap=pthread_create\
522 }} %{fmudflap|fmudflapth: --wrap=main}"
523 #endif
524 #ifndef MFLIB_SPEC
525 #define MFLIB_SPEC "%{fmudflap|fmudflapth: -export-dynamic}"
526 #endif
528 /* When using -fsplit-stack we need to wrap pthread_create, in order
529 to initialize the stack guard. We always use wrapping, rather than
530 shared library ordering, and we keep the wrapper function in
531 libgcc. This is not yet a real spec, though it could become one;
532 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
533 only works with GNU ld and gold. FIXME: This is incompatible with
534 -fmudflap when linking statically, which wants to do its own
535 wrapping. */
536 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
538 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
539 included. */
540 #ifndef LIBGCC_SPEC
541 #if defined(REAL_LIBGCC_SPEC)
542 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
543 #elif defined(LINK_LIBGCC_SPECIAL_1)
544 /* Have gcc do the search for libgcc.a. */
545 #define LIBGCC_SPEC "libgcc.a%s"
546 #else
547 #define LIBGCC_SPEC "-lgcc"
548 #endif
549 #endif
551 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
552 #ifndef STARTFILE_SPEC
553 #define STARTFILE_SPEC \
554 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
555 #endif
557 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
558 #ifndef ENDFILE_SPEC
559 #define ENDFILE_SPEC ""
560 #endif
562 #ifndef LINKER_NAME
563 #define LINKER_NAME "collect2"
564 #endif
566 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
567 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
568 #else
569 #define ASM_MAP ""
570 #endif
572 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
573 to the assembler. */
574 #ifndef ASM_DEBUG_SPEC
575 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
576 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
577 # define ASM_DEBUG_SPEC \
578 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
579 ? "%{!g0:%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}}" ASM_MAP \
580 : "%{!g0:%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
581 # else
582 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
583 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gstabs}}" ASM_MAP
584 # endif
585 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
586 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gdwarf2}}" ASM_MAP
587 # endif
588 # endif
589 #endif
590 #ifndef ASM_DEBUG_SPEC
591 # define ASM_DEBUG_SPEC ""
592 #endif
594 /* Here is the spec for running the linker, after compiling all files. */
596 /* This is overridable by the target in case they need to specify the
597 -lgcc and -lc order specially, yet not require them to override all
598 of LINK_COMMAND_SPEC. */
599 #ifndef LINK_GCC_C_SEQUENCE_SPEC
600 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
601 #endif
603 #ifndef LINK_SSP_SPEC
604 #ifdef TARGET_LIBC_PROVIDES_SSP
605 #define LINK_SSP_SPEC "%{fstack-protector:}"
606 #else
607 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all:-lssp_nonshared -lssp}"
608 #endif
609 #endif
611 #ifndef LINK_PIE_SPEC
612 #ifdef HAVE_LD_PIE
613 #define LINK_PIE_SPEC "%{pie:-pie} "
614 #else
615 #define LINK_PIE_SPEC "%{pie:} "
616 #endif
617 #endif
619 #ifndef LINK_BUILDID_SPEC
620 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
621 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
622 # endif
623 #endif
625 /* Conditional to test whether the LTO plugin is used or not.
626 FIXME: For slim LTO we will need to enable plugin unconditionally. This
627 still cause problems with PLUGIN_LD != LD and when plugin is built but
628 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
629 plugin only when LTO is enabled. We still honor explicit
630 -fuse-linker-plugin if the linker used understands -plugin. */
632 /* The linker has some plugin support. */
633 #if HAVE_LTO_PLUGIN > 0
634 /* The linker used has full plugin support, use LTO plugin by default. */
635 #if HAVE_LTO_PLUGIN == 2
636 #define PLUGIN_COND "!fno-use-linker-plugin:%{flto|flto=*|fuse-linker-plugin"
637 #define PLUGIN_COND_CLOSE "}"
638 #else
639 /* The linker used has limited plugin support, use LTO plugin with explicit
640 -fuse-linker-plugin. */
641 #define PLUGIN_COND "fuse-linker-plugin"
642 #define PLUGIN_COND_CLOSE ""
643 #endif
644 #define LINK_PLUGIN_SPEC \
645 "%{"PLUGIN_COND": \
646 -plugin %(linker_plugin_file) \
647 -plugin-opt=%(lto_wrapper) \
648 -plugin-opt=-fresolution=%u.res \
649 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
650 }"PLUGIN_COND_CLOSE
651 #else
652 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
653 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
654 %e-fuse-linker-plugin is not supported in this configuration}"
655 #endif
658 /* -u* was put back because both BSD and SysV seem to support it. */
659 /* %{static:} simply prevents an error message if the target machine
660 doesn't handle -static. */
661 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
662 scripts which exist in user specified directories, or in standard
663 directories. */
664 /* We pass any -flto flags on to the linker, which is expected
665 to understand them. In practice, this means it had better be collect2. */
666 /* %{e*} includes -export-dynamic; see comment in common.opt. */
667 #ifndef LINK_COMMAND_SPEC
668 #define LINK_COMMAND_SPEC "\
669 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
670 %(linker) " \
671 LINK_PLUGIN_SPEC \
672 "%{flto|flto=*:%<fcompare-debug*} \
673 %{flto} %{flto=*} %l " LINK_PIE_SPEC \
674 "%X %{o*} %{e*} %{N} %{n} %{r}\
675 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}}\
676 %{static:} %{L*} %(mfwrap) %(link_libgcc) %o\
677 %{fopenmp|ftree-parallelize-loops=*:%:include(libgomp.spec)%(link_gomp)}\
678 %(mflib) " STACK_SPLIT_SPEC "\
679 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov}\
680 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
681 %{!nostdlib:%{!nostartfiles:%E}} %{T*} }}}}}}"
682 #endif
684 #ifndef LINK_LIBGCC_SPEC
685 /* Generate -L options for startfile prefix list. */
686 # define LINK_LIBGCC_SPEC "%D"
687 #endif
689 #ifndef STARTFILE_PREFIX_SPEC
690 # define STARTFILE_PREFIX_SPEC ""
691 #endif
693 #ifndef SYSROOT_SPEC
694 # define SYSROOT_SPEC "--sysroot=%R"
695 #endif
697 #ifndef SYSROOT_SUFFIX_SPEC
698 # define SYSROOT_SUFFIX_SPEC ""
699 #endif
701 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
702 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
703 #endif
705 static const char *asm_debug;
706 static const char *cpp_spec = CPP_SPEC;
707 static const char *cc1_spec = CC1_SPEC;
708 static const char *cc1plus_spec = CC1PLUS_SPEC;
709 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
710 static const char *link_ssp_spec = LINK_SSP_SPEC;
711 static const char *asm_spec = ASM_SPEC;
712 static const char *asm_final_spec = ASM_FINAL_SPEC;
713 static const char *link_spec = LINK_SPEC;
714 static const char *lib_spec = LIB_SPEC;
715 static const char *mfwrap_spec = MFWRAP_SPEC;
716 static const char *mflib_spec = MFLIB_SPEC;
717 static const char *link_gomp_spec = "";
718 static const char *libgcc_spec = LIBGCC_SPEC;
719 static const char *endfile_spec = ENDFILE_SPEC;
720 static const char *startfile_spec = STARTFILE_SPEC;
721 static const char *linker_name_spec = LINKER_NAME;
722 static const char *linker_plugin_file_spec = "";
723 static const char *lto_wrapper_spec = "";
724 static const char *lto_gcc_spec = "";
725 static const char *link_command_spec = LINK_COMMAND_SPEC;
726 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
727 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
728 static const char *sysroot_spec = SYSROOT_SPEC;
729 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
730 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
732 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
733 There should be no need to override these in target dependent files,
734 but we need to copy them to the specs file so that newer versions
735 of the GCC driver can correctly drive older tool chains with the
736 appropriate -B options. */
738 /* When cpplib handles traditional preprocessing, get rid of this, and
739 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
740 that we default the front end language better. */
741 static const char *trad_capable_cpp =
742 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
744 /* We don't wrap .d files in %W{} since a missing .d file, and
745 therefore no dependency entry, confuses make into thinking a .o
746 file that happens to exist is up-to-date. */
747 static const char *cpp_unique_options =
748 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
749 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
750 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
751 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
752 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
753 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
754 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
755 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
756 %{fmudflap:-D_MUDFLAP -include mf-runtime.h}\
757 %{fmudflapth:-D_MUDFLAP -D_MUDFLAPTH -include mf-runtime.h}\
758 %{E|M|MM:%W{o*}}";
760 /* This contains cpp options which are common with cc1_options and are passed
761 only when preprocessing only to avoid duplication. We pass the cc1 spec
762 options to the preprocessor so that it the cc1 spec may manipulate
763 options used to set target flags. Those special target flags settings may
764 in turn cause preprocessor symbols to be defined specially. */
765 static const char *cpp_options =
766 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
767 %{f*} %{g*:%{!g0:%{g*} %{!fno-working-directory:-fworking-directory}}} %{O*}\
768 %{undef} %{save-temps*:-fpch-preprocess}";
770 /* This contains cpp options which are not passed when the preprocessor
771 output will be used by another program. */
772 static const char *cpp_debug_options = "%{d*}";
774 /* NB: This is shared amongst all front-ends, except for Ada. */
775 static const char *cc1_options =
776 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
777 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
778 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
779 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
780 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
781 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
782 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
783 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
784 %{-target-help:--target-help}\
785 %{-version:--version}\
786 %{-help=*:--help=%*}\
787 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
788 %{fsyntax-only:-o %j} %{-param*}\
789 %{fmudflap|fmudflapth:-fno-builtin -fno-merge-constants}\
790 %{coverage:-fprofile-arcs -ftest-coverage}";
792 static const char *asm_options =
793 "%{-target-help:%:print-asm-header()} "
794 #if HAVE_GNU_AS
795 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
796 to the assembler equivalents. */
797 "%{v} %{w:-W} %{I*} "
798 #endif
799 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
801 static const char *invoke_as =
802 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
803 "%{!fwpa:\
804 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
805 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
807 #else
808 "%{!fwpa:\
809 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
810 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
812 #endif
814 /* Some compilers have limits on line lengths, and the multilib_select
815 and/or multilib_matches strings can be very long, so we build them at
816 run time. */
817 static struct obstack multilib_obstack;
818 static const char *multilib_select;
819 static const char *multilib_matches;
820 static const char *multilib_defaults;
821 static const char *multilib_exclusions;
823 /* Check whether a particular argument is a default argument. */
825 #ifndef MULTILIB_DEFAULTS
826 #define MULTILIB_DEFAULTS { "" }
827 #endif
829 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
831 #ifndef DRIVER_SELF_SPECS
832 #define DRIVER_SELF_SPECS ""
833 #endif
835 /* Adding -fopenmp should imply pthreads. This is particularly important
836 for targets that use different start files and suchlike. */
837 #ifndef GOMP_SELF_SPECS
838 #define GOMP_SELF_SPECS "%{fopenmp|ftree-parallelize-loops=*: -pthread}"
839 #endif
841 static const char *const driver_self_specs[] = {
842 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
843 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS
846 #ifndef OPTION_DEFAULT_SPECS
847 #define OPTION_DEFAULT_SPECS { "", "" }
848 #endif
850 struct default_spec
852 const char *name;
853 const char *spec;
856 static const struct default_spec
857 option_default_specs[] = { OPTION_DEFAULT_SPECS };
859 struct user_specs
861 struct user_specs *next;
862 const char *filename;
865 static struct user_specs *user_specs_head, *user_specs_tail;
868 /* Record the mapping from file suffixes for compilation specs. */
870 struct compiler
872 const char *suffix; /* Use this compiler for input files
873 whose names end in this suffix. */
875 const char *spec; /* To use this compiler, run this spec. */
877 const char *cpp_spec; /* If non-NULL, substitute this spec
878 for `%C', rather than the usual
879 cpp_spec. */
880 const int combinable; /* If nonzero, compiler can deal with
881 multiple source files at once (IMA). */
882 const int needs_preprocessing; /* If nonzero, source files need to
883 be run through a preprocessor. */
886 /* Pointer to a vector of `struct compiler' that gives the spec for
887 compiling a file, based on its suffix.
888 A file that does not end in any of these suffixes will be passed
889 unchanged to the loader and nothing else will be done to it.
891 An entry containing two 0s is used to terminate the vector.
893 If multiple entries match a file, the last matching one is used. */
895 static struct compiler *compilers;
897 /* Number of entries in `compilers', not counting the null terminator. */
899 static int n_compilers;
901 /* The default list of file name suffixes and their compilation specs. */
903 static const struct compiler default_compilers[] =
905 /* Add lists of suffixes of known languages here. If those languages
906 were not present when we built the driver, we will hit these copies
907 and be given a more meaningful error than "file not used since
908 linking is not done". */
909 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
910 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
911 {".mii", "#Objective-C++", 0, 0, 0},
912 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
913 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
914 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
915 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
916 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
917 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
918 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
919 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
920 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
921 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
922 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
923 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
924 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
925 {".r", "#Ratfor", 0, 0, 0},
926 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
927 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
928 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
929 {".go", "#Go", 0, 1, 0},
930 /* Next come the entries for C. */
931 {".c", "@c", 0, 0, 1},
932 {"@c",
933 /* cc1 has an integrated ISO C preprocessor. We should invoke the
934 external preprocessor if -save-temps is given. */
935 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
936 %{!E:%{!M:%{!MM:\
937 %{traditional:\
938 %eGNU C no longer supports -traditional without -E}\
939 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
940 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
941 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
942 %(cc1_options)}\
943 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
944 cc1 %(cpp_unique_options) %(cc1_options)}}}\
945 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
946 {"-",
947 "%{!E:%e-E or -x required when input is from standard input}\
948 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
949 {".h", "@c-header", 0, 0, 0},
950 {"@c-header",
951 /* cc1 has an integrated ISO C preprocessor. We should invoke the
952 external preprocessor if -save-temps is given. */
953 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
954 %{!E:%{!M:%{!MM:\
955 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
956 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
957 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
958 %(cc1_options)\
959 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
960 %W{o*:--output-pch=%*}}%V}\
961 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
962 cc1 %(cpp_unique_options) %(cc1_options)\
963 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
964 %W{o*:--output-pch=%*}}%V}}}}}}", 0, 0, 0},
965 {".i", "@cpp-output", 0, 0, 0},
966 {"@cpp-output",
967 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
968 {".s", "@assembler", 0, 0, 0},
969 {"@assembler",
970 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
971 {".sx", "@assembler-with-cpp", 0, 0, 0},
972 {".S", "@assembler-with-cpp", 0, 0, 0},
973 {"@assembler-with-cpp",
974 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
975 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
976 %{E|M|MM:%(cpp_debug_options)}\
977 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
978 as %(asm_debug) %(asm_options) %|.s %A }}}}"
979 #else
980 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
981 %{E|M|MM:%(cpp_debug_options)}\
982 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
983 as %(asm_debug) %(asm_options) %m.s %A }}}}"
984 #endif
985 , 0, 0, 0},
987 #include "specs.h"
988 /* Mark end of table. */
989 {0, 0, 0, 0, 0}
992 /* Number of elements in default_compilers, not counting the terminator. */
994 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
996 typedef char *char_p; /* For DEF_VEC_P. */
997 DEF_VEC_P(char_p);
998 DEF_VEC_ALLOC_P(char_p,heap);
1000 /* A vector of options to give to the linker.
1001 These options are accumulated by %x,
1002 and substituted into the linker command with %X. */
1003 static VEC(char_p,heap) *linker_options;
1005 /* A vector of options to give to the assembler.
1006 These options are accumulated by -Wa,
1007 and substituted into the assembler command with %Y. */
1008 static VEC(char_p,heap) *assembler_options;
1010 /* A vector of options to give to the preprocessor.
1011 These options are accumulated by -Wp,
1012 and substituted into the preprocessor command with %Z. */
1013 static VEC(char_p,heap) *preprocessor_options;
1015 static char *
1016 skip_whitespace (char *p)
1018 while (1)
1020 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1021 be considered whitespace. */
1022 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1023 return p + 1;
1024 else if (*p == '\n' || *p == ' ' || *p == '\t')
1025 p++;
1026 else if (*p == '#')
1028 while (*p != '\n')
1029 p++;
1030 p++;
1032 else
1033 break;
1036 return p;
1038 /* Structures to keep track of prefixes to try when looking for files. */
1040 struct prefix_list
1042 const char *prefix; /* String to prepend to the path. */
1043 struct prefix_list *next; /* Next in linked list. */
1044 int require_machine_suffix; /* Don't use without machine_suffix. */
1045 /* 2 means try both machine_suffix and just_machine_suffix. */
1046 int priority; /* Sort key - priority within list. */
1047 int os_multilib; /* 1 if OS multilib scheme should be used,
1048 0 for GCC multilib scheme. */
1051 struct path_prefix
1053 struct prefix_list *plist; /* List of prefixes to try */
1054 int max_len; /* Max length of a prefix in PLIST */
1055 const char *name; /* Name of this list (used in config stuff) */
1058 /* List of prefixes to try when looking for executables. */
1060 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1062 /* List of prefixes to try when looking for startup (crt0) files. */
1064 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1066 /* List of prefixes to try when looking for include files. */
1068 static struct path_prefix include_prefixes = { 0, 0, "include" };
1070 /* Suffix to attach to directories searched for commands.
1071 This looks like `MACHINE/VERSION/'. */
1073 static const char *machine_suffix = 0;
1075 /* Suffix to attach to directories searched for commands.
1076 This is just `MACHINE/'. */
1078 static const char *just_machine_suffix = 0;
1080 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1082 static const char *gcc_exec_prefix;
1084 /* Adjusted value of standard_libexec_prefix. */
1086 static const char *gcc_libexec_prefix;
1088 /* Default prefixes to attach to command names. */
1090 #ifndef STANDARD_STARTFILE_PREFIX_1
1091 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1092 #endif
1093 #ifndef STANDARD_STARTFILE_PREFIX_2
1094 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1095 #endif
1097 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1098 #undef MD_EXEC_PREFIX
1099 #undef MD_STARTFILE_PREFIX
1100 #undef MD_STARTFILE_PREFIX_1
1101 #endif
1103 /* If no prefixes defined, use the null string, which will disable them. */
1104 #ifndef MD_EXEC_PREFIX
1105 #define MD_EXEC_PREFIX ""
1106 #endif
1107 #ifndef MD_STARTFILE_PREFIX
1108 #define MD_STARTFILE_PREFIX ""
1109 #endif
1110 #ifndef MD_STARTFILE_PREFIX_1
1111 #define MD_STARTFILE_PREFIX_1 ""
1112 #endif
1114 /* These directories are locations set at configure-time based on the
1115 --prefix option provided to configure. Their initializers are
1116 defined in Makefile.in. These paths are not *directly* used when
1117 gcc_exec_prefix is set because, in that case, we know where the
1118 compiler has been installed, and use paths relative to that
1119 location instead. */
1120 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1121 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1122 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1123 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1125 /* For native compilers, these are well-known paths containing
1126 components that may be provided by the system. For cross
1127 compilers, these paths are not used. */
1128 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1129 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1130 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1131 static const char *const standard_startfile_prefix_1
1132 = STANDARD_STARTFILE_PREFIX_1;
1133 static const char *const standard_startfile_prefix_2
1134 = STANDARD_STARTFILE_PREFIX_2;
1136 /* A relative path to be used in finding the location of tools
1137 relative to the driver. */
1138 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1140 /* Subdirectory to use for locating libraries. Set by
1141 set_multilib_dir based on the compilation options. */
1143 static const char *multilib_dir;
1145 /* Subdirectory to use for locating libraries in OS conventions. Set by
1146 set_multilib_dir based on the compilation options. */
1148 static const char *multilib_os_dir;
1150 /* Structure to keep track of the specs that have been defined so far.
1151 These are accessed using %(specname) or %[specname] in a compiler
1152 or link spec. */
1154 struct spec_list
1156 /* The following 2 fields must be first */
1157 /* to allow EXTRA_SPECS to be initialized */
1158 const char *name; /* name of the spec. */
1159 const char *ptr; /* available ptr if no static pointer */
1161 /* The following fields are not initialized */
1162 /* by EXTRA_SPECS */
1163 const char **ptr_spec; /* pointer to the spec itself. */
1164 struct spec_list *next; /* Next spec in linked list. */
1165 int name_len; /* length of the name */
1166 int alloc_p; /* whether string was allocated */
1169 #define INIT_STATIC_SPEC(NAME,PTR) \
1170 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, 0 }
1172 /* List of statically defined specs. */
1173 static struct spec_list static_specs[] =
1175 INIT_STATIC_SPEC ("asm", &asm_spec),
1176 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1177 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1178 INIT_STATIC_SPEC ("asm_options", &asm_options),
1179 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1180 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1181 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1182 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1183 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1184 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1185 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1186 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1187 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1188 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1189 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1190 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1191 INIT_STATIC_SPEC ("link", &link_spec),
1192 INIT_STATIC_SPEC ("lib", &lib_spec),
1193 INIT_STATIC_SPEC ("mfwrap", &mfwrap_spec),
1194 INIT_STATIC_SPEC ("mflib", &mflib_spec),
1195 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1196 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1197 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1198 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1199 INIT_STATIC_SPEC ("version", &compiler_version),
1200 INIT_STATIC_SPEC ("multilib", &multilib_select),
1201 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1202 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1203 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1204 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1205 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1206 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1207 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1208 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1209 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1210 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1211 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1212 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1213 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1214 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1215 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1216 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1217 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1220 #ifdef EXTRA_SPECS /* additional specs needed */
1221 /* Structure to keep track of just the first two args of a spec_list.
1222 That is all that the EXTRA_SPECS macro gives us. */
1223 struct spec_list_1
1225 const char *const name;
1226 const char *const ptr;
1229 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1230 static struct spec_list *extra_specs = (struct spec_list *) 0;
1231 #endif
1233 /* List of dynamically allocates specs that have been defined so far. */
1235 static struct spec_list *specs = (struct spec_list *) 0;
1237 /* List of static spec functions. */
1239 static const struct spec_function static_spec_functions[] =
1241 { "getenv", getenv_spec_function },
1242 { "if-exists", if_exists_spec_function },
1243 { "if-exists-else", if_exists_else_spec_function },
1244 { "replace-outfile", replace_outfile_spec_function },
1245 { "remove-outfile", remove_outfile_spec_function },
1246 { "version-compare", version_compare_spec_function },
1247 { "include", include_spec_function },
1248 { "find-file", find_file_spec_function },
1249 { "find-plugindir", find_plugindir_spec_function },
1250 { "print-asm-header", print_asm_header_spec_function },
1251 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1252 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1253 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1254 { "pass-through-libs", pass_through_libs_spec_func },
1255 #ifdef EXTRA_SPEC_FUNCTIONS
1256 EXTRA_SPEC_FUNCTIONS
1257 #endif
1258 { 0, 0 }
1261 static int processing_spec_function;
1263 /* Add appropriate libgcc specs to OBSTACK, taking into account
1264 various permutations of -shared-libgcc, -shared, and such. */
1266 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1268 #ifndef USE_LD_AS_NEEDED
1269 #define USE_LD_AS_NEEDED 0
1270 #endif
1272 static void
1273 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1274 const char *static_name, const char *eh_name)
1276 char *buf;
1278 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1279 "%{!static:%{!static-libgcc:"
1280 #if USE_LD_AS_NEEDED
1281 "%{!shared-libgcc:",
1282 static_name, " --as-needed ", shared_name, " --no-as-needed"
1284 "%{shared-libgcc:",
1285 shared_name, "%{!shared: ", static_name, "}"
1287 #else
1288 "%{!shared:"
1289 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1290 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1292 #ifdef LINK_EH_SPEC
1293 "%{shared:"
1294 "%{shared-libgcc:", shared_name, "}"
1295 "%{!shared-libgcc:", static_name, "}"
1297 #else
1298 "%{shared:", shared_name, "}"
1299 #endif
1300 #endif
1301 "}}", NULL);
1303 obstack_grow (obstack, buf, strlen (buf));
1304 free (buf);
1306 #endif /* ENABLE_SHARED_LIBGCC */
1308 /* Initialize the specs lookup routines. */
1310 static void
1311 init_spec (void)
1313 struct spec_list *next = (struct spec_list *) 0;
1314 struct spec_list *sl = (struct spec_list *) 0;
1315 int i;
1317 if (specs)
1318 return; /* Already initialized. */
1320 if (verbose_flag)
1321 fnotice (stderr, "Using built-in specs.\n");
1323 #ifdef EXTRA_SPECS
1324 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1326 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1328 sl = &extra_specs[i];
1329 sl->name = extra_specs_1[i].name;
1330 sl->ptr = extra_specs_1[i].ptr;
1331 sl->next = next;
1332 sl->name_len = strlen (sl->name);
1333 sl->ptr_spec = &sl->ptr;
1334 next = sl;
1336 #endif
1338 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1340 sl = &static_specs[i];
1341 sl->next = next;
1342 next = sl;
1345 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1346 /* ??? If neither -shared-libgcc nor --static-libgcc was
1347 seen, then we should be making an educated guess. Some proposed
1348 heuristics for ELF include:
1350 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1351 program will be doing dynamic loading, which will likely
1352 need the shared libgcc.
1354 (2) If "-ldl", then it's also a fair bet that we're doing
1355 dynamic loading.
1357 (3) For each ET_DYN we're linking against (either through -lfoo
1358 or /some/path/foo.so), check to see whether it or one of
1359 its dependencies depends on a shared libgcc.
1361 (4) If "-shared"
1363 If the runtime is fixed to look for program headers instead
1364 of calling __register_frame_info at all, for each object,
1365 use the shared libgcc if any EH symbol referenced.
1367 If crtstuff is fixed to not invoke __register_frame_info
1368 automatically, for each object, use the shared libgcc if
1369 any non-empty unwind section found.
1371 Doing any of this probably requires invoking an external program to
1372 do the actual object file scanning. */
1374 const char *p = libgcc_spec;
1375 int in_sep = 1;
1377 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1378 when given the proper command line arguments. */
1379 while (*p)
1381 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1383 init_gcc_specs (&obstack,
1384 "-lgcc_s"
1385 #ifdef USE_LIBUNWIND_EXCEPTIONS
1386 " -lunwind"
1387 #endif
1389 "-lgcc",
1390 "-lgcc_eh"
1391 #ifdef USE_LIBUNWIND_EXCEPTIONS
1392 # ifdef HAVE_LD_STATIC_DYNAMIC
1393 " %{!static:" LD_STATIC_OPTION "} -lunwind"
1394 " %{!static:" LD_DYNAMIC_OPTION "}"
1395 # else
1396 " -lunwind"
1397 # endif
1398 #endif
1401 p += 5;
1402 in_sep = 0;
1404 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1406 /* Ug. We don't know shared library extensions. Hope that
1407 systems that use this form don't do shared libraries. */
1408 init_gcc_specs (&obstack,
1409 "-lgcc_s",
1410 "libgcc.a%s",
1411 "libgcc_eh.a%s"
1412 #ifdef USE_LIBUNWIND_EXCEPTIONS
1413 " -lunwind"
1414 #endif
1416 p += 10;
1417 in_sep = 0;
1419 else
1421 obstack_1grow (&obstack, *p);
1422 in_sep = (*p == ' ');
1423 p += 1;
1427 obstack_1grow (&obstack, '\0');
1428 libgcc_spec = XOBFINISH (&obstack, const char *);
1430 #endif
1431 #ifdef USE_AS_TRADITIONAL_FORMAT
1432 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1434 static const char tf[] = "--traditional-format ";
1435 obstack_grow (&obstack, tf, sizeof(tf) - 1);
1436 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1437 asm_spec = XOBFINISH (&obstack, const char *);
1439 #endif
1441 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC
1442 # ifdef LINK_BUILDID_SPEC
1443 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1444 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof(LINK_BUILDID_SPEC) - 1);
1445 # endif
1446 # ifdef LINK_EH_SPEC
1447 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1448 obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1449 # endif
1450 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1451 link_spec = XOBFINISH (&obstack, const char *);
1452 #endif
1454 specs = sl;
1457 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1458 removed; If the spec starts with a + then SPEC is added to the end of the
1459 current spec. */
1461 static void
1462 set_spec (const char *name, const char *spec)
1464 struct spec_list *sl;
1465 const char *old_spec;
1466 int name_len = strlen (name);
1467 int i;
1469 /* If this is the first call, initialize the statically allocated specs. */
1470 if (!specs)
1472 struct spec_list *next = (struct spec_list *) 0;
1473 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1475 sl = &static_specs[i];
1476 sl->next = next;
1477 next = sl;
1479 specs = sl;
1482 /* See if the spec already exists. */
1483 for (sl = specs; sl; sl = sl->next)
1484 if (name_len == sl->name_len && !strcmp (sl->name, name))
1485 break;
1487 if (!sl)
1489 /* Not found - make it. */
1490 sl = XNEW (struct spec_list);
1491 sl->name = xstrdup (name);
1492 sl->name_len = name_len;
1493 sl->ptr_spec = &sl->ptr;
1494 sl->alloc_p = 0;
1495 *(sl->ptr_spec) = "";
1496 sl->next = specs;
1497 specs = sl;
1500 old_spec = *(sl->ptr_spec);
1501 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1502 ? concat (old_spec, spec + 1, NULL)
1503 : xstrdup (spec));
1505 #ifdef DEBUG_SPECS
1506 if (verbose_flag)
1507 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1508 #endif
1510 /* Free the old spec. */
1511 if (old_spec && sl->alloc_p)
1512 free (CONST_CAST(char *, old_spec));
1514 sl->alloc_p = 1;
1517 /* Accumulate a command (program name and args), and run it. */
1519 typedef const char *const_char_p; /* For DEF_VEC_P. */
1520 DEF_VEC_P(const_char_p);
1521 DEF_VEC_ALLOC_P(const_char_p,heap);
1523 /* Vector of pointers to arguments in the current line of specifications. */
1525 static VEC(const_char_p,heap) *argbuf;
1527 /* Position in the argbuf vector containing the name of the output file
1528 (the value associated with the "-o" flag). */
1530 static int have_o_argbuf_index = 0;
1532 /* Were the options -c, -S or -E passed. */
1533 static int have_c = 0;
1535 /* Was the option -o passed. */
1536 static int have_o = 0;
1538 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1539 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1540 it here. */
1542 static struct temp_name {
1543 const char *suffix; /* suffix associated with the code. */
1544 int length; /* strlen (suffix). */
1545 int unique; /* Indicates whether %g or %u/%U was used. */
1546 const char *filename; /* associated filename. */
1547 int filename_length; /* strlen (filename). */
1548 struct temp_name *next;
1549 } *temp_names;
1551 /* Number of commands executed so far. */
1553 static int execution_count;
1555 /* Number of commands that exited with a signal. */
1557 static int signal_count;
1559 /* Allocate the argument vector. */
1561 static void
1562 alloc_args (void)
1564 argbuf = VEC_alloc (const_char_p, heap, 10);
1567 /* Clear out the vector of arguments (after a command is executed). */
1569 static void
1570 clear_args (void)
1572 VEC_truncate (const_char_p, argbuf, 0);
1575 /* Add one argument to the vector at the end.
1576 This is done when a space is seen or at the end of the line.
1577 If DELETE_ALWAYS is nonzero, the arg is a filename
1578 and the file should be deleted eventually.
1579 If DELETE_FAILURE is nonzero, the arg is a filename
1580 and the file should be deleted if this compilation fails. */
1582 static void
1583 store_arg (const char *arg, int delete_always, int delete_failure)
1585 VEC_safe_push (const_char_p, heap, argbuf, arg);
1587 if (strcmp (arg, "-o") == 0)
1588 have_o_argbuf_index = VEC_length (const_char_p, argbuf);
1589 if (delete_always || delete_failure)
1591 const char *p;
1592 /* If the temporary file we should delete is specified as
1593 part of a joined argument extract the filename. */
1594 if (arg[0] == '-'
1595 && (p = strrchr (arg, '=')))
1596 arg = p + 1;
1597 record_temp_file (arg, delete_always, delete_failure);
1601 /* Load specs from a file name named FILENAME, replacing occurrences of
1602 various different types of line-endings, \r\n, \n\r and just \r, with
1603 a single \n. */
1605 static char *
1606 load_specs (const char *filename)
1608 int desc;
1609 int readlen;
1610 struct stat statbuf;
1611 char *buffer;
1612 char *buffer_p;
1613 char *specs;
1614 char *specs_p;
1616 if (verbose_flag)
1617 fnotice (stderr, "Reading specs from %s\n", filename);
1619 /* Open and stat the file. */
1620 desc = open (filename, O_RDONLY, 0);
1621 if (desc < 0)
1622 pfatal_with_name (filename);
1623 if (stat (filename, &statbuf) < 0)
1624 pfatal_with_name (filename);
1626 /* Read contents of file into BUFFER. */
1627 buffer = XNEWVEC (char, statbuf.st_size + 1);
1628 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1629 if (readlen < 0)
1630 pfatal_with_name (filename);
1631 buffer[readlen] = 0;
1632 close (desc);
1634 specs = XNEWVEC (char, readlen + 1);
1635 specs_p = specs;
1636 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1638 int skip = 0;
1639 char c = *buffer_p;
1640 if (c == '\r')
1642 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1643 skip = 1;
1644 else if (*(buffer_p + 1) == '\n') /* \r\n */
1645 skip = 1;
1646 else /* \r */
1647 c = '\n';
1649 if (! skip)
1650 *specs_p++ = c;
1652 *specs_p = '\0';
1654 free (buffer);
1655 return (specs);
1658 /* Read compilation specs from a file named FILENAME,
1659 replacing the default ones.
1661 A suffix which starts with `*' is a definition for
1662 one of the machine-specific sub-specs. The "suffix" should be
1663 *asm, *cc1, *cpp, *link, *startfile, etc.
1664 The corresponding spec is stored in asm_spec, etc.,
1665 rather than in the `compilers' vector.
1667 Anything invalid in the file is a fatal error. */
1669 static void
1670 read_specs (const char *filename, int main_p)
1672 char *buffer;
1673 char *p;
1675 buffer = load_specs (filename);
1677 /* Scan BUFFER for specs, putting them in the vector. */
1678 p = buffer;
1679 while (1)
1681 char *suffix;
1682 char *spec;
1683 char *in, *out, *p1, *p2, *p3;
1685 /* Advance P in BUFFER to the next nonblank nocomment line. */
1686 p = skip_whitespace (p);
1687 if (*p == 0)
1688 break;
1690 /* Is this a special command that starts with '%'? */
1691 /* Don't allow this for the main specs file, since it would
1692 encourage people to overwrite it. */
1693 if (*p == '%' && !main_p)
1695 p1 = p;
1696 while (*p && *p != '\n')
1697 p++;
1699 /* Skip '\n'. */
1700 p++;
1702 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1703 && (p1[sizeof "%include" - 1] == ' '
1704 || p1[sizeof "%include" - 1] == '\t'))
1706 char *new_filename;
1708 p1 += sizeof ("%include");
1709 while (*p1 == ' ' || *p1 == '\t')
1710 p1++;
1712 if (*p1++ != '<' || p[-2] != '>')
1713 fatal_error ("specs %%include syntax malformed after "
1714 "%ld characters",
1715 (long) (p1 - buffer + 1));
1717 p[-2] = '\0';
1718 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1719 read_specs (new_filename ? new_filename : p1, FALSE);
1720 continue;
1722 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1723 && (p1[sizeof "%include_noerr" - 1] == ' '
1724 || p1[sizeof "%include_noerr" - 1] == '\t'))
1726 char *new_filename;
1728 p1 += sizeof "%include_noerr";
1729 while (*p1 == ' ' || *p1 == '\t')
1730 p1++;
1732 if (*p1++ != '<' || p[-2] != '>')
1733 fatal_error ("specs %%include syntax malformed after "
1734 "%ld characters",
1735 (long) (p1 - buffer + 1));
1737 p[-2] = '\0';
1738 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1739 if (new_filename)
1740 read_specs (new_filename, FALSE);
1741 else if (verbose_flag)
1742 fnotice (stderr, "could not find specs file %s\n", p1);
1743 continue;
1745 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1746 && (p1[sizeof "%rename" - 1] == ' '
1747 || p1[sizeof "%rename" - 1] == '\t'))
1749 int name_len;
1750 struct spec_list *sl;
1751 struct spec_list *newsl;
1753 /* Get original name. */
1754 p1 += sizeof "%rename";
1755 while (*p1 == ' ' || *p1 == '\t')
1756 p1++;
1758 if (! ISALPHA ((unsigned char) *p1))
1759 fatal_error ("specs %%rename syntax malformed after "
1760 "%ld characters",
1761 (long) (p1 - buffer));
1763 p2 = p1;
1764 while (*p2 && !ISSPACE ((unsigned char) *p2))
1765 p2++;
1767 if (*p2 != ' ' && *p2 != '\t')
1768 fatal_error ("specs %%rename syntax malformed after "
1769 "%ld characters",
1770 (long) (p2 - buffer));
1772 name_len = p2 - p1;
1773 *p2++ = '\0';
1774 while (*p2 == ' ' || *p2 == '\t')
1775 p2++;
1777 if (! ISALPHA ((unsigned char) *p2))
1778 fatal_error ("specs %%rename syntax malformed after "
1779 "%ld characters",
1780 (long) (p2 - buffer));
1782 /* Get new spec name. */
1783 p3 = p2;
1784 while (*p3 && !ISSPACE ((unsigned char) *p3))
1785 p3++;
1787 if (p3 != p - 1)
1788 fatal_error ("specs %%rename syntax malformed after "
1789 "%ld characters",
1790 (long) (p3 - buffer));
1791 *p3 = '\0';
1793 for (sl = specs; sl; sl = sl->next)
1794 if (name_len == sl->name_len && !strcmp (sl->name, p1))
1795 break;
1797 if (!sl)
1798 fatal_error ("specs %s spec was not found to be renamed", p1);
1800 if (strcmp (p1, p2) == 0)
1801 continue;
1803 for (newsl = specs; newsl; newsl = newsl->next)
1804 if (strcmp (newsl->name, p2) == 0)
1805 fatal_error ("%s: attempt to rename spec %qs to "
1806 "already defined spec %qs",
1807 filename, p1, p2);
1809 if (verbose_flag)
1811 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
1812 #ifdef DEBUG_SPECS
1813 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
1814 #endif
1817 set_spec (p2, *(sl->ptr_spec));
1818 if (sl->alloc_p)
1819 free (CONST_CAST (char *, *(sl->ptr_spec)));
1821 *(sl->ptr_spec) = "";
1822 sl->alloc_p = 0;
1823 continue;
1825 else
1826 fatal_error ("specs unknown %% command after %ld characters",
1827 (long) (p1 - buffer));
1830 /* Find the colon that should end the suffix. */
1831 p1 = p;
1832 while (*p1 && *p1 != ':' && *p1 != '\n')
1833 p1++;
1835 /* The colon shouldn't be missing. */
1836 if (*p1 != ':')
1837 fatal_error ("specs file malformed after %ld characters",
1838 (long) (p1 - buffer));
1840 /* Skip back over trailing whitespace. */
1841 p2 = p1;
1842 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
1843 p2--;
1845 /* Copy the suffix to a string. */
1846 suffix = save_string (p, p2 - p);
1847 /* Find the next line. */
1848 p = skip_whitespace (p1 + 1);
1849 if (p[1] == 0)
1850 fatal_error ("specs file malformed after %ld characters",
1851 (long) (p - buffer));
1853 p1 = p;
1854 /* Find next blank line or end of string. */
1855 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
1856 p1++;
1858 /* Specs end at the blank line and do not include the newline. */
1859 spec = save_string (p, p1 - p);
1860 p = p1;
1862 /* Delete backslash-newline sequences from the spec. */
1863 in = spec;
1864 out = spec;
1865 while (*in != 0)
1867 if (in[0] == '\\' && in[1] == '\n')
1868 in += 2;
1869 else if (in[0] == '#')
1870 while (*in && *in != '\n')
1871 in++;
1873 else
1874 *out++ = *in++;
1876 *out = 0;
1878 if (suffix[0] == '*')
1880 if (! strcmp (suffix, "*link_command"))
1881 link_command_spec = spec;
1882 else
1883 set_spec (suffix + 1, spec);
1885 else
1887 /* Add this pair to the vector. */
1888 compilers
1889 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
1891 compilers[n_compilers].suffix = suffix;
1892 compilers[n_compilers].spec = spec;
1893 n_compilers++;
1894 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
1897 if (*suffix == 0)
1898 link_command_spec = spec;
1901 if (link_command_spec == 0)
1902 fatal_error ("spec file has no spec for linking");
1905 /* Record the names of temporary files we tell compilers to write,
1906 and delete them at the end of the run. */
1908 /* This is the common prefix we use to make temp file names.
1909 It is chosen once for each run of this program.
1910 It is substituted into a spec by %g or %j.
1911 Thus, all temp file names contain this prefix.
1912 In practice, all temp file names start with this prefix.
1914 This prefix comes from the envvar TMPDIR if it is defined;
1915 otherwise, from the P_tmpdir macro if that is defined;
1916 otherwise, in /usr/tmp or /tmp;
1917 or finally the current directory if all else fails. */
1919 static const char *temp_filename;
1921 /* Length of the prefix. */
1923 static int temp_filename_length;
1925 /* Define the list of temporary files to delete. */
1927 struct temp_file
1929 const char *name;
1930 struct temp_file *next;
1933 /* Queue of files to delete on success or failure of compilation. */
1934 static struct temp_file *always_delete_queue;
1935 /* Queue of files to delete on failure of compilation. */
1936 static struct temp_file *failure_delete_queue;
1938 /* Record FILENAME as a file to be deleted automatically.
1939 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
1940 otherwise delete it in any case.
1941 FAIL_DELETE nonzero means delete it if a compilation step fails;
1942 otherwise delete it in any case. */
1944 void
1945 record_temp_file (const char *filename, int always_delete, int fail_delete)
1947 char *const name = xstrdup (filename);
1949 if (always_delete)
1951 struct temp_file *temp;
1952 for (temp = always_delete_queue; temp; temp = temp->next)
1953 if (! filename_cmp (name, temp->name))
1954 goto already1;
1956 temp = XNEW (struct temp_file);
1957 temp->next = always_delete_queue;
1958 temp->name = name;
1959 always_delete_queue = temp;
1961 already1:;
1964 if (fail_delete)
1966 struct temp_file *temp;
1967 for (temp = failure_delete_queue; temp; temp = temp->next)
1968 if (! filename_cmp (name, temp->name))
1969 goto already2;
1971 temp = XNEW (struct temp_file);
1972 temp->next = failure_delete_queue;
1973 temp->name = name;
1974 failure_delete_queue = temp;
1976 already2:;
1980 /* Delete all the temporary files whose names we previously recorded. */
1982 #ifndef DELETE_IF_ORDINARY
1983 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
1984 do \
1986 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
1987 if (unlink (NAME) < 0) \
1988 if (VERBOSE_FLAG) \
1989 perror_with_name (NAME); \
1990 } while (0)
1991 #endif
1993 static void
1994 delete_if_ordinary (const char *name)
1996 struct stat st;
1997 #ifdef DEBUG
1998 int i, c;
2000 printf ("Delete %s? (y or n) ", name);
2001 fflush (stdout);
2002 i = getchar ();
2003 if (i != '\n')
2004 while ((c = getchar ()) != '\n' && c != EOF)
2007 if (i == 'y' || i == 'Y')
2008 #endif /* DEBUG */
2009 DELETE_IF_ORDINARY (name, st, verbose_flag);
2012 static void
2013 delete_temp_files (void)
2015 struct temp_file *temp;
2017 for (temp = always_delete_queue; temp; temp = temp->next)
2018 delete_if_ordinary (temp->name);
2019 always_delete_queue = 0;
2022 /* Delete all the files to be deleted on error. */
2024 static void
2025 delete_failure_queue (void)
2027 struct temp_file *temp;
2029 for (temp = failure_delete_queue; temp; temp = temp->next)
2030 delete_if_ordinary (temp->name);
2033 static void
2034 clear_failure_queue (void)
2036 failure_delete_queue = 0;
2039 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2040 returns non-NULL.
2041 If DO_MULTI is true iterate over the paths twice, first with multilib
2042 suffix then without, otherwise iterate over the paths once without
2043 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2044 to avoid visiting the same path twice, but we could do better. For
2045 instance, /usr/lib/../lib is considered different from /usr/lib.
2046 At least EXTRA_SPACE chars past the end of the path passed to
2047 CALLBACK are available for use by the callback.
2048 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2050 Returns the value returned by CALLBACK. */
2052 static void *
2053 for_each_path (const struct path_prefix *paths,
2054 bool do_multi,
2055 size_t extra_space,
2056 void *(*callback) (char *, void *),
2057 void *callback_info)
2059 struct prefix_list *pl;
2060 const char *multi_dir = NULL;
2061 const char *multi_os_dir = NULL;
2062 const char *multi_suffix;
2063 const char *just_multi_suffix;
2064 char *path = NULL;
2065 void *ret = NULL;
2066 bool skip_multi_dir = false;
2067 bool skip_multi_os_dir = false;
2069 multi_suffix = machine_suffix;
2070 just_multi_suffix = just_machine_suffix;
2071 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2073 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2074 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2075 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2077 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2078 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2080 while (1)
2082 size_t multi_dir_len = 0;
2083 size_t multi_os_dir_len = 0;
2084 size_t suffix_len;
2085 size_t just_suffix_len;
2086 size_t len;
2088 if (multi_dir)
2089 multi_dir_len = strlen (multi_dir);
2090 if (multi_os_dir)
2091 multi_os_dir_len = strlen (multi_os_dir);
2092 suffix_len = strlen (multi_suffix);
2093 just_suffix_len = strlen (just_multi_suffix);
2095 if (path == NULL)
2097 len = paths->max_len + extra_space + 1;
2098 if (suffix_len > multi_os_dir_len)
2099 len += suffix_len;
2100 else
2101 len += multi_os_dir_len;
2102 path = XNEWVEC (char, len);
2105 for (pl = paths->plist; pl != 0; pl = pl->next)
2107 len = strlen (pl->prefix);
2108 memcpy (path, pl->prefix, len);
2110 /* Look first in MACHINE/VERSION subdirectory. */
2111 if (!skip_multi_dir)
2113 memcpy (path + len, multi_suffix, suffix_len + 1);
2114 ret = callback (path, callback_info);
2115 if (ret)
2116 break;
2119 /* Some paths are tried with just the machine (ie. target)
2120 subdir. This is used for finding as, ld, etc. */
2121 if (!skip_multi_dir
2122 && pl->require_machine_suffix == 2)
2124 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2125 ret = callback (path, callback_info);
2126 if (ret)
2127 break;
2130 /* Now try the base path. */
2131 if (!pl->require_machine_suffix
2132 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2134 const char *this_multi;
2135 size_t this_multi_len;
2137 if (pl->os_multilib)
2139 this_multi = multi_os_dir;
2140 this_multi_len = multi_os_dir_len;
2142 else
2144 this_multi = multi_dir;
2145 this_multi_len = multi_dir_len;
2148 if (this_multi_len)
2149 memcpy (path + len, this_multi, this_multi_len + 1);
2150 else
2151 path[len] = '\0';
2153 ret = callback (path, callback_info);
2154 if (ret)
2155 break;
2158 if (pl)
2159 break;
2161 if (multi_dir == NULL && multi_os_dir == NULL)
2162 break;
2164 /* Run through the paths again, this time without multilibs.
2165 Don't repeat any we have already seen. */
2166 if (multi_dir)
2168 free (CONST_CAST (char *, multi_dir));
2169 multi_dir = NULL;
2170 free (CONST_CAST (char *, multi_suffix));
2171 multi_suffix = machine_suffix;
2172 free (CONST_CAST (char *, just_multi_suffix));
2173 just_multi_suffix = just_machine_suffix;
2175 else
2176 skip_multi_dir = true;
2177 if (multi_os_dir)
2179 free (CONST_CAST (char *, multi_os_dir));
2180 multi_os_dir = NULL;
2182 else
2183 skip_multi_os_dir = true;
2186 if (multi_dir)
2188 free (CONST_CAST (char *, multi_dir));
2189 free (CONST_CAST (char *, multi_suffix));
2190 free (CONST_CAST (char *, just_multi_suffix));
2192 if (multi_os_dir)
2193 free (CONST_CAST (char *, multi_os_dir));
2194 if (ret != path)
2195 free (path);
2196 return ret;
2199 /* Callback for build_search_list. Adds path to obstack being built. */
2201 struct add_to_obstack_info {
2202 struct obstack *ob;
2203 bool check_dir;
2204 bool first_time;
2207 static void *
2208 add_to_obstack (char *path, void *data)
2210 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2212 if (info->check_dir && !is_directory (path, false))
2213 return NULL;
2215 if (!info->first_time)
2216 obstack_1grow (info->ob, PATH_SEPARATOR);
2218 obstack_grow (info->ob, path, strlen (path));
2220 info->first_time = false;
2221 return NULL;
2224 /* Add or change the value of an environment variable, outputting the
2225 change to standard error if in verbose mode. */
2226 static void
2227 xputenv (const char *string)
2229 if (verbose_flag)
2230 fnotice (stderr, "%s\n", string);
2231 putenv (CONST_CAST (char *, string));
2234 /* Build a list of search directories from PATHS.
2235 PREFIX is a string to prepend to the list.
2236 If CHECK_DIR_P is true we ensure the directory exists.
2237 If DO_MULTI is true, multilib paths are output first, then
2238 non-multilib paths.
2239 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2240 It is also used by the --print-search-dirs flag. */
2242 static char *
2243 build_search_list (const struct path_prefix *paths, const char *prefix,
2244 bool check_dir, bool do_multi)
2246 struct add_to_obstack_info info;
2248 info.ob = &collect_obstack;
2249 info.check_dir = check_dir;
2250 info.first_time = true;
2252 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2253 obstack_1grow (&collect_obstack, '=');
2255 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2257 obstack_1grow (&collect_obstack, '\0');
2258 return XOBFINISH (&collect_obstack, char *);
2261 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2262 for collect. */
2264 static void
2265 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2266 bool do_multi)
2268 xputenv (build_search_list (paths, env_var, true, do_multi));
2271 /* Check whether NAME can be accessed in MODE. This is like access,
2272 except that it never considers directories to be executable. */
2274 static int
2275 access_check (const char *name, int mode)
2277 if (mode == X_OK)
2279 struct stat st;
2281 if (stat (name, &st) < 0
2282 || S_ISDIR (st.st_mode))
2283 return -1;
2286 return access (name, mode);
2289 /* Callback for find_a_file. Appends the file name to the directory
2290 path. If the resulting file exists in the right mode, return the
2291 full pathname to the file. */
2293 struct file_at_path_info {
2294 const char *name;
2295 const char *suffix;
2296 int name_len;
2297 int suffix_len;
2298 int mode;
2301 static void *
2302 file_at_path (char *path, void *data)
2304 struct file_at_path_info *info = (struct file_at_path_info *) data;
2305 size_t len = strlen (path);
2307 memcpy (path + len, info->name, info->name_len);
2308 len += info->name_len;
2310 /* Some systems have a suffix for executable files.
2311 So try appending that first. */
2312 if (info->suffix_len)
2314 memcpy (path + len, info->suffix, info->suffix_len + 1);
2315 if (access_check (path, info->mode) == 0)
2316 return path;
2319 path[len] = '\0';
2320 if (access_check (path, info->mode) == 0)
2321 return path;
2323 return NULL;
2326 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2327 access to check permissions. If DO_MULTI is true, search multilib
2328 paths then non-multilib paths, otherwise do not search multilib paths.
2329 Return 0 if not found, otherwise return its name, allocated with malloc. */
2331 static char *
2332 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2333 bool do_multi)
2335 struct file_at_path_info info;
2337 #ifdef DEFAULT_ASSEMBLER
2338 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2339 return xstrdup (DEFAULT_ASSEMBLER);
2340 #endif
2342 #ifdef DEFAULT_LINKER
2343 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2344 return xstrdup (DEFAULT_LINKER);
2345 #endif
2347 /* Determine the filename to execute (special case for absolute paths). */
2349 if (IS_ABSOLUTE_PATH (name))
2351 if (access (name, mode) == 0)
2352 return xstrdup (name);
2354 return NULL;
2357 info.name = name;
2358 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2359 info.name_len = strlen (info.name);
2360 info.suffix_len = strlen (info.suffix);
2361 info.mode = mode;
2363 return (char*) for_each_path (pprefix, do_multi,
2364 info.name_len + info.suffix_len,
2365 file_at_path, &info);
2368 /* Ranking of prefixes in the sort list. -B prefixes are put before
2369 all others. */
2371 enum path_prefix_priority
2373 PREFIX_PRIORITY_B_OPT,
2374 PREFIX_PRIORITY_LAST
2377 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2378 order according to PRIORITY. Within each PRIORITY, new entries are
2379 appended.
2381 If WARN is nonzero, we will warn if no file is found
2382 through this prefix. WARN should point to an int
2383 which will be set to 1 if this entry is used.
2385 COMPONENT is the value to be passed to update_path.
2387 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2388 the complete value of machine_suffix.
2389 2 means try both machine_suffix and just_machine_suffix. */
2391 static void
2392 add_prefix (struct path_prefix *pprefix, const char *prefix,
2393 const char *component, /* enum prefix_priority */ int priority,
2394 int require_machine_suffix, int os_multilib)
2396 struct prefix_list *pl, **prev;
2397 int len;
2399 for (prev = &pprefix->plist;
2400 (*prev) != NULL && (*prev)->priority <= priority;
2401 prev = &(*prev)->next)
2404 /* Keep track of the longest prefix. */
2406 prefix = update_path (prefix, component);
2407 len = strlen (prefix);
2408 if (len > pprefix->max_len)
2409 pprefix->max_len = len;
2411 pl = XNEW (struct prefix_list);
2412 pl->prefix = prefix;
2413 pl->require_machine_suffix = require_machine_suffix;
2414 pl->priority = priority;
2415 pl->os_multilib = os_multilib;
2417 /* Insert after PREV. */
2418 pl->next = (*prev);
2419 (*prev) = pl;
2422 /* Same as add_prefix, but prepending target_system_root to prefix. */
2423 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2424 static void
2425 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2426 const char *component,
2427 /* enum prefix_priority */ int priority,
2428 int require_machine_suffix, int os_multilib)
2430 if (!IS_ABSOLUTE_PATH (prefix))
2431 fatal_error ("system path %qs is not absolute", prefix);
2433 if (target_system_root)
2435 if (target_sysroot_suffix)
2436 prefix = concat (target_sysroot_suffix, prefix, NULL);
2437 prefix = concat (target_system_root, prefix, NULL);
2439 /* We have to override this because GCC's notion of sysroot
2440 moves along with GCC. */
2441 component = "GCC";
2444 add_prefix (pprefix, prefix, component, priority,
2445 require_machine_suffix, os_multilib);
2448 /* Execute the command specified by the arguments on the current line of spec.
2449 When using pipes, this includes several piped-together commands
2450 with `|' between them.
2452 Return 0 if successful, -1 if failed. */
2454 static int
2455 execute (void)
2457 int i;
2458 int n_commands; /* # of command. */
2459 char *string;
2460 struct pex_obj *pex;
2461 struct command
2463 const char *prog; /* program name. */
2464 const char **argv; /* vector of args. */
2466 const char *arg;
2468 struct command *commands; /* each command buffer with above info. */
2470 gcc_assert (!processing_spec_function);
2472 if (wrapper_string)
2474 string = find_a_file (&exec_prefixes,
2475 VEC_index (const_char_p, argbuf, 0), X_OK, false);
2476 if (string)
2477 VEC_replace (const_char_p, argbuf, 0, string);
2478 insert_wrapper (wrapper_string);
2481 /* Count # of piped commands. */
2482 for (n_commands = 1, i = 0; VEC_iterate (const_char_p, argbuf, i, arg); i++)
2483 if (strcmp (arg, "|") == 0)
2484 n_commands++;
2486 /* Get storage for each command. */
2487 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2489 /* Split argbuf into its separate piped processes,
2490 and record info about each one.
2491 Also search for the programs that are to be run. */
2493 VEC_safe_push (const_char_p, heap, argbuf, 0);
2495 commands[0].prog = VEC_index (const_char_p, argbuf, 0); /* first command. */
2496 commands[0].argv = VEC_address (const_char_p, argbuf);
2498 if (!wrapper_string)
2500 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2501 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2504 for (n_commands = 1, i = 0; VEC_iterate (const_char_p, argbuf, i, arg); i++)
2505 if (arg && strcmp (arg, "|") == 0)
2506 { /* each command. */
2507 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2508 fatal_error ("-pipe not supported");
2509 #endif
2510 VEC_replace (const_char_p, argbuf, i, 0); /* Termination of
2511 command args. */
2512 commands[n_commands].prog = VEC_index (const_char_p, argbuf, i + 1);
2513 commands[n_commands].argv
2514 = &(VEC_address (const_char_p, argbuf))[i + 1];
2515 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2516 X_OK, false);
2517 if (string)
2518 commands[n_commands].argv[0] = string;
2519 n_commands++;
2522 /* If -v, print what we are about to do, and maybe query. */
2524 if (verbose_flag)
2526 /* For help listings, put a blank line between sub-processes. */
2527 if (print_help_list)
2528 fputc ('\n', stderr);
2530 /* Print each piped command as a separate line. */
2531 for (i = 0; i < n_commands; i++)
2533 const char *const *j;
2535 if (verbose_only_flag)
2537 for (j = commands[i].argv; *j; j++)
2539 const char *p;
2540 for (p = *j; *p; ++p)
2541 if (!ISALNUM ((unsigned char) *p)
2542 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2543 break;
2544 if (*p || !*j)
2546 fprintf (stderr, " \"");
2547 for (p = *j; *p; ++p)
2549 if (*p == '"' || *p == '\\' || *p == '$')
2550 fputc ('\\', stderr);
2551 fputc (*p, stderr);
2553 fputc ('"', stderr);
2555 /* If it's empty, print "". */
2556 else if (!**j)
2557 fprintf (stderr, " \"\"");
2558 else
2559 fprintf (stderr, " %s", *j);
2562 else
2563 for (j = commands[i].argv; *j; j++)
2564 /* If it's empty, print "". */
2565 if (!**j)
2566 fprintf (stderr, " \"\"");
2567 else
2568 fprintf (stderr, " %s", *j);
2570 /* Print a pipe symbol after all but the last command. */
2571 if (i + 1 != n_commands)
2572 fprintf (stderr, " |");
2573 fprintf (stderr, "\n");
2575 fflush (stderr);
2576 if (verbose_only_flag != 0)
2578 /* verbose_only_flag should act as if the spec was
2579 executed, so increment execution_count before
2580 returning. This prevents spurious warnings about
2581 unused linker input files, etc. */
2582 execution_count++;
2583 return 0;
2585 #ifdef DEBUG
2586 fnotice (stderr, "\nGo ahead? (y or n) ");
2587 fflush (stderr);
2588 i = getchar ();
2589 if (i != '\n')
2590 while (getchar () != '\n')
2593 if (i != 'y' && i != 'Y')
2594 return 0;
2595 #endif /* DEBUG */
2598 #ifdef ENABLE_VALGRIND_CHECKING
2599 /* Run the each command through valgrind. To simplify prepending the
2600 path to valgrind and the option "-q" (for quiet operation unless
2601 something triggers), we allocate a separate argv array. */
2603 for (i = 0; i < n_commands; i++)
2605 const char **argv;
2606 int argc;
2607 int j;
2609 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2612 argv = XALLOCAVEC (const char *, argc + 3);
2614 argv[0] = VALGRIND_PATH;
2615 argv[1] = "-q";
2616 for (j = 2; j < argc + 2; j++)
2617 argv[j] = commands[i].argv[j - 2];
2618 argv[j] = NULL;
2620 commands[i].argv = argv;
2621 commands[i].prog = argv[0];
2623 #endif
2625 /* Run each piped subprocess. */
2627 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
2628 ? PEX_RECORD_TIMES : 0),
2629 progname, temp_filename);
2630 if (pex == NULL)
2631 fatal_error ("pex_init failed: %m");
2633 for (i = 0; i < n_commands; i++)
2635 const char *errmsg;
2636 int err;
2637 const char *string = commands[i].argv[0];
2639 errmsg = pex_run (pex,
2640 ((i + 1 == n_commands ? PEX_LAST : 0)
2641 | (string == commands[i].prog ? PEX_SEARCH : 0)),
2642 string, CONST_CAST (char **, commands[i].argv),
2643 NULL, NULL, &err);
2644 if (errmsg != NULL)
2646 if (err == 0)
2647 fatal_error (errmsg);
2648 else
2650 errno = err;
2651 pfatal_with_name (errmsg);
2655 if (string != commands[i].prog)
2656 free (CONST_CAST (char *, string));
2659 execution_count++;
2661 /* Wait for all the subprocesses to finish. */
2664 int *statuses;
2665 struct pex_time *times = NULL;
2666 int ret_code = 0;
2668 statuses = (int *) alloca (n_commands * sizeof (int));
2669 if (!pex_get_status (pex, n_commands, statuses))
2670 fatal_error ("failed to get exit status: %m");
2672 if (report_times || report_times_to_file)
2674 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
2675 if (!pex_get_times (pex, n_commands, times))
2676 fatal_error ("failed to get process times: %m");
2679 pex_free (pex);
2681 for (i = 0; i < n_commands; ++i)
2683 int status = statuses[i];
2685 if (WIFSIGNALED (status))
2687 #ifdef SIGPIPE
2688 /* SIGPIPE is a special case. It happens in -pipe mode
2689 when the compiler dies before the preprocessor is done,
2690 or the assembler dies before the compiler is done.
2691 There's generally been an error already, and this is
2692 just fallout. So don't generate another error unless
2693 we would otherwise have succeeded. */
2694 if (WTERMSIG (status) == SIGPIPE
2695 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2697 signal_count++;
2698 ret_code = -1;
2700 else
2701 #endif
2702 internal_error ("%s (program %s)",
2703 strsignal (WTERMSIG (status)), commands[i].prog);
2705 else if (WIFEXITED (status)
2706 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2708 if (WEXITSTATUS (status) > greatest_status)
2709 greatest_status = WEXITSTATUS (status);
2710 ret_code = -1;
2713 if (report_times || report_times_to_file)
2715 struct pex_time *pt = &times[i];
2716 double ut, st;
2718 ut = ((double) pt->user_seconds
2719 + (double) pt->user_microseconds / 1.0e6);
2720 st = ((double) pt->system_seconds
2721 + (double) pt->system_microseconds / 1.0e6);
2723 if (ut + st != 0)
2725 if (report_times)
2726 fnotice (stderr, "# %s %.2f %.2f\n",
2727 commands[i].prog, ut, st);
2729 if (report_times_to_file)
2731 int c = 0;
2732 const char *const *j;
2734 fprintf (report_times_to_file, "%g %g", ut, st);
2736 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
2738 const char *p;
2739 for (p = *j; *p; ++p)
2740 if (*p == '"' || *p == '\\' || *p == '$'
2741 || ISSPACE (*p))
2742 break;
2744 if (*p)
2746 fprintf (report_times_to_file, " \"");
2747 for (p = *j; *p; ++p)
2749 if (*p == '"' || *p == '\\' || *p == '$')
2750 fputc ('\\', report_times_to_file);
2751 fputc (*p, report_times_to_file);
2753 fputc ('"', report_times_to_file);
2755 else
2756 fprintf (report_times_to_file, " %s", *j);
2759 fputc ('\n', report_times_to_file);
2765 return ret_code;
2769 /* Find all the switches given to us
2770 and make a vector describing them.
2771 The elements of the vector are strings, one per switch given.
2772 If a switch uses following arguments, then the `part1' field
2773 is the switch itself and the `args' field
2774 is a null-terminated vector containing the following arguments.
2775 Bits in the `live_cond' field are:
2776 SWITCH_LIVE to indicate this switch is true in a conditional spec.
2777 SWITCH_FALSE to indicate this switch is overridden by a later switch.
2778 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
2779 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored
2780 in all do_spec calls afterwards. Used for %<S from self specs.
2781 The `validated' field is nonzero if any spec has looked at this switch;
2782 if it remains zero at the end of the run, it must be meaningless. */
2784 #define SWITCH_LIVE (1 << 0)
2785 #define SWITCH_FALSE (1 << 1)
2786 #define SWITCH_IGNORE (1 << 2)
2787 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
2788 #define SWITCH_KEEP_FOR_GCC (1 << 4)
2790 struct switchstr
2792 const char *part1;
2793 const char **args;
2794 unsigned int live_cond;
2795 unsigned char validated;
2796 unsigned char ordering;
2799 static struct switchstr *switches;
2801 static int n_switches;
2803 static int n_switches_alloc;
2805 /* Set to zero if -fcompare-debug is disabled, positive if it's
2806 enabled and we're running the first compilation, negative if it's
2807 enabled and we're running the second compilation. For most of the
2808 time, it's in the range -1..1, but it can be temporarily set to 2
2809 or 3 to indicate that the -fcompare-debug flags didn't come from
2810 the command-line, but rather from the GCC_COMPARE_DEBUG environment
2811 variable, until a synthesized -fcompare-debug flag is added to the
2812 command line. */
2813 int compare_debug;
2815 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
2816 int compare_debug_second;
2818 /* Set to the flags that should be passed to the second compilation in
2819 a -fcompare-debug compilation. */
2820 const char *compare_debug_opt;
2822 static struct switchstr *switches_debug_check[2];
2824 static int n_switches_debug_check[2];
2826 static int n_switches_alloc_debug_check[2];
2828 static char *debug_check_temp_file[2];
2830 /* Language is one of three things:
2832 1) The name of a real programming language.
2833 2) NULL, indicating that no one has figured out
2834 what it is yet.
2835 3) '*', indicating that the file should be passed
2836 to the linker. */
2837 struct infile
2839 const char *name;
2840 const char *language;
2841 struct compiler *incompiler;
2842 bool compiled;
2843 bool preprocessed;
2846 /* Also a vector of input files specified. */
2848 static struct infile *infiles;
2850 int n_infiles;
2852 static int n_infiles_alloc;
2854 /* True if multiple input files are being compiled to a single
2855 assembly file. */
2857 static bool combine_inputs;
2859 /* This counts the number of libraries added by lang_specific_driver, so that
2860 we can tell if there were any user supplied any files or libraries. */
2862 static int added_libraries;
2864 /* And a vector of corresponding output files is made up later. */
2866 const char **outfiles;
2868 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2870 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
2871 is true if we should look for an executable suffix. DO_OBJ
2872 is true if we should look for an object suffix. */
2874 static const char *
2875 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
2876 int do_obj ATTRIBUTE_UNUSED)
2878 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2879 int i;
2880 #endif
2881 int len;
2883 if (name == NULL)
2884 return NULL;
2886 len = strlen (name);
2888 #ifdef HAVE_TARGET_OBJECT_SUFFIX
2889 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
2890 if (do_obj && len > 2
2891 && name[len - 2] == '.'
2892 && name[len - 1] == 'o')
2894 obstack_grow (&obstack, name, len - 2);
2895 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
2896 name = XOBFINISH (&obstack, const char *);
2898 #endif
2900 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2901 /* If there is no filetype, make it the executable suffix (which includes
2902 the "."). But don't get confused if we have just "-o". */
2903 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
2904 return name;
2906 for (i = len - 1; i >= 0; i--)
2907 if (IS_DIR_SEPARATOR (name[i]))
2908 break;
2910 for (i++; i < len; i++)
2911 if (name[i] == '.')
2912 return name;
2914 obstack_grow (&obstack, name, len);
2915 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
2916 strlen (TARGET_EXECUTABLE_SUFFIX));
2917 name = XOBFINISH (&obstack, const char *);
2918 #endif
2920 return name;
2922 #endif
2924 /* Display the command line switches accepted by gcc. */
2925 static void
2926 display_help (void)
2928 printf (_("Usage: %s [options] file...\n"), progname);
2929 fputs (_("Options:\n"), stdout);
2931 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
2932 fputs (_(" --help Display this information\n"), stdout);
2933 fputs (_(" --target-help Display target specific command line options\n"), stdout);
2934 fputs (_(" --help={target|optimizers|warnings|params|[^]{joined|separate|undocumented}}[,...]\n"), stdout);
2935 fputs (_(" Display specific types of command line options\n"), stdout);
2936 if (! verbose_flag)
2937 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
2938 fputs (_(" --version Display compiler version information\n"), stdout);
2939 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
2940 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
2941 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
2942 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
2943 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
2944 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
2945 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
2946 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
2947 fputs (_("\
2948 -print-multi-lib Display the mapping between command line options and\n\
2949 multiple library search directories\n"), stdout);
2950 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
2951 fputs (_(" -print-sysroot Display the target libraries directory\n"), stdout);
2952 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
2953 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
2954 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
2955 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
2956 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
2957 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
2958 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
2959 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
2960 fputs (_(" -save-temps=<arg> Do not delete intermediate files\n"), stdout);
2961 fputs (_("\
2962 -[no-]canonical-prefixes Specify the path canonicalization for relative\n\
2963 prefixes to other gcc components\n"), stdout);
2964 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
2965 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
2966 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
2967 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
2968 fputs (_("\
2969 --sysroot=<directory> Use <directory> as the root directory for headers\n\
2970 and libraries\n"), stdout);
2971 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
2972 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
2973 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
2974 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
2975 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
2976 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
2977 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
2978 fputs (_("\
2979 -x <language> Specify the language of the following input files\n\
2980 Permissible languages include: c c++ assembler none\n\
2981 'none' means revert to the default behavior of\n\
2982 guessing the language based on the file's extension\n\
2983 "), stdout);
2985 printf (_("\
2986 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
2987 passed on to the various sub-processes invoked by %s. In order to pass\n\
2988 other options on to these processes the -W<letter> options must be used.\n\
2989 "), progname);
2991 /* The rest of the options are displayed by invocations of the various
2992 sub-processes. */
2995 static void
2996 add_preprocessor_option (const char *option, int len)
2998 VEC_safe_push (char_p, heap, preprocessor_options,
2999 save_string (option, len));
3002 static void
3003 add_assembler_option (const char *option, int len)
3005 VEC_safe_push (char_p, heap, assembler_options, save_string (option, len));
3008 static void
3009 add_linker_option (const char *option, int len)
3011 VEC_safe_push (char_p, heap, linker_options, save_string (option, len));
3014 /* Allocate space for an input file in infiles. */
3016 static void
3017 alloc_infile (void)
3019 if (n_infiles_alloc == 0)
3021 n_infiles_alloc = 16;
3022 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3024 else if (n_infiles_alloc == n_infiles)
3026 n_infiles_alloc *= 2;
3027 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3031 /* Store an input file with the given NAME and LANGUAGE in
3032 infiles. */
3034 static void
3035 add_infile (const char *name, const char *language)
3037 alloc_infile ();
3038 infiles[n_infiles].name = name;
3039 infiles[n_infiles++].language = language;
3042 /* Allocate space for a switch in switches. */
3044 static void
3045 alloc_switch (void)
3047 if (n_switches_alloc == 0)
3049 n_switches_alloc = 16;
3050 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3052 else if (n_switches_alloc == n_switches)
3054 n_switches_alloc *= 2;
3055 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3059 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3060 as validated if VALIDATED. */
3062 static void
3063 save_switch (const char *opt, size_t n_args, const char *const *args,
3064 bool validated)
3066 alloc_switch ();
3067 switches[n_switches].part1 = opt + 1;
3068 if (n_args == 0)
3069 switches[n_switches].args = 0;
3070 else
3072 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3073 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3074 switches[n_switches].args[n_args] = NULL;
3077 switches[n_switches].live_cond = 0;
3078 switches[n_switches].validated = validated;
3079 switches[n_switches].ordering = 0;
3080 n_switches++;
3083 /* Handle an option DECODED that is unknown to the option-processing
3084 machinery. */
3086 static bool
3087 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3089 const char *opt = decoded->arg;
3090 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3091 && !(decoded->errors & CL_ERR_NEGATIVE))
3093 /* Leave unknown -Wno-* options for the compiler proper, to be
3094 diagnosed only if there are warnings. */
3095 save_switch (decoded->canonical_option[0],
3096 decoded->canonical_option_num_elements - 1,
3097 &decoded->canonical_option[1], false);
3098 return false;
3100 else
3101 return true;
3104 /* Handle an option DECODED that is not marked as CL_DRIVER.
3105 LANG_MASK will always be CL_DRIVER. */
3107 static void
3108 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3109 unsigned int lang_mask ATTRIBUTE_UNUSED)
3111 /* At this point, non-driver options are accepted (and expected to
3112 be passed down by specs) unless marked to be rejected by the
3113 driver. Options to be rejected by the driver but accepted by the
3114 compilers proper are treated just like completely unknown
3115 options. */
3116 const struct cl_option *option = &cl_options[decoded->opt_index];
3118 if (option->cl_reject_driver)
3119 error ("unrecognized command line option %qs",
3120 decoded->orig_option_with_args_text);
3121 else
3122 save_switch (decoded->canonical_option[0],
3123 decoded->canonical_option_num_elements - 1,
3124 &decoded->canonical_option[1], false);
3127 /* Note that an option (index OPT_INDEX, argument ARG, value VALUE)
3128 has been successfully handled with a handler for mask MASK. */
3130 static void
3131 driver_post_handling_callback (const struct cl_decoded_option *decoded ATTRIBUTE_UNUSED,
3132 unsigned int mask ATTRIBUTE_UNUSED)
3134 /* Nothing to do here. */
3137 static const char *spec_lang = 0;
3138 static int last_language_n_infiles;
3140 /* Handle a driver option; arguments and return value as for
3141 handle_option. */
3143 static bool
3144 driver_handle_option (struct gcc_options *opts,
3145 struct gcc_options *opts_set,
3146 const struct cl_decoded_option *decoded,
3147 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3148 location_t loc,
3149 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3150 diagnostic_context *dc)
3152 size_t opt_index = decoded->opt_index;
3153 const char *arg = decoded->arg;
3154 const char *compare_debug_replacement_opt;
3155 int value = decoded->value;
3156 bool validated = false;
3157 bool do_save = true;
3159 gcc_assert (opts == &global_options);
3160 gcc_assert (opts_set == &global_options_set);
3161 gcc_assert (kind == DK_UNSPECIFIED);
3162 gcc_assert (loc == UNKNOWN_LOCATION);
3163 gcc_assert (dc == global_dc);
3165 switch (opt_index)
3167 case OPT_dumpspecs:
3169 struct spec_list *sl;
3170 init_spec ();
3171 for (sl = specs; sl; sl = sl->next)
3172 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3173 if (link_command_spec)
3174 printf ("*link_command:\n%s\n\n", link_command_spec);
3175 exit (0);
3178 case OPT_dumpversion:
3179 printf ("%s\n", spec_version);
3180 exit (0);
3182 case OPT_dumpmachine:
3183 printf ("%s\n", spec_machine);
3184 exit (0);
3186 case OPT__version:
3187 print_version = 1;
3189 /* CPP driver cannot obtain switch from cc1_options. */
3190 if (is_cpp_driver)
3191 add_preprocessor_option ("--version", strlen ("--version"));
3192 add_assembler_option ("--version", strlen ("--version"));
3193 add_linker_option ("--version", strlen ("--version"));
3194 break;
3196 case OPT__help:
3197 print_help_list = 1;
3199 /* CPP driver cannot obtain switch from cc1_options. */
3200 if (is_cpp_driver)
3201 add_preprocessor_option ("--help", 6);
3202 add_assembler_option ("--help", 6);
3203 add_linker_option ("--help", 6);
3204 break;
3206 case OPT__help_:
3207 print_subprocess_help = 2;
3208 break;
3210 case OPT__target_help:
3211 print_subprocess_help = 1;
3213 /* CPP driver cannot obtain switch from cc1_options. */
3214 if (is_cpp_driver)
3215 add_preprocessor_option ("--target-help", 13);
3216 add_assembler_option ("--target-help", 13);
3217 add_linker_option ("--target-help", 13);
3218 break;
3220 case OPT_pass_exit_codes:
3221 case OPT_print_search_dirs:
3222 case OPT_print_file_name_:
3223 case OPT_print_prog_name_:
3224 case OPT_print_multi_lib:
3225 case OPT_print_multi_directory:
3226 case OPT_print_sysroot:
3227 case OPT_print_multi_os_directory:
3228 case OPT_print_sysroot_headers_suffix:
3229 case OPT_time:
3230 case OPT_wrapper:
3231 /* These options set the variables specified in common.opt
3232 automatically, and do not need to be saved for spec
3233 processing. */
3234 do_save = false;
3235 break;
3237 case OPT_print_libgcc_file_name:
3238 print_file_name = "libgcc.a";
3239 do_save = false;
3240 break;
3242 case OPT_fcompare_debug_second:
3243 compare_debug_second = 1;
3244 break;
3246 case OPT_fcompare_debug:
3247 switch (value)
3249 case 0:
3250 compare_debug_replacement_opt = "-fcompare-debug=";
3251 arg = "";
3252 goto compare_debug_with_arg;
3254 case 1:
3255 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3256 arg = "-gtoggle";
3257 goto compare_debug_with_arg;
3259 default:
3260 gcc_unreachable ();
3262 break;
3264 case OPT_fcompare_debug_:
3265 compare_debug_replacement_opt = decoded->canonical_option[0];
3266 compare_debug_with_arg:
3267 gcc_assert (decoded->canonical_option_num_elements == 1);
3268 gcc_assert (arg != NULL);
3269 if (arg)
3270 compare_debug = 1;
3271 else
3272 compare_debug = -1;
3273 if (compare_debug < 0)
3274 compare_debug_opt = NULL;
3275 else
3276 compare_debug_opt = arg;
3277 save_switch (compare_debug_replacement_opt, 0, NULL, validated);
3278 return true;
3280 case OPT_Wa_:
3282 int prev, j;
3283 /* Pass the rest of this option to the assembler. */
3285 /* Split the argument at commas. */
3286 prev = 0;
3287 for (j = 0; arg[j]; j++)
3288 if (arg[j] == ',')
3290 add_assembler_option (arg + prev, j - prev);
3291 prev = j + 1;
3294 /* Record the part after the last comma. */
3295 add_assembler_option (arg + prev, j - prev);
3297 do_save = false;
3298 break;
3300 case OPT_Wp_:
3302 int prev, j;
3303 /* Pass the rest of this option to the preprocessor. */
3305 /* Split the argument at commas. */
3306 prev = 0;
3307 for (j = 0; arg[j]; j++)
3308 if (arg[j] == ',')
3310 add_preprocessor_option (arg + prev, j - prev);
3311 prev = j + 1;
3314 /* Record the part after the last comma. */
3315 add_preprocessor_option (arg + prev, j - prev);
3317 do_save = false;
3318 break;
3320 case OPT_Wl_:
3322 int prev, j;
3323 /* Split the argument at commas. */
3324 prev = 0;
3325 for (j = 0; arg[j]; j++)
3326 if (arg[j] == ',')
3328 add_infile (save_string (arg + prev, j - prev), "*");
3329 prev = j + 1;
3331 /* Record the part after the last comma. */
3332 add_infile (arg + prev, "*");
3334 do_save = false;
3335 break;
3337 case OPT_Xlinker:
3338 add_infile (arg, "*");
3339 do_save = false;
3340 break;
3342 case OPT_Xpreprocessor:
3343 add_preprocessor_option (arg, strlen (arg));
3344 do_save = false;
3345 break;
3347 case OPT_Xassembler:
3348 add_assembler_option (arg, strlen (arg));
3349 do_save = false;
3350 break;
3352 case OPT_l:
3353 /* POSIX allows separation of -l and the lib arg; canonicalize
3354 by concatenating -l with its arg */
3355 add_infile (concat ("-l", arg, NULL), "*");
3356 do_save = false;
3357 break;
3359 case OPT_L:
3360 /* Similarly, canonicalize -L for linkers that may not accept
3361 separate arguments. */
3362 save_switch (concat ("-L", arg, NULL), 0, NULL, validated);
3363 return true;
3365 case OPT_F:
3366 /* Likewise -F. */
3367 save_switch (concat ("-F", arg, NULL), 0, NULL, validated);
3368 return true;
3370 case OPT_save_temps:
3371 save_temps_flag = SAVE_TEMPS_CWD;
3372 validated = true;
3373 break;
3375 case OPT_save_temps_:
3376 if (strcmp (arg, "cwd") == 0)
3377 save_temps_flag = SAVE_TEMPS_CWD;
3378 else if (strcmp (arg, "obj") == 0
3379 || strcmp (arg, "object") == 0)
3380 save_temps_flag = SAVE_TEMPS_OBJ;
3381 else
3382 fatal_error ("%qs is an unknown -save-temps option",
3383 decoded->orig_option_with_args_text);
3384 break;
3386 case OPT_canonical_prefixes:
3387 case OPT_no_canonical_prefixes:
3388 /* Already handled as a special case, so ignored here. */
3389 do_save = false;
3390 break;
3392 case OPT_pipe:
3393 validated = true;
3394 /* These options set the variables specified in common.opt
3395 automatically, but do need to be saved for spec
3396 processing. */
3397 break;
3399 case OPT_specs_:
3401 struct user_specs *user = XNEW (struct user_specs);
3403 user->next = (struct user_specs *) 0;
3404 user->filename = arg;
3405 if (user_specs_tail)
3406 user_specs_tail->next = user;
3407 else
3408 user_specs_head = user;
3409 user_specs_tail = user;
3411 do_save = false;
3412 break;
3414 case OPT__sysroot_:
3415 target_system_root = arg;
3416 target_system_root_changed = 1;
3417 do_save = false;
3418 break;
3420 case OPT_time_:
3421 if (report_times_to_file)
3422 fclose (report_times_to_file);
3423 report_times_to_file = fopen (arg, "a");
3424 do_save = false;
3425 break;
3427 case OPT____:
3428 /* "-###"
3429 This is similar to -v except that there is no execution
3430 of the commands and the echoed arguments are quoted. It
3431 is intended for use in shell scripts to capture the
3432 driver-generated command line. */
3433 verbose_only_flag++;
3434 verbose_flag = 1;
3435 do_save = false;
3436 break;
3438 case OPT_B:
3440 size_t len = strlen (arg);
3442 /* Catch the case where the user has forgotten to append a
3443 directory separator to the path. Note, they may be using
3444 -B to add an executable name prefix, eg "i386-elf-", in
3445 order to distinguish between multiple installations of
3446 GCC in the same directory. Hence we must check to see
3447 if appending a directory separator actually makes a
3448 valid directory name. */
3449 if (!IS_DIR_SEPARATOR (arg[len - 1])
3450 && is_directory (arg, false))
3452 char *tmp = XNEWVEC (char, len + 2);
3453 strcpy (tmp, arg);
3454 tmp[len] = DIR_SEPARATOR;
3455 tmp[++len] = 0;
3456 arg = tmp;
3459 add_prefix (&exec_prefixes, arg, NULL,
3460 PREFIX_PRIORITY_B_OPT, 0, 0);
3461 add_prefix (&startfile_prefixes, arg, NULL,
3462 PREFIX_PRIORITY_B_OPT, 0, 0);
3463 add_prefix (&include_prefixes, arg, NULL,
3464 PREFIX_PRIORITY_B_OPT, 0, 0);
3466 validated = true;
3467 break;
3469 case OPT_x:
3470 spec_lang = arg;
3471 if (!strcmp (spec_lang, "none"))
3472 /* Suppress the warning if -xnone comes after the last input
3473 file, because alternate command interfaces like g++ might
3474 find it useful to place -xnone after each input file. */
3475 spec_lang = 0;
3476 else
3477 last_language_n_infiles = n_infiles;
3478 do_save = false;
3479 break;
3481 case OPT_o:
3482 have_o = 1;
3483 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3484 arg = convert_filename (arg, ! have_c, 0);
3485 #endif
3486 /* Save the output name in case -save-temps=obj was used. */
3487 save_temps_prefix = xstrdup (arg);
3488 /* On some systems, ld cannot handle "-o" without a space. So
3489 split the option from its argument. */
3490 save_switch ("-o", 1, &arg, validated);
3491 return true;
3493 case OPT_static_libgcc:
3494 case OPT_shared_libgcc:
3495 case OPT_static_libgfortran:
3496 case OPT_static_libstdc__:
3497 /* These are always valid, since gcc.c itself understands the
3498 first two, gfortranspec.c understands -static-libgfortran and
3499 g++spec.c understands -static-libstdc++ */
3500 validated = true;
3501 break;
3503 default:
3504 /* Various driver options need no special processing at this
3505 point, having been handled in a prescan above or being
3506 handled by specs. */
3507 break;
3510 if (do_save)
3511 save_switch (decoded->canonical_option[0],
3512 decoded->canonical_option_num_elements - 1,
3513 &decoded->canonical_option[1], validated);
3514 return true;
3517 /* Put the driver's standard set of option handlers in *HANDLERS. */
3519 static void
3520 set_option_handlers (struct cl_option_handlers *handlers)
3522 handlers->unknown_option_callback = driver_unknown_option_callback;
3523 handlers->wrong_lang_callback = driver_wrong_lang_callback;
3524 handlers->post_handling_callback = driver_post_handling_callback;
3525 handlers->num_handlers = 1;
3526 handlers->handlers[0].handler = driver_handle_option;
3527 handlers->handlers[0].mask = CL_DRIVER;
3530 /* Create the vector `switches' and its contents.
3531 Store its length in `n_switches'. */
3533 static void
3534 process_command (unsigned int decoded_options_count,
3535 struct cl_decoded_option *decoded_options)
3537 const char *temp;
3538 char *temp1;
3539 const char *tooldir_prefix;
3540 char *(*get_relative_prefix) (const char *, const char *,
3541 const char *) = NULL;
3542 struct cl_option_handlers handlers;
3543 unsigned int j;
3545 gcc_exec_prefix = getenv ("GCC_EXEC_PREFIX");
3547 n_switches = 0;
3548 n_infiles = 0;
3549 added_libraries = 0;
3551 /* Figure compiler version from version string. */
3553 compiler_version = temp1 = xstrdup (version_string);
3555 for (; *temp1; ++temp1)
3557 if (*temp1 == ' ')
3559 *temp1 = '\0';
3560 break;
3564 /* Handle any -[no-]canonical-prefixes flags early, to assign the function
3565 that builds relative prefixes. This function creates default search
3566 paths that are needed later in normal option handling. */
3568 for (j = 1; j < decoded_options_count; j++)
3570 if (decoded_options[j].opt_index == OPT_canonical_prefixes)
3571 get_relative_prefix = make_relative_prefix;
3572 else if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
3573 get_relative_prefix = make_relative_prefix_ignore_links;
3575 if (! get_relative_prefix)
3577 #ifdef ENABLE_CANONICAL_PREFIXES
3578 get_relative_prefix = make_relative_prefix;
3579 #else
3580 get_relative_prefix = make_relative_prefix_ignore_links;
3581 #endif
3584 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3585 see if we can create it from the pathname specified in
3586 decoded_options[0].arg. */
3588 gcc_libexec_prefix = standard_libexec_prefix;
3589 #ifndef VMS
3590 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3591 if (!gcc_exec_prefix)
3593 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
3594 standard_bindir_prefix,
3595 standard_exec_prefix);
3596 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
3597 standard_bindir_prefix,
3598 standard_libexec_prefix);
3599 if (gcc_exec_prefix)
3600 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3602 else
3604 /* make_relative_prefix requires a program name, but
3605 GCC_EXEC_PREFIX is typically a directory name with a trailing
3606 / (which is ignored by make_relative_prefix), so append a
3607 program name. */
3608 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
3609 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
3610 standard_exec_prefix,
3611 standard_libexec_prefix);
3613 /* The path is unrelocated, so fallback to the original setting. */
3614 if (!gcc_libexec_prefix)
3615 gcc_libexec_prefix = standard_libexec_prefix;
3617 free (tmp_prefix);
3619 #else
3620 #endif
3621 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
3622 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
3623 or an automatically created GCC_EXEC_PREFIX from
3624 decoded_options[0].arg. */
3626 /* Do language-specific adjustment/addition of flags. */
3627 lang_specific_driver (&decoded_options, &decoded_options_count,
3628 &added_libraries);
3630 if (gcc_exec_prefix)
3632 int len = strlen (gcc_exec_prefix);
3634 if (len > (int) sizeof ("/lib/gcc/") - 1
3635 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3637 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3638 if (IS_DIR_SEPARATOR (*temp)
3639 && filename_ncmp (temp + 1, "lib", 3) == 0
3640 && IS_DIR_SEPARATOR (temp[4])
3641 && filename_ncmp (temp + 5, "gcc", 3) == 0)
3642 len -= sizeof ("/lib/gcc/") - 1;
3645 set_std_prefix (gcc_exec_prefix, len);
3646 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3647 PREFIX_PRIORITY_LAST, 0, 0);
3648 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3649 PREFIX_PRIORITY_LAST, 0, 0);
3652 /* COMPILER_PATH and LIBRARY_PATH have values
3653 that are lists of directory names with colons. */
3655 temp = getenv ("COMPILER_PATH");
3656 if (temp)
3658 const char *startp, *endp;
3659 char *nstore = (char *) alloca (strlen (temp) + 3);
3661 startp = endp = temp;
3662 while (1)
3664 if (*endp == PATH_SEPARATOR || *endp == 0)
3666 strncpy (nstore, startp, endp - startp);
3667 if (endp == startp)
3668 strcpy (nstore, concat (".", dir_separator_str, NULL));
3669 else if (!IS_DIR_SEPARATOR (endp[-1]))
3671 nstore[endp - startp] = DIR_SEPARATOR;
3672 nstore[endp - startp + 1] = 0;
3674 else
3675 nstore[endp - startp] = 0;
3676 add_prefix (&exec_prefixes, nstore, 0,
3677 PREFIX_PRIORITY_LAST, 0, 0);
3678 add_prefix (&include_prefixes, nstore, 0,
3679 PREFIX_PRIORITY_LAST, 0, 0);
3680 if (*endp == 0)
3681 break;
3682 endp = startp = endp + 1;
3684 else
3685 endp++;
3689 temp = getenv (LIBRARY_PATH_ENV);
3690 if (temp && *cross_compile == '0')
3692 const char *startp, *endp;
3693 char *nstore = (char *) alloca (strlen (temp) + 3);
3695 startp = endp = temp;
3696 while (1)
3698 if (*endp == PATH_SEPARATOR || *endp == 0)
3700 strncpy (nstore, startp, endp - startp);
3701 if (endp == startp)
3702 strcpy (nstore, concat (".", dir_separator_str, NULL));
3703 else if (!IS_DIR_SEPARATOR (endp[-1]))
3705 nstore[endp - startp] = DIR_SEPARATOR;
3706 nstore[endp - startp + 1] = 0;
3708 else
3709 nstore[endp - startp] = 0;
3710 add_prefix (&startfile_prefixes, nstore, NULL,
3711 PREFIX_PRIORITY_LAST, 0, 1);
3712 if (*endp == 0)
3713 break;
3714 endp = startp = endp + 1;
3716 else
3717 endp++;
3721 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3722 temp = getenv ("LPATH");
3723 if (temp && *cross_compile == '0')
3725 const char *startp, *endp;
3726 char *nstore = (char *) alloca (strlen (temp) + 3);
3728 startp = endp = temp;
3729 while (1)
3731 if (*endp == PATH_SEPARATOR || *endp == 0)
3733 strncpy (nstore, startp, endp - startp);
3734 if (endp == startp)
3735 strcpy (nstore, concat (".", dir_separator_str, NULL));
3736 else if (!IS_DIR_SEPARATOR (endp[-1]))
3738 nstore[endp - startp] = DIR_SEPARATOR;
3739 nstore[endp - startp + 1] = 0;
3741 else
3742 nstore[endp - startp] = 0;
3743 add_prefix (&startfile_prefixes, nstore, NULL,
3744 PREFIX_PRIORITY_LAST, 0, 1);
3745 if (*endp == 0)
3746 break;
3747 endp = startp = endp + 1;
3749 else
3750 endp++;
3754 /* Process the options and store input files and switches in their
3755 vectors. */
3757 last_language_n_infiles = -1;
3759 set_option_handlers (&handlers);
3761 for (j = 1; j < decoded_options_count; j++)
3763 switch (decoded_options[j].opt_index)
3765 case OPT_S:
3766 case OPT_c:
3767 case OPT_E:
3768 have_c = 1;
3769 break;
3771 if (have_c)
3772 break;
3775 for (j = 1; j < decoded_options_count; j++)
3777 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
3779 const char *arg = decoded_options[j].arg;
3780 const char *p = strrchr (arg, '@');
3781 char *fname;
3782 long offset;
3783 int consumed;
3784 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3785 arg = convert_filename (arg, 0, access (arg, F_OK));
3786 #endif
3787 /* For LTO static archive support we handle input file
3788 specifications that are composed of a filename and
3789 an offset like FNAME@OFFSET. */
3790 if (p
3791 && p != arg
3792 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
3793 && strlen (p) == (unsigned int)consumed)
3795 fname = (char *)xmalloc (p - arg + 1);
3796 memcpy (fname, arg, p - arg);
3797 fname[p - arg] = '\0';
3798 /* Only accept non-stdin and existing FNAME parts, otherwise
3799 try with the full name. */
3800 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
3802 free (fname);
3803 fname = xstrdup (arg);
3806 else
3807 fname = xstrdup (arg);
3809 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
3810 perror_with_name (fname);
3811 else
3812 add_infile (arg, spec_lang);
3814 free (fname);
3815 continue;
3818 read_cmdline_option (&global_options, &global_options_set,
3819 decoded_options + j, UNKNOWN_LOCATION,
3820 CL_DRIVER, &handlers, global_dc);
3823 /* If -save-temps=obj and -o name, create the prefix to use for %b.
3824 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
3825 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
3827 save_temps_length = strlen (save_temps_prefix);
3828 temp = strrchr (lbasename (save_temps_prefix), '.');
3829 if (temp)
3831 save_temps_length -= strlen (temp);
3832 save_temps_prefix[save_temps_length] = '\0';
3836 else if (save_temps_prefix != NULL)
3838 free (save_temps_prefix);
3839 save_temps_prefix = NULL;
3842 if (save_temps_flag && use_pipes)
3844 /* -save-temps overrides -pipe, so that temp files are produced */
3845 if (save_temps_flag)
3846 warning (0, "-pipe ignored because -save-temps specified");
3847 use_pipes = 0;
3850 if (!compare_debug)
3852 const char *gcd = getenv ("GCC_COMPARE_DEBUG");
3854 if (gcd && gcd[0] == '-')
3856 compare_debug = 2;
3857 compare_debug_opt = gcd;
3859 else if (gcd && *gcd && strcmp (gcd, "0"))
3861 compare_debug = 3;
3862 compare_debug_opt = "-gtoggle";
3865 else if (compare_debug < 0)
3867 compare_debug = 0;
3868 gcc_assert (!compare_debug_opt);
3871 /* Set up the search paths. We add directories that we expect to
3872 contain GNU Toolchain components before directories specified by
3873 the machine description so that we will find GNU components (like
3874 the GNU assembler) before those of the host system. */
3876 /* If we don't know where the toolchain has been installed, use the
3877 configured-in locations. */
3878 if (!gcc_exec_prefix)
3880 #ifndef OS2
3881 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
3882 PREFIX_PRIORITY_LAST, 1, 0);
3883 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
3884 PREFIX_PRIORITY_LAST, 2, 0);
3885 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
3886 PREFIX_PRIORITY_LAST, 2, 0);
3887 #endif
3888 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
3889 PREFIX_PRIORITY_LAST, 1, 0);
3892 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
3893 tooldir_prefix = concat (tooldir_base_prefix, spec_machine,
3894 dir_separator_str, NULL);
3896 /* Look for tools relative to the location from which the driver is
3897 running, or, if that is not available, the configured prefix. */
3898 tooldir_prefix
3899 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
3900 spec_machine, dir_separator_str,
3901 spec_version, dir_separator_str, tooldir_prefix, NULL);
3903 add_prefix (&exec_prefixes,
3904 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
3905 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
3906 add_prefix (&startfile_prefixes,
3907 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
3908 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
3910 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
3911 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
3912 then consider it to relocate with the rest of the GCC installation
3913 if GCC_EXEC_PREFIX is set.
3914 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
3915 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
3917 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
3918 standard_bindir_prefix,
3919 target_system_root);
3920 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
3922 target_system_root = tmp_prefix;
3923 target_system_root_changed = 1;
3926 #endif
3928 /* More prefixes are enabled in main, after we read the specs file
3929 and determine whether this is cross-compilation or not. */
3931 if (n_infiles == last_language_n_infiles && spec_lang != 0)
3932 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
3934 if (compare_debug == 2 || compare_debug == 3)
3936 alloc_switch ();
3937 switches[n_switches].part1 = concat ("fcompare-debug=",
3938 compare_debug_opt,
3939 NULL);
3940 switches[n_switches].args = 0;
3941 switches[n_switches].live_cond = 0;
3942 switches[n_switches].validated = 0;
3943 switches[n_switches].ordering = 0;
3944 n_switches++;
3945 compare_debug = 1;
3948 /* Ensure we only invoke each subprocess once. */
3949 if (print_subprocess_help || print_help_list || print_version)
3951 n_infiles = 0;
3953 /* Create a dummy input file, so that we can pass
3954 the help option on to the various sub-processes. */
3955 add_infile ("help-dummy", "c");
3958 alloc_switch ();
3959 switches[n_switches].part1 = 0;
3960 alloc_infile ();
3961 infiles[n_infiles].name = 0;
3964 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
3965 and place that in the environment. */
3967 static void
3968 set_collect_gcc_options (void)
3970 int i;
3971 int first_time;
3973 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
3974 the compiler. */
3975 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
3976 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
3978 first_time = TRUE;
3979 for (i = 0; (int) i < n_switches; i++)
3981 const char *const *args;
3982 const char *p, *q;
3983 if (!first_time)
3984 obstack_grow (&collect_obstack, " ", 1);
3986 first_time = FALSE;
3988 /* Ignore elided switches. */
3989 if ((switches[i].live_cond
3990 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
3991 == SWITCH_IGNORE)
3992 continue;
3994 obstack_grow (&collect_obstack, "'-", 2);
3995 q = switches[i].part1;
3996 while ((p = strchr (q, '\'')))
3998 obstack_grow (&collect_obstack, q, p - q);
3999 obstack_grow (&collect_obstack, "'\\''", 4);
4000 q = ++p;
4002 obstack_grow (&collect_obstack, q, strlen (q));
4003 obstack_grow (&collect_obstack, "'", 1);
4005 for (args = switches[i].args; args && *args; args++)
4007 obstack_grow (&collect_obstack, " '", 2);
4008 q = *args;
4009 while ((p = strchr (q, '\'')))
4011 obstack_grow (&collect_obstack, q, p - q);
4012 obstack_grow (&collect_obstack, "'\\''", 4);
4013 q = ++p;
4015 obstack_grow (&collect_obstack, q, strlen (q));
4016 obstack_grow (&collect_obstack, "'", 1);
4019 obstack_grow (&collect_obstack, "\0", 1);
4020 xputenv (XOBFINISH (&collect_obstack, char *));
4023 /* Process a spec string, accumulating and running commands. */
4025 /* These variables describe the input file name.
4026 input_file_number is the index on outfiles of this file,
4027 so that the output file name can be stored for later use by %o.
4028 input_basename is the start of the part of the input file
4029 sans all directory names, and basename_length is the number
4030 of characters starting there excluding the suffix .c or whatever. */
4032 static const char *gcc_input_filename;
4033 static int input_file_number;
4034 size_t input_filename_length;
4035 static int basename_length;
4036 static int suffixed_basename_length;
4037 static const char *input_basename;
4038 static const char *input_suffix;
4039 #ifndef HOST_LACKS_INODE_NUMBERS
4040 static struct stat input_stat;
4041 #endif
4042 static int input_stat_set;
4044 /* The compiler used to process the current input file. */
4045 static struct compiler *input_file_compiler;
4047 /* These are variables used within do_spec and do_spec_1. */
4049 /* Nonzero if an arg has been started and not yet terminated
4050 (with space, tab or newline). */
4051 static int arg_going;
4053 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4054 is a temporary file name. */
4055 static int delete_this_arg;
4057 /* Nonzero means %w has been seen; the next arg to be terminated
4058 is the output file name of this compilation. */
4059 static int this_is_output_file;
4061 /* Nonzero means %s has been seen; the next arg to be terminated
4062 is the name of a library file and we should try the standard
4063 search dirs for it. */
4064 static int this_is_library_file;
4066 /* Nonzero means %T has been seen; the next arg to be terminated
4067 is the name of a linker script and we should try all of the
4068 standard search dirs for it. If it is found insert a --script
4069 command line switch and then substitute the full path in place,
4070 otherwise generate an error message. */
4071 static int this_is_linker_script;
4073 /* Nonzero means that the input of this command is coming from a pipe. */
4074 static int input_from_pipe;
4076 /* Nonnull means substitute this for any suffix when outputting a switches
4077 arguments. */
4078 static const char *suffix_subst;
4080 /* If there is an argument being accumulated, terminate it and store it. */
4082 static void
4083 end_going_arg (void)
4085 if (arg_going)
4087 const char *string;
4089 obstack_1grow (&obstack, 0);
4090 string = XOBFINISH (&obstack, const char *);
4091 if (this_is_library_file)
4092 string = find_file (string);
4093 if (this_is_linker_script)
4095 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4097 if (full_script_path == NULL)
4099 error ("unable to locate default linker script %qs in the library search paths", string);
4100 /* Script was not found on search path. */
4101 return;
4103 store_arg ("--script", false, false);
4104 string = full_script_path;
4106 store_arg (string, delete_this_arg, this_is_output_file);
4107 if (this_is_output_file)
4108 outfiles[input_file_number] = string;
4109 arg_going = 0;
4114 /* Parse the WRAPPER string which is a comma separated list of the command line
4115 and insert them into the beginning of argbuf. */
4117 static void
4118 insert_wrapper (const char *wrapper)
4120 int n = 0;
4121 int i;
4122 char *buf = xstrdup (wrapper);
4123 char *p = buf;
4124 unsigned int old_length = VEC_length (const_char_p, argbuf);
4128 n++;
4129 while (*p == ',')
4130 p++;
4132 while ((p = strchr (p, ',')) != NULL);
4134 VEC_safe_grow (const_char_p, heap, argbuf, old_length + n);
4135 memmove (VEC_address (const_char_p, argbuf) + n,
4136 VEC_address (const_char_p, argbuf),
4137 old_length * sizeof (const_char_p));
4139 i = 0;
4140 p = buf;
4143 while (*p == ',')
4145 *p = 0;
4146 p++;
4148 VEC_replace (const_char_p, argbuf, i, p);
4149 i++;
4151 while ((p = strchr (p, ',')) != NULL);
4152 gcc_assert (i == n);
4155 /* Process the spec SPEC and run the commands specified therein.
4156 Returns 0 if the spec is successfully processed; -1 if failed. */
4159 do_spec (const char *spec)
4161 int value;
4163 value = do_spec_2 (spec);
4165 /* Force out any unfinished command.
4166 If -pipe, this forces out the last command if it ended in `|'. */
4167 if (value == 0)
4169 if (VEC_length (const_char_p, argbuf) > 0
4170 && !strcmp (VEC_last (const_char_p, argbuf), "|"))
4171 VEC_pop (const_char_p, argbuf);
4173 set_collect_gcc_options ();
4175 if (VEC_length (const_char_p, argbuf) > 0)
4176 value = execute ();
4179 return value;
4182 static int
4183 do_spec_2 (const char *spec)
4185 int result;
4187 clear_args ();
4188 arg_going = 0;
4189 delete_this_arg = 0;
4190 this_is_output_file = 0;
4191 this_is_library_file = 0;
4192 this_is_linker_script = 0;
4193 input_from_pipe = 0;
4194 suffix_subst = NULL;
4196 result = do_spec_1 (spec, 0, NULL);
4198 end_going_arg ();
4200 return result;
4204 /* Process the given spec string and add any new options to the end
4205 of the switches/n_switches array. */
4207 static void
4208 do_option_spec (const char *name, const char *spec)
4210 unsigned int i, value_count, value_len;
4211 const char *p, *q, *value;
4212 char *tmp_spec, *tmp_spec_p;
4214 if (configure_default_options[0].name == NULL)
4215 return;
4217 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4218 if (strcmp (configure_default_options[i].name, name) == 0)
4219 break;
4220 if (i == ARRAY_SIZE (configure_default_options))
4221 return;
4223 value = configure_default_options[i].value;
4224 value_len = strlen (value);
4226 /* Compute the size of the final spec. */
4227 value_count = 0;
4228 p = spec;
4229 while ((p = strstr (p, "%(VALUE)")) != NULL)
4231 p ++;
4232 value_count ++;
4235 /* Replace each %(VALUE) by the specified value. */
4236 tmp_spec = (char *) alloca (strlen (spec) + 1
4237 + value_count * (value_len - strlen ("%(VALUE)")));
4238 tmp_spec_p = tmp_spec;
4239 q = spec;
4240 while ((p = strstr (q, "%(VALUE)")) != NULL)
4242 memcpy (tmp_spec_p, q, p - q);
4243 tmp_spec_p = tmp_spec_p + (p - q);
4244 memcpy (tmp_spec_p, value, value_len);
4245 tmp_spec_p += value_len;
4246 q = p + strlen ("%(VALUE)");
4248 strcpy (tmp_spec_p, q);
4250 do_self_spec (tmp_spec);
4253 /* Process the given spec string and add any new options to the end
4254 of the switches/n_switches array. */
4256 static void
4257 do_self_spec (const char *spec)
4259 int i;
4261 do_spec_2 (spec);
4262 do_spec_1 (" ", 0, NULL);
4264 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4265 do_self_specs adds the replacements to switches array, so it shouldn't
4266 be processed afterwards. */
4267 for (i = 0; i < n_switches; i++)
4268 if ((switches[i].live_cond & SWITCH_IGNORE))
4269 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4271 if (VEC_length (const_char_p, argbuf) > 0)
4273 const char **argbuf_copy;
4274 struct cl_decoded_option *decoded_options;
4275 struct cl_option_handlers handlers;
4276 unsigned int decoded_options_count;
4277 unsigned int j;
4279 /* Create a copy of argbuf with a dummy argv[0] entry for
4280 decode_cmdline_options_to_array. */
4281 argbuf_copy = XNEWVEC (const char *,
4282 VEC_length (const_char_p, argbuf) + 1);
4283 argbuf_copy[0] = "";
4284 memcpy (argbuf_copy + 1, VEC_address (const_char_p, argbuf),
4285 VEC_length (const_char_p, argbuf) * sizeof (const char *));
4287 decode_cmdline_options_to_array (VEC_length (const_char_p, argbuf) + 1,
4288 argbuf_copy,
4289 CL_DRIVER, &decoded_options,
4290 &decoded_options_count);
4292 set_option_handlers (&handlers);
4294 for (j = 1; j < decoded_options_count; j++)
4296 switch (decoded_options[j].opt_index)
4298 case OPT_SPECIAL_input_file:
4299 /* Specs should only generate options, not input
4300 files. */
4301 if (strcmp (decoded_options[j].arg, "-") != 0)
4302 fatal_error ("switch %qs does not start with %<-%>",
4303 decoded_options[j].arg);
4304 else
4305 fatal_error ("spec-generated switch is just %<-%>");
4306 break;
4308 case OPT_fcompare_debug_second:
4309 case OPT_fcompare_debug:
4310 case OPT_fcompare_debug_:
4311 case OPT_o:
4312 /* Avoid duplicate processing of some options from
4313 compare-debug specs; just save them here. */
4314 save_switch (decoded_options[j].canonical_option[0],
4315 (decoded_options[j].canonical_option_num_elements
4316 - 1),
4317 &decoded_options[j].canonical_option[1], false);
4318 break;
4320 default:
4321 read_cmdline_option (&global_options, &global_options_set,
4322 decoded_options + j, UNKNOWN_LOCATION,
4323 CL_DRIVER, &handlers, global_dc);
4324 break;
4328 alloc_switch ();
4329 switches[n_switches].part1 = 0;
4333 /* Callback for processing %D and %I specs. */
4335 struct spec_path_info {
4336 const char *option;
4337 const char *append;
4338 size_t append_len;
4339 bool omit_relative;
4340 bool separate_options;
4343 static void *
4344 spec_path (char *path, void *data)
4346 struct spec_path_info *info = (struct spec_path_info *) data;
4347 size_t len = 0;
4348 char save = 0;
4350 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4351 return NULL;
4353 if (info->append_len != 0)
4355 len = strlen (path);
4356 memcpy (path + len, info->append, info->append_len + 1);
4359 if (!is_directory (path, true))
4360 return NULL;
4362 do_spec_1 (info->option, 1, NULL);
4363 if (info->separate_options)
4364 do_spec_1 (" ", 0, NULL);
4366 if (info->append_len == 0)
4368 len = strlen (path);
4369 save = path[len - 1];
4370 if (IS_DIR_SEPARATOR (path[len - 1]))
4371 path[len - 1] = '\0';
4374 do_spec_1 (path, 1, NULL);
4375 do_spec_1 (" ", 0, NULL);
4377 /* Must not damage the original path. */
4378 if (info->append_len == 0)
4379 path[len - 1] = save;
4381 return NULL;
4384 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
4385 argument list. */
4387 static void
4388 create_at_file (char **argv)
4390 char *temp_file = make_temp_file ("");
4391 char *at_argument = concat ("@", temp_file, NULL);
4392 FILE *f = fopen (temp_file, "w");
4393 int status;
4395 if (f == NULL)
4396 fatal_error ("could not open temporary response file %s",
4397 temp_file);
4399 status = writeargv (argv, f);
4401 if (status)
4402 fatal_error ("could not write to temporary response file %s",
4403 temp_file);
4405 status = fclose (f);
4407 if (EOF == status)
4408 fatal_error ("could not close temporary response file %s",
4409 temp_file);
4411 store_arg (at_argument, 0, 0);
4413 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
4416 /* True if we should compile INFILE. */
4418 static bool
4419 compile_input_file_p (struct infile *infile)
4421 if ((!infile->language) || (infile->language[0] != '*'))
4422 if (infile->incompiler == input_file_compiler)
4423 return true;
4424 return false;
4427 /* Process each member of VEC as a spec. */
4429 static void
4430 do_specs_vec (VEC(char_p,heap) *vec)
4432 unsigned ix;
4433 char *opt;
4435 FOR_EACH_VEC_ELT (char_p, vec, ix, opt)
4437 do_spec_1 (opt, 1, NULL);
4438 /* Make each accumulated option a separate argument. */
4439 do_spec_1 (" ", 0, NULL);
4443 /* Process the sub-spec SPEC as a portion of a larger spec.
4444 This is like processing a whole spec except that we do
4445 not initialize at the beginning and we do not supply a
4446 newline by default at the end.
4447 INSWITCH nonzero means don't process %-sequences in SPEC;
4448 in this case, % is treated as an ordinary character.
4449 This is used while substituting switches.
4450 INSWITCH nonzero also causes SPC not to terminate an argument.
4452 Value is zero unless a line was finished
4453 and the command on that line reported an error. */
4455 static int
4456 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4458 const char *p = spec;
4459 int c;
4460 int i;
4461 int value;
4463 /* If it's an empty string argument to a switch, keep it as is. */
4464 if (inswitch && !*p)
4465 arg_going = 1;
4467 while ((c = *p++))
4468 /* If substituting a switch, treat all chars like letters.
4469 Otherwise, NL, SPC, TAB and % are special. */
4470 switch (inswitch ? 'a' : c)
4472 case '\n':
4473 end_going_arg ();
4475 if (VEC_length (const_char_p, argbuf) > 0
4476 && !strcmp (VEC_last (const_char_p, argbuf), "|"))
4478 /* A `|' before the newline means use a pipe here,
4479 but only if -pipe was specified.
4480 Otherwise, execute now and don't pass the `|' as an arg. */
4481 if (use_pipes)
4483 input_from_pipe = 1;
4484 break;
4486 else
4487 VEC_pop (const_char_p, argbuf);
4490 set_collect_gcc_options ();
4492 if (VEC_length (const_char_p, argbuf) > 0)
4494 value = execute ();
4495 if (value)
4496 return value;
4498 /* Reinitialize for a new command, and for a new argument. */
4499 clear_args ();
4500 arg_going = 0;
4501 delete_this_arg = 0;
4502 this_is_output_file = 0;
4503 this_is_library_file = 0;
4504 this_is_linker_script = 0;
4505 input_from_pipe = 0;
4506 break;
4508 case '|':
4509 end_going_arg ();
4511 /* Use pipe */
4512 obstack_1grow (&obstack, c);
4513 arg_going = 1;
4514 break;
4516 case '\t':
4517 case ' ':
4518 end_going_arg ();
4520 /* Reinitialize for a new argument. */
4521 delete_this_arg = 0;
4522 this_is_output_file = 0;
4523 this_is_library_file = 0;
4524 this_is_linker_script = 0;
4525 break;
4527 case '%':
4528 switch (c = *p++)
4530 case 0:
4531 fatal_error ("spec %qs invalid", spec);
4533 case 'b':
4534 if (save_temps_length)
4535 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4536 else
4537 obstack_grow (&obstack, input_basename, basename_length);
4538 if (compare_debug < 0)
4539 obstack_grow (&obstack, ".gk", 3);
4540 arg_going = 1;
4541 break;
4543 case 'B':
4544 if (save_temps_length)
4545 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4546 else
4547 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4548 if (compare_debug < 0)
4549 obstack_grow (&obstack, ".gk", 3);
4550 arg_going = 1;
4551 break;
4553 case 'd':
4554 delete_this_arg = 2;
4555 break;
4557 /* Dump out the directories specified with LIBRARY_PATH,
4558 followed by the absolute directories
4559 that we search for startfiles. */
4560 case 'D':
4562 struct spec_path_info info;
4564 info.option = "-L";
4565 info.append_len = 0;
4566 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4567 /* Used on systems which record the specified -L dirs
4568 and use them to search for dynamic linking.
4569 Relative directories always come from -B,
4570 and it is better not to use them for searching
4571 at run time. In particular, stage1 loses. */
4572 info.omit_relative = true;
4573 #else
4574 info.omit_relative = false;
4575 #endif
4576 info.separate_options = false;
4578 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
4580 break;
4582 case 'e':
4583 /* %efoo means report an error with `foo' as error message
4584 and don't execute any more commands for this file. */
4586 const char *q = p;
4587 char *buf;
4588 while (*p != 0 && *p != '\n')
4589 p++;
4590 buf = (char *) alloca (p - q + 1);
4591 strncpy (buf, q, p - q);
4592 buf[p - q] = 0;
4593 error ("%s", _(buf));
4594 return -1;
4596 break;
4597 case 'n':
4598 /* %nfoo means report a notice with `foo' on stderr. */
4600 const char *q = p;
4601 char *buf;
4602 while (*p != 0 && *p != '\n')
4603 p++;
4604 buf = (char *) alloca (p - q + 1);
4605 strncpy (buf, q, p - q);
4606 buf[p - q] = 0;
4607 inform (0, "%s", _(buf));
4608 if (*p)
4609 p++;
4611 break;
4613 case 'j':
4615 struct stat st;
4617 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4618 defined, and it is not a directory, and it is
4619 writable, use it. Otherwise, treat this like any
4620 other temporary file. */
4622 if ((!save_temps_flag)
4623 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4624 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4626 obstack_grow (&obstack, HOST_BIT_BUCKET,
4627 strlen (HOST_BIT_BUCKET));
4628 delete_this_arg = 0;
4629 arg_going = 1;
4630 break;
4633 goto create_temp_file;
4634 case '|':
4635 if (use_pipes)
4637 obstack_1grow (&obstack, '-');
4638 delete_this_arg = 0;
4639 arg_going = 1;
4641 /* consume suffix */
4642 while (*p == '.' || ISALNUM ((unsigned char) *p))
4643 p++;
4644 if (p[0] == '%' && p[1] == 'O')
4645 p += 2;
4647 break;
4649 goto create_temp_file;
4650 case 'm':
4651 if (use_pipes)
4653 /* consume suffix */
4654 while (*p == '.' || ISALNUM ((unsigned char) *p))
4655 p++;
4656 if (p[0] == '%' && p[1] == 'O')
4657 p += 2;
4659 break;
4661 goto create_temp_file;
4662 case 'g':
4663 case 'u':
4664 case 'U':
4665 create_temp_file:
4667 struct temp_name *t;
4668 int suffix_length;
4669 const char *suffix = p;
4670 char *saved_suffix = NULL;
4672 while (*p == '.' || ISALNUM ((unsigned char) *p))
4673 p++;
4674 suffix_length = p - suffix;
4675 if (p[0] == '%' && p[1] == 'O')
4677 p += 2;
4678 /* We don't support extra suffix characters after %O. */
4679 if (*p == '.' || ISALNUM ((unsigned char) *p))
4680 fatal_error ("spec %qs has invalid %<%%0%c%>", spec, *p);
4681 if (suffix_length == 0)
4682 suffix = TARGET_OBJECT_SUFFIX;
4683 else
4685 saved_suffix
4686 = XNEWVEC (char, suffix_length
4687 + strlen (TARGET_OBJECT_SUFFIX));
4688 strncpy (saved_suffix, suffix, suffix_length);
4689 strcpy (saved_suffix + suffix_length,
4690 TARGET_OBJECT_SUFFIX);
4692 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4695 if (compare_debug < 0)
4697 suffix = concat (".gk", suffix, NULL);
4698 suffix_length += 3;
4701 /* If -save-temps=obj and -o were specified, use that for the
4702 temp file. */
4703 if (save_temps_length)
4705 char *tmp;
4706 temp_filename_length
4707 = save_temps_length + suffix_length + 1;
4708 tmp = (char *) alloca (temp_filename_length);
4709 memcpy (tmp, save_temps_prefix, save_temps_length);
4710 memcpy (tmp + save_temps_length, suffix, suffix_length);
4711 tmp[save_temps_length + suffix_length] = '\0';
4712 temp_filename = save_string (tmp,
4713 temp_filename_length + 1);
4714 obstack_grow (&obstack, temp_filename,
4715 temp_filename_length);
4716 arg_going = 1;
4717 delete_this_arg = 0;
4718 break;
4721 /* If the gcc_input_filename has the same suffix specified
4722 for the %g, %u, or %U, and -save-temps is specified,
4723 we could end up using that file as an intermediate
4724 thus clobbering the user's source file (.e.g.,
4725 gcc -save-temps foo.s would clobber foo.s with the
4726 output of cpp0). So check for this condition and
4727 generate a temp file as the intermediate. */
4729 if (save_temps_flag)
4731 char *tmp;
4732 temp_filename_length = basename_length + suffix_length + 1;
4733 tmp = (char *) alloca (temp_filename_length);
4734 memcpy (tmp, input_basename, basename_length);
4735 memcpy (tmp + basename_length, suffix, suffix_length);
4736 tmp[basename_length + suffix_length] = '\0';
4737 temp_filename = tmp;
4739 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
4741 #ifndef HOST_LACKS_INODE_NUMBERS
4742 struct stat st_temp;
4744 /* Note, set_input() resets input_stat_set to 0. */
4745 if (input_stat_set == 0)
4747 input_stat_set = stat (gcc_input_filename,
4748 &input_stat);
4749 if (input_stat_set >= 0)
4750 input_stat_set = 1;
4753 /* If we have the stat for the gcc_input_filename
4754 and we can do the stat for the temp_filename
4755 then the they could still refer to the same
4756 file if st_dev/st_ino's are the same. */
4757 if (input_stat_set != 1
4758 || stat (temp_filename, &st_temp) < 0
4759 || input_stat.st_dev != st_temp.st_dev
4760 || input_stat.st_ino != st_temp.st_ino)
4761 #else
4762 /* Just compare canonical pathnames. */
4763 char* input_realname = lrealpath (gcc_input_filename);
4764 char* temp_realname = lrealpath (temp_filename);
4765 bool files_differ = filename_cmp (input_realname, temp_realname);
4766 free (input_realname);
4767 free (temp_realname);
4768 if (files_differ)
4769 #endif
4771 temp_filename = save_string (temp_filename,
4772 temp_filename_length + 1);
4773 obstack_grow (&obstack, temp_filename,
4774 temp_filename_length);
4775 arg_going = 1;
4776 delete_this_arg = 0;
4777 break;
4782 /* See if we already have an association of %g/%u/%U and
4783 suffix. */
4784 for (t = temp_names; t; t = t->next)
4785 if (t->length == suffix_length
4786 && strncmp (t->suffix, suffix, suffix_length) == 0
4787 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4788 break;
4790 /* Make a new association if needed. %u and %j
4791 require one. */
4792 if (t == 0 || c == 'u' || c == 'j')
4794 if (t == 0)
4796 t = XNEW (struct temp_name);
4797 t->next = temp_names;
4798 temp_names = t;
4800 t->length = suffix_length;
4801 if (saved_suffix)
4803 t->suffix = saved_suffix;
4804 saved_suffix = NULL;
4806 else
4807 t->suffix = save_string (suffix, suffix_length);
4808 t->unique = (c == 'u' || c == 'U' || c == 'j');
4809 temp_filename = make_temp_file (t->suffix);
4810 temp_filename_length = strlen (temp_filename);
4811 t->filename = temp_filename;
4812 t->filename_length = temp_filename_length;
4815 if (saved_suffix)
4816 free (saved_suffix);
4818 obstack_grow (&obstack, t->filename, t->filename_length);
4819 delete_this_arg = 1;
4821 arg_going = 1;
4822 break;
4824 case 'i':
4825 if (combine_inputs)
4827 if (at_file_supplied)
4829 /* We are going to expand `%i' to `@FILE', where FILE
4830 is a newly-created temporary filename. The filenames
4831 that would usually be expanded in place of %o will be
4832 written to the temporary file. */
4833 char **argv;
4834 int n_files = 0;
4835 int j;
4837 for (i = 0; i < n_infiles; i++)
4838 if (compile_input_file_p (&infiles[i]))
4839 n_files++;
4841 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
4843 /* Copy the strings over. */
4844 for (i = 0, j = 0; i < n_infiles; i++)
4845 if (compile_input_file_p (&infiles[i]))
4847 argv[j] = CONST_CAST (char *, infiles[i].name);
4848 infiles[i].compiled = true;
4849 j++;
4851 argv[j] = NULL;
4853 create_at_file (argv);
4855 else
4856 for (i = 0; (int) i < n_infiles; i++)
4857 if (compile_input_file_p (&infiles[i]))
4859 store_arg (infiles[i].name, 0, 0);
4860 infiles[i].compiled = true;
4863 else
4865 obstack_grow (&obstack, gcc_input_filename,
4866 input_filename_length);
4867 arg_going = 1;
4869 break;
4871 case 'I':
4873 struct spec_path_info info;
4875 if (multilib_dir)
4877 do_spec_1 ("-imultilib", 1, NULL);
4878 /* Make this a separate argument. */
4879 do_spec_1 (" ", 0, NULL);
4880 do_spec_1 (multilib_dir, 1, NULL);
4881 do_spec_1 (" ", 0, NULL);
4884 if (gcc_exec_prefix)
4886 do_spec_1 ("-iprefix", 1, NULL);
4887 /* Make this a separate argument. */
4888 do_spec_1 (" ", 0, NULL);
4889 do_spec_1 (gcc_exec_prefix, 1, NULL);
4890 do_spec_1 (" ", 0, NULL);
4893 if (target_system_root_changed ||
4894 (target_system_root && target_sysroot_hdrs_suffix))
4896 do_spec_1 ("-isysroot", 1, NULL);
4897 /* Make this a separate argument. */
4898 do_spec_1 (" ", 0, NULL);
4899 do_spec_1 (target_system_root, 1, NULL);
4900 if (target_sysroot_hdrs_suffix)
4901 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
4902 do_spec_1 (" ", 0, NULL);
4905 info.option = "-isystem";
4906 info.append = "include";
4907 info.append_len = strlen (info.append);
4908 info.omit_relative = false;
4909 info.separate_options = true;
4911 for_each_path (&include_prefixes, false, info.append_len,
4912 spec_path, &info);
4914 info.append = "include-fixed";
4915 if (*sysroot_hdrs_suffix_spec)
4916 info.append = concat (info.append, dir_separator_str,
4917 multilib_dir, NULL);
4918 info.append_len = strlen (info.append);
4919 for_each_path (&include_prefixes, false, info.append_len,
4920 spec_path, &info);
4922 break;
4924 case 'o':
4926 int max = n_infiles;
4927 max += lang_specific_extra_outfiles;
4929 if (HAVE_GNU_LD && at_file_supplied)
4931 /* We are going to expand `%o' to `@FILE', where FILE
4932 is a newly-created temporary filename. The filenames
4933 that would usually be expanded in place of %o will be
4934 written to the temporary file. */
4936 char **argv;
4937 int n_files, j;
4939 /* Convert OUTFILES into a form suitable for writeargv. */
4941 /* Determine how many are non-NULL. */
4942 for (n_files = 0, i = 0; i < max; i++)
4943 n_files += outfiles[i] != NULL;
4945 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
4947 /* Copy the strings over. */
4948 for (i = 0, j = 0; i < max; i++)
4949 if (outfiles[i])
4951 argv[j] = CONST_CAST (char *, outfiles[i]);
4952 j++;
4954 argv[j] = NULL;
4956 create_at_file (argv);
4958 else
4959 for (i = 0; i < max; i++)
4960 if (outfiles[i])
4961 store_arg (outfiles[i], 0, 0);
4962 break;
4965 case 'O':
4966 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
4967 arg_going = 1;
4968 break;
4970 case 's':
4971 this_is_library_file = 1;
4972 break;
4974 case 'T':
4975 this_is_linker_script = 1;
4976 break;
4978 case 'V':
4979 outfiles[input_file_number] = NULL;
4980 break;
4982 case 'w':
4983 this_is_output_file = 1;
4984 break;
4986 case 'W':
4988 unsigned int cur_index = VEC_length (const_char_p, argbuf);
4989 /* Handle the {...} following the %W. */
4990 if (*p != '{')
4991 fatal_error ("spec %qs has invalid %<%%W%c%>", spec, *p);
4992 p = handle_braces (p + 1);
4993 if (p == 0)
4994 return -1;
4995 end_going_arg ();
4996 /* If any args were output, mark the last one for deletion
4997 on failure. */
4998 if (VEC_length (const_char_p, argbuf) != cur_index)
4999 record_temp_file (VEC_last (const_char_p, argbuf), 0, 1);
5000 break;
5003 /* %x{OPTION} records OPTION for %X to output. */
5004 case 'x':
5006 const char *p1 = p;
5007 char *string;
5008 char *opt;
5009 unsigned ix;
5011 /* Skip past the option value and make a copy. */
5012 if (*p != '{')
5013 fatal_error ("spec %qs has invalid %<%%x%c%>", spec, *p);
5014 while (*p++ != '}')
5016 string = save_string (p1 + 1, p - p1 - 2);
5018 /* See if we already recorded this option. */
5019 FOR_EACH_VEC_ELT (char_p, linker_options, ix, opt)
5020 if (! strcmp (string, opt))
5022 free (string);
5023 return 0;
5026 /* This option is new; add it. */
5027 add_linker_option (string, strlen (string));
5029 break;
5031 /* Dump out the options accumulated previously using %x. */
5032 case 'X':
5033 do_specs_vec (linker_options);
5034 break;
5036 /* Dump out the options accumulated previously using -Wa,. */
5037 case 'Y':
5038 do_specs_vec (assembler_options);
5039 break;
5041 /* Dump out the options accumulated previously using -Wp,. */
5042 case 'Z':
5043 do_specs_vec (preprocessor_options);
5044 break;
5046 /* Here are digits and numbers that just process
5047 a certain constant string as a spec. */
5049 case '1':
5050 value = do_spec_1 (cc1_spec, 0, NULL);
5051 if (value != 0)
5052 return value;
5053 break;
5055 case '2':
5056 value = do_spec_1 (cc1plus_spec, 0, NULL);
5057 if (value != 0)
5058 return value;
5059 break;
5061 case 'a':
5062 value = do_spec_1 (asm_spec, 0, NULL);
5063 if (value != 0)
5064 return value;
5065 break;
5067 case 'A':
5068 value = do_spec_1 (asm_final_spec, 0, NULL);
5069 if (value != 0)
5070 return value;
5071 break;
5073 case 'C':
5075 const char *const spec
5076 = (input_file_compiler->cpp_spec
5077 ? input_file_compiler->cpp_spec
5078 : cpp_spec);
5079 value = do_spec_1 (spec, 0, NULL);
5080 if (value != 0)
5081 return value;
5083 break;
5085 case 'E':
5086 value = do_spec_1 (endfile_spec, 0, NULL);
5087 if (value != 0)
5088 return value;
5089 break;
5091 case 'l':
5092 value = do_spec_1 (link_spec, 0, NULL);
5093 if (value != 0)
5094 return value;
5095 break;
5097 case 'L':
5098 value = do_spec_1 (lib_spec, 0, NULL);
5099 if (value != 0)
5100 return value;
5101 break;
5103 case 'G':
5104 value = do_spec_1 (libgcc_spec, 0, NULL);
5105 if (value != 0)
5106 return value;
5107 break;
5109 case 'R':
5110 /* We assume there is a directory
5111 separator at the end of this string. */
5112 if (target_system_root)
5114 obstack_grow (&obstack, target_system_root,
5115 strlen (target_system_root));
5116 if (target_sysroot_suffix)
5117 obstack_grow (&obstack, target_sysroot_suffix,
5118 strlen (target_sysroot_suffix));
5120 break;
5122 case 'S':
5123 value = do_spec_1 (startfile_spec, 0, NULL);
5124 if (value != 0)
5125 return value;
5126 break;
5128 /* Here we define characters other than letters and digits. */
5130 case '{':
5131 p = handle_braces (p);
5132 if (p == 0)
5133 return -1;
5134 break;
5136 case ':':
5137 p = handle_spec_function (p);
5138 if (p == 0)
5139 return -1;
5140 break;
5142 case '%':
5143 obstack_1grow (&obstack, '%');
5144 break;
5146 case '.':
5148 unsigned len = 0;
5150 while (p[len] && p[len] != ' ' && p[len] != '%')
5151 len++;
5152 suffix_subst = save_string (p - 1, len + 1);
5153 p += len;
5155 break;
5157 /* Henceforth ignore the option(s) matching the pattern
5158 after the %<. */
5159 case '<':
5160 case '>':
5162 unsigned len = 0;
5163 int have_wildcard = 0;
5164 int i;
5165 int switch_option;
5167 if (c == '>')
5168 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5169 else
5170 switch_option = SWITCH_IGNORE;
5172 while (p[len] && p[len] != ' ' && p[len] != '\t')
5173 len++;
5175 if (p[len-1] == '*')
5176 have_wildcard = 1;
5178 for (i = 0; i < n_switches; i++)
5179 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5180 && (have_wildcard || switches[i].part1[len] == '\0'))
5182 switches[i].live_cond |= switch_option;
5183 switches[i].validated = 1;
5186 p += len;
5188 break;
5190 case '*':
5191 if (soft_matched_part)
5193 if (soft_matched_part[0])
5194 do_spec_1 (soft_matched_part, 1, NULL);
5195 do_spec_1 (" ", 0, NULL);
5197 else
5198 /* Catch the case where a spec string contains something like
5199 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5200 hand side of the :. */
5201 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5202 break;
5204 /* Process a string found as the value of a spec given by name.
5205 This feature allows individual machine descriptions
5206 to add and use their own specs.
5207 %[...] modifies -D options the way %P does;
5208 %(...) uses the spec unmodified. */
5209 case '[':
5210 warning (0, "use of obsolete %%[ operator in specs");
5211 case '(':
5213 const char *name = p;
5214 struct spec_list *sl;
5215 int len;
5217 /* The string after the S/P is the name of a spec that is to be
5218 processed. */
5219 while (*p && *p != ')' && *p != ']')
5220 p++;
5222 /* See if it's in the list. */
5223 for (len = p - name, sl = specs; sl; sl = sl->next)
5224 if (sl->name_len == len && !strncmp (sl->name, name, len))
5226 name = *(sl->ptr_spec);
5227 #ifdef DEBUG_SPECS
5228 fnotice (stderr, "Processing spec %c%s%c, which is '%s'\n",
5229 c, sl->name, (c == '(') ? ')' : ']', name);
5230 #endif
5231 break;
5234 if (sl)
5236 if (c == '(')
5238 value = do_spec_1 (name, 0, NULL);
5239 if (value != 0)
5240 return value;
5242 else
5244 char *x = (char *) alloca (strlen (name) * 2 + 1);
5245 char *buf = x;
5246 const char *y = name;
5247 int flag = 0;
5249 /* Copy all of NAME into BUF, but put __ after
5250 every -D and at the end of each arg. */
5251 while (1)
5253 if (! strncmp (y, "-D", 2))
5255 *x++ = '-';
5256 *x++ = 'D';
5257 *x++ = '_';
5258 *x++ = '_';
5259 y += 2;
5260 flag = 1;
5261 continue;
5263 else if (flag
5264 && (*y == ' ' || *y == '\t' || *y == '='
5265 || *y == '}' || *y == 0))
5267 *x++ = '_';
5268 *x++ = '_';
5269 flag = 0;
5271 if (*y == 0)
5272 break;
5273 else
5274 *x++ = *y++;
5276 *x = 0;
5278 value = do_spec_1 (buf, 0, NULL);
5279 if (value != 0)
5280 return value;
5284 /* Discard the closing paren or bracket. */
5285 if (*p)
5286 p++;
5288 break;
5290 default:
5291 error ("spec failure: unrecognized spec option %qc", c);
5292 break;
5294 break;
5296 case '\\':
5297 /* Backslash: treat next character as ordinary. */
5298 c = *p++;
5300 /* Fall through. */
5301 default:
5302 /* Ordinary character: put it into the current argument. */
5303 obstack_1grow (&obstack, c);
5304 arg_going = 1;
5307 /* End of string. If we are processing a spec function, we need to
5308 end any pending argument. */
5309 if (processing_spec_function)
5310 end_going_arg ();
5312 return 0;
5315 /* Look up a spec function. */
5317 static const struct spec_function *
5318 lookup_spec_function (const char *name)
5320 const struct spec_function *sf;
5322 for (sf = static_spec_functions; sf->name != NULL; sf++)
5323 if (strcmp (sf->name, name) == 0)
5324 return sf;
5326 return NULL;
5329 /* Evaluate a spec function. */
5331 static const char *
5332 eval_spec_function (const char *func, const char *args)
5334 const struct spec_function *sf;
5335 const char *funcval;
5337 /* Saved spec processing context. */
5338 VEC(const_char_p,heap) *save_argbuf;
5340 int save_arg_going;
5341 int save_delete_this_arg;
5342 int save_this_is_output_file;
5343 int save_this_is_library_file;
5344 int save_input_from_pipe;
5345 int save_this_is_linker_script;
5346 const char *save_suffix_subst;
5349 sf = lookup_spec_function (func);
5350 if (sf == NULL)
5351 fatal_error ("unknown spec function %qs", func);
5353 /* Push the spec processing context. */
5354 save_argbuf = argbuf;
5356 save_arg_going = arg_going;
5357 save_delete_this_arg = delete_this_arg;
5358 save_this_is_output_file = this_is_output_file;
5359 save_this_is_library_file = this_is_library_file;
5360 save_this_is_linker_script = this_is_linker_script;
5361 save_input_from_pipe = input_from_pipe;
5362 save_suffix_subst = suffix_subst;
5364 /* Create a new spec processing context, and build the function
5365 arguments. */
5367 alloc_args ();
5368 if (do_spec_2 (args) < 0)
5369 fatal_error ("error in args to spec function %qs", func);
5371 /* argbuf_index is an index for the next argument to be inserted, and
5372 so contains the count of the args already inserted. */
5374 funcval = (*sf->func) (VEC_length (const_char_p, argbuf),
5375 VEC_address (const_char_p, argbuf));
5377 /* Pop the spec processing context. */
5378 VEC_free (const_char_p, heap, argbuf);
5379 argbuf = save_argbuf;
5381 arg_going = save_arg_going;
5382 delete_this_arg = save_delete_this_arg;
5383 this_is_output_file = save_this_is_output_file;
5384 this_is_library_file = save_this_is_library_file;
5385 this_is_linker_script = save_this_is_linker_script;
5386 input_from_pipe = save_input_from_pipe;
5387 suffix_subst = save_suffix_subst;
5389 return funcval;
5392 /* Handle a spec function call of the form:
5394 %:function(args)
5396 ARGS is processed as a spec in a separate context and split into an
5397 argument vector in the normal fashion. The function returns a string
5398 containing a spec which we then process in the caller's context, or
5399 NULL if no processing is required. */
5401 static const char *
5402 handle_spec_function (const char *p)
5404 char *func, *args;
5405 const char *endp, *funcval;
5406 int count;
5408 processing_spec_function++;
5410 /* Get the function name. */
5411 for (endp = p; *endp != '\0'; endp++)
5413 if (*endp == '(') /* ) */
5414 break;
5415 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5416 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5417 fatal_error ("malformed spec function name");
5419 if (*endp != '(') /* ) */
5420 fatal_error ("no arguments for spec function");
5421 func = save_string (p, endp - p);
5422 p = ++endp;
5424 /* Get the arguments. */
5425 for (count = 0; *endp != '\0'; endp++)
5427 /* ( */
5428 if (*endp == ')')
5430 if (count == 0)
5431 break;
5432 count--;
5434 else if (*endp == '(') /* ) */
5435 count++;
5437 /* ( */
5438 if (*endp != ')')
5439 fatal_error ("malformed spec function arguments");
5440 args = save_string (p, endp - p);
5441 p = ++endp;
5443 /* p now points to just past the end of the spec function expression. */
5445 funcval = eval_spec_function (func, args);
5446 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5447 p = NULL;
5449 free (func);
5450 free (args);
5452 processing_spec_function--;
5454 return p;
5457 /* Inline subroutine of handle_braces. Returns true if the current
5458 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5459 static inline bool
5460 input_suffix_matches (const char *atom, const char *end_atom)
5462 return (input_suffix
5463 && !strncmp (input_suffix, atom, end_atom - atom)
5464 && input_suffix[end_atom - atom] == '\0');
5467 /* Subroutine of handle_braces. Returns true if the current
5468 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
5469 static bool
5470 input_spec_matches (const char *atom, const char *end_atom)
5472 return (input_file_compiler
5473 && input_file_compiler->suffix
5474 && input_file_compiler->suffix[0] != '\0'
5475 && !strncmp (input_file_compiler->suffix + 1, atom,
5476 end_atom - atom)
5477 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
5480 /* Subroutine of handle_braces. Returns true if a switch
5481 matching the atom bracketed by ATOM and END_ATOM appeared on the
5482 command line. */
5483 static bool
5484 switch_matches (const char *atom, const char *end_atom, int starred)
5486 int i;
5487 int len = end_atom - atom;
5488 int plen = starred ? len : -1;
5490 for (i = 0; i < n_switches; i++)
5491 if (!strncmp (switches[i].part1, atom, len)
5492 && (starred || switches[i].part1[len] == '\0')
5493 && check_live_switch (i, plen))
5494 return true;
5496 return false;
5499 /* Inline subroutine of handle_braces. Mark all of the switches which
5500 match ATOM (extends to END_ATOM; STARRED indicates whether there
5501 was a star after the atom) for later processing. */
5502 static inline void
5503 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5505 int i;
5506 int len = end_atom - atom;
5507 int plen = starred ? len : -1;
5509 for (i = 0; i < n_switches; i++)
5510 if (!strncmp (switches[i].part1, atom, len)
5511 && (starred || switches[i].part1[len] == '\0')
5512 && check_live_switch (i, plen))
5513 switches[i].ordering = 1;
5516 /* Inline subroutine of handle_braces. Process all the currently
5517 marked switches through give_switch, and clear the marks. */
5518 static inline void
5519 process_marked_switches (void)
5521 int i;
5523 for (i = 0; i < n_switches; i++)
5524 if (switches[i].ordering == 1)
5526 switches[i].ordering = 0;
5527 give_switch (i, 0);
5531 /* Handle a %{ ... } construct. P points just inside the leading {.
5532 Returns a pointer one past the end of the brace block, or 0
5533 if we call do_spec_1 and that returns -1. */
5535 static const char *
5536 handle_braces (const char *p)
5538 const char *atom, *end_atom;
5539 const char *d_atom = NULL, *d_end_atom = NULL;
5540 const char *orig = p;
5542 bool a_is_suffix;
5543 bool a_is_spectype;
5544 bool a_is_starred;
5545 bool a_is_negated;
5546 bool a_matched;
5548 bool a_must_be_last = false;
5549 bool ordered_set = false;
5550 bool disjunct_set = false;
5551 bool disj_matched = false;
5552 bool disj_starred = true;
5553 bool n_way_choice = false;
5554 bool n_way_matched = false;
5556 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5560 if (a_must_be_last)
5561 goto invalid;
5563 /* Scan one "atom" (S in the description above of %{}, possibly
5564 with '!', '.', '@', ',', or '*' modifiers). */
5565 a_matched = false;
5566 a_is_suffix = false;
5567 a_is_starred = false;
5568 a_is_negated = false;
5569 a_is_spectype = false;
5571 SKIP_WHITE();
5572 if (*p == '!')
5573 p++, a_is_negated = true;
5575 SKIP_WHITE();
5576 if (*p == '.')
5577 p++, a_is_suffix = true;
5578 else if (*p == ',')
5579 p++, a_is_spectype = true;
5581 atom = p;
5582 while (ISIDNUM(*p) || *p == '-' || *p == '+' || *p == '='
5583 || *p == ',' || *p == '.' || *p == '@')
5584 p++;
5585 end_atom = p;
5587 if (*p == '*')
5588 p++, a_is_starred = 1;
5590 SKIP_WHITE();
5591 switch (*p)
5593 case '&': case '}':
5594 /* Substitute the switch(es) indicated by the current atom. */
5595 ordered_set = true;
5596 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5597 || a_is_spectype || atom == end_atom)
5598 goto invalid;
5600 mark_matching_switches (atom, end_atom, a_is_starred);
5602 if (*p == '}')
5603 process_marked_switches ();
5604 break;
5606 case '|': case ':':
5607 /* Substitute some text if the current atom appears as a switch
5608 or suffix. */
5609 disjunct_set = true;
5610 if (ordered_set)
5611 goto invalid;
5613 if (atom == end_atom)
5615 if (!n_way_choice || disj_matched || *p == '|'
5616 || a_is_negated || a_is_suffix || a_is_spectype
5617 || a_is_starred)
5618 goto invalid;
5620 /* An empty term may appear as the last choice of an
5621 N-way choice set; it means "otherwise". */
5622 a_must_be_last = true;
5623 disj_matched = !n_way_matched;
5624 disj_starred = false;
5626 else
5628 if ((a_is_suffix || a_is_spectype) && a_is_starred)
5629 goto invalid;
5631 if (!a_is_starred)
5632 disj_starred = false;
5634 /* Don't bother testing this atom if we already have a
5635 match. */
5636 if (!disj_matched && !n_way_matched)
5638 if (a_is_suffix)
5639 a_matched = input_suffix_matches (atom, end_atom);
5640 else if (a_is_spectype)
5641 a_matched = input_spec_matches (atom, end_atom);
5642 else
5643 a_matched = switch_matches (atom, end_atom, a_is_starred);
5645 if (a_matched != a_is_negated)
5647 disj_matched = true;
5648 d_atom = atom;
5649 d_end_atom = end_atom;
5654 if (*p == ':')
5656 /* Found the body, that is, the text to substitute if the
5657 current disjunction matches. */
5658 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5659 disj_matched && !n_way_matched);
5660 if (p == 0)
5661 return 0;
5663 /* If we have an N-way choice, reset state for the next
5664 disjunction. */
5665 if (*p == ';')
5667 n_way_choice = true;
5668 n_way_matched |= disj_matched;
5669 disj_matched = false;
5670 disj_starred = true;
5671 d_atom = d_end_atom = NULL;
5674 break;
5676 default:
5677 goto invalid;
5680 while (*p++ != '}');
5682 return p;
5684 invalid:
5685 fatal_error ("braced spec %qs is invalid at %qc", orig, *p);
5687 #undef SKIP_WHITE
5690 /* Subroutine of handle_braces. Scan and process a brace substitution body
5691 (X in the description of %{} syntax). P points one past the colon;
5692 ATOM and END_ATOM bracket the first atom which was found to be true
5693 (present) in the current disjunction; STARRED indicates whether all
5694 the atoms in the current disjunction were starred (for syntax validation);
5695 MATCHED indicates whether the disjunction matched or not, and therefore
5696 whether or not the body is to be processed through do_spec_1 or just
5697 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5698 returns -1. */
5700 static const char *
5701 process_brace_body (const char *p, const char *atom, const char *end_atom,
5702 int starred, int matched)
5704 const char *body, *end_body;
5705 unsigned int nesting_level;
5706 bool have_subst = false;
5708 /* Locate the closing } or ;, honoring nested braces.
5709 Trim trailing whitespace. */
5710 body = p;
5711 nesting_level = 1;
5712 for (;;)
5714 if (*p == '{')
5715 nesting_level++;
5716 else if (*p == '}')
5718 if (!--nesting_level)
5719 break;
5721 else if (*p == ';' && nesting_level == 1)
5722 break;
5723 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5724 have_subst = true;
5725 else if (*p == '\0')
5726 goto invalid;
5727 p++;
5730 end_body = p;
5731 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5732 end_body--;
5734 if (have_subst && !starred)
5735 goto invalid;
5737 if (matched)
5739 /* Copy the substitution body to permanent storage and execute it.
5740 If have_subst is false, this is a simple matter of running the
5741 body through do_spec_1... */
5742 char *string = save_string (body, end_body - body);
5743 if (!have_subst)
5745 if (do_spec_1 (string, 0, NULL) < 0)
5746 return 0;
5748 else
5750 /* ... but if have_subst is true, we have to process the
5751 body once for each matching switch, with %* set to the
5752 variant part of the switch. */
5753 unsigned int hard_match_len = end_atom - atom;
5754 int i;
5756 for (i = 0; i < n_switches; i++)
5757 if (!strncmp (switches[i].part1, atom, hard_match_len)
5758 && check_live_switch (i, hard_match_len))
5760 if (do_spec_1 (string, 0,
5761 &switches[i].part1[hard_match_len]) < 0)
5762 return 0;
5763 /* Pass any arguments this switch has. */
5764 give_switch (i, 1);
5765 suffix_subst = NULL;
5770 return p;
5772 invalid:
5773 fatal_error ("braced spec body %qs is invalid", body);
5776 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5777 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5778 spec, or -1 if either exact match or %* is used.
5780 A -O switch is obsoleted by a later -O switch. A -f, -m, or -W switch
5781 whose value does not begin with "no-" is obsoleted by the same value
5782 with the "no-", similarly for a switch with the "no-" prefix. */
5784 static int
5785 check_live_switch (int switchnum, int prefix_length)
5787 const char *name = switches[switchnum].part1;
5788 int i;
5790 /* If we already processed this switch and determined if it was
5791 live or not, return our past determination. */
5792 if (switches[switchnum].live_cond != 0)
5793 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
5794 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
5795 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
5796 == 0);
5798 /* In the common case of {<at-most-one-letter>*}, a negating
5799 switch would always match, so ignore that case. We will just
5800 send the conflicting switches to the compiler phase. */
5801 if (prefix_length >= 0 && prefix_length <= 1)
5802 return 1;
5804 /* Now search for duplicate in a manner that depends on the name. */
5805 switch (*name)
5807 case 'O':
5808 for (i = switchnum + 1; i < n_switches; i++)
5809 if (switches[i].part1[0] == 'O')
5811 switches[switchnum].validated = 1;
5812 switches[switchnum].live_cond = SWITCH_FALSE;
5813 return 0;
5815 break;
5817 case 'W': case 'f': case 'm':
5818 if (! strncmp (name + 1, "no-", 3))
5820 /* We have Xno-YYY, search for XYYY. */
5821 for (i = switchnum + 1; i < n_switches; i++)
5822 if (switches[i].part1[0] == name[0]
5823 && ! strcmp (&switches[i].part1[1], &name[4]))
5825 switches[switchnum].validated = 1;
5826 switches[switchnum].live_cond = SWITCH_FALSE;
5827 return 0;
5830 else
5832 /* We have XYYY, search for Xno-YYY. */
5833 for (i = switchnum + 1; i < n_switches; i++)
5834 if (switches[i].part1[0] == name[0]
5835 && switches[i].part1[1] == 'n'
5836 && switches[i].part1[2] == 'o'
5837 && switches[i].part1[3] == '-'
5838 && !strcmp (&switches[i].part1[4], &name[1]))
5840 switches[switchnum].validated = 1;
5841 switches[switchnum].live_cond = SWITCH_FALSE;
5842 return 0;
5845 break;
5848 /* Otherwise the switch is live. */
5849 switches[switchnum].live_cond |= SWITCH_LIVE;
5850 return 1;
5853 /* Pass a switch to the current accumulating command
5854 in the same form that we received it.
5855 SWITCHNUM identifies the switch; it is an index into
5856 the vector of switches gcc received, which is `switches'.
5857 This cannot fail since it never finishes a command line.
5859 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
5861 static void
5862 give_switch (int switchnum, int omit_first_word)
5864 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
5865 return;
5867 if (!omit_first_word)
5869 do_spec_1 ("-", 0, NULL);
5870 do_spec_1 (switches[switchnum].part1, 1, NULL);
5873 if (switches[switchnum].args != 0)
5875 const char **p;
5876 for (p = switches[switchnum].args; *p; p++)
5878 const char *arg = *p;
5880 do_spec_1 (" ", 0, NULL);
5881 if (suffix_subst)
5883 unsigned length = strlen (arg);
5884 int dot = 0;
5886 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
5887 if (arg[length] == '.')
5889 (CONST_CAST(char *, arg))[length] = 0;
5890 dot = 1;
5891 break;
5893 do_spec_1 (arg, 1, NULL);
5894 if (dot)
5895 (CONST_CAST(char *, arg))[length] = '.';
5896 do_spec_1 (suffix_subst, 1, NULL);
5898 else
5899 do_spec_1 (arg, 1, NULL);
5903 do_spec_1 (" ", 0, NULL);
5904 switches[switchnum].validated = 1;
5907 /* Search for a file named NAME trying various prefixes including the
5908 user's -B prefix and some standard ones.
5909 Return the absolute file name found. If nothing is found, return NAME. */
5911 static const char *
5912 find_file (const char *name)
5914 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
5915 return newname ? newname : name;
5918 /* Determine whether a directory exists. If LINKER, return 0 for
5919 certain fixed names not needed by the linker. */
5921 static int
5922 is_directory (const char *path1, bool linker)
5924 int len1;
5925 char *path;
5926 char *cp;
5927 struct stat st;
5929 /* Ensure the string ends with "/.". The resulting path will be a
5930 directory even if the given path is a symbolic link. */
5931 len1 = strlen (path1);
5932 path = (char *) alloca (3 + len1);
5933 memcpy (path, path1, len1);
5934 cp = path + len1;
5935 if (!IS_DIR_SEPARATOR (cp[-1]))
5936 *cp++ = DIR_SEPARATOR;
5937 *cp++ = '.';
5938 *cp = '\0';
5940 /* Exclude directories that the linker is known to search. */
5941 if (linker
5942 && IS_DIR_SEPARATOR (path[0])
5943 && ((cp - path == 6
5944 && filename_ncmp (path + 1, "lib", 3) == 0)
5945 || (cp - path == 10
5946 && filename_ncmp (path + 1, "usr", 3) == 0
5947 && IS_DIR_SEPARATOR (path[4])
5948 && filename_ncmp (path + 5, "lib", 3) == 0)))
5949 return 0;
5951 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
5954 /* Set up the various global variables to indicate that we're processing
5955 the input file named FILENAME. */
5957 void
5958 set_input (const char *filename)
5960 const char *p;
5962 gcc_input_filename = filename;
5963 input_filename_length = strlen (gcc_input_filename);
5964 input_basename = lbasename (gcc_input_filename);
5966 /* Find a suffix starting with the last period,
5967 and set basename_length to exclude that suffix. */
5968 basename_length = strlen (input_basename);
5969 suffixed_basename_length = basename_length;
5970 p = input_basename + basename_length;
5971 while (p != input_basename && *p != '.')
5972 --p;
5973 if (*p == '.' && p != input_basename)
5975 basename_length = p - input_basename;
5976 input_suffix = p + 1;
5978 else
5979 input_suffix = "";
5981 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
5982 we will need to do a stat on the gcc_input_filename. The
5983 INPUT_STAT_SET signals that the stat is needed. */
5984 input_stat_set = 0;
5987 /* On fatal signals, delete all the temporary files. */
5989 static void
5990 fatal_signal (int signum)
5992 signal (signum, SIG_DFL);
5993 delete_failure_queue ();
5994 delete_temp_files ();
5995 /* Get the same signal again, this time not handled,
5996 so its normal effect occurs. */
5997 kill (getpid (), signum);
6000 /* Compare the contents of the two files named CMPFILE[0] and
6001 CMPFILE[1]. Return zero if they're identical, nonzero
6002 otherwise. */
6004 static int
6005 compare_files (char *cmpfile[])
6007 int ret = 0;
6008 FILE *temp[2] = { NULL, NULL };
6009 int i;
6011 #if HAVE_MMAP_FILE
6013 size_t length[2];
6014 void *map[2] = { NULL, NULL };
6016 for (i = 0; i < 2; i++)
6018 struct stat st;
6020 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
6022 error ("%s: could not determine length of compare-debug file %s",
6023 gcc_input_filename, cmpfile[i]);
6024 ret = 1;
6025 break;
6028 length[i] = st.st_size;
6031 if (!ret && length[0] != length[1])
6033 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
6034 ret = 1;
6037 if (!ret)
6038 for (i = 0; i < 2; i++)
6040 int fd = open (cmpfile[i], O_RDONLY);
6041 if (fd < 0)
6043 error ("%s: could not open compare-debug file %s",
6044 gcc_input_filename, cmpfile[i]);
6045 ret = 1;
6046 break;
6049 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
6050 close (fd);
6052 if (map[i] == (void *) MAP_FAILED)
6054 ret = -1;
6055 break;
6059 if (!ret)
6061 if (memcmp (map[0], map[1], length[0]) != 0)
6063 error ("%s: -fcompare-debug failure", gcc_input_filename);
6064 ret = 1;
6068 for (i = 0; i < 2; i++)
6069 if (map[i])
6070 munmap ((caddr_t) map[i], length[i]);
6072 if (ret >= 0)
6073 return ret;
6075 ret = 0;
6077 #endif
6079 for (i = 0; i < 2; i++)
6081 temp[i] = fopen (cmpfile[i], "r");
6082 if (!temp[i])
6084 error ("%s: could not open compare-debug file %s",
6085 gcc_input_filename, cmpfile[i]);
6086 ret = 1;
6087 break;
6091 if (!ret && temp[0] && temp[1])
6092 for (;;)
6094 int c0, c1;
6095 c0 = fgetc (temp[0]);
6096 c1 = fgetc (temp[1]);
6098 if (c0 != c1)
6100 error ("%s: -fcompare-debug failure",
6101 gcc_input_filename);
6102 ret = 1;
6103 break;
6106 if (c0 == EOF)
6107 break;
6110 for (i = 1; i >= 0; i--)
6112 if (temp[i])
6113 fclose (temp[i]);
6116 return ret;
6119 extern int main (int, char **);
6122 main (int argc, char **argv)
6124 size_t i;
6125 int value;
6126 int linker_was_run = 0;
6127 int lang_n_infiles = 0;
6128 int num_linker_inputs = 0;
6129 char *explicit_link_files;
6130 char *specs_file;
6131 char *lto_wrapper_file;
6132 const char *p;
6133 struct user_specs *uptr;
6134 char **old_argv = argv;
6135 struct cl_decoded_option *decoded_options;
6136 unsigned int decoded_options_count;
6138 /* Initialize here, not in definition. The IRIX 6 O32 cc sometimes chokes
6139 on ?: in file-scope variable initializations. */
6140 asm_debug = ASM_DEBUG_SPEC;
6142 p = argv[0] + strlen (argv[0]);
6143 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
6144 --p;
6145 progname = p;
6147 xmalloc_set_program_name (progname);
6149 expandargv (&argc, &argv);
6151 /* Determine if any expansions were made. */
6152 if (argv != old_argv)
6153 at_file_supplied = true;
6155 global_options = global_options_init;
6157 decode_cmdline_options_to_array (argc, CONST_CAST2 (const char **, char **,
6158 argv),
6159 CL_DRIVER,
6160 &decoded_options, &decoded_options_count);
6162 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6163 /* Perform host dependent initialization when needed. */
6164 GCC_DRIVER_HOST_INITIALIZATION;
6165 #endif
6167 /* Unlock the stdio streams. */
6168 unlock_std_streams ();
6170 gcc_init_libintl ();
6172 diagnostic_initialize (global_dc, 0);
6173 if (atexit (delete_temp_files) != 0)
6174 fatal_error ("atexit failed");
6176 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6177 signal (SIGINT, fatal_signal);
6178 #ifdef SIGHUP
6179 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6180 signal (SIGHUP, fatal_signal);
6181 #endif
6182 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6183 signal (SIGTERM, fatal_signal);
6184 #ifdef SIGPIPE
6185 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6186 signal (SIGPIPE, fatal_signal);
6187 #endif
6188 #ifdef SIGCHLD
6189 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6190 receive the signal. A different setting is inheritable */
6191 signal (SIGCHLD, SIG_DFL);
6192 #endif
6194 /* Allocate the argument vector. */
6195 alloc_args ();
6197 obstack_init (&obstack);
6199 /* Build multilib_select, et. al from the separate lines that make up each
6200 multilib selection. */
6202 const char *const *q = multilib_raw;
6203 int need_space;
6205 obstack_init (&multilib_obstack);
6206 while ((p = *q++) != (char *) 0)
6207 obstack_grow (&multilib_obstack, p, strlen (p));
6209 obstack_1grow (&multilib_obstack, 0);
6210 multilib_select = XOBFINISH (&multilib_obstack, const char *);
6212 q = multilib_matches_raw;
6213 while ((p = *q++) != (char *) 0)
6214 obstack_grow (&multilib_obstack, p, strlen (p));
6216 obstack_1grow (&multilib_obstack, 0);
6217 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
6219 q = multilib_exclusions_raw;
6220 while ((p = *q++) != (char *) 0)
6221 obstack_grow (&multilib_obstack, p, strlen (p));
6223 obstack_1grow (&multilib_obstack, 0);
6224 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
6226 need_space = FALSE;
6227 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6229 if (need_space)
6230 obstack_1grow (&multilib_obstack, ' ');
6231 obstack_grow (&multilib_obstack,
6232 multilib_defaults_raw[i],
6233 strlen (multilib_defaults_raw[i]));
6234 need_space = TRUE;
6237 obstack_1grow (&multilib_obstack, 0);
6238 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
6241 #ifdef INIT_ENVIRONMENT
6242 /* Set up any other necessary machine specific environment variables. */
6243 xputenv (INIT_ENVIRONMENT);
6244 #endif
6246 /* Make a table of what switches there are (switches, n_switches).
6247 Make a table of specified input files (infiles, n_infiles).
6248 Decode switches that are handled locally. */
6250 process_command (decoded_options_count, decoded_options);
6252 /* Initialize the vector of specs to just the default.
6253 This means one element containing 0s, as a terminator. */
6255 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
6256 memcpy (compilers, default_compilers, sizeof default_compilers);
6257 n_compilers = n_default_compilers;
6259 /* Read specs from a file if there is one. */
6261 machine_suffix = concat (spec_machine, dir_separator_str,
6262 spec_version, dir_separator_str, NULL);
6263 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6265 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
6266 /* Read the specs file unless it is a default one. */
6267 if (specs_file != 0 && strcmp (specs_file, "specs"))
6268 read_specs (specs_file, TRUE);
6269 else
6270 init_spec ();
6272 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6273 for any override of as, ld and libraries. */
6274 specs_file = (char *) alloca (strlen (standard_exec_prefix)
6275 + strlen (just_machine_suffix) + sizeof ("specs"));
6277 strcpy (specs_file, standard_exec_prefix);
6278 strcat (specs_file, just_machine_suffix);
6279 strcat (specs_file, "specs");
6280 if (access (specs_file, R_OK) == 0)
6281 read_specs (specs_file, TRUE);
6283 /* Process any configure-time defaults specified for the command line
6284 options, via OPTION_DEFAULT_SPECS. */
6285 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6286 do_option_spec (option_default_specs[i].name,
6287 option_default_specs[i].spec);
6289 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6290 of the command line. */
6292 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6293 do_self_spec (driver_self_specs[i]);
6295 if (compare_debug)
6297 enum save_temps save;
6299 if (!compare_debug_second)
6301 n_switches_debug_check[1] = n_switches;
6302 n_switches_alloc_debug_check[1] = n_switches_alloc;
6303 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
6304 n_switches_alloc);
6306 do_self_spec ("%:compare-debug-self-opt()");
6307 n_switches_debug_check[0] = n_switches;
6308 n_switches_alloc_debug_check[0] = n_switches_alloc;
6309 switches_debug_check[0] = switches;
6311 n_switches = n_switches_debug_check[1];
6312 n_switches_alloc = n_switches_alloc_debug_check[1];
6313 switches = switches_debug_check[1];
6316 /* Avoid crash when computing %j in this early. */
6317 save = save_temps_flag;
6318 save_temps_flag = SAVE_TEMPS_NONE;
6320 compare_debug = -compare_debug;
6321 do_self_spec ("%:compare-debug-self-opt()");
6323 save_temps_flag = save;
6325 if (!compare_debug_second)
6327 n_switches_debug_check[1] = n_switches;
6328 n_switches_alloc_debug_check[1] = n_switches_alloc;
6329 switches_debug_check[1] = switches;
6330 compare_debug = -compare_debug;
6331 n_switches = n_switches_debug_check[0];
6332 n_switches_alloc = n_switches_debug_check[0];
6333 switches = switches_debug_check[0];
6337 /* If not cross-compiling, look for executables in the standard
6338 places. */
6339 if (*cross_compile == '0')
6341 if (*md_exec_prefix)
6343 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6344 PREFIX_PRIORITY_LAST, 0, 0);
6348 /* Process sysroot_suffix_spec. */
6349 if (*sysroot_suffix_spec != 0
6350 && do_spec_2 (sysroot_suffix_spec) == 0)
6352 if (VEC_length (const_char_p, argbuf) > 1)
6353 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
6354 else if (VEC_length (const_char_p, argbuf) == 1)
6355 target_sysroot_suffix = xstrdup (VEC_last (const_char_p, argbuf));
6358 #ifdef HAVE_LD_SYSROOT
6359 /* Pass the --sysroot option to the linker, if it supports that. If
6360 there is a sysroot_suffix_spec, it has already been processed by
6361 this point, so target_system_root really is the system root we
6362 should be using. */
6363 if (target_system_root)
6365 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
6366 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
6367 set_spec ("link", XOBFINISH (&obstack, const char *));
6369 #endif
6371 /* Process sysroot_hdrs_suffix_spec. */
6372 if (*sysroot_hdrs_suffix_spec != 0
6373 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6375 if (VEC_length (const_char_p, argbuf) > 1)
6376 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
6377 else if (VEC_length (const_char_p, argbuf) == 1)
6378 target_sysroot_hdrs_suffix = xstrdup (VEC_last (const_char_p, argbuf));
6381 /* Look for startfiles in the standard places. */
6382 if (*startfile_prefix_spec != 0
6383 && do_spec_2 (startfile_prefix_spec) == 0
6384 && do_spec_1 (" ", 0, NULL) == 0)
6386 const char *arg;
6387 int ndx;
6388 FOR_EACH_VEC_ELT (const_char_p, argbuf, ndx, arg)
6389 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
6390 PREFIX_PRIORITY_LAST, 0, 1);
6392 /* We should eventually get rid of all these and stick to
6393 startfile_prefix_spec exclusively. */
6394 else if (*cross_compile == '0' || target_system_root)
6396 if (*md_startfile_prefix)
6397 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6398 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6400 if (*md_startfile_prefix_1)
6401 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6402 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6404 /* If standard_startfile_prefix is relative, base it on
6405 standard_exec_prefix. This lets us move the installed tree
6406 as a unit. If GCC_EXEC_PREFIX is defined, base
6407 standard_startfile_prefix on that as well.
6409 If the prefix is relative, only search it for native compilers;
6410 otherwise we will search a directory containing host libraries. */
6411 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6412 add_sysrooted_prefix (&startfile_prefixes,
6413 standard_startfile_prefix, "BINUTILS",
6414 PREFIX_PRIORITY_LAST, 0, 1);
6415 else if (*cross_compile == '0')
6417 add_prefix (&startfile_prefixes,
6418 concat (gcc_exec_prefix
6419 ? gcc_exec_prefix : standard_exec_prefix,
6420 machine_suffix,
6421 standard_startfile_prefix, NULL),
6422 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6425 /* Sysrooted prefixes are relocated because target_system_root is
6426 also relocated by gcc_exec_prefix. */
6427 if (*standard_startfile_prefix_1)
6428 add_sysrooted_prefix (&startfile_prefixes,
6429 standard_startfile_prefix_1, "BINUTILS",
6430 PREFIX_PRIORITY_LAST, 0, 1);
6431 if (*standard_startfile_prefix_2)
6432 add_sysrooted_prefix (&startfile_prefixes,
6433 standard_startfile_prefix_2, "BINUTILS",
6434 PREFIX_PRIORITY_LAST, 0, 1);
6437 /* Process any user specified specs in the order given on the command
6438 line. */
6439 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6441 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6442 R_OK, true);
6443 read_specs (filename ? filename : uptr->filename, FALSE);
6446 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6447 if (gcc_exec_prefix)
6448 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6449 spec_version, dir_separator_str, NULL);
6451 /* Now we have the specs.
6452 Set the `valid' bits for switches that match anything in any spec. */
6454 validate_all_switches ();
6456 /* Now that we have the switches and the specs, set
6457 the subdirectory based on the options. */
6458 set_multilib_dir ();
6460 /* Set up to remember the pathname of gcc and any options
6461 needed for collect. We use argv[0] instead of progname because
6462 we need the complete pathname. */
6463 obstack_init (&collect_obstack);
6464 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
6465 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
6466 xputenv (XOBFINISH (&collect_obstack, char *));
6468 /* Set up to remember the pathname of the lto wrapper. */
6470 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper", X_OK, false);
6471 if (lto_wrapper_file)
6473 lto_wrapper_spec = lto_wrapper_file;
6474 obstack_init (&collect_obstack);
6475 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
6476 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
6477 obstack_grow (&collect_obstack, lto_wrapper_spec,
6478 strlen (lto_wrapper_spec) + 1);
6479 xputenv (XOBFINISH (&collect_obstack, char *));
6482 /* Warn about any switches that no pass was interested in. */
6484 for (i = 0; (int) i < n_switches; i++)
6485 if (! switches[i].validated)
6486 error ("unrecognized option %<-%s%>", switches[i].part1);
6488 /* Obey some of the options. */
6490 if (print_search_dirs)
6492 printf (_("install: %s%s\n"),
6493 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
6494 gcc_exec_prefix ? "" : machine_suffix);
6495 printf (_("programs: %s\n"),
6496 build_search_list (&exec_prefixes, "", false, false));
6497 printf (_("libraries: %s\n"),
6498 build_search_list (&startfile_prefixes, "", false, true));
6499 return (0);
6502 if (print_file_name)
6504 printf ("%s\n", find_file (print_file_name));
6505 return (0);
6508 if (print_prog_name)
6510 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6511 printf ("%s\n", (newname ? newname : print_prog_name));
6512 return (0);
6515 if (print_multi_lib)
6517 print_multilib_info ();
6518 return (0);
6521 if (print_multi_directory)
6523 if (multilib_dir == NULL)
6524 printf (".\n");
6525 else
6526 printf ("%s\n", multilib_dir);
6527 return (0);
6530 if (print_sysroot)
6532 if (target_system_root)
6534 if (target_sysroot_suffix)
6535 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
6536 else
6537 printf ("%s\n", target_system_root);
6539 return (0);
6542 if (print_multi_os_directory)
6544 if (multilib_os_dir == NULL)
6545 printf (".\n");
6546 else
6547 printf ("%s\n", multilib_os_dir);
6548 return (0);
6551 if (print_sysroot_headers_suffix)
6553 if (*sysroot_hdrs_suffix_spec)
6555 printf("%s\n", (target_sysroot_hdrs_suffix
6556 ? target_sysroot_hdrs_suffix
6557 : ""));
6558 return (0);
6560 else
6561 /* The error status indicates that only one set of fixed
6562 headers should be built. */
6563 fatal_error ("not configured with sysroot headers suffix");
6566 if (print_help_list)
6568 display_help ();
6570 if (! verbose_flag)
6572 printf (_("\nFor bug reporting instructions, please see:\n"));
6573 printf ("%s.\n", bug_report_url);
6575 return (0);
6578 /* We do not exit here. Instead we have created a fake input file
6579 called 'help-dummy' which needs to be compiled, and we pass this
6580 on the various sub-processes, along with the --help switch.
6581 Ensure their output appears after ours. */
6582 fputc ('\n', stdout);
6583 fflush (stdout);
6586 if (print_version)
6588 printf (_("%s %s%s\n"), progname, pkgversion_string,
6589 version_string);
6590 printf ("Copyright %s 2011 Free Software Foundation, Inc.\n",
6591 _("(C)"));
6592 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
6593 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
6594 stdout);
6595 if (! verbose_flag)
6596 return 0;
6598 /* We do not exit here. We use the same mechanism of --help to print
6599 the version of the sub-processes. */
6600 fputc ('\n', stdout);
6601 fflush (stdout);
6604 if (verbose_flag)
6606 int n;
6607 const char *thrmod;
6609 fnotice (stderr, "Target: %s\n", spec_machine);
6610 fnotice (stderr, "Configured with: %s\n", configuration_arguments);
6612 #ifdef THREAD_MODEL_SPEC
6613 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6614 but there's no point in doing all this processing just to get
6615 thread_model back. */
6616 obstack_init (&obstack);
6617 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6618 obstack_1grow (&obstack, '\0');
6619 thrmod = XOBFINISH (&obstack, const char *);
6620 #else
6621 thrmod = thread_model;
6622 #endif
6624 fnotice (stderr, "Thread model: %s\n", thrmod);
6626 /* compiler_version is truncated at the first space when initialized
6627 from version string, so truncate version_string at the first space
6628 before comparing. */
6629 for (n = 0; version_string[n]; n++)
6630 if (version_string[n] == ' ')
6631 break;
6633 if (! strncmp (version_string, compiler_version, n)
6634 && compiler_version[n] == 0)
6635 fnotice (stderr, "gcc version %s %s\n", version_string,
6636 pkgversion_string);
6637 else
6638 fnotice (stderr, "gcc driver version %s %sexecuting gcc version %s\n",
6639 version_string, pkgversion_string, compiler_version);
6641 if (n_infiles == 0)
6642 return (0);
6645 if (n_infiles == added_libraries)
6646 fatal_error ("no input files");
6648 if (seen_error ())
6649 goto out;
6651 /* Make a place to record the compiler output file names
6652 that correspond to the input files. */
6654 i = n_infiles;
6655 i += lang_specific_extra_outfiles;
6656 outfiles = XCNEWVEC (const char *, i);
6658 /* Record which files were specified explicitly as link input. */
6660 explicit_link_files = XCNEWVEC (char, n_infiles);
6662 combine_inputs = have_o || flag_wpa;
6664 for (i = 0; (int) i < n_infiles; i++)
6666 const char *name = infiles[i].name;
6667 struct compiler *compiler = lookup_compiler (name,
6668 strlen (name),
6669 infiles[i].language);
6671 if (compiler && !(compiler->combinable))
6672 combine_inputs = false;
6674 if (lang_n_infiles > 0 && compiler != input_file_compiler
6675 && infiles[i].language && infiles[i].language[0] != '*')
6676 infiles[i].incompiler = compiler;
6677 else if (compiler)
6679 lang_n_infiles++;
6680 input_file_compiler = compiler;
6681 infiles[i].incompiler = compiler;
6683 else
6685 /* Since there is no compiler for this input file, assume it is a
6686 linker file. */
6687 explicit_link_files[i] = 1;
6688 infiles[i].incompiler = NULL;
6690 infiles[i].compiled = false;
6691 infiles[i].preprocessed = false;
6694 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
6695 fatal_error ("cannot specify -o with -c, -S or -E with multiple files");
6697 for (i = 0; (int) i < n_infiles; i++)
6699 int this_file_error = 0;
6701 /* Tell do_spec what to substitute for %i. */
6703 input_file_number = i;
6704 set_input (infiles[i].name);
6706 if (infiles[i].compiled)
6707 continue;
6709 /* Use the same thing in %o, unless cp->spec says otherwise. */
6711 outfiles[i] = gcc_input_filename;
6713 /* Figure out which compiler from the file's suffix. */
6715 input_file_compiler
6716 = lookup_compiler (infiles[i].name, input_filename_length,
6717 infiles[i].language);
6719 if (input_file_compiler)
6721 /* Ok, we found an applicable compiler. Run its spec. */
6723 if (input_file_compiler->spec[0] == '#')
6725 error ("%s: %s compiler not installed on this system",
6726 gcc_input_filename, &input_file_compiler->spec[1]);
6727 this_file_error = 1;
6729 else
6731 if (compare_debug)
6733 if (debug_check_temp_file[0])
6734 free (debug_check_temp_file[0]);
6735 debug_check_temp_file[0] = NULL;
6737 if (debug_check_temp_file[1])
6738 free (debug_check_temp_file[1]);
6739 debug_check_temp_file[1] = NULL;
6742 value = do_spec (input_file_compiler->spec);
6743 infiles[i].compiled = true;
6744 if (value < 0)
6745 this_file_error = 1;
6746 else if (compare_debug && debug_check_temp_file[0])
6748 if (verbose_flag)
6749 inform (0, "recompiling with -fcompare-debug");
6751 compare_debug = -compare_debug;
6752 n_switches = n_switches_debug_check[1];
6753 n_switches_alloc = n_switches_alloc_debug_check[1];
6754 switches = switches_debug_check[1];
6756 value = do_spec (input_file_compiler->spec);
6758 compare_debug = -compare_debug;
6759 n_switches = n_switches_debug_check[0];
6760 n_switches_alloc = n_switches_alloc_debug_check[0];
6761 switches = switches_debug_check[0];
6763 if (value < 0)
6765 error ("during -fcompare-debug recompilation");
6766 this_file_error = 1;
6769 gcc_assert (debug_check_temp_file[1]
6770 && filename_cmp (debug_check_temp_file[0],
6771 debug_check_temp_file[1]));
6773 if (verbose_flag)
6774 inform (0, "comparing final insns dumps");
6776 if (compare_files (debug_check_temp_file))
6777 this_file_error = 1;
6780 if (compare_debug)
6782 if (debug_check_temp_file[0])
6783 free (debug_check_temp_file[0]);
6784 debug_check_temp_file[0] = NULL;
6786 if (debug_check_temp_file[1])
6787 free (debug_check_temp_file[1]);
6788 debug_check_temp_file[1] = NULL;
6793 /* If this file's name does not contain a recognized suffix,
6794 record it as explicit linker input. */
6796 else
6797 explicit_link_files[i] = 1;
6799 /* Clear the delete-on-failure queue, deleting the files in it
6800 if this compilation failed. */
6802 if (this_file_error)
6804 delete_failure_queue ();
6805 errorcount++;
6807 /* If this compilation succeeded, don't delete those files later. */
6808 clear_failure_queue ();
6811 /* Reset the input file name to the first compile/object file name, for use
6812 with %b in LINK_SPEC. We use the first input file that we can find
6813 a compiler to compile it instead of using infiles.language since for
6814 languages other than C we use aliases that we then lookup later. */
6815 if (n_infiles > 0)
6817 int i;
6819 for (i = 0; i < n_infiles ; i++)
6820 if (infiles[i].incompiler
6821 || (infiles[i].language && infiles[i].language[0] != '*'))
6823 set_input (infiles[i].name);
6824 break;
6828 if (!seen_error ())
6830 /* Make sure INPUT_FILE_NUMBER points to first available open
6831 slot. */
6832 input_file_number = n_infiles;
6833 if (lang_specific_pre_link ())
6834 errorcount++;
6837 /* Determine if there are any linker input files. */
6838 num_linker_inputs = 0;
6839 for (i = 0; (int) i < n_infiles; i++)
6840 if (explicit_link_files[i] || outfiles[i] != NULL)
6841 num_linker_inputs++;
6843 /* Run ld to link all the compiler output files. */
6845 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
6847 int tmp = execution_count;
6848 #if HAVE_LTO_PLUGIN > 0
6849 #if HAVE_LTO_PLUGIN == 2
6850 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
6851 #else
6852 const char *fuse_linker_plugin = "fuse-linker-plugin";
6853 #endif
6854 #endif
6856 /* We'll use ld if we can't find collect2. */
6857 if (! strcmp (linker_name_spec, "collect2"))
6859 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
6860 if (s == NULL)
6861 linker_name_spec = "ld";
6864 #if HAVE_LTO_PLUGIN > 0
6865 #if HAVE_LTO_PLUGIN == 2
6866 if (!switch_matches (fno_use_linker_plugin,
6867 fno_use_linker_plugin + strlen (fno_use_linker_plugin), 0))
6868 #else
6869 if (switch_matches (fuse_linker_plugin,
6870 fuse_linker_plugin + strlen (fuse_linker_plugin), 0))
6871 #endif
6873 linker_plugin_file_spec = find_a_file (&exec_prefixes,
6874 LTOPLUGINSONAME, R_OK,
6875 false);
6876 if (!linker_plugin_file_spec)
6877 fatal_error ("-fuse-linker-plugin, but " LTOPLUGINSONAME " not found");
6879 #endif
6880 lto_gcc_spec = argv[0];
6882 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
6883 for collect. */
6884 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
6885 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
6887 if (print_subprocess_help == 1)
6889 printf (_("\nLinker options\n==============\n\n"));
6890 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
6891 " to the linker.\n\n"));
6892 fflush (stdout);
6894 value = do_spec (link_command_spec);
6895 if (value < 0)
6896 errorcount = 1;
6897 linker_was_run = (tmp != execution_count);
6900 /* If options said don't run linker,
6901 complain about input files to be given to the linker. */
6903 if (! linker_was_run && !seen_error ())
6904 for (i = 0; (int) i < n_infiles; i++)
6905 if (explicit_link_files[i]
6906 && !(infiles[i].language && infiles[i].language[0] == '*'))
6907 warning (0, "%s: linker input file unused because linking not done",
6908 outfiles[i]);
6910 /* Delete some or all of the temporary files we made. */
6912 if (seen_error ())
6913 delete_failure_queue ();
6914 delete_temp_files ();
6916 if (print_help_list)
6918 printf (("\nFor bug reporting instructions, please see:\n"));
6919 printf ("%s\n", bug_report_url);
6922 out:
6923 return (signal_count != 0 ? 2
6924 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
6925 : 0);
6928 /* Find the proper compilation spec for the file name NAME,
6929 whose length is LENGTH. LANGUAGE is the specified language,
6930 or 0 if this file is to be passed to the linker. */
6932 static struct compiler *
6933 lookup_compiler (const char *name, size_t length, const char *language)
6935 struct compiler *cp;
6937 /* If this was specified by the user to be a linker input, indicate that. */
6938 if (language != 0 && language[0] == '*')
6939 return 0;
6941 /* Otherwise, look for the language, if one is spec'd. */
6942 if (language != 0)
6944 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6945 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
6946 return cp;
6948 error ("language %s not recognized", language);
6949 return 0;
6952 /* Look for a suffix. */
6953 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6955 if (/* The suffix `-' matches only the file name `-'. */
6956 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6957 || (strlen (cp->suffix) < length
6958 /* See if the suffix matches the end of NAME. */
6959 && !strcmp (cp->suffix,
6960 name + length - strlen (cp->suffix))
6962 break;
6965 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
6966 /* Look again, but case-insensitively this time. */
6967 if (cp < compilers)
6968 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6970 if (/* The suffix `-' matches only the file name `-'. */
6971 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6972 || (strlen (cp->suffix) < length
6973 /* See if the suffix matches the end of NAME. */
6974 && ((!strcmp (cp->suffix,
6975 name + length - strlen (cp->suffix))
6976 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
6977 && !strcasecmp (cp->suffix,
6978 name + length - strlen (cp->suffix)))
6980 break;
6982 #endif
6984 if (cp >= compilers)
6986 if (cp->spec[0] != '@')
6987 /* A non-alias entry: return it. */
6988 return cp;
6990 /* An alias entry maps a suffix to a language.
6991 Search for the language; pass 0 for NAME and LENGTH
6992 to avoid infinite recursion if language not found. */
6993 return lookup_compiler (NULL, 0, cp->spec + 1);
6995 return 0;
6998 static char *
6999 save_string (const char *s, int len)
7001 char *result = XNEWVEC (char, len + 1);
7003 memcpy (result, s, len);
7004 result[len] = 0;
7005 return result;
7008 void
7009 pfatal_with_name (const char *name)
7011 perror_with_name (name);
7012 delete_temp_files ();
7013 exit (1);
7016 static void
7017 perror_with_name (const char *name)
7019 error ("%s: %m", name);
7022 static inline void
7023 validate_switches_from_spec (const char *spec)
7025 const char *p = spec;
7026 char c;
7027 while ((c = *p++))
7028 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
7029 /* We have a switch spec. */
7030 p = validate_switches (p + 1);
7033 static void
7034 validate_all_switches (void)
7036 struct compiler *comp;
7037 struct spec_list *spec;
7039 for (comp = compilers; comp->spec; comp++)
7040 validate_switches_from_spec (comp->spec);
7042 /* Look through the linked list of specs read from the specs file. */
7043 for (spec = specs; spec; spec = spec->next)
7044 validate_switches_from_spec (*spec->ptr_spec);
7046 validate_switches_from_spec (link_command_spec);
7049 /* Look at the switch-name that comes after START
7050 and mark as valid all supplied switches that match it. */
7052 static const char *
7053 validate_switches (const char *start)
7055 const char *p = start;
7056 const char *atom;
7057 size_t len;
7058 int i;
7059 bool suffix = false;
7060 bool starred = false;
7062 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
7064 next_member:
7065 SKIP_WHITE ();
7067 if (*p == '!')
7068 p++;
7070 SKIP_WHITE ();
7071 if (*p == '.' || *p == ',')
7072 suffix = true, p++;
7074 atom = p;
7075 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
7076 || *p == ',' || *p == '.' || *p == '@')
7077 p++;
7078 len = p - atom;
7080 if (*p == '*')
7081 starred = true, p++;
7083 SKIP_WHITE ();
7085 if (!suffix)
7087 /* Mark all matching switches as valid. */
7088 for (i = 0; i < n_switches; i++)
7089 if (!strncmp (switches[i].part1, atom, len)
7090 && (starred || switches[i].part1[len] == 0))
7091 switches[i].validated = 1;
7094 if (*p) p++;
7095 if (*p && (p[-1] == '|' || p[-1] == '&'))
7096 goto next_member;
7098 if (*p && p[-1] == ':')
7100 while (*p && *p != ';' && *p != '}')
7102 if (*p == '%')
7104 p++;
7105 if (*p == '{' || *p == '<')
7106 p = validate_switches (p+1);
7107 else if (p[0] == 'W' && p[1] == '{')
7108 p = validate_switches (p+2);
7110 else
7111 p++;
7114 if (*p) p++;
7115 if (*p && p[-1] == ';')
7116 goto next_member;
7119 return p;
7120 #undef SKIP_WHITE
7123 struct mdswitchstr
7125 const char *str;
7126 int len;
7129 static struct mdswitchstr *mdswitches;
7130 static int n_mdswitches;
7132 /* Check whether a particular argument was used. The first time we
7133 canonicalize the switches to keep only the ones we care about. */
7135 static int
7136 used_arg (const char *p, int len)
7138 struct mswitchstr
7140 const char *str;
7141 const char *replace;
7142 int len;
7143 int rep_len;
7146 static struct mswitchstr *mswitches;
7147 static int n_mswitches;
7148 int i, j;
7150 if (!mswitches)
7152 struct mswitchstr *matches;
7153 const char *q;
7154 int cnt = 0;
7156 /* Break multilib_matches into the component strings of string
7157 and replacement string. */
7158 for (q = multilib_matches; *q != '\0'; q++)
7159 if (*q == ';')
7160 cnt++;
7162 matches
7163 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
7164 i = 0;
7165 q = multilib_matches;
7166 while (*q != '\0')
7168 matches[i].str = q;
7169 while (*q != ' ')
7171 if (*q == '\0')
7173 invalid_matches:
7174 fatal_error ("multilib spec %qs is invalid",
7175 multilib_matches);
7177 q++;
7179 matches[i].len = q - matches[i].str;
7181 matches[i].replace = ++q;
7182 while (*q != ';' && *q != '\0')
7184 if (*q == ' ')
7185 goto invalid_matches;
7186 q++;
7188 matches[i].rep_len = q - matches[i].replace;
7189 i++;
7190 if (*q == ';')
7191 q++;
7194 /* Now build a list of the replacement string for switches that we care
7195 about. Make sure we allocate at least one entry. This prevents
7196 xmalloc from calling fatal, and prevents us from re-executing this
7197 block of code. */
7198 mswitches
7199 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
7200 for (i = 0; i < n_switches; i++)
7201 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
7203 int xlen = strlen (switches[i].part1);
7204 for (j = 0; j < cnt; j++)
7205 if (xlen == matches[j].len
7206 && ! strncmp (switches[i].part1, matches[j].str, xlen))
7208 mswitches[n_mswitches].str = matches[j].replace;
7209 mswitches[n_mswitches].len = matches[j].rep_len;
7210 mswitches[n_mswitches].replace = (char *) 0;
7211 mswitches[n_mswitches].rep_len = 0;
7212 n_mswitches++;
7213 break;
7217 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
7218 on the command line nor any options mutually incompatible with
7219 them. */
7220 for (i = 0; i < n_mdswitches; i++)
7222 const char *r;
7224 for (q = multilib_options; *q != '\0'; q++)
7226 while (*q == ' ')
7227 q++;
7229 r = q;
7230 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
7231 || strchr (" /", q[mdswitches[i].len]) == NULL)
7233 while (*q != ' ' && *q != '/' && *q != '\0')
7234 q++;
7235 if (*q != '/')
7236 break;
7237 q++;
7240 if (*q != ' ' && *q != '\0')
7242 while (*r != ' ' && *r != '\0')
7244 q = r;
7245 while (*q != ' ' && *q != '/' && *q != '\0')
7246 q++;
7248 if (used_arg (r, q - r))
7249 break;
7251 if (*q != '/')
7253 mswitches[n_mswitches].str = mdswitches[i].str;
7254 mswitches[n_mswitches].len = mdswitches[i].len;
7255 mswitches[n_mswitches].replace = (char *) 0;
7256 mswitches[n_mswitches].rep_len = 0;
7257 n_mswitches++;
7258 break;
7261 r = q + 1;
7263 break;
7269 for (i = 0; i < n_mswitches; i++)
7270 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7271 return 1;
7273 return 0;
7276 static int
7277 default_arg (const char *p, int len)
7279 int i;
7281 for (i = 0; i < n_mdswitches; i++)
7282 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7283 return 1;
7285 return 0;
7288 /* Work out the subdirectory to use based on the options. The format of
7289 multilib_select is a list of elements. Each element is a subdirectory
7290 name followed by a list of options followed by a semicolon. The format
7291 of multilib_exclusions is the same, but without the preceding
7292 directory. First gcc will check the exclusions, if none of the options
7293 beginning with an exclamation point are present, and all of the other
7294 options are present, then we will ignore this completely. Passing
7295 that, gcc will consider each multilib_select in turn using the same
7296 rules for matching the options. If a match is found, that subdirectory
7297 will be used. */
7299 static void
7300 set_multilib_dir (void)
7302 const char *p;
7303 unsigned int this_path_len;
7304 const char *this_path, *this_arg;
7305 const char *start, *end;
7306 int not_arg;
7307 int ok, ndfltok, first;
7309 n_mdswitches = 0;
7310 start = multilib_defaults;
7311 while (*start == ' ' || *start == '\t')
7312 start++;
7313 while (*start != '\0')
7315 n_mdswitches++;
7316 while (*start != ' ' && *start != '\t' && *start != '\0')
7317 start++;
7318 while (*start == ' ' || *start == '\t')
7319 start++;
7322 if (n_mdswitches)
7324 int i = 0;
7326 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
7327 for (start = multilib_defaults; *start != '\0'; start = end + 1)
7329 while (*start == ' ' || *start == '\t')
7330 start++;
7332 if (*start == '\0')
7333 break;
7335 for (end = start + 1;
7336 *end != ' ' && *end != '\t' && *end != '\0'; end++)
7339 obstack_grow (&multilib_obstack, start, end - start);
7340 obstack_1grow (&multilib_obstack, 0);
7341 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
7342 mdswitches[i++].len = end - start;
7344 if (*end == '\0')
7345 break;
7349 p = multilib_exclusions;
7350 while (*p != '\0')
7352 /* Ignore newlines. */
7353 if (*p == '\n')
7355 ++p;
7356 continue;
7359 /* Check the arguments. */
7360 ok = 1;
7361 while (*p != ';')
7363 if (*p == '\0')
7365 invalid_exclusions:
7366 fatal_error ("multilib exclusions %qs is invalid",
7367 multilib_exclusions);
7370 if (! ok)
7372 ++p;
7373 continue;
7376 this_arg = p;
7377 while (*p != ' ' && *p != ';')
7379 if (*p == '\0')
7380 goto invalid_exclusions;
7381 ++p;
7384 if (*this_arg != '!')
7385 not_arg = 0;
7386 else
7388 not_arg = 1;
7389 ++this_arg;
7392 ok = used_arg (this_arg, p - this_arg);
7393 if (not_arg)
7394 ok = ! ok;
7396 if (*p == ' ')
7397 ++p;
7400 if (ok)
7401 return;
7403 ++p;
7406 first = 1;
7407 p = multilib_select;
7408 while (*p != '\0')
7410 /* Ignore newlines. */
7411 if (*p == '\n')
7413 ++p;
7414 continue;
7417 /* Get the initial path. */
7418 this_path = p;
7419 while (*p != ' ')
7421 if (*p == '\0')
7423 invalid_select:
7424 fatal_error ("multilib select %qs is invalid",
7425 multilib_select);
7427 ++p;
7429 this_path_len = p - this_path;
7431 /* Check the arguments. */
7432 ok = 1;
7433 ndfltok = 1;
7434 ++p;
7435 while (*p != ';')
7437 if (*p == '\0')
7438 goto invalid_select;
7440 if (! ok)
7442 ++p;
7443 continue;
7446 this_arg = p;
7447 while (*p != ' ' && *p != ';')
7449 if (*p == '\0')
7450 goto invalid_select;
7451 ++p;
7454 if (*this_arg != '!')
7455 not_arg = 0;
7456 else
7458 not_arg = 1;
7459 ++this_arg;
7462 /* If this is a default argument, we can just ignore it.
7463 This is true even if this_arg begins with '!'. Beginning
7464 with '!' does not mean that this argument is necessarily
7465 inappropriate for this library: it merely means that
7466 there is a more specific library which uses this
7467 argument. If this argument is a default, we need not
7468 consider that more specific library. */
7469 ok = used_arg (this_arg, p - this_arg);
7470 if (not_arg)
7471 ok = ! ok;
7473 if (! ok)
7474 ndfltok = 0;
7476 if (default_arg (this_arg, p - this_arg))
7477 ok = 1;
7479 if (*p == ' ')
7480 ++p;
7483 if (ok && first)
7485 if (this_path_len != 1
7486 || this_path[0] != '.')
7488 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
7489 char *q;
7491 strncpy (new_multilib_dir, this_path, this_path_len);
7492 new_multilib_dir[this_path_len] = '\0';
7493 q = strchr (new_multilib_dir, ':');
7494 if (q != NULL)
7495 *q = '\0';
7496 multilib_dir = new_multilib_dir;
7498 first = 0;
7501 if (ndfltok)
7503 const char *q = this_path, *end = this_path + this_path_len;
7505 while (q < end && *q != ':')
7506 q++;
7507 if (q < end)
7509 char *new_multilib_os_dir = XNEWVEC (char, end - q);
7510 memcpy (new_multilib_os_dir, q + 1, end - q - 1);
7511 new_multilib_os_dir[end - q - 1] = '\0';
7512 multilib_os_dir = new_multilib_os_dir;
7513 break;
7517 ++p;
7520 if (multilib_dir == NULL && multilib_os_dir != NULL
7521 && strcmp (multilib_os_dir, ".") == 0)
7523 free (CONST_CAST (char *, multilib_os_dir));
7524 multilib_os_dir = NULL;
7526 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7527 multilib_os_dir = multilib_dir;
7530 /* Print out the multiple library subdirectory selection
7531 information. This prints out a series of lines. Each line looks
7532 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7533 required. Only the desired options are printed out, the negative
7534 matches. The options are print without a leading dash. There are
7535 no spaces to make it easy to use the information in the shell.
7536 Each subdirectory is printed only once. This assumes the ordering
7537 generated by the genmultilib script. Also, we leave out ones that match
7538 the exclusions. */
7540 static void
7541 print_multilib_info (void)
7543 const char *p = multilib_select;
7544 const char *last_path = 0, *this_path;
7545 int skip;
7546 unsigned int last_path_len = 0;
7548 while (*p != '\0')
7550 skip = 0;
7551 /* Ignore newlines. */
7552 if (*p == '\n')
7554 ++p;
7555 continue;
7558 /* Get the initial path. */
7559 this_path = p;
7560 while (*p != ' ')
7562 if (*p == '\0')
7564 invalid_select:
7565 fatal_error ("multilib select %qs is invalid", multilib_select);
7568 ++p;
7571 /* When --disable-multilib was used but target defines
7572 MULTILIB_OSDIRNAMES, entries starting with .: are there just
7573 to find multilib_os_dir, so skip them from output. */
7574 if (this_path[0] == '.' && this_path[1] == ':')
7575 skip = 1;
7577 /* Check for matches with the multilib_exclusions. We don't bother
7578 with the '!' in either list. If any of the exclusion rules match
7579 all of its options with the select rule, we skip it. */
7581 const char *e = multilib_exclusions;
7582 const char *this_arg;
7584 while (*e != '\0')
7586 int m = 1;
7587 /* Ignore newlines. */
7588 if (*e == '\n')
7590 ++e;
7591 continue;
7594 /* Check the arguments. */
7595 while (*e != ';')
7597 const char *q;
7598 int mp = 0;
7600 if (*e == '\0')
7602 invalid_exclusion:
7603 fatal_error ("multilib exclusion %qs is invalid",
7604 multilib_exclusions);
7607 if (! m)
7609 ++e;
7610 continue;
7613 this_arg = e;
7615 while (*e != ' ' && *e != ';')
7617 if (*e == '\0')
7618 goto invalid_exclusion;
7619 ++e;
7622 q = p + 1;
7623 while (*q != ';')
7625 const char *arg;
7626 int len = e - this_arg;
7628 if (*q == '\0')
7629 goto invalid_select;
7631 arg = q;
7633 while (*q != ' ' && *q != ';')
7635 if (*q == '\0')
7636 goto invalid_select;
7637 ++q;
7640 if (! strncmp (arg, this_arg,
7641 (len < q - arg) ? q - arg : len)
7642 || default_arg (this_arg, e - this_arg))
7644 mp = 1;
7645 break;
7648 if (*q == ' ')
7649 ++q;
7652 if (! mp)
7653 m = 0;
7655 if (*e == ' ')
7656 ++e;
7659 if (m)
7661 skip = 1;
7662 break;
7665 if (*e != '\0')
7666 ++e;
7670 if (! skip)
7672 /* If this is a duplicate, skip it. */
7673 skip = (last_path != 0
7674 && (unsigned int) (p - this_path) == last_path_len
7675 && ! filename_ncmp (last_path, this_path, last_path_len));
7677 last_path = this_path;
7678 last_path_len = p - this_path;
7681 /* If this directory requires any default arguments, we can skip
7682 it. We will already have printed a directory identical to
7683 this one which does not require that default argument. */
7684 if (! skip)
7686 const char *q;
7688 q = p + 1;
7689 while (*q != ';')
7691 const char *arg;
7693 if (*q == '\0')
7694 goto invalid_select;
7696 if (*q == '!')
7697 arg = NULL;
7698 else
7699 arg = q;
7701 while (*q != ' ' && *q != ';')
7703 if (*q == '\0')
7704 goto invalid_select;
7705 ++q;
7708 if (arg != NULL
7709 && default_arg (arg, q - arg))
7711 skip = 1;
7712 break;
7715 if (*q == ' ')
7716 ++q;
7720 if (! skip)
7722 const char *p1;
7724 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
7725 putchar (*p1);
7726 putchar (';');
7729 ++p;
7730 while (*p != ';')
7732 int use_arg;
7734 if (*p == '\0')
7735 goto invalid_select;
7737 if (skip)
7739 ++p;
7740 continue;
7743 use_arg = *p != '!';
7745 if (use_arg)
7746 putchar ('@');
7748 while (*p != ' ' && *p != ';')
7750 if (*p == '\0')
7751 goto invalid_select;
7752 if (use_arg)
7753 putchar (*p);
7754 ++p;
7757 if (*p == ' ')
7758 ++p;
7761 if (! skip)
7763 /* If there are extra options, print them now. */
7764 if (multilib_extra && *multilib_extra)
7766 int print_at = TRUE;
7767 const char *q;
7769 for (q = multilib_extra; *q != '\0'; q++)
7771 if (*q == ' ')
7772 print_at = TRUE;
7773 else
7775 if (print_at)
7776 putchar ('@');
7777 putchar (*q);
7778 print_at = FALSE;
7783 putchar ('\n');
7786 ++p;
7790 /* getenv built-in spec function.
7792 Returns the value of the environment variable given by its first
7793 argument, concatenated with the second argument. If the
7794 environment variable is not defined, a fatal error is issued. */
7796 static const char *
7797 getenv_spec_function (int argc, const char **argv)
7799 char *value;
7800 char *result;
7801 char *ptr;
7802 size_t len;
7804 if (argc != 2)
7805 return NULL;
7807 value = getenv (argv[0]);
7808 if (!value)
7809 fatal_error ("environment variable %qs not defined", argv[0]);
7811 /* We have to escape every character of the environment variable so
7812 they are not interpreted as active spec characters. A
7813 particularly painful case is when we are reading a variable
7814 holding a windows path complete with \ separators. */
7815 len = strlen (value) * 2 + strlen (argv[1]) + 1;
7816 result = XNEWVAR (char, len);
7817 for (ptr = result; *value; ptr += 2)
7819 ptr[0] = '\\';
7820 ptr[1] = *value++;
7823 strcpy (ptr, argv[1]);
7825 return result;
7828 /* if-exists built-in spec function.
7830 Checks to see if the file specified by the absolute pathname in
7831 ARGS exists. Returns that pathname if found.
7833 The usual use for this function is to check for a library file
7834 (whose name has been expanded with %s). */
7836 static const char *
7837 if_exists_spec_function (int argc, const char **argv)
7839 /* Must have only one argument. */
7840 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7841 return argv[0];
7843 return NULL;
7846 /* if-exists-else built-in spec function.
7848 This is like if-exists, but takes an additional argument which
7849 is returned if the first argument does not exist. */
7851 static const char *
7852 if_exists_else_spec_function (int argc, const char **argv)
7854 /* Must have exactly two arguments. */
7855 if (argc != 2)
7856 return NULL;
7858 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7859 return argv[0];
7861 return argv[1];
7864 /* replace-outfile built-in spec function.
7866 This looks for the first argument in the outfiles array's name and
7867 replaces it with the second argument. */
7869 static const char *
7870 replace_outfile_spec_function (int argc, const char **argv)
7872 int i;
7873 /* Must have exactly two arguments. */
7874 if (argc != 2)
7875 abort ();
7877 for (i = 0; i < n_infiles; i++)
7879 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
7880 outfiles[i] = xstrdup (argv[1]);
7882 return NULL;
7885 /* remove-outfile built-in spec function.
7887 * This looks for the first argument in the outfiles array's name and
7888 * removes it. */
7890 static const char *
7891 remove_outfile_spec_function (int argc, const char **argv)
7893 int i;
7894 /* Must have exactly one argument. */
7895 if (argc != 1)
7896 abort ();
7898 for (i = 0; i < n_infiles; i++)
7900 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
7901 outfiles[i] = NULL;
7903 return NULL;
7906 /* Given two version numbers, compares the two numbers.
7907 A version number must match the regular expression
7908 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
7910 static int
7911 compare_version_strings (const char *v1, const char *v2)
7913 int rresult;
7914 regex_t r;
7916 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
7917 REG_EXTENDED | REG_NOSUB) != 0)
7918 abort ();
7919 rresult = regexec (&r, v1, 0, NULL, 0);
7920 if (rresult == REG_NOMATCH)
7921 fatal_error ("invalid version number %qs", v1);
7922 else if (rresult != 0)
7923 abort ();
7924 rresult = regexec (&r, v2, 0, NULL, 0);
7925 if (rresult == REG_NOMATCH)
7926 fatal_error ("invalid version number %qs", v2);
7927 else if (rresult != 0)
7928 abort ();
7930 return strverscmp (v1, v2);
7934 /* version_compare built-in spec function.
7936 This takes an argument of the following form:
7938 <comparison-op> <arg1> [<arg2>] <switch> <result>
7940 and produces "result" if the comparison evaluates to true,
7941 and nothing if it doesn't.
7943 The supported <comparison-op> values are:
7945 >= true if switch is a later (or same) version than arg1
7946 !> opposite of >=
7947 < true if switch is an earlier version than arg1
7948 !< opposite of <
7949 >< true if switch is arg1 or later, and earlier than arg2
7950 <> true if switch is earlier than arg1 or is arg2 or later
7952 If the switch is not present, the condition is false unless
7953 the first character of the <comparison-op> is '!'.
7955 For example,
7956 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
7957 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
7959 static const char *
7960 version_compare_spec_function (int argc, const char **argv)
7962 int comp1, comp2;
7963 size_t switch_len;
7964 const char *switch_value = NULL;
7965 int nargs = 1, i;
7966 bool result;
7968 if (argc < 3)
7969 fatal_error ("too few arguments to %%:version-compare");
7970 if (argv[0][0] == '\0')
7971 abort ();
7972 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
7973 nargs = 2;
7974 if (argc != nargs + 3)
7975 fatal_error ("too many arguments to %%:version-compare");
7977 switch_len = strlen (argv[nargs + 1]);
7978 for (i = 0; i < n_switches; i++)
7979 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
7980 && check_live_switch (i, switch_len))
7981 switch_value = switches[i].part1 + switch_len;
7983 if (switch_value == NULL)
7984 comp1 = comp2 = -1;
7985 else
7987 comp1 = compare_version_strings (switch_value, argv[1]);
7988 if (nargs == 2)
7989 comp2 = compare_version_strings (switch_value, argv[2]);
7990 else
7991 comp2 = -1; /* This value unused. */
7994 switch (argv[0][0] << 8 | argv[0][1])
7996 case '>' << 8 | '=':
7997 result = comp1 >= 0;
7998 break;
7999 case '!' << 8 | '<':
8000 result = comp1 >= 0 || switch_value == NULL;
8001 break;
8002 case '<' << 8:
8003 result = comp1 < 0;
8004 break;
8005 case '!' << 8 | '>':
8006 result = comp1 < 0 || switch_value == NULL;
8007 break;
8008 case '>' << 8 | '<':
8009 result = comp1 >= 0 && comp2 < 0;
8010 break;
8011 case '<' << 8 | '>':
8012 result = comp1 < 0 || comp2 >= 0;
8013 break;
8015 default:
8016 fatal_error ("unknown operator %qs in %%:version-compare", argv[0]);
8018 if (! result)
8019 return NULL;
8021 return argv[nargs + 2];
8024 /* %:include builtin spec function. This differs from %include in that it
8025 can be nested inside a spec, and thus be conditionalized. It takes
8026 one argument, the filename, and looks for it in the startfile path.
8027 The result is always NULL, i.e. an empty expansion. */
8029 static const char *
8030 include_spec_function (int argc, const char **argv)
8032 char *file;
8034 if (argc != 1)
8035 abort ();
8037 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
8038 read_specs (file ? file : argv[0], FALSE);
8040 return NULL;
8043 /* %:find-file spec function. This function replaces its argument by
8044 the file found thru find_file, that is the -print-file-name gcc
8045 program option. */
8046 static const char *
8047 find_file_spec_function (int argc, const char **argv)
8049 const char *file;
8051 if (argc != 1)
8052 abort ();
8054 file = find_file (argv[0]);
8055 return file;
8059 /* %:find-plugindir spec function. This function replaces its argument
8060 by the -iplugindir=<dir> option. `dir' is found thru find_file, that
8061 is the -print-file-name gcc program option. */
8062 static const char *
8063 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
8065 const char *option;
8067 if (argc != 0)
8068 abort ();
8070 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
8071 return option;
8075 /* %:print-asm-header spec function. Print a banner to say that the
8076 following output is from the assembler. */
8078 static const char *
8079 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
8080 const char **argv ATTRIBUTE_UNUSED)
8082 printf (_("Assembler options\n=================\n\n"));
8083 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
8084 fflush (stdout);
8085 return NULL;
8088 /* Compute a timestamp to initialize flag_random_seed. */
8090 static unsigned
8091 get_local_tick (void)
8093 unsigned ret = 0;
8095 /* Get some more or less random data. */
8096 #ifdef HAVE_GETTIMEOFDAY
8098 struct timeval tv;
8100 gettimeofday (&tv, NULL);
8101 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
8103 #else
8105 time_t now = time (NULL);
8107 if (now != (time_t)-1)
8108 ret = (unsigned) now;
8110 #endif
8112 return ret;
8115 /* %:compare-debug-dump-opt spec function. Save the last argument,
8116 expected to be the last -fdump-final-insns option, or generate a
8117 temporary. */
8119 static const char *
8120 compare_debug_dump_opt_spec_function (int arg,
8121 const char **argv ATTRIBUTE_UNUSED)
8123 const char *ret;
8124 char *name;
8125 int which;
8126 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
8128 if (arg != 0)
8129 fatal_error ("too many arguments to %%:compare-debug-dump-opt");
8131 do_spec_2 ("%{fdump-final-insns=*:%*}");
8132 do_spec_1 (" ", 0, NULL);
8134 if (VEC_length (const_char_p, argbuf) > 0
8135 && strcmp (argv[VEC_length (const_char_p, argbuf) - 1], "."))
8137 if (!compare_debug)
8138 return NULL;
8140 name = xstrdup (argv[VEC_length (const_char_p, argbuf) - 1]);
8141 ret = NULL;
8143 else
8145 const char *ext = NULL;
8147 if (VEC_length (const_char_p, argbuf) > 0)
8149 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
8150 ext = ".gkd";
8152 else if (!compare_debug)
8153 return NULL;
8154 else
8155 do_spec_2 ("%g.gkd");
8157 do_spec_1 (" ", 0, NULL);
8159 gcc_assert (VEC_length (const_char_p, argbuf) > 0);
8161 name = concat (VEC_last (const_char_p, argbuf), ext, NULL);
8163 ret = concat ("-fdump-final-insns=", name, NULL);
8166 which = compare_debug < 0;
8167 debug_check_temp_file[which] = name;
8169 if (!which)
8171 unsigned HOST_WIDE_INT value = get_local_tick () ^ getpid ();
8173 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
8176 if (*random_seed)
8177 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
8178 ret, NULL);
8180 if (which)
8181 *random_seed = 0;
8183 return ret;
8186 static const char *debug_auxbase_opt;
8188 /* %:compare-debug-self-opt spec function. Expands to the options
8189 that are to be passed in the second compilation of
8190 compare-debug. */
8192 static const char *
8193 compare_debug_self_opt_spec_function (int arg,
8194 const char **argv ATTRIBUTE_UNUSED)
8196 if (arg != 0)
8197 fatal_error ("too many arguments to %%:compare-debug-self-opt");
8199 if (compare_debug >= 0)
8200 return NULL;
8202 do_spec_2 ("%{c|S:%{o*:%*}}");
8203 do_spec_1 (" ", 0, NULL);
8205 if (VEC_length (const_char_p, argbuf) > 0)
8206 debug_auxbase_opt = concat ("-auxbase-strip ",
8207 VEC_last (const_char_p, argbuf),
8208 NULL);
8209 else
8210 debug_auxbase_opt = NULL;
8212 return concat ("\
8213 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
8214 %<fdump-final-insns=* -w -S -o %j \
8215 %{!fcompare-debug-second:-fcompare-debug-second} \
8216 ", compare_debug_opt, NULL);
8219 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
8220 options that are to be passed in the second compilation of
8221 compare-debug. It expects, as an argument, the basename of the
8222 current input file name, with the .gk suffix appended to it. */
8224 static const char *
8225 compare_debug_auxbase_opt_spec_function (int arg,
8226 const char **argv)
8228 char *name;
8229 int len;
8231 if (arg == 0)
8232 fatal_error ("too few arguments to %%:compare-debug-auxbase-opt");
8234 if (arg != 1)
8235 fatal_error ("too many arguments to %%:compare-debug-auxbase-opt");
8237 if (compare_debug >= 0)
8238 return NULL;
8240 len = strlen (argv[0]);
8241 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
8242 fatal_error ("argument to %%:compare-debug-auxbase-opt "
8243 "does not end in .gk");
8245 if (debug_auxbase_opt)
8246 return debug_auxbase_opt;
8248 #define OPT "-auxbase "
8250 len -= 3;
8251 name = (char*) xmalloc (sizeof (OPT) + len);
8252 memcpy (name, OPT, sizeof (OPT) - 1);
8253 memcpy (name + sizeof (OPT) - 1, argv[0], len);
8254 name[sizeof (OPT) - 1 + len] = '\0';
8256 #undef OPT
8258 return name;
8261 /* %:pass-through-libs spec function. Finds all -l options and input
8262 file names in the lib spec passed to it, and makes a list of them
8263 prepended with the plugin option to cause them to be passed through
8264 to the final link after all the new object files have been added. */
8266 const char *
8267 pass_through_libs_spec_func (int argc, const char **argv)
8269 char *prepended = xstrdup (" ");
8270 int n;
8271 /* Shlemiel the painter's algorithm. Innately horrible, but at least
8272 we know that there will never be more than a handful of strings to
8273 concat, and it's only once per run, so it's not worth optimising. */
8274 for (n = 0; n < argc; n++)
8276 char *old = prepended;
8277 /* Anything that isn't an option is a full path to an output
8278 file; pass it through if it ends in '.a'. Among options,
8279 pass only -l. */
8280 if (argv[n][0] == '-' && argv[n][1] == 'l')
8282 const char *lopt = argv[n] + 2;
8283 /* Handle both joined and non-joined -l options. If for any
8284 reason there's a trailing -l with no joined or following
8285 arg just discard it. */
8286 if (!*lopt && ++n >= argc)
8287 break;
8288 else if (!*lopt)
8289 lopt = argv[n];
8290 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
8291 lopt, " ", NULL);
8293 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
8295 prepended = concat (prepended, "-plugin-opt=-pass-through=",
8296 argv[n], " ", NULL);
8298 if (prepended != old)
8299 free (old);
8301 return prepended;