Merge trunk version 218477 into gupc branch.
[official-gcc.git] / gcc / gcc.c
blob8bcdecb40ba353daecdfd7402831eddaf1489a2a
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987-2014 Free Software Foundation, Inc.
4 This file is part of GCC.
6 GCC is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 3, or (at your option) any later
9 version.
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14 for more details.
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING3. If not see
18 <http://www.gnu.org/licenses/>. */
20 /* This program is the user interface to the C compiler and possibly to
21 other compilers. It is used because compilation is a complicated procedure
22 which involves running several programs and passing temporary files between
23 them, forwarding the users switches to those programs selectively,
24 and deleting the temporary files at the end.
26 CC recognizes how to compile each input file by suffixes in the file names.
27 Once it knows which kind of compilation to perform, the procedure for
28 compilation is specified by a string called a "spec". */
30 #include "config.h"
31 #include "system.h"
32 #include "coretypes.h"
33 #include "multilib.h" /* before tm.h */
34 #include "tm.h"
35 #include "xregex.h"
36 #include "obstack.h"
37 #include "intl.h"
38 #include "prefix.h"
39 #include "gcc.h"
40 #include "diagnostic.h"
41 #include "flags.h"
42 #include "opts.h"
43 #include "params.h"
44 #include "vec.h"
45 #include "filenames.h"
47 /* By default there is no special suffix for target executables. */
48 /* FIXME: when autoconf is fixed, remove the host check - dj */
49 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
50 #define HAVE_TARGET_EXECUTABLE_SUFFIX
51 #endif
53 /* By default there is no special suffix for host executables. */
54 #ifdef HOST_EXECUTABLE_SUFFIX
55 #define HAVE_HOST_EXECUTABLE_SUFFIX
56 #else
57 #define HOST_EXECUTABLE_SUFFIX ""
58 #endif
60 /* By default, the suffix for target object files is ".o". */
61 #ifdef TARGET_OBJECT_SUFFIX
62 #define HAVE_TARGET_OBJECT_SUFFIX
63 #else
64 #define TARGET_OBJECT_SUFFIX ".o"
65 #endif
67 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
69 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
70 #ifndef LIBRARY_PATH_ENV
71 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
72 #endif
74 /* If a stage of compilation returns an exit status >= 1,
75 compilation of that file ceases. */
77 #define MIN_FATAL_STATUS 1
79 /* Flag set by cppspec.c to 1. */
80 int is_cpp_driver;
82 /* Flag set to nonzero if an @file argument has been supplied to gcc. */
83 static bool at_file_supplied;
85 /* Definition of string containing the arguments given to configure. */
86 #include "configargs.h"
88 /* Flag saying to print the command line options understood by gcc and its
89 sub-processes. */
91 static int print_help_list;
93 /* Flag saying to print the version of gcc and its sub-processes. */
95 static int print_version;
97 /* Flag indicating whether we should ONLY print the command and
98 arguments (like verbose_flag) without executing the command.
99 Displayed arguments are quoted so that the generated command
100 line is suitable for execution. This is intended for use in
101 shell scripts to capture the driver-generated command line. */
102 static int verbose_only_flag;
104 /* Flag indicating how to print command line options of sub-processes. */
106 static int print_subprocess_help;
108 /* Linker suffix passed to -fuse-ld=... */
109 static const char *use_ld;
111 /* Whether we should report subprocess execution times to a file. */
113 FILE *report_times_to_file = NULL;
115 /* Nonzero means place this string before uses of /, so that include
116 and library files can be found in an alternate location. */
118 #ifdef TARGET_SYSTEM_ROOT
119 static const char *target_system_root = TARGET_SYSTEM_ROOT;
120 #else
121 static const char *target_system_root = 0;
122 #endif
124 /* Nonzero means pass the updated target_system_root to the compiler. */
126 static int target_system_root_changed;
128 /* Nonzero means append this string to target_system_root. */
130 static const char *target_sysroot_suffix = 0;
132 /* Nonzero means append this string to target_system_root for headers. */
134 static const char *target_sysroot_hdrs_suffix = 0;
136 /* Nonzero means write "temp" files in source directory
137 and use the source file's name in them, and don't delete them. */
139 static enum save_temps {
140 SAVE_TEMPS_NONE, /* no -save-temps */
141 SAVE_TEMPS_CWD, /* -save-temps in current directory */
142 SAVE_TEMPS_OBJ /* -save-temps in object directory */
143 } save_temps_flag;
145 /* Output file to use to get the object directory for -save-temps=obj */
146 static char *save_temps_prefix = 0;
147 static size_t save_temps_length = 0;
149 /* The compiler version. */
151 static const char *compiler_version;
153 /* The target version. */
155 static const char *const spec_version = DEFAULT_TARGET_VERSION;
157 /* The target machine. */
159 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
160 static const char *spec_host_machine = DEFAULT_REAL_TARGET_MACHINE;
162 /* List of offload targets. */
164 static char *offload_targets = NULL;
166 /* Nonzero if cross-compiling.
167 When -b is used, the value comes from the `specs' file. */
169 #ifdef CROSS_DIRECTORY_STRUCTURE
170 static const char *cross_compile = "1";
171 #else
172 static const char *cross_compile = "0";
173 #endif
175 /* Greatest exit code of sub-processes that has been encountered up to
176 now. */
177 static int greatest_status = 1;
179 /* This is the obstack which we use to allocate many strings. */
181 static struct obstack obstack;
183 /* This is the obstack to build an environment variable to pass to
184 collect2 that describes all of the relevant switches of what to
185 pass the compiler in building the list of pointers to constructors
186 and destructors. */
188 static struct obstack collect_obstack;
190 /* Forward declaration for prototypes. */
191 struct path_prefix;
192 struct prefix_list;
194 static void init_spec (void);
195 static void store_arg (const char *, int, int);
196 static void insert_wrapper (const char *);
197 static char *load_specs (const char *);
198 static void read_specs (const char *, bool, bool);
199 static void set_spec (const char *, const char *, bool);
200 static struct compiler *lookup_compiler (const char *, size_t, const char *);
201 static char *build_search_list (const struct path_prefix *, const char *,
202 bool, bool);
203 static void xputenv (const char *);
204 static void putenv_from_prefixes (const struct path_prefix *, const char *,
205 bool);
206 static int access_check (const char *, int);
207 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
208 static void add_prefix (struct path_prefix *, const char *, const char *,
209 int, int, int);
210 static void add_sysrooted_prefix (struct path_prefix *, const char *,
211 const char *, int, int, int);
212 static char *skip_whitespace (char *);
213 static void delete_if_ordinary (const char *);
214 static void delete_temp_files (void);
215 static void delete_failure_queue (void);
216 static void clear_failure_queue (void);
217 static int check_live_switch (int, int);
218 static const char *handle_braces (const char *);
219 static inline bool input_suffix_matches (const char *, const char *);
220 static inline bool switch_matches (const char *, const char *, int);
221 static inline void mark_matching_switches (const char *, const char *, int);
222 static inline void process_marked_switches (void);
223 static const char *process_brace_body (const char *, const char *, const char *, int, int);
224 static const struct spec_function *lookup_spec_function (const char *);
225 static const char *eval_spec_function (const char *, const char *);
226 static const char *handle_spec_function (const char *, bool *);
227 static char *save_string (const char *, int);
228 static void set_collect_gcc_options (void);
229 static int do_spec_1 (const char *, int, const char *);
230 static int do_spec_2 (const char *);
231 static void do_option_spec (const char *, const char *);
232 static void do_self_spec (const char *);
233 static const char *find_file (const char *);
234 static int is_directory (const char *, bool);
235 static const char *validate_switches (const char *, bool);
236 static void validate_all_switches (void);
237 static inline void validate_switches_from_spec (const char *, bool);
238 static void give_switch (int, int);
239 static int used_arg (const char *, int);
240 static int default_arg (const char *, int);
241 static void set_multilib_dir (void);
242 static void print_multilib_info (void);
243 static void perror_with_name (const char *);
244 static void display_help (void);
245 static void add_preprocessor_option (const char *, int);
246 static void add_assembler_option (const char *, int);
247 static void add_linker_option (const char *, int);
248 static void process_command (unsigned int, struct cl_decoded_option *);
249 static int execute (void);
250 static void alloc_args (void);
251 static void clear_args (void);
252 static void fatal_signal (int);
253 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
254 static void init_gcc_specs (struct obstack *, const char *, const char *,
255 const char *);
256 #endif
257 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
258 static const char *convert_filename (const char *, int, int);
259 #endif
261 static void try_generate_repro (const char **argv);
262 static const char *getenv_spec_function (int, const char **);
263 static const char *if_exists_spec_function (int, const char **);
264 static const char *if_exists_else_spec_function (int, const char **);
265 static const char *sanitize_spec_function (int, const char **);
266 static const char *replace_outfile_spec_function (int, const char **);
267 static const char *remove_outfile_spec_function (int, const char **);
268 static const char *version_compare_spec_function (int, const char **);
269 static const char *include_spec_function (int, const char **);
270 static const char *find_file_spec_function (int, const char **);
271 static const char *find_plugindir_spec_function (int, const char **);
272 static const char *print_asm_header_spec_function (int, const char **);
273 static const char *compare_debug_dump_opt_spec_function (int, const char **);
274 static const char *compare_debug_self_opt_spec_function (int, const char **);
275 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
276 static const char *pass_through_libs_spec_func (int, const char **);
277 static const char *replace_extension_spec_func (int, const char **);
278 static char *convert_white_space (char *);
280 /* The Specs Language
282 Specs are strings containing lines, each of which (if not blank)
283 is made up of a program name, and arguments separated by spaces.
284 The program name must be exact and start from root, since no path
285 is searched and it is unreliable to depend on the current working directory.
286 Redirection of input or output is not supported; the subprograms must
287 accept filenames saying what files to read and write.
289 In addition, the specs can contain %-sequences to substitute variable text
290 or for conditional text. Here is a table of all defined %-sequences.
291 Note that spaces are not generated automatically around the results of
292 expanding these sequences; therefore, you can concatenate them together
293 or with constant text in a single argument.
295 %% substitute one % into the program name or argument.
296 %i substitute the name of the input file being processed.
297 %b substitute the basename of the input file being processed.
298 This is the substring up to (and not including) the last period
299 and not including the directory unless -save-temps was specified
300 to put temporaries in a different location.
301 %B same as %b, but include the file suffix (text after the last period).
302 %gSUFFIX
303 substitute a file name that has suffix SUFFIX and is chosen
304 once per compilation, and mark the argument a la %d. To reduce
305 exposure to denial-of-service attacks, the file name is now
306 chosen in a way that is hard to predict even when previously
307 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
308 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
309 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
310 had been pre-processed. Previously, %g was simply substituted
311 with a file name chosen once per compilation, without regard
312 to any appended suffix (which was therefore treated just like
313 ordinary text), making such attacks more likely to succeed.
314 %|SUFFIX
315 like %g, but if -pipe is in effect, expands simply to "-".
316 %mSUFFIX
317 like %g, but if -pipe is in effect, expands to nothing. (We have both
318 %| and %m to accommodate differences between system assemblers; see
319 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
320 %uSUFFIX
321 like %g, but generates a new temporary file name even if %uSUFFIX
322 was already seen.
323 %USUFFIX
324 substitutes the last file name generated with %uSUFFIX, generating a
325 new one if there is no such last file name. In the absence of any
326 %uSUFFIX, this is just like %gSUFFIX, except they don't share
327 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
328 would involve the generation of two distinct file names, one
329 for each `%g.s' and another for each `%U.s'. Previously, %U was
330 simply substituted with a file name chosen for the previous %u,
331 without regard to any appended suffix.
332 %jSUFFIX
333 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
334 writable, and if save-temps is off; otherwise, substitute the name
335 of a temporary file, just like %u. This temporary file is not
336 meant for communication between processes, but rather as a junk
337 disposal mechanism.
338 %.SUFFIX
339 substitutes .SUFFIX for the suffixes of a matched switch's args when
340 it is subsequently output with %*. SUFFIX is terminated by the next
341 space or %.
342 %d marks the argument containing or following the %d as a
343 temporary file name, so that that file will be deleted if GCC exits
344 successfully. Unlike %g, this contributes no text to the argument.
345 %w marks the argument containing or following the %w as the
346 "output file" of this compilation. This puts the argument
347 into the sequence of arguments that %o will substitute later.
348 %V indicates that this compilation produces no "output file".
349 %W{...}
350 like %{...} but mark last argument supplied within
351 as a file to be deleted on failure.
352 %o substitutes the names of all the output files, with spaces
353 automatically placed around them. You should write spaces
354 around the %o as well or the results are undefined.
355 %o is for use in the specs for running the linker.
356 Input files whose names have no recognized suffix are not compiled
357 at all, but they are included among the output files, so they will
358 be linked.
359 %O substitutes the suffix for object files. Note that this is
360 handled specially when it immediately follows %g, %u, or %U
361 (with or without a suffix argument) because of the need for
362 those to form complete file names. The handling is such that
363 %O is treated exactly as if it had already been substituted,
364 except that %g, %u, and %U do not currently support additional
365 SUFFIX characters following %O as they would following, for
366 example, `.o'.
367 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
368 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
369 and -B options) and -imultilib as necessary.
370 %s current argument is the name of a library or startup file of some sort.
371 Search for that file in a standard list of directories
372 and substitute the full name found.
373 %eSTR Print STR as an error message. STR is terminated by a newline.
374 Use this when inconsistent options are detected.
375 %nSTR Print STR as a notice. STR is terminated by a newline.
376 %x{OPTION} Accumulate an option for %X.
377 %X Output the accumulated linker options specified by compilations.
378 %Y Output the accumulated assembler options specified by compilations.
379 %Z Output the accumulated preprocessor options specified by compilations.
380 %a process ASM_SPEC as a spec.
381 This allows config.h to specify part of the spec for running as.
382 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
383 used here. This can be used to run a post-processor after the
384 assembler has done its job.
385 %D Dump out a -L option for each directory in startfile_prefixes.
386 If multilib_dir is set, extra entries are generated with it affixed.
387 %l process LINK_SPEC as a spec.
388 %L process LIB_SPEC as a spec.
389 %M Output multilib_os_dir.
390 %G process LIBGCC_SPEC as a spec.
391 %R Output the concatenation of target_system_root and
392 target_sysroot_suffix.
393 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
394 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
395 %C process CPP_SPEC as a spec.
396 %1 process CC1_SPEC as a spec.
397 %2 process CC1PLUS_SPEC as a spec.
398 %* substitute the variable part of a matched option. (See below.)
399 Note that each comma in the substituted string is replaced by
400 a single space. A space is appended after the last substition
401 unless there is more text in current sequence.
402 %<S remove all occurrences of -S from the command line.
403 Note - this command is position dependent. % commands in the
404 spec string before this one will see -S, % commands in the
405 spec string after this one will not.
406 %>S Similar to "%<S", but keep it in the GCC command line.
407 %<S* remove all occurrences of all switches beginning with -S from the
408 command line.
409 %:function(args)
410 Call the named function FUNCTION, passing it ARGS. ARGS is
411 first processed as a nested spec string, then split into an
412 argument vector in the usual fashion. The function returns
413 a string which is processed as if it had appeared literally
414 as part of the current spec.
415 %{S} substitutes the -S switch, if that switch was given to GCC.
416 If that switch was not specified, this substitutes nothing.
417 Here S is a metasyntactic variable.
418 %{S*} substitutes all the switches specified to GCC whose names start
419 with -S. This is used for -o, -I, etc; switches that take
420 arguments. GCC considers `-o foo' as being one switch whose
421 name starts with `o'. %{o*} would substitute this text,
422 including the space; thus, two arguments would be generated.
423 %{S*&T*} likewise, but preserve order of S and T options (the order
424 of S and T in the spec is not significant). Can be any number
425 of ampersand-separated variables; for each the wild card is
426 optional. Useful for CPP as %{D*&U*&A*}.
428 %{S:X} substitutes X, if the -S switch was given to GCC.
429 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
430 %{S*:X} substitutes X if one or more switches whose names start
431 with -S was given to GCC. Normally X is substituted only
432 once, no matter how many such switches appeared. However,
433 if %* appears somewhere in X, then X will be substituted
434 once for each matching switch, with the %* replaced by the
435 part of that switch that matched the '*'. A space will be
436 appended after the last substition unless there is more
437 text in current sequence.
438 %{.S:X} substitutes X, if processing a file with suffix S.
439 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
440 %{,S:X} substitutes X, if processing a file which will use spec S.
441 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
443 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
444 combined with '!', '.', ',', and '*' as above binding stronger
445 than the OR.
446 If %* appears in X, all of the alternatives must be starred, and
447 only the first matching alternative is substituted.
448 %{%:function(args):X}
449 Call function named FUNCTION with args ARGS. If the function
450 returns non-NULL, then X is substituted, if it returns
451 NULL, it isn't substituted.
452 %{S:X; if S was given to GCC, substitutes X;
453 T:Y; else if T was given to GCC, substitutes Y;
454 :D} else substitutes D. There can be as many clauses as you need.
455 This may be combined with '.', '!', ',', '|', and '*' as above.
457 %(Spec) processes a specification defined in a specs file as *Spec:
459 The conditional text X in a %{S:X} or similar construct may contain
460 other nested % constructs or spaces, or even newlines. They are
461 processed as usual, as described above. Trailing white space in X is
462 ignored. White space may also appear anywhere on the left side of the
463 colon in these constructs, except between . or * and the corresponding
464 word.
466 The -O, -f, -g, -m, and -W switches are handled specifically in these
467 constructs. If another value of -O or the negated form of a -f, -m, or
468 -W switch is found later in the command line, the earlier switch
469 value is ignored, except with {S*} where S is just one letter; this
470 passes all matching options.
472 The character | at the beginning of the predicate text is used to indicate
473 that a command should be piped to the following command, but only if -pipe
474 is specified.
476 Note that it is built into GCC which switches take arguments and which
477 do not. You might think it would be useful to generalize this to
478 allow each compiler's spec to say which switches take arguments. But
479 this cannot be done in a consistent fashion. GCC cannot even decide
480 which input files have been specified without knowing which switches
481 take arguments, and it must know which input files to compile in order
482 to tell which compilers to run.
484 GCC also knows implicitly that arguments starting in `-l' are to be
485 treated as compiler output files, and passed to the linker in their
486 proper position among the other output files. */
488 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
490 /* config.h can define ASM_SPEC to provide extra args to the assembler
491 or extra switch-translations. */
492 #ifndef ASM_SPEC
493 #define ASM_SPEC ""
494 #endif
496 /* config.h can define ASM_FINAL_SPEC to run a post processor after
497 the assembler has run. */
498 #ifndef ASM_FINAL_SPEC
499 #define ASM_FINAL_SPEC \
500 "%{gsplit-dwarf: \n\
501 objcopy --extract-dwo \
502 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
503 %{c:%{o*:%:replace-extension(%{o*:%*} .dwo)}%{!o*:%b.dwo}}%{!c:%b.dwo} \n\
504 objcopy --strip-dwo \
505 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
507 #endif
509 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
510 or extra switch-translations. */
511 #ifndef CPP_SPEC
512 #define CPP_SPEC ""
513 #endif
515 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
516 or extra switch-translations. */
517 #ifndef CC1_SPEC
518 #define CC1_SPEC ""
519 #endif
521 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
522 or extra switch-translations. */
523 #ifndef CC1PLUS_SPEC
524 #define CC1PLUS_SPEC ""
525 #endif
527 /* config.h can define LINK_SPEC to provide extra args to the linker
528 or extra switch-translations. */
529 #ifndef LINK_SPEC
530 #define LINK_SPEC ""
531 #endif
533 /* config.h can define LIB_SPEC to override the default libraries. */
534 #ifndef LIB_SPEC
535 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
536 #endif
538 /* When using -fsplit-stack we need to wrap pthread_create, in order
539 to initialize the stack guard. We always use wrapping, rather than
540 shared library ordering, and we keep the wrapper function in
541 libgcc. This is not yet a real spec, though it could become one;
542 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
543 only works with GNU ld and gold. */
544 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
546 #ifndef LIBASAN_SPEC
547 #define STATIC_LIBASAN_LIBS \
548 " %{static-libasan:%:include(libsanitizer.spec)%(link_libasan)}"
549 #ifdef LIBASAN_EARLY_SPEC
550 #define LIBASAN_SPEC STATIC_LIBASAN_LIBS
551 #elif defined(HAVE_LD_STATIC_DYNAMIC)
552 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
553 "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
554 STATIC_LIBASAN_LIBS
555 #else
556 #define LIBASAN_SPEC "-lasan" STATIC_LIBASAN_LIBS
557 #endif
558 #endif
560 #ifndef LIBASAN_EARLY_SPEC
561 #define LIBASAN_EARLY_SPEC ""
562 #endif
564 #ifndef LIBTSAN_SPEC
565 #define STATIC_LIBTSAN_LIBS \
566 " %{static-libtsan:%:include(libsanitizer.spec)%(link_libtsan)}"
567 #ifdef LIBTSAN_EARLY_SPEC
568 #define LIBTSAN_SPEC STATIC_LIBTSAN_LIBS
569 #elif defined(HAVE_LD_STATIC_DYNAMIC)
570 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
571 "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}" \
572 STATIC_LIBTSAN_LIBS
573 #else
574 #define LIBTSAN_SPEC "-ltsan" STATIC_LIBTSAN_LIBS
575 #endif
576 #endif
578 #ifndef LIBTSAN_EARLY_SPEC
579 #define LIBTSAN_EARLY_SPEC ""
580 #endif
582 #ifndef LIBLSAN_SPEC
583 #define STATIC_LIBLSAN_LIBS \
584 " %{static-liblsan:%:include(libsanitizer.spec)%(link_liblsan)}"
585 #ifdef LIBLSAN_EARLY_SPEC
586 #define LIBLSAN_SPEC STATIC_LIBLSAN_LIBS
587 #elif defined(HAVE_LD_STATIC_DYNAMIC)
588 #define LIBLSAN_SPEC "%{static-liblsan:" LD_STATIC_OPTION \
589 "} -llsan %{static-liblsan:" LD_DYNAMIC_OPTION "}" \
590 STATIC_LIBLSAN_LIBS
591 #else
592 #define LIBLSAN_SPEC "-llsan" STATIC_LIBLSAN_LIBS
593 #endif
594 #endif
596 #ifndef LIBLSAN_EARLY_SPEC
597 #define LIBLSAN_EARLY_SPEC ""
598 #endif
600 #ifndef LIBUBSAN_SPEC
601 #define STATIC_LIBUBSAN_LIBS \
602 " %{static-libubsan:%:include(libsanitizer.spec)%(link_libubsan)}"
603 #ifdef HAVE_LD_STATIC_DYNAMIC
604 #define LIBUBSAN_SPEC "%{static-libubsan:" LD_STATIC_OPTION \
605 "} -lubsan %{static-libubsan:" LD_DYNAMIC_OPTION "}" \
606 STATIC_LIBUBSAN_LIBS
607 #else
608 #define LIBUBSAN_SPEC "-lubsan" STATIC_LIBUBSAN_LIBS
609 #endif
610 #endif
612 /* Linker options for compressed debug sections. */
613 #if HAVE_LD_COMPRESS_DEBUG == 0
614 /* No linker support. */
615 #define LINK_COMPRESS_DEBUG_SPEC \
616 " %{gz*:%e-gz is not supported in this configuration} "
617 #elif HAVE_LD_COMPRESS_DEBUG == 1
618 /* GNU style on input, GNU ld options. Reject, not useful. */
619 #define LINK_COMPRESS_DEBUG_SPEC \
620 " %{gz*:%e-gz is not supported in this configuration} "
621 #elif HAVE_LD_COMPRESS_DEBUG == 2
622 /* GNU style, GNU gold options. */
623 #define LINK_COMPRESS_DEBUG_SPEC \
624 " %{gz|gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
625 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
626 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
627 #elif HAVE_LD_COMPRESS_DEBUG == 3
628 /* ELF gABI style. */
629 #define LINK_COMPRESS_DEBUG_SPEC \
630 " %{gz|gz=zlib:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
631 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
632 " %{gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
633 #else
634 #error Unknown value for HAVE_LD_COMPRESS_DEBUG.
635 #endif
637 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
638 included. */
639 #ifndef LIBGCC_SPEC
640 #if defined(REAL_LIBGCC_SPEC)
641 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
642 #elif defined(LINK_LIBGCC_SPECIAL_1)
643 /* Have gcc do the search for libgcc.a. */
644 #define LIBGCC_SPEC "libgcc.a%s"
645 #else
646 #define LIBGCC_SPEC "-lgcc"
647 #endif
648 #endif
650 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
651 #ifndef STARTFILE_SPEC
652 #define STARTFILE_SPEC \
653 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
654 #endif
656 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
657 #ifndef ENDFILE_SPEC
658 #define ENDFILE_SPEC ""
659 #endif
661 #ifndef LINKER_NAME
662 #define LINKER_NAME "collect2"
663 #endif
665 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
666 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
667 #else
668 #define ASM_MAP ""
669 #endif
671 /* Assembler options for compressed debug sections. */
672 #if HAVE_LD_COMPRESS_DEBUG < 2
673 /* Reject if the linker cannot write compressed debug sections. */
674 #define ASM_COMPRESS_DEBUG_SPEC \
675 " %{gz*:%e-gz is not supported in this configuration} "
676 #else /* HAVE_LD_COMPRESS_DEBUG >= 2 */
677 #if HAVE_AS_COMPRESS_DEBUG == 0
678 /* No assembler support. Ignore silently. */
679 #define ASM_COMPRESS_DEBUG_SPEC \
680 " %{gz*:} "
681 #elif HAVE_AS_COMPRESS_DEBUG == 1
682 /* GNU style, GNU as options. */
683 #define ASM_COMPRESS_DEBUG_SPEC \
684 " %{gz|gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "}" \
685 " %{gz=none:" AS_NO_COMPRESS_DEBUG_OPTION "}" \
686 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
687 #elif HAVE_AS_COMPRESS_DEBUG == 2
688 /* ELF gABI style. */
689 #define ASM_COMPRESS_DEBUG_SPEC \
690 " %{gz|gz=zlib:" AS_COMPRESS_DEBUG_OPTION "=zlib}" \
691 " %{gz=none:" AS_COMPRESS_DEBUG_OPTION "=none}" \
692 " %{gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
693 #else
694 #error Unknown value for HAVE_AS_COMPRESS_DEBUG.
695 #endif
696 #endif /* HAVE_LD_COMPRESS_DEBUG >= 2 */
698 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
699 to the assembler. */
700 #ifndef ASM_DEBUG_SPEC
701 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
702 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
703 # define ASM_DEBUG_SPEC \
704 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
705 ? "%{!g0:%{gdwarf*:--gdwarf2}%{!gdwarf*:%{g*:--gstabs}}}" ASM_MAP \
706 : "%{!g0:%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
707 # else
708 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
709 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gstabs}}" ASM_MAP
710 # endif
711 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
712 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gdwarf2}}" ASM_MAP
713 # endif
714 # endif
715 #endif
716 #ifndef ASM_DEBUG_SPEC
717 # define ASM_DEBUG_SPEC ""
718 #endif
720 /* Here is the spec for running the linker, after compiling all files. */
722 /* This is overridable by the target in case they need to specify the
723 -lgcc and -lc order specially, yet not require them to override all
724 of LINK_COMMAND_SPEC. */
725 #ifndef LINK_GCC_C_SEQUENCE_SPEC
726 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
727 #endif
729 #ifndef LINK_SSP_SPEC
730 #ifdef TARGET_LIBC_PROVIDES_SSP
731 #define LINK_SSP_SPEC "%{fstack-protector:}"
732 #else
733 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-strong|fstack-protector-all:-lssp_nonshared -lssp}"
734 #endif
735 #endif
737 #ifndef LINK_PIE_SPEC
738 #ifdef HAVE_LD_PIE
739 #define LINK_PIE_SPEC "%{pie:-pie} "
740 #else
741 #define LINK_PIE_SPEC "%{pie:} "
742 #endif
743 #endif
745 #ifndef LINK_BUILDID_SPEC
746 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
747 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
748 # endif
749 #endif
751 /* Conditional to test whether the LTO plugin is used or not.
752 FIXME: For slim LTO we will need to enable plugin unconditionally. This
753 still cause problems with PLUGIN_LD != LD and when plugin is built but
754 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
755 plugin only when LTO is enabled. We still honor explicit
756 -fuse-linker-plugin if the linker used understands -plugin. */
758 /* The linker has some plugin support. */
759 #if HAVE_LTO_PLUGIN > 0
760 /* The linker used has full plugin support, use LTO plugin by default. */
761 #if HAVE_LTO_PLUGIN == 2
762 #define PLUGIN_COND "!fno-use-linker-plugin:%{!fno-lto"
763 #define PLUGIN_COND_CLOSE "}"
764 #else
765 /* The linker used has limited plugin support, use LTO plugin with explicit
766 -fuse-linker-plugin. */
767 #define PLUGIN_COND "fuse-linker-plugin"
768 #define PLUGIN_COND_CLOSE ""
769 #endif
770 #define LINK_PLUGIN_SPEC \
771 "%{"PLUGIN_COND": \
772 -plugin %(linker_plugin_file) \
773 -plugin-opt=%(lto_wrapper) \
774 -plugin-opt=-fresolution=%u.res \
775 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
776 }"PLUGIN_COND_CLOSE
777 #else
778 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
779 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
780 %e-fuse-linker-plugin is not supported in this configuration}"
781 #endif
783 /* Linker command line options for -fsanitize= early on the command line. */
784 #ifndef SANITIZER_EARLY_SPEC
785 #define SANITIZER_EARLY_SPEC "\
786 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_EARLY_SPEC "} \
787 %{%:sanitize(thread):" LIBTSAN_EARLY_SPEC "} \
788 %{%:sanitize(leak):" LIBLSAN_EARLY_SPEC "}}}"
789 #endif
791 /* Linker command line options for -fsanitize= late on the command line. */
792 #ifndef SANITIZER_SPEC
793 #define SANITIZER_SPEC "\
794 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_SPEC "\
795 %{static:%ecannot specify -static with -fsanitize=address}}\
796 %{%:sanitize(thread):" LIBTSAN_SPEC "\
797 %{static:%ecannot specify -static with -fsanitize=thread}}\
798 %{%:sanitize(undefined):" LIBUBSAN_SPEC "}\
799 %{%:sanitize(leak):" LIBLSAN_SPEC "}}}"
800 #endif
802 /* This is the spec to use, once the code for creating the vtable
803 verification runtime library, libvtv.so, has been created. Currently
804 the vtable verification runtime functions are in libstdc++, so we use
805 the spec just below this one. */
806 #ifndef VTABLE_VERIFICATION_SPEC
807 #define VTABLE_VERIFICATION_SPEC "\
808 %{!nostdlib:%{fvtable-verify=std: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}\
809 %{fvtable-verify=preinit: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}}"
810 #endif
812 /* -u* was put back because both BSD and SysV seem to support it. */
813 /* %{static:} simply prevents an error message if the target machine
814 doesn't handle -static. */
815 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
816 scripts which exist in user specified directories, or in standard
817 directories. */
818 /* We pass any -flto flags on to the linker, which is expected
819 to understand them. In practice, this means it had better be collect2. */
820 /* %{e*} includes -export-dynamic; see comment in common.opt. */
821 #ifndef LINK_COMMAND_SPEC
822 #define LINK_COMMAND_SPEC "\
823 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
824 %(linker) " \
825 LINK_PLUGIN_SPEC \
826 "%{flto|flto=*:%<fcompare-debug*} \
827 %{flto} %{fno-lto} %{flto=*} %l " LINK_PIE_SPEC \
828 "%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
829 "%X %{o*} %{e*} %{N} %{n} %{r}\
830 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}} " VTABLE_VERIFICATION_SPEC " \
831 %{!nostdlib:%{!nostartfiles:%{fupc:%:include(upc-crtbegin.spec)%(upc_crtbegin)}}}\
832 %{static:} %{L*} %(mfwrap) %(link_libgcc) " SANITIZER_EARLY_SPEC " %o\
833 %{fopenmp|ftree-parallelize-loops=*:%:include(libgomp.spec)%(link_gomp)}\
834 %{fcilkplus:%:include(libcilkrts.spec)%(link_cilkrts)}\
835 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
836 %{fupc:%:include(libgupc.spec)%(link_upc)}\
837 %(mflib) " STACK_SPLIT_SPEC "\
838 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
839 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
840 %{!nostdlib:%{!nostartfiles:%{fupc:%:include(upc-crtend.spec)%(upc_crtend)}}}\
841 %{!nostdlib:%{!nostartfiles:%E}} %{T*} }}}}}}"
842 #endif
844 #ifndef LINK_LIBGCC_SPEC
845 /* Generate -L options for startfile prefix list. */
846 # define LINK_LIBGCC_SPEC "%D"
847 #endif
849 #ifndef STARTFILE_PREFIX_SPEC
850 # define STARTFILE_PREFIX_SPEC ""
851 #endif
853 #ifndef SYSROOT_SPEC
854 # define SYSROOT_SPEC "--sysroot=%R"
855 #endif
857 #ifndef SYSROOT_SUFFIX_SPEC
858 # define SYSROOT_SUFFIX_SPEC ""
859 #endif
861 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
862 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
863 #endif
865 static const char *asm_debug = ASM_DEBUG_SPEC;
866 static const char *cpp_spec = CPP_SPEC;
867 static const char *cc1_spec = CC1_SPEC;
868 static const char *cc1plus_spec = CC1PLUS_SPEC;
869 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
870 static const char *link_ssp_spec = LINK_SSP_SPEC;
871 static const char *asm_spec = ASM_SPEC;
872 static const char *asm_final_spec = ASM_FINAL_SPEC;
873 static const char *link_spec = LINK_SPEC;
874 static const char *lib_spec = LIB_SPEC;
875 static const char *link_gomp_spec = "";
876 static const char *upc_crtbegin_spec = "";
877 static const char *link_upc_spec = "";
878 static const char *upc_crtend_spec = "";
879 static const char *libgcc_spec = LIBGCC_SPEC;
880 static const char *endfile_spec = ENDFILE_SPEC;
881 static const char *startfile_spec = STARTFILE_SPEC;
882 static const char *linker_name_spec = LINKER_NAME;
883 static const char *linker_plugin_file_spec = "";
884 static const char *lto_wrapper_spec = "";
885 static const char *lto_gcc_spec = "";
886 static const char *link_command_spec = LINK_COMMAND_SPEC;
887 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
888 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
889 static const char *sysroot_spec = SYSROOT_SPEC;
890 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
891 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
892 static const char *self_spec = "";
894 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
895 There should be no need to override these in target dependent files,
896 but we need to copy them to the specs file so that newer versions
897 of the GCC driver can correctly drive older tool chains with the
898 appropriate -B options. */
900 /* When cpplib handles traditional preprocessing, get rid of this, and
901 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
902 that we default the front end language better. */
903 static const char *trad_capable_cpp =
904 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
906 /* We don't wrap .d files in %W{} since a missing .d file, and
907 therefore no dependency entry, confuses make into thinking a .o
908 file that happens to exist is up-to-date. */
909 static const char *cpp_unique_options =
910 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
911 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
912 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
913 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
914 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
915 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
916 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
917 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
918 %{E|M|MM:%W{o*}}";
920 /* This contains cpp options which are common with cc1_options and are passed
921 only when preprocessing only to avoid duplication. We pass the cc1 spec
922 options to the preprocessor so that it the cc1 spec may manipulate
923 options used to set target flags. Those special target flags settings may
924 in turn cause preprocessor symbols to be defined specially. */
925 static const char *cpp_options =
926 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
927 %{f*} %{g*:%{!g0:%{g*} %{!fno-working-directory:-fworking-directory}}} %{O*}\
928 %{undef} %{save-temps*:-fpch-preprocess}";
930 /* This contains cpp options which are not passed when the preprocessor
931 output will be used by another program. */
932 static const char *cpp_debug_options = "%{d*}";
934 /* NB: This is shared amongst all front-ends, except for Ada. */
935 static const char *cc1_options =
936 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
937 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
938 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
939 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
940 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
941 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
942 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
943 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
944 %{-target-help:--target-help}\
945 %{-version:--version}\
946 %{-help=*:--help=%*}\
947 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
948 %{fsyntax-only:-o %j} %{-param*}\
949 %{coverage:-fprofile-arcs -ftest-coverage}";
951 static const char *upc_options =
952 "-fupc %{!fno-upc-pre-include:-include gcc-upc.h}";
954 static const char *asm_options =
955 "%{-target-help:%:print-asm-header()} "
956 #if HAVE_GNU_AS
957 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
958 to the assembler equivalents. */
959 "%{v} %{w:-W} %{I*} "
960 #endif
961 ASM_COMPRESS_DEBUG_SPEC
962 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
964 static const char *invoke_as =
965 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
966 "%{!fwpa*:\
967 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
968 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
970 #else
971 "%{!fwpa*:\
972 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
973 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
975 #endif
977 /* Some compilers have limits on line lengths, and the multilib_select
978 and/or multilib_matches strings can be very long, so we build them at
979 run time. */
980 static struct obstack multilib_obstack;
981 static const char *multilib_select;
982 static const char *multilib_matches;
983 static const char *multilib_defaults;
984 static const char *multilib_exclusions;
985 static const char *multilib_reuse;
987 /* Check whether a particular argument is a default argument. */
989 #ifndef MULTILIB_DEFAULTS
990 #define MULTILIB_DEFAULTS { "" }
991 #endif
993 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
995 #ifndef DRIVER_SELF_SPECS
996 #define DRIVER_SELF_SPECS ""
997 #endif
999 /* Linking to libgomp implies pthreads. This is particularly important
1000 for targets that use different start files and suchlike. */
1001 #ifndef GOMP_SELF_SPECS
1002 #define GOMP_SELF_SPECS "%{fopenmp|ftree-parallelize-loops=*: -pthread}"
1003 #endif
1005 /* Likewise for -fgnu-tm. */
1006 #ifndef GTM_SELF_SPECS
1007 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
1008 #endif
1010 /* Likewise for -fcilkplus. */
1011 #ifndef CILK_SELF_SPECS
1012 #define CILK_SELF_SPECS "%{fcilkplus: -pthread}"
1013 #endif
1015 static const char *const driver_self_specs[] = {
1016 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
1017 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS,
1018 CILK_SELF_SPECS
1021 #ifndef OPTION_DEFAULT_SPECS
1022 #define OPTION_DEFAULT_SPECS { "", "" }
1023 #endif
1025 struct default_spec
1027 const char *name;
1028 const char *spec;
1031 static const struct default_spec
1032 option_default_specs[] = { OPTION_DEFAULT_SPECS };
1034 struct user_specs
1036 struct user_specs *next;
1037 const char *filename;
1040 static struct user_specs *user_specs_head, *user_specs_tail;
1043 /* Record the mapping from file suffixes for compilation specs. */
1045 struct compiler
1047 const char *suffix; /* Use this compiler for input files
1048 whose names end in this suffix. */
1050 const char *spec; /* To use this compiler, run this spec. */
1052 const char *cpp_spec; /* If non-NULL, substitute this spec
1053 for `%C', rather than the usual
1054 cpp_spec. */
1055 const int combinable; /* If nonzero, compiler can deal with
1056 multiple source files at once (IMA). */
1057 const int needs_preprocessing; /* If nonzero, source files need to
1058 be run through a preprocessor. */
1061 /* Pointer to a vector of `struct compiler' that gives the spec for
1062 compiling a file, based on its suffix.
1063 A file that does not end in any of these suffixes will be passed
1064 unchanged to the loader and nothing else will be done to it.
1066 An entry containing two 0s is used to terminate the vector.
1068 If multiple entries match a file, the last matching one is used. */
1070 static struct compiler *compilers;
1072 /* Number of entries in `compilers', not counting the null terminator. */
1074 static int n_compilers;
1076 /* The default list of file name suffixes and their compilation specs. */
1078 static const struct compiler default_compilers[] =
1080 /* Add lists of suffixes of known languages here. If those languages
1081 were not present when we built the driver, we will hit these copies
1082 and be given a more meaningful error than "file not used since
1083 linking is not done". */
1084 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
1085 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
1086 {".mii", "#Objective-C++", 0, 0, 0},
1087 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
1088 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
1089 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
1090 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
1091 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
1092 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
1093 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
1094 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
1095 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
1096 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
1097 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
1098 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1099 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1100 {".r", "#Ratfor", 0, 0, 0},
1101 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
1102 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
1103 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
1104 {".go", "#Go", 0, 1, 0},
1105 /* Next come the entries for C. */
1106 {".c", "@c", 0, 0, 1},
1107 {"@c",
1108 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1109 external preprocessor if -save-temps is given. */
1110 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1111 %{!E:%{!M:%{!MM:\
1112 %{traditional:\
1113 %eGNU C no longer supports -traditional without -E}\
1114 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1115 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1116 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1117 %(cc1_options)}\
1118 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1119 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1120 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1121 {"-",
1122 "%{!E:%e-E or -x required when input is from standard input}\
1123 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1124 {".h", "@c-header", 0, 0, 0},
1125 {"@c-header",
1126 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1127 external preprocessor if -save-temps is given. */
1128 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1129 %{!E:%{!M:%{!MM:\
1130 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1131 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1132 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1133 %(cc1_options)\
1134 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1135 %W{o*:--output-pch=%*}}%V}\
1136 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1137 cc1 %(cpp_unique_options) %(cc1_options)\
1138 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1139 %W{o*:--output-pch=%*}}%V}}}}}}", 0, 0, 0},
1140 {".i", "@cpp-output", 0, 0, 0},
1141 {"@cpp-output",
1142 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1143 {".s", "@assembler", 0, 0, 0},
1144 {"@assembler",
1145 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1146 {".sx", "@assembler-with-cpp", 0, 0, 0},
1147 {".S", "@assembler-with-cpp", 0, 0, 0},
1148 {"@assembler-with-cpp",
1149 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1150 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1151 %{E|M|MM:%(cpp_debug_options)}\
1152 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1153 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1154 #else
1155 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1156 %{E|M|MM:%(cpp_debug_options)}\
1157 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1158 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1159 #endif
1160 , 0, 0, 0},
1161 {".upc", "@upc", 0, 0, 0},
1162 {"@upc",
1163 /* Same as "@c" above, with the addition of %(upc_options). */
1164 "%{E|M|MM:cc1 -E %(upc_options) %(cpp_options) %(cpp_debug_options)}\
1165 %{!E:%{!M:%{!MM:\
1166 %{traditional|ftraditional|traditional-cpp:\
1167 %e UPC does not support traditional compilation}\
1168 %{save-temps|no-integrated-cpp:\
1169 cc1 -E %(upc_options) %(cpp_options)\
1170 %{save-temps:%b.mi} %{!save-temps:%g.mi} \n\
1171 cc1 -fpreprocessed %{save-temps:%b.mi} %{!save-temps:%g.mi}\
1172 %(upc_options) %(cc1_options)}\
1173 %{!save-temps:%{!no-integrated-cpp:\
1174 cc1 %(cpp_unique_options) %(upc_options) %(cc1_options)}}\
1175 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1177 #include "specs.h"
1178 /* Mark end of table. */
1179 {0, 0, 0, 0, 0}
1182 /* Number of elements in default_compilers, not counting the terminator. */
1184 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1186 typedef char *char_p; /* For DEF_VEC_P. */
1188 /* A vector of options to give to the linker.
1189 These options are accumulated by %x,
1190 and substituted into the linker command with %X. */
1191 static vec<char_p> linker_options;
1193 /* A vector of options to give to the assembler.
1194 These options are accumulated by -Wa,
1195 and substituted into the assembler command with %Y. */
1196 static vec<char_p> assembler_options;
1198 /* A vector of options to give to the preprocessor.
1199 These options are accumulated by -Wp,
1200 and substituted into the preprocessor command with %Z. */
1201 static vec<char_p> preprocessor_options;
1203 static char *
1204 skip_whitespace (char *p)
1206 while (1)
1208 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1209 be considered whitespace. */
1210 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1211 return p + 1;
1212 else if (*p == '\n' || *p == ' ' || *p == '\t')
1213 p++;
1214 else if (*p == '#')
1216 while (*p != '\n')
1217 p++;
1218 p++;
1220 else
1221 break;
1224 return p;
1226 /* Structures to keep track of prefixes to try when looking for files. */
1228 struct prefix_list
1230 const char *prefix; /* String to prepend to the path. */
1231 struct prefix_list *next; /* Next in linked list. */
1232 int require_machine_suffix; /* Don't use without machine_suffix. */
1233 /* 2 means try both machine_suffix and just_machine_suffix. */
1234 int priority; /* Sort key - priority within list. */
1235 int os_multilib; /* 1 if OS multilib scheme should be used,
1236 0 for GCC multilib scheme. */
1239 struct path_prefix
1241 struct prefix_list *plist; /* List of prefixes to try */
1242 int max_len; /* Max length of a prefix in PLIST */
1243 const char *name; /* Name of this list (used in config stuff) */
1246 /* List of prefixes to try when looking for executables. */
1248 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1250 /* List of prefixes to try when looking for startup (crt0) files. */
1252 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1254 /* List of prefixes to try when looking for include files. */
1256 static struct path_prefix include_prefixes = { 0, 0, "include" };
1258 /* Suffix to attach to directories searched for commands.
1259 This looks like `MACHINE/VERSION/'. */
1261 static const char *machine_suffix = 0;
1263 /* Suffix to attach to directories searched for commands.
1264 This is just `MACHINE/'. */
1266 static const char *just_machine_suffix = 0;
1268 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1270 static const char *gcc_exec_prefix;
1272 /* Adjusted value of standard_libexec_prefix. */
1274 static const char *gcc_libexec_prefix;
1276 /* Default prefixes to attach to command names. */
1278 #ifndef STANDARD_STARTFILE_PREFIX_1
1279 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1280 #endif
1281 #ifndef STANDARD_STARTFILE_PREFIX_2
1282 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1283 #endif
1285 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1286 #undef MD_EXEC_PREFIX
1287 #undef MD_STARTFILE_PREFIX
1288 #undef MD_STARTFILE_PREFIX_1
1289 #endif
1291 /* If no prefixes defined, use the null string, which will disable them. */
1292 #ifndef MD_EXEC_PREFIX
1293 #define MD_EXEC_PREFIX ""
1294 #endif
1295 #ifndef MD_STARTFILE_PREFIX
1296 #define MD_STARTFILE_PREFIX ""
1297 #endif
1298 #ifndef MD_STARTFILE_PREFIX_1
1299 #define MD_STARTFILE_PREFIX_1 ""
1300 #endif
1302 /* These directories are locations set at configure-time based on the
1303 --prefix option provided to configure. Their initializers are
1304 defined in Makefile.in. These paths are not *directly* used when
1305 gcc_exec_prefix is set because, in that case, we know where the
1306 compiler has been installed, and use paths relative to that
1307 location instead. */
1308 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1309 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1310 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1311 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1313 /* For native compilers, these are well-known paths containing
1314 components that may be provided by the system. For cross
1315 compilers, these paths are not used. */
1316 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1317 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1318 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1319 static const char *const standard_startfile_prefix_1
1320 = STANDARD_STARTFILE_PREFIX_1;
1321 static const char *const standard_startfile_prefix_2
1322 = STANDARD_STARTFILE_PREFIX_2;
1324 /* A relative path to be used in finding the location of tools
1325 relative to the driver. */
1326 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1328 /* A prefix to be used when this is an accelerator compiler. */
1329 static const char *const accel_dir_suffix = ACCEL_DIR_SUFFIX;
1331 /* Subdirectory to use for locating libraries. Set by
1332 set_multilib_dir based on the compilation options. */
1334 static const char *multilib_dir;
1336 /* Subdirectory to use for locating libraries in OS conventions. Set by
1337 set_multilib_dir based on the compilation options. */
1339 static const char *multilib_os_dir;
1341 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1342 set_multilib_dir based on the compilation options. */
1344 static const char *multiarch_dir;
1346 /* Structure to keep track of the specs that have been defined so far.
1347 These are accessed using %(specname) in a compiler or link
1348 spec. */
1350 struct spec_list
1352 /* The following 2 fields must be first */
1353 /* to allow EXTRA_SPECS to be initialized */
1354 const char *name; /* name of the spec. */
1355 const char *ptr; /* available ptr if no static pointer */
1357 /* The following fields are not initialized */
1358 /* by EXTRA_SPECS */
1359 const char **ptr_spec; /* pointer to the spec itself. */
1360 struct spec_list *next; /* Next spec in linked list. */
1361 int name_len; /* length of the name */
1362 bool user_p; /* whether string come from file spec. */
1363 bool alloc_p; /* whether string was allocated */
1366 #define INIT_STATIC_SPEC(NAME,PTR) \
1367 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false }
1369 /* List of statically defined specs. */
1370 static struct spec_list static_specs[] =
1372 INIT_STATIC_SPEC ("asm", &asm_spec),
1373 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1374 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1375 INIT_STATIC_SPEC ("asm_options", &asm_options),
1376 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1377 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1378 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1379 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1380 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1381 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1382 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1383 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1384 INIT_STATIC_SPEC ("upc_options", &upc_options),
1385 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1386 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1387 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1388 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1389 INIT_STATIC_SPEC ("link", &link_spec),
1390 INIT_STATIC_SPEC ("lib", &lib_spec),
1391 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1392 INIT_STATIC_SPEC ("upc_crtbegin", &upc_crtbegin_spec),
1393 INIT_STATIC_SPEC ("link_upc", &link_upc_spec),
1394 INIT_STATIC_SPEC ("upc_crtend", &upc_crtend_spec),
1395 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1396 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1397 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1398 INIT_STATIC_SPEC ("version", &compiler_version),
1399 INIT_STATIC_SPEC ("multilib", &multilib_select),
1400 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1401 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1402 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1403 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1404 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1405 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1406 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1407 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1408 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1409 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1410 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1411 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1412 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1413 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1414 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1415 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1416 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1417 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1418 INIT_STATIC_SPEC ("self_spec", &self_spec),
1421 #ifdef EXTRA_SPECS /* additional specs needed */
1422 /* Structure to keep track of just the first two args of a spec_list.
1423 That is all that the EXTRA_SPECS macro gives us. */
1424 struct spec_list_1
1426 const char *const name;
1427 const char *const ptr;
1430 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1431 static struct spec_list *extra_specs = (struct spec_list *) 0;
1432 #endif
1434 /* List of dynamically allocates specs that have been defined so far. */
1436 static struct spec_list *specs = (struct spec_list *) 0;
1438 /* List of static spec functions. */
1440 static const struct spec_function static_spec_functions[] =
1442 { "getenv", getenv_spec_function },
1443 { "if-exists", if_exists_spec_function },
1444 { "if-exists-else", if_exists_else_spec_function },
1445 { "sanitize", sanitize_spec_function },
1446 { "replace-outfile", replace_outfile_spec_function },
1447 { "remove-outfile", remove_outfile_spec_function },
1448 { "version-compare", version_compare_spec_function },
1449 { "include", include_spec_function },
1450 { "find-file", find_file_spec_function },
1451 { "find-plugindir", find_plugindir_spec_function },
1452 { "print-asm-header", print_asm_header_spec_function },
1453 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1454 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1455 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1456 { "pass-through-libs", pass_through_libs_spec_func },
1457 { "replace-extension", replace_extension_spec_func },
1458 #ifdef EXTRA_SPEC_FUNCTIONS
1459 EXTRA_SPEC_FUNCTIONS
1460 #endif
1461 { 0, 0 }
1464 static int processing_spec_function;
1466 /* Add appropriate libgcc specs to OBSTACK, taking into account
1467 various permutations of -shared-libgcc, -shared, and such. */
1469 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1471 #ifndef USE_LD_AS_NEEDED
1472 #define USE_LD_AS_NEEDED 0
1473 #endif
1475 static void
1476 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1477 const char *static_name, const char *eh_name)
1479 char *buf;
1481 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1482 "%{!static:%{!static-libgcc:"
1483 #if USE_LD_AS_NEEDED
1484 "%{!shared-libgcc:",
1485 static_name, " " LD_AS_NEEDED_OPTION " ",
1486 shared_name, " " LD_NO_AS_NEEDED_OPTION
1488 "%{shared-libgcc:",
1489 shared_name, "%{!shared: ", static_name, "}"
1491 #else
1492 "%{!shared:"
1493 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1494 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1496 #ifdef LINK_EH_SPEC
1497 "%{shared:"
1498 "%{shared-libgcc:", shared_name, "}"
1499 "%{!shared-libgcc:", static_name, "}"
1501 #else
1502 "%{shared:", shared_name, "}"
1503 #endif
1504 #endif
1505 "}}", NULL);
1507 obstack_grow (obstack, buf, strlen (buf));
1508 free (buf);
1510 #endif /* ENABLE_SHARED_LIBGCC */
1512 /* Initialize the specs lookup routines. */
1514 static void
1515 init_spec (void)
1517 struct spec_list *next = (struct spec_list *) 0;
1518 struct spec_list *sl = (struct spec_list *) 0;
1519 int i;
1521 if (specs)
1522 return; /* Already initialized. */
1524 if (verbose_flag)
1525 fnotice (stderr, "Using built-in specs.\n");
1527 #ifdef EXTRA_SPECS
1528 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1530 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1532 sl = &extra_specs[i];
1533 sl->name = extra_specs_1[i].name;
1534 sl->ptr = extra_specs_1[i].ptr;
1535 sl->next = next;
1536 sl->name_len = strlen (sl->name);
1537 sl->ptr_spec = &sl->ptr;
1538 next = sl;
1540 #endif
1542 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1544 sl = &static_specs[i];
1545 sl->next = next;
1546 next = sl;
1549 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1550 /* ??? If neither -shared-libgcc nor --static-libgcc was
1551 seen, then we should be making an educated guess. Some proposed
1552 heuristics for ELF include:
1554 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1555 program will be doing dynamic loading, which will likely
1556 need the shared libgcc.
1558 (2) If "-ldl", then it's also a fair bet that we're doing
1559 dynamic loading.
1561 (3) For each ET_DYN we're linking against (either through -lfoo
1562 or /some/path/foo.so), check to see whether it or one of
1563 its dependencies depends on a shared libgcc.
1565 (4) If "-shared"
1567 If the runtime is fixed to look for program headers instead
1568 of calling __register_frame_info at all, for each object,
1569 use the shared libgcc if any EH symbol referenced.
1571 If crtstuff is fixed to not invoke __register_frame_info
1572 automatically, for each object, use the shared libgcc if
1573 any non-empty unwind section found.
1575 Doing any of this probably requires invoking an external program to
1576 do the actual object file scanning. */
1578 const char *p = libgcc_spec;
1579 int in_sep = 1;
1581 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1582 when given the proper command line arguments. */
1583 while (*p)
1585 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1587 init_gcc_specs (&obstack,
1588 "-lgcc_s"
1589 #ifdef USE_LIBUNWIND_EXCEPTIONS
1590 " -lunwind"
1591 #endif
1593 "-lgcc",
1594 "-lgcc_eh"
1595 #ifdef USE_LIBUNWIND_EXCEPTIONS
1596 # ifdef HAVE_LD_STATIC_DYNAMIC
1597 " %{!static:" LD_STATIC_OPTION "} -lunwind"
1598 " %{!static:" LD_DYNAMIC_OPTION "}"
1599 # else
1600 " -lunwind"
1601 # endif
1602 #endif
1605 p += 5;
1606 in_sep = 0;
1608 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1610 /* Ug. We don't know shared library extensions. Hope that
1611 systems that use this form don't do shared libraries. */
1612 init_gcc_specs (&obstack,
1613 "-lgcc_s",
1614 "libgcc.a%s",
1615 "libgcc_eh.a%s"
1616 #ifdef USE_LIBUNWIND_EXCEPTIONS
1617 " -lunwind"
1618 #endif
1620 p += 10;
1621 in_sep = 0;
1623 else
1625 obstack_1grow (&obstack, *p);
1626 in_sep = (*p == ' ');
1627 p += 1;
1631 obstack_1grow (&obstack, '\0');
1632 libgcc_spec = XOBFINISH (&obstack, const char *);
1634 #endif
1635 #ifdef USE_AS_TRADITIONAL_FORMAT
1636 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1638 static const char tf[] = "--traditional-format ";
1639 obstack_grow (&obstack, tf, sizeof (tf) - 1);
1640 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1641 asm_spec = XOBFINISH (&obstack, const char *);
1643 #endif
1645 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1646 defined LINKER_HASH_STYLE
1647 # ifdef LINK_BUILDID_SPEC
1648 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1649 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof (LINK_BUILDID_SPEC) - 1);
1650 # endif
1651 # ifdef LINK_EH_SPEC
1652 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1653 obstack_grow (&obstack, LINK_EH_SPEC, sizeof (LINK_EH_SPEC) - 1);
1654 # endif
1655 # ifdef LINKER_HASH_STYLE
1656 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1657 before. */
1659 static const char hash_style[] = "--hash-style=";
1660 obstack_grow (&obstack, hash_style, sizeof (hash_style) - 1);
1661 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof (LINKER_HASH_STYLE) - 1);
1662 obstack_1grow (&obstack, ' ');
1664 # endif
1665 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1666 link_spec = XOBFINISH (&obstack, const char *);
1667 #endif
1669 specs = sl;
1672 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1673 removed; If the spec starts with a + then SPEC is added to the end of the
1674 current spec. */
1676 static void
1677 set_spec (const char *name, const char *spec, bool user_p)
1679 struct spec_list *sl;
1680 const char *old_spec;
1681 int name_len = strlen (name);
1682 int i;
1684 /* If this is the first call, initialize the statically allocated specs. */
1685 if (!specs)
1687 struct spec_list *next = (struct spec_list *) 0;
1688 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1690 sl = &static_specs[i];
1691 sl->next = next;
1692 next = sl;
1694 specs = sl;
1697 /* See if the spec already exists. */
1698 for (sl = specs; sl; sl = sl->next)
1699 if (name_len == sl->name_len && !strcmp (sl->name, name))
1700 break;
1702 if (!sl)
1704 /* Not found - make it. */
1705 sl = XNEW (struct spec_list);
1706 sl->name = xstrdup (name);
1707 sl->name_len = name_len;
1708 sl->ptr_spec = &sl->ptr;
1709 sl->alloc_p = 0;
1710 *(sl->ptr_spec) = "";
1711 sl->next = specs;
1712 specs = sl;
1715 old_spec = *(sl->ptr_spec);
1716 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1717 ? concat (old_spec, spec + 1, NULL)
1718 : xstrdup (spec));
1720 #ifdef DEBUG_SPECS
1721 if (verbose_flag)
1722 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1723 #endif
1725 /* Free the old spec. */
1726 if (old_spec && sl->alloc_p)
1727 free (CONST_CAST (char *, old_spec));
1729 sl->user_p = user_p;
1730 sl->alloc_p = true;
1733 /* Accumulate a command (program name and args), and run it. */
1735 typedef const char *const_char_p; /* For DEF_VEC_P. */
1737 /* Vector of pointers to arguments in the current line of specifications. */
1739 static vec<const_char_p> argbuf;
1741 /* Were the options -c, -S or -E passed. */
1742 static int have_c = 0;
1744 /* Was the option -o passed. */
1745 static int have_o = 0;
1747 /* Pointer to output file name passed in with -o. */
1748 static const char *output_file = 0;
1750 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1751 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1752 it here. */
1754 static struct temp_name {
1755 const char *suffix; /* suffix associated with the code. */
1756 int length; /* strlen (suffix). */
1757 int unique; /* Indicates whether %g or %u/%U was used. */
1758 const char *filename; /* associated filename. */
1759 int filename_length; /* strlen (filename). */
1760 struct temp_name *next;
1761 } *temp_names;
1763 /* Number of commands executed so far. */
1765 static int execution_count;
1767 /* Number of commands that exited with a signal. */
1769 static int signal_count;
1771 /* Allocate the argument vector. */
1773 static void
1774 alloc_args (void)
1776 argbuf.create (10);
1779 /* Clear out the vector of arguments (after a command is executed). */
1781 static void
1782 clear_args (void)
1784 argbuf.truncate (0);
1787 /* Add one argument to the vector at the end.
1788 This is done when a space is seen or at the end of the line.
1789 If DELETE_ALWAYS is nonzero, the arg is a filename
1790 and the file should be deleted eventually.
1791 If DELETE_FAILURE is nonzero, the arg is a filename
1792 and the file should be deleted if this compilation fails. */
1794 static void
1795 store_arg (const char *arg, int delete_always, int delete_failure)
1797 argbuf.safe_push (arg);
1799 if (delete_always || delete_failure)
1801 const char *p;
1802 /* If the temporary file we should delete is specified as
1803 part of a joined argument extract the filename. */
1804 if (arg[0] == '-'
1805 && (p = strrchr (arg, '=')))
1806 arg = p + 1;
1807 record_temp_file (arg, delete_always, delete_failure);
1811 /* Load specs from a file name named FILENAME, replacing occurrences of
1812 various different types of line-endings, \r\n, \n\r and just \r, with
1813 a single \n. */
1815 static char *
1816 load_specs (const char *filename)
1818 int desc;
1819 int readlen;
1820 struct stat statbuf;
1821 char *buffer;
1822 char *buffer_p;
1823 char *specs;
1824 char *specs_p;
1826 if (verbose_flag)
1827 fnotice (stderr, "Reading specs from %s\n", filename);
1829 /* Open and stat the file. */
1830 desc = open (filename, O_RDONLY, 0);
1831 if (desc < 0)
1832 pfatal_with_name (filename);
1833 if (stat (filename, &statbuf) < 0)
1834 pfatal_with_name (filename);
1836 /* Read contents of file into BUFFER. */
1837 buffer = XNEWVEC (char, statbuf.st_size + 1);
1838 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1839 if (readlen < 0)
1840 pfatal_with_name (filename);
1841 buffer[readlen] = 0;
1842 close (desc);
1844 specs = XNEWVEC (char, readlen + 1);
1845 specs_p = specs;
1846 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1848 int skip = 0;
1849 char c = *buffer_p;
1850 if (c == '\r')
1852 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1853 skip = 1;
1854 else if (*(buffer_p + 1) == '\n') /* \r\n */
1855 skip = 1;
1856 else /* \r */
1857 c = '\n';
1859 if (! skip)
1860 *specs_p++ = c;
1862 *specs_p = '\0';
1864 free (buffer);
1865 return (specs);
1868 /* Read compilation specs from a file named FILENAME,
1869 replacing the default ones.
1871 A suffix which starts with `*' is a definition for
1872 one of the machine-specific sub-specs. The "suffix" should be
1873 *asm, *cc1, *cpp, *link, *startfile, etc.
1874 The corresponding spec is stored in asm_spec, etc.,
1875 rather than in the `compilers' vector.
1877 Anything invalid in the file is a fatal error. */
1879 static void
1880 read_specs (const char *filename, bool main_p, bool user_p)
1882 char *buffer;
1883 char *p;
1885 buffer = load_specs (filename);
1887 /* Scan BUFFER for specs, putting them in the vector. */
1888 p = buffer;
1889 while (1)
1891 char *suffix;
1892 char *spec;
1893 char *in, *out, *p1, *p2, *p3;
1895 /* Advance P in BUFFER to the next nonblank nocomment line. */
1896 p = skip_whitespace (p);
1897 if (*p == 0)
1898 break;
1900 /* Is this a special command that starts with '%'? */
1901 /* Don't allow this for the main specs file, since it would
1902 encourage people to overwrite it. */
1903 if (*p == '%' && !main_p)
1905 p1 = p;
1906 while (*p && *p != '\n')
1907 p++;
1909 /* Skip '\n'. */
1910 p++;
1912 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1913 && (p1[sizeof "%include" - 1] == ' '
1914 || p1[sizeof "%include" - 1] == '\t'))
1916 char *new_filename;
1918 p1 += sizeof ("%include");
1919 while (*p1 == ' ' || *p1 == '\t')
1920 p1++;
1922 if (*p1++ != '<' || p[-2] != '>')
1923 fatal_error ("specs %%include syntax malformed after "
1924 "%ld characters",
1925 (long) (p1 - buffer + 1));
1927 p[-2] = '\0';
1928 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1929 read_specs (new_filename ? new_filename : p1, false, user_p);
1930 continue;
1932 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1933 && (p1[sizeof "%include_noerr" - 1] == ' '
1934 || p1[sizeof "%include_noerr" - 1] == '\t'))
1936 char *new_filename;
1938 p1 += sizeof "%include_noerr";
1939 while (*p1 == ' ' || *p1 == '\t')
1940 p1++;
1942 if (*p1++ != '<' || p[-2] != '>')
1943 fatal_error ("specs %%include syntax malformed after "
1944 "%ld characters",
1945 (long) (p1 - buffer + 1));
1947 p[-2] = '\0';
1948 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1949 if (new_filename)
1950 read_specs (new_filename, false, user_p);
1951 else if (verbose_flag)
1952 fnotice (stderr, "could not find specs file %s\n", p1);
1953 continue;
1955 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1956 && (p1[sizeof "%rename" - 1] == ' '
1957 || p1[sizeof "%rename" - 1] == '\t'))
1959 int name_len;
1960 struct spec_list *sl;
1961 struct spec_list *newsl;
1963 /* Get original name. */
1964 p1 += sizeof "%rename";
1965 while (*p1 == ' ' || *p1 == '\t')
1966 p1++;
1968 if (! ISALPHA ((unsigned char) *p1))
1969 fatal_error ("specs %%rename syntax malformed after "
1970 "%ld characters",
1971 (long) (p1 - buffer));
1973 p2 = p1;
1974 while (*p2 && !ISSPACE ((unsigned char) *p2))
1975 p2++;
1977 if (*p2 != ' ' && *p2 != '\t')
1978 fatal_error ("specs %%rename syntax malformed after "
1979 "%ld characters",
1980 (long) (p2 - buffer));
1982 name_len = p2 - p1;
1983 *p2++ = '\0';
1984 while (*p2 == ' ' || *p2 == '\t')
1985 p2++;
1987 if (! ISALPHA ((unsigned char) *p2))
1988 fatal_error ("specs %%rename syntax malformed after "
1989 "%ld characters",
1990 (long) (p2 - buffer));
1992 /* Get new spec name. */
1993 p3 = p2;
1994 while (*p3 && !ISSPACE ((unsigned char) *p3))
1995 p3++;
1997 if (p3 != p - 1)
1998 fatal_error ("specs %%rename syntax malformed after "
1999 "%ld characters",
2000 (long) (p3 - buffer));
2001 *p3 = '\0';
2003 for (sl = specs; sl; sl = sl->next)
2004 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2005 break;
2007 if (!sl)
2008 fatal_error ("specs %s spec was not found to be renamed", p1);
2010 if (strcmp (p1, p2) == 0)
2011 continue;
2013 for (newsl = specs; newsl; newsl = newsl->next)
2014 if (strcmp (newsl->name, p2) == 0)
2015 fatal_error ("%s: attempt to rename spec %qs to "
2016 "already defined spec %qs",
2017 filename, p1, p2);
2019 if (verbose_flag)
2021 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
2022 #ifdef DEBUG_SPECS
2023 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
2024 #endif
2027 set_spec (p2, *(sl->ptr_spec), user_p);
2028 if (sl->alloc_p)
2029 free (CONST_CAST (char *, *(sl->ptr_spec)));
2031 *(sl->ptr_spec) = "";
2032 sl->alloc_p = 0;
2033 continue;
2035 else
2036 fatal_error ("specs unknown %% command after %ld characters",
2037 (long) (p1 - buffer));
2040 /* Find the colon that should end the suffix. */
2041 p1 = p;
2042 while (*p1 && *p1 != ':' && *p1 != '\n')
2043 p1++;
2045 /* The colon shouldn't be missing. */
2046 if (*p1 != ':')
2047 fatal_error ("specs file malformed after %ld characters",
2048 (long) (p1 - buffer));
2050 /* Skip back over trailing whitespace. */
2051 p2 = p1;
2052 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2053 p2--;
2055 /* Copy the suffix to a string. */
2056 suffix = save_string (p, p2 - p);
2057 /* Find the next line. */
2058 p = skip_whitespace (p1 + 1);
2059 if (p[1] == 0)
2060 fatal_error ("specs file malformed after %ld characters",
2061 (long) (p - buffer));
2063 p1 = p;
2064 /* Find next blank line or end of string. */
2065 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2066 p1++;
2068 /* Specs end at the blank line and do not include the newline. */
2069 spec = save_string (p, p1 - p);
2070 p = p1;
2072 /* Delete backslash-newline sequences from the spec. */
2073 in = spec;
2074 out = spec;
2075 while (*in != 0)
2077 if (in[0] == '\\' && in[1] == '\n')
2078 in += 2;
2079 else if (in[0] == '#')
2080 while (*in && *in != '\n')
2081 in++;
2083 else
2084 *out++ = *in++;
2086 *out = 0;
2088 if (suffix[0] == '*')
2090 if (! strcmp (suffix, "*link_command"))
2091 link_command_spec = spec;
2092 else
2093 set_spec (suffix + 1, spec, user_p);
2095 else
2097 /* Add this pair to the vector. */
2098 compilers
2099 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
2101 compilers[n_compilers].suffix = suffix;
2102 compilers[n_compilers].spec = spec;
2103 n_compilers++;
2104 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2107 if (*suffix == 0)
2108 link_command_spec = spec;
2111 if (link_command_spec == 0)
2112 fatal_error ("spec file has no spec for linking");
2115 /* Record the names of temporary files we tell compilers to write,
2116 and delete them at the end of the run. */
2118 /* This is the common prefix we use to make temp file names.
2119 It is chosen once for each run of this program.
2120 It is substituted into a spec by %g or %j.
2121 Thus, all temp file names contain this prefix.
2122 In practice, all temp file names start with this prefix.
2124 This prefix comes from the envvar TMPDIR if it is defined;
2125 otherwise, from the P_tmpdir macro if that is defined;
2126 otherwise, in /usr/tmp or /tmp;
2127 or finally the current directory if all else fails. */
2129 static const char *temp_filename;
2131 /* Length of the prefix. */
2133 static int temp_filename_length;
2135 /* Define the list of temporary files to delete. */
2137 struct temp_file
2139 const char *name;
2140 struct temp_file *next;
2143 /* Queue of files to delete on success or failure of compilation. */
2144 static struct temp_file *always_delete_queue;
2145 /* Queue of files to delete on failure of compilation. */
2146 static struct temp_file *failure_delete_queue;
2148 /* Record FILENAME as a file to be deleted automatically.
2149 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2150 otherwise delete it in any case.
2151 FAIL_DELETE nonzero means delete it if a compilation step fails;
2152 otherwise delete it in any case. */
2154 void
2155 record_temp_file (const char *filename, int always_delete, int fail_delete)
2157 char *const name = xstrdup (filename);
2159 if (always_delete)
2161 struct temp_file *temp;
2162 for (temp = always_delete_queue; temp; temp = temp->next)
2163 if (! filename_cmp (name, temp->name))
2164 goto already1;
2166 temp = XNEW (struct temp_file);
2167 temp->next = always_delete_queue;
2168 temp->name = name;
2169 always_delete_queue = temp;
2171 already1:;
2174 if (fail_delete)
2176 struct temp_file *temp;
2177 for (temp = failure_delete_queue; temp; temp = temp->next)
2178 if (! filename_cmp (name, temp->name))
2180 free (name);
2181 goto already2;
2184 temp = XNEW (struct temp_file);
2185 temp->next = failure_delete_queue;
2186 temp->name = name;
2187 failure_delete_queue = temp;
2189 already2:;
2193 /* Delete all the temporary files whose names we previously recorded. */
2195 #ifndef DELETE_IF_ORDINARY
2196 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2197 do \
2199 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2200 if (unlink (NAME) < 0) \
2201 if (VERBOSE_FLAG) \
2202 perror_with_name (NAME); \
2203 } while (0)
2204 #endif
2206 static void
2207 delete_if_ordinary (const char *name)
2209 struct stat st;
2210 #ifdef DEBUG
2211 int i, c;
2213 printf ("Delete %s? (y or n) ", name);
2214 fflush (stdout);
2215 i = getchar ();
2216 if (i != '\n')
2217 while ((c = getchar ()) != '\n' && c != EOF)
2220 if (i == 'y' || i == 'Y')
2221 #endif /* DEBUG */
2222 DELETE_IF_ORDINARY (name, st, verbose_flag);
2225 static void
2226 delete_temp_files (void)
2228 struct temp_file *temp;
2230 for (temp = always_delete_queue; temp; temp = temp->next)
2231 delete_if_ordinary (temp->name);
2232 always_delete_queue = 0;
2235 /* Delete all the files to be deleted on error. */
2237 static void
2238 delete_failure_queue (void)
2240 struct temp_file *temp;
2242 for (temp = failure_delete_queue; temp; temp = temp->next)
2243 delete_if_ordinary (temp->name);
2246 static void
2247 clear_failure_queue (void)
2249 failure_delete_queue = 0;
2252 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2253 returns non-NULL.
2254 If DO_MULTI is true iterate over the paths twice, first with multilib
2255 suffix then without, otherwise iterate over the paths once without
2256 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2257 to avoid visiting the same path twice, but we could do better. For
2258 instance, /usr/lib/../lib is considered different from /usr/lib.
2259 At least EXTRA_SPACE chars past the end of the path passed to
2260 CALLBACK are available for use by the callback.
2261 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2263 Returns the value returned by CALLBACK. */
2265 static void *
2266 for_each_path (const struct path_prefix *paths,
2267 bool do_multi,
2268 size_t extra_space,
2269 void *(*callback) (char *, void *),
2270 void *callback_info)
2272 struct prefix_list *pl;
2273 const char *multi_dir = NULL;
2274 const char *multi_os_dir = NULL;
2275 const char *multiarch_suffix = NULL;
2276 const char *multi_suffix;
2277 const char *just_multi_suffix;
2278 char *path = NULL;
2279 void *ret = NULL;
2280 bool skip_multi_dir = false;
2281 bool skip_multi_os_dir = false;
2283 multi_suffix = machine_suffix;
2284 just_multi_suffix = just_machine_suffix;
2285 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2287 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2288 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2289 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2291 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2292 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2293 if (multiarch_dir)
2294 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2296 while (1)
2298 size_t multi_dir_len = 0;
2299 size_t multi_os_dir_len = 0;
2300 size_t multiarch_len = 0;
2301 size_t suffix_len;
2302 size_t just_suffix_len;
2303 size_t len;
2305 if (multi_dir)
2306 multi_dir_len = strlen (multi_dir);
2307 if (multi_os_dir)
2308 multi_os_dir_len = strlen (multi_os_dir);
2309 if (multiarch_suffix)
2310 multiarch_len = strlen (multiarch_suffix);
2311 suffix_len = strlen (multi_suffix);
2312 just_suffix_len = strlen (just_multi_suffix);
2314 if (path == NULL)
2316 len = paths->max_len + extra_space + 1;
2317 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2318 path = XNEWVEC (char, len);
2321 for (pl = paths->plist; pl != 0; pl = pl->next)
2323 len = strlen (pl->prefix);
2324 memcpy (path, pl->prefix, len);
2326 /* Look first in MACHINE/VERSION subdirectory. */
2327 if (!skip_multi_dir)
2329 memcpy (path + len, multi_suffix, suffix_len + 1);
2330 ret = callback (path, callback_info);
2331 if (ret)
2332 break;
2335 /* Some paths are tried with just the machine (ie. target)
2336 subdir. This is used for finding as, ld, etc. */
2337 if (!skip_multi_dir
2338 && pl->require_machine_suffix == 2)
2340 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2341 ret = callback (path, callback_info);
2342 if (ret)
2343 break;
2346 /* Now try the multiarch path. */
2347 if (!skip_multi_dir
2348 && !pl->require_machine_suffix && multiarch_dir)
2350 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2351 ret = callback (path, callback_info);
2352 if (ret)
2353 break;
2356 /* Now try the base path. */
2357 if (!pl->require_machine_suffix
2358 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2360 const char *this_multi;
2361 size_t this_multi_len;
2363 if (pl->os_multilib)
2365 this_multi = multi_os_dir;
2366 this_multi_len = multi_os_dir_len;
2368 else
2370 this_multi = multi_dir;
2371 this_multi_len = multi_dir_len;
2374 if (this_multi_len)
2375 memcpy (path + len, this_multi, this_multi_len + 1);
2376 else
2377 path[len] = '\0';
2379 ret = callback (path, callback_info);
2380 if (ret)
2381 break;
2384 if (pl)
2385 break;
2387 if (multi_dir == NULL && multi_os_dir == NULL)
2388 break;
2390 /* Run through the paths again, this time without multilibs.
2391 Don't repeat any we have already seen. */
2392 if (multi_dir)
2394 free (CONST_CAST (char *, multi_dir));
2395 multi_dir = NULL;
2396 free (CONST_CAST (char *, multi_suffix));
2397 multi_suffix = machine_suffix;
2398 free (CONST_CAST (char *, just_multi_suffix));
2399 just_multi_suffix = just_machine_suffix;
2401 else
2402 skip_multi_dir = true;
2403 if (multi_os_dir)
2405 free (CONST_CAST (char *, multi_os_dir));
2406 multi_os_dir = NULL;
2408 else
2409 skip_multi_os_dir = true;
2412 if (multi_dir)
2414 free (CONST_CAST (char *, multi_dir));
2415 free (CONST_CAST (char *, multi_suffix));
2416 free (CONST_CAST (char *, just_multi_suffix));
2418 if (multi_os_dir)
2419 free (CONST_CAST (char *, multi_os_dir));
2420 if (ret != path)
2421 free (path);
2422 return ret;
2425 /* Callback for build_search_list. Adds path to obstack being built. */
2427 struct add_to_obstack_info {
2428 struct obstack *ob;
2429 bool check_dir;
2430 bool first_time;
2433 static void *
2434 add_to_obstack (char *path, void *data)
2436 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2438 if (info->check_dir && !is_directory (path, false))
2439 return NULL;
2441 if (!info->first_time)
2442 obstack_1grow (info->ob, PATH_SEPARATOR);
2444 obstack_grow (info->ob, path, strlen (path));
2446 info->first_time = false;
2447 return NULL;
2450 /* Add or change the value of an environment variable, outputting the
2451 change to standard error if in verbose mode. */
2452 static void
2453 xputenv (const char *string)
2455 if (verbose_flag)
2456 fnotice (stderr, "%s\n", string);
2457 putenv (CONST_CAST (char *, string));
2460 /* Build a list of search directories from PATHS.
2461 PREFIX is a string to prepend to the list.
2462 If CHECK_DIR_P is true we ensure the directory exists.
2463 If DO_MULTI is true, multilib paths are output first, then
2464 non-multilib paths.
2465 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2466 It is also used by the --print-search-dirs flag. */
2468 static char *
2469 build_search_list (const struct path_prefix *paths, const char *prefix,
2470 bool check_dir, bool do_multi)
2472 struct add_to_obstack_info info;
2474 info.ob = &collect_obstack;
2475 info.check_dir = check_dir;
2476 info.first_time = true;
2478 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2479 obstack_1grow (&collect_obstack, '=');
2481 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2483 obstack_1grow (&collect_obstack, '\0');
2484 return XOBFINISH (&collect_obstack, char *);
2487 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2488 for collect. */
2490 static void
2491 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2492 bool do_multi)
2494 xputenv (build_search_list (paths, env_var, true, do_multi));
2497 /* Check whether NAME can be accessed in MODE. This is like access,
2498 except that it never considers directories to be executable. */
2500 static int
2501 access_check (const char *name, int mode)
2503 if (mode == X_OK)
2505 struct stat st;
2507 if (stat (name, &st) < 0
2508 || S_ISDIR (st.st_mode))
2509 return -1;
2512 return access (name, mode);
2515 /* Callback for find_a_file. Appends the file name to the directory
2516 path. If the resulting file exists in the right mode, return the
2517 full pathname to the file. */
2519 struct file_at_path_info {
2520 const char *name;
2521 const char *suffix;
2522 int name_len;
2523 int suffix_len;
2524 int mode;
2527 static void *
2528 file_at_path (char *path, void *data)
2530 struct file_at_path_info *info = (struct file_at_path_info *) data;
2531 size_t len = strlen (path);
2533 memcpy (path + len, info->name, info->name_len);
2534 len += info->name_len;
2536 /* Some systems have a suffix for executable files.
2537 So try appending that first. */
2538 if (info->suffix_len)
2540 memcpy (path + len, info->suffix, info->suffix_len + 1);
2541 if (access_check (path, info->mode) == 0)
2542 return path;
2545 path[len] = '\0';
2546 if (access_check (path, info->mode) == 0)
2547 return path;
2549 return NULL;
2552 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2553 access to check permissions. If DO_MULTI is true, search multilib
2554 paths then non-multilib paths, otherwise do not search multilib paths.
2555 Return 0 if not found, otherwise return its name, allocated with malloc. */
2557 static char *
2558 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2559 bool do_multi)
2561 struct file_at_path_info info;
2563 #ifdef DEFAULT_ASSEMBLER
2564 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2565 return xstrdup (DEFAULT_ASSEMBLER);
2566 #endif
2568 #ifdef DEFAULT_LINKER
2569 if (! strcmp (name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2570 return xstrdup (DEFAULT_LINKER);
2571 #endif
2573 /* Determine the filename to execute (special case for absolute paths). */
2575 if (IS_ABSOLUTE_PATH (name))
2577 if (access (name, mode) == 0)
2578 return xstrdup (name);
2580 return NULL;
2583 info.name = name;
2584 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2585 info.name_len = strlen (info.name);
2586 info.suffix_len = strlen (info.suffix);
2587 info.mode = mode;
2589 return (char*) for_each_path (pprefix, do_multi,
2590 info.name_len + info.suffix_len,
2591 file_at_path, &info);
2594 /* Ranking of prefixes in the sort list. -B prefixes are put before
2595 all others. */
2597 enum path_prefix_priority
2599 PREFIX_PRIORITY_B_OPT,
2600 PREFIX_PRIORITY_LAST
2603 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2604 order according to PRIORITY. Within each PRIORITY, new entries are
2605 appended.
2607 If WARN is nonzero, we will warn if no file is found
2608 through this prefix. WARN should point to an int
2609 which will be set to 1 if this entry is used.
2611 COMPONENT is the value to be passed to update_path.
2613 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2614 the complete value of machine_suffix.
2615 2 means try both machine_suffix and just_machine_suffix. */
2617 static void
2618 add_prefix (struct path_prefix *pprefix, const char *prefix,
2619 const char *component, /* enum prefix_priority */ int priority,
2620 int require_machine_suffix, int os_multilib)
2622 struct prefix_list *pl, **prev;
2623 int len;
2625 for (prev = &pprefix->plist;
2626 (*prev) != NULL && (*prev)->priority <= priority;
2627 prev = &(*prev)->next)
2630 /* Keep track of the longest prefix. */
2632 prefix = update_path (prefix, component);
2633 len = strlen (prefix);
2634 if (len > pprefix->max_len)
2635 pprefix->max_len = len;
2637 pl = XNEW (struct prefix_list);
2638 pl->prefix = prefix;
2639 pl->require_machine_suffix = require_machine_suffix;
2640 pl->priority = priority;
2641 pl->os_multilib = os_multilib;
2643 /* Insert after PREV. */
2644 pl->next = (*prev);
2645 (*prev) = pl;
2648 /* Same as add_prefix, but prepending target_system_root to prefix. */
2649 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2650 static void
2651 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2652 const char *component,
2653 /* enum prefix_priority */ int priority,
2654 int require_machine_suffix, int os_multilib)
2656 if (!IS_ABSOLUTE_PATH (prefix))
2657 fatal_error ("system path %qs is not absolute", prefix);
2659 if (target_system_root)
2661 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2662 size_t sysroot_len = strlen (target_system_root);
2664 if (sysroot_len > 0
2665 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2666 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2668 if (target_sysroot_suffix)
2669 prefix = concat (sysroot_no_trailing_dir_separator,
2670 target_sysroot_suffix, prefix, NULL);
2671 else
2672 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2674 free (sysroot_no_trailing_dir_separator);
2676 /* We have to override this because GCC's notion of sysroot
2677 moves along with GCC. */
2678 component = "GCC";
2681 add_prefix (pprefix, prefix, component, priority,
2682 require_machine_suffix, os_multilib);
2685 /* Execute the command specified by the arguments on the current line of spec.
2686 When using pipes, this includes several piped-together commands
2687 with `|' between them.
2689 Return 0 if successful, -1 if failed. */
2691 static int
2692 execute (void)
2694 int i;
2695 int n_commands; /* # of command. */
2696 char *string;
2697 struct pex_obj *pex;
2698 struct command
2700 const char *prog; /* program name. */
2701 const char **argv; /* vector of args. */
2703 const char *arg;
2705 struct command *commands; /* each command buffer with above info. */
2707 gcc_assert (!processing_spec_function);
2709 if (wrapper_string)
2711 string = find_a_file (&exec_prefixes,
2712 argbuf[0], X_OK, false);
2713 if (string)
2714 argbuf[0] = string;
2715 insert_wrapper (wrapper_string);
2718 /* Count # of piped commands. */
2719 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2720 if (strcmp (arg, "|") == 0)
2721 n_commands++;
2723 /* Get storage for each command. */
2724 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2726 /* Split argbuf into its separate piped processes,
2727 and record info about each one.
2728 Also search for the programs that are to be run. */
2730 argbuf.safe_push (0);
2732 commands[0].prog = argbuf[0]; /* first command. */
2733 commands[0].argv = argbuf.address ();
2735 if (!wrapper_string)
2737 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2738 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2741 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2742 if (arg && strcmp (arg, "|") == 0)
2743 { /* each command. */
2744 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2745 fatal_error ("-pipe not supported");
2746 #endif
2747 argbuf[i] = 0; /* Termination of
2748 command args. */
2749 commands[n_commands].prog = argbuf[i + 1];
2750 commands[n_commands].argv
2751 = &(argbuf.address ())[i + 1];
2752 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2753 X_OK, false);
2754 if (string)
2755 commands[n_commands].argv[0] = string;
2756 n_commands++;
2759 /* If -v, print what we are about to do, and maybe query. */
2761 if (verbose_flag)
2763 /* For help listings, put a blank line between sub-processes. */
2764 if (print_help_list)
2765 fputc ('\n', stderr);
2767 /* Print each piped command as a separate line. */
2768 for (i = 0; i < n_commands; i++)
2770 const char *const *j;
2772 if (verbose_only_flag)
2774 for (j = commands[i].argv; *j; j++)
2776 const char *p;
2777 for (p = *j; *p; ++p)
2778 if (!ISALNUM ((unsigned char) *p)
2779 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2780 break;
2781 if (*p || !*j)
2783 fprintf (stderr, " \"");
2784 for (p = *j; *p; ++p)
2786 if (*p == '"' || *p == '\\' || *p == '$')
2787 fputc ('\\', stderr);
2788 fputc (*p, stderr);
2790 fputc ('"', stderr);
2792 /* If it's empty, print "". */
2793 else if (!**j)
2794 fprintf (stderr, " \"\"");
2795 else
2796 fprintf (stderr, " %s", *j);
2799 else
2800 for (j = commands[i].argv; *j; j++)
2801 /* If it's empty, print "". */
2802 if (!**j)
2803 fprintf (stderr, " \"\"");
2804 else
2805 fprintf (stderr, " %s", *j);
2807 /* Print a pipe symbol after all but the last command. */
2808 if (i + 1 != n_commands)
2809 fprintf (stderr, " |");
2810 fprintf (stderr, "\n");
2812 fflush (stderr);
2813 if (verbose_only_flag != 0)
2815 /* verbose_only_flag should act as if the spec was
2816 executed, so increment execution_count before
2817 returning. This prevents spurious warnings about
2818 unused linker input files, etc. */
2819 execution_count++;
2820 return 0;
2822 #ifdef DEBUG
2823 fnotice (stderr, "\nGo ahead? (y or n) ");
2824 fflush (stderr);
2825 i = getchar ();
2826 if (i != '\n')
2827 while (getchar () != '\n')
2830 if (i != 'y' && i != 'Y')
2831 return 0;
2832 #endif /* DEBUG */
2835 #ifdef ENABLE_VALGRIND_CHECKING
2836 /* Run the each command through valgrind. To simplify prepending the
2837 path to valgrind and the option "-q" (for quiet operation unless
2838 something triggers), we allocate a separate argv array. */
2840 for (i = 0; i < n_commands; i++)
2842 const char **argv;
2843 int argc;
2844 int j;
2846 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2849 argv = XALLOCAVEC (const char *, argc + 3);
2851 argv[0] = VALGRIND_PATH;
2852 argv[1] = "-q";
2853 for (j = 2; j < argc + 2; j++)
2854 argv[j] = commands[i].argv[j - 2];
2855 argv[j] = NULL;
2857 commands[i].argv = argv;
2858 commands[i].prog = argv[0];
2860 #endif
2862 /* Run each piped subprocess. */
2864 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
2865 ? PEX_RECORD_TIMES : 0),
2866 progname, temp_filename);
2867 if (pex == NULL)
2868 fatal_error ("pex_init failed: %m");
2870 for (i = 0; i < n_commands; i++)
2872 const char *errmsg;
2873 int err;
2874 const char *string = commands[i].argv[0];
2876 errmsg = pex_run (pex,
2877 ((i + 1 == n_commands ? PEX_LAST : 0)
2878 | (string == commands[i].prog ? PEX_SEARCH : 0)),
2879 string, CONST_CAST (char **, commands[i].argv),
2880 NULL, NULL, &err);
2881 if (errmsg != NULL)
2883 if (err == 0)
2884 fatal_error (errmsg);
2885 else
2887 errno = err;
2888 pfatal_with_name (errmsg);
2892 if (i && string != commands[i].prog)
2893 free (CONST_CAST (char *, string));
2896 execution_count++;
2898 /* Wait for all the subprocesses to finish. */
2901 int *statuses;
2902 struct pex_time *times = NULL;
2903 int ret_code = 0;
2905 statuses = (int *) alloca (n_commands * sizeof (int));
2906 if (!pex_get_status (pex, n_commands, statuses))
2907 fatal_error ("failed to get exit status: %m");
2909 if (report_times || report_times_to_file)
2911 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
2912 if (!pex_get_times (pex, n_commands, times))
2913 fatal_error ("failed to get process times: %m");
2916 pex_free (pex);
2918 for (i = 0; i < n_commands; ++i)
2920 int status = statuses[i];
2922 if (WIFSIGNALED (status))
2924 #ifdef SIGPIPE
2925 /* SIGPIPE is a special case. It happens in -pipe mode
2926 when the compiler dies before the preprocessor is done,
2927 or the assembler dies before the compiler is done.
2928 There's generally been an error already, and this is
2929 just fallout. So don't generate another error unless
2930 we would otherwise have succeeded. */
2931 if (WTERMSIG (status) == SIGPIPE
2932 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2934 signal_count++;
2935 ret_code = -1;
2937 else
2938 #endif
2939 internal_error ("%s (program %s)",
2940 strsignal (WTERMSIG (status)), commands[i].prog);
2942 else if (WIFEXITED (status)
2943 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2945 /* For ICEs in cc1, cc1obj, cc1plus see if it is
2946 reproducible or not. */
2947 const char *p;
2948 if (flag_report_bug
2949 && WEXITSTATUS (status) == ICE_EXIT_CODE
2950 && i == 0
2951 && (p = strrchr (commands[0].argv[0], DIR_SEPARATOR))
2952 && ! strncmp (p + 1, "cc1", 3))
2953 try_generate_repro (commands[0].argv);
2954 if (WEXITSTATUS (status) > greatest_status)
2955 greatest_status = WEXITSTATUS (status);
2956 ret_code = -1;
2959 if (report_times || report_times_to_file)
2961 struct pex_time *pt = &times[i];
2962 double ut, st;
2964 ut = ((double) pt->user_seconds
2965 + (double) pt->user_microseconds / 1.0e6);
2966 st = ((double) pt->system_seconds
2967 + (double) pt->system_microseconds / 1.0e6);
2969 if (ut + st != 0)
2971 if (report_times)
2972 fnotice (stderr, "# %s %.2f %.2f\n",
2973 commands[i].prog, ut, st);
2975 if (report_times_to_file)
2977 int c = 0;
2978 const char *const *j;
2980 fprintf (report_times_to_file, "%g %g", ut, st);
2982 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
2984 const char *p;
2985 for (p = *j; *p; ++p)
2986 if (*p == '"' || *p == '\\' || *p == '$'
2987 || ISSPACE (*p))
2988 break;
2990 if (*p)
2992 fprintf (report_times_to_file, " \"");
2993 for (p = *j; *p; ++p)
2995 if (*p == '"' || *p == '\\' || *p == '$')
2996 fputc ('\\', report_times_to_file);
2997 fputc (*p, report_times_to_file);
2999 fputc ('"', report_times_to_file);
3001 else
3002 fprintf (report_times_to_file, " %s", *j);
3005 fputc ('\n', report_times_to_file);
3011 if (commands[0].argv[0] != commands[0].prog)
3012 free (CONST_CAST (char *, commands[0].argv[0]));
3014 return ret_code;
3018 /* Find all the switches given to us
3019 and make a vector describing them.
3020 The elements of the vector are strings, one per switch given.
3021 If a switch uses following arguments, then the `part1' field
3022 is the switch itself and the `args' field
3023 is a null-terminated vector containing the following arguments.
3024 Bits in the `live_cond' field are:
3025 SWITCH_LIVE to indicate this switch is true in a conditional spec.
3026 SWITCH_FALSE to indicate this switch is overridden by a later switch.
3027 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
3028 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored
3029 in all do_spec calls afterwards. Used for %<S from self specs.
3030 The `validated' field is nonzero if any spec has looked at this switch;
3031 if it remains zero at the end of the run, it must be meaningless. */
3033 #define SWITCH_LIVE (1 << 0)
3034 #define SWITCH_FALSE (1 << 1)
3035 #define SWITCH_IGNORE (1 << 2)
3036 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
3037 #define SWITCH_KEEP_FOR_GCC (1 << 4)
3039 struct switchstr
3041 const char *part1;
3042 const char **args;
3043 unsigned int live_cond;
3044 bool known;
3045 bool validated;
3046 bool ordering;
3049 static struct switchstr *switches;
3051 static int n_switches;
3053 static int n_switches_alloc;
3055 /* Set to zero if -fcompare-debug is disabled, positive if it's
3056 enabled and we're running the first compilation, negative if it's
3057 enabled and we're running the second compilation. For most of the
3058 time, it's in the range -1..1, but it can be temporarily set to 2
3059 or 3 to indicate that the -fcompare-debug flags didn't come from
3060 the command-line, but rather from the GCC_COMPARE_DEBUG environment
3061 variable, until a synthesized -fcompare-debug flag is added to the
3062 command line. */
3063 int compare_debug;
3065 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
3066 int compare_debug_second;
3068 /* Set to the flags that should be passed to the second compilation in
3069 a -fcompare-debug compilation. */
3070 const char *compare_debug_opt;
3072 static struct switchstr *switches_debug_check[2];
3074 static int n_switches_debug_check[2];
3076 static int n_switches_alloc_debug_check[2];
3078 static char *debug_check_temp_file[2];
3080 /* Language is one of three things:
3082 1) The name of a real programming language.
3083 2) NULL, indicating that no one has figured out
3084 what it is yet.
3085 3) '*', indicating that the file should be passed
3086 to the linker. */
3087 struct infile
3089 const char *name;
3090 const char *language;
3091 struct compiler *incompiler;
3092 bool compiled;
3093 bool preprocessed;
3096 /* Also a vector of input files specified. */
3098 static struct infile *infiles;
3100 int n_infiles;
3102 static int n_infiles_alloc;
3104 /* True if multiple input files are being compiled to a single
3105 assembly file. */
3107 static bool combine_inputs;
3109 /* This counts the number of libraries added by lang_specific_driver, so that
3110 we can tell if there were any user supplied any files or libraries. */
3112 static int added_libraries;
3114 /* And a vector of corresponding output files is made up later. */
3116 const char **outfiles;
3118 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3120 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3121 is true if we should look for an executable suffix. DO_OBJ
3122 is true if we should look for an object suffix. */
3124 static const char *
3125 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3126 int do_obj ATTRIBUTE_UNUSED)
3128 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3129 int i;
3130 #endif
3131 int len;
3133 if (name == NULL)
3134 return NULL;
3136 len = strlen (name);
3138 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3139 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3140 if (do_obj && len > 2
3141 && name[len - 2] == '.'
3142 && name[len - 1] == 'o')
3144 obstack_grow (&obstack, name, len - 2);
3145 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3146 name = XOBFINISH (&obstack, const char *);
3148 #endif
3150 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3151 /* If there is no filetype, make it the executable suffix (which includes
3152 the "."). But don't get confused if we have just "-o". */
3153 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3154 return name;
3156 for (i = len - 1; i >= 0; i--)
3157 if (IS_DIR_SEPARATOR (name[i]))
3158 break;
3160 for (i++; i < len; i++)
3161 if (name[i] == '.')
3162 return name;
3164 obstack_grow (&obstack, name, len);
3165 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3166 strlen (TARGET_EXECUTABLE_SUFFIX));
3167 name = XOBFINISH (&obstack, const char *);
3168 #endif
3170 return name;
3172 #endif
3174 /* Display the command line switches accepted by gcc. */
3175 static void
3176 display_help (void)
3178 printf (_("Usage: %s [options] file...\n"), progname);
3179 fputs (_("Options:\n"), stdout);
3181 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3182 fputs (_(" --help Display this information\n"), stdout);
3183 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3184 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...]\n"), stdout);
3185 fputs (_(" Display specific types of command line options\n"), stdout);
3186 if (! verbose_flag)
3187 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3188 fputs (_(" --version Display compiler version information\n"), stdout);
3189 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3190 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3191 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3192 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3193 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3194 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3195 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3196 fputs (_("\
3197 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3198 a component in the library path\n"), stdout);
3199 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3200 fputs (_("\
3201 -print-multi-lib Display the mapping between command line options and\n\
3202 multiple library search directories\n"), stdout);
3203 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3204 fputs (_(" -print-sysroot Display the target libraries directory\n"), stdout);
3205 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
3206 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3207 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3208 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3209 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3210 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3211 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3212 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3213 fputs (_(" -save-temps=<arg> Do not delete intermediate files\n"), stdout);
3214 fputs (_("\
3215 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3216 prefixes to other gcc components\n"), stdout);
3217 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3218 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3219 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3220 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3221 fputs (_("\
3222 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3223 and libraries\n"), stdout);
3224 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3225 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3226 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3227 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3228 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3229 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3230 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3231 fputs (_(" -pie Create a position independent executable\n"), stdout);
3232 fputs (_(" -shared Create a shared library\n"), stdout);
3233 fputs (_("\
3234 -x <language> Specify the language of the following input files\n\
3235 Permissible languages include: c c++ assembler none\n\
3236 'none' means revert to the default behavior of\n\
3237 guessing the language based on the file's extension\n\
3238 "), stdout);
3240 printf (_("\
3241 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3242 passed on to the various sub-processes invoked by %s. In order to pass\n\
3243 other options on to these processes the -W<letter> options must be used.\n\
3244 "), progname);
3246 /* The rest of the options are displayed by invocations of the various
3247 sub-processes. */
3250 static void
3251 add_preprocessor_option (const char *option, int len)
3253 preprocessor_options.safe_push (save_string (option, len));
3256 static void
3257 add_assembler_option (const char *option, int len)
3259 assembler_options.safe_push (save_string (option, len));
3262 static void
3263 add_linker_option (const char *option, int len)
3265 linker_options.safe_push (save_string (option, len));
3268 /* Allocate space for an input file in infiles. */
3270 static void
3271 alloc_infile (void)
3273 if (n_infiles_alloc == 0)
3275 n_infiles_alloc = 16;
3276 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3278 else if (n_infiles_alloc == n_infiles)
3280 n_infiles_alloc *= 2;
3281 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3285 /* Store an input file with the given NAME and LANGUAGE in
3286 infiles. */
3288 static void
3289 add_infile (const char *name, const char *language)
3291 alloc_infile ();
3292 infiles[n_infiles].name = name;
3293 infiles[n_infiles++].language = language;
3296 /* Allocate space for a switch in switches. */
3298 static void
3299 alloc_switch (void)
3301 if (n_switches_alloc == 0)
3303 n_switches_alloc = 16;
3304 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3306 else if (n_switches_alloc == n_switches)
3308 n_switches_alloc *= 2;
3309 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3313 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3314 as validated if VALIDATED and KNOWN if it is an internal switch. */
3316 static void
3317 save_switch (const char *opt, size_t n_args, const char *const *args,
3318 bool validated, bool known)
3320 alloc_switch ();
3321 switches[n_switches].part1 = opt + 1;
3322 if (n_args == 0)
3323 switches[n_switches].args = 0;
3324 else
3326 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3327 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3328 switches[n_switches].args[n_args] = NULL;
3331 switches[n_switches].live_cond = 0;
3332 switches[n_switches].validated = validated;
3333 switches[n_switches].known = known;
3334 switches[n_switches].ordering = 0;
3335 n_switches++;
3338 /* Handle an option DECODED that is unknown to the option-processing
3339 machinery. */
3341 static bool
3342 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3344 const char *opt = decoded->arg;
3345 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3346 && !(decoded->errors & CL_ERR_NEGATIVE))
3348 /* Leave unknown -Wno-* options for the compiler proper, to be
3349 diagnosed only if there are warnings. */
3350 save_switch (decoded->canonical_option[0],
3351 decoded->canonical_option_num_elements - 1,
3352 &decoded->canonical_option[1], false, true);
3353 return false;
3355 if (decoded->opt_index == OPT_SPECIAL_unknown)
3357 /* Give it a chance to define it a a spec file. */
3358 save_switch (decoded->canonical_option[0],
3359 decoded->canonical_option_num_elements - 1,
3360 &decoded->canonical_option[1], false, false);
3361 return false;
3363 else
3364 return true;
3367 /* Handle an option DECODED that is not marked as CL_DRIVER.
3368 LANG_MASK will always be CL_DRIVER. */
3370 static void
3371 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3372 unsigned int lang_mask ATTRIBUTE_UNUSED)
3374 /* At this point, non-driver options are accepted (and expected to
3375 be passed down by specs) unless marked to be rejected by the
3376 driver. Options to be rejected by the driver but accepted by the
3377 compilers proper are treated just like completely unknown
3378 options. */
3379 const struct cl_option *option = &cl_options[decoded->opt_index];
3381 if (option->cl_reject_driver)
3382 error ("unrecognized command line option %qs",
3383 decoded->orig_option_with_args_text);
3384 else
3385 save_switch (decoded->canonical_option[0],
3386 decoded->canonical_option_num_elements - 1,
3387 &decoded->canonical_option[1], false, true);
3390 static const char *spec_lang = 0;
3391 static int last_language_n_infiles;
3393 /* Parse -foffload option argument. */
3395 static void
3396 handle_foffload_option (const char *arg)
3398 const char *c, *cur, *n, *next, *end;
3399 char *target;
3401 /* If option argument starts with '-' then no target is specified and we
3402 do not need to parse it. */
3403 if (arg[0] == '-')
3404 return;
3406 end = strchr (arg, '=');
3407 if (end == NULL)
3408 end = strchr (arg, '\0');
3409 cur = arg;
3411 while (cur < end)
3413 next = strchr (cur, ',');
3414 if (next == NULL)
3415 next = end;
3416 next = (next > end) ? end : next;
3418 target = XNEWVEC (char, next - cur + 1);
3419 memcpy (target, cur, next - cur);
3420 target[next - cur] = '\0';
3422 /* If 'disable' is passed to the option, stop parsing the option and clean
3423 the list of offload targets. */
3424 if (strcmp (target, "disable") == 0)
3426 free (offload_targets);
3427 offload_targets = xstrdup ("");
3428 break;
3431 /* Check that GCC is configured to support the offload target. */
3432 c = OFFLOAD_TARGETS;
3433 while (c)
3435 n = strchr (c, ',');
3436 if (n == NULL)
3437 n = strchr (c, '\0');
3439 if (next - cur == n - c && strncmp (target, c, n - c) == 0)
3440 break;
3442 c = *n ? n + 1 : NULL;
3445 if (!c)
3446 fatal_error ("GCC is not configured to support %s as offload target",
3447 target);
3449 if (!offload_targets)
3451 offload_targets = target;
3452 target = NULL;
3454 else
3456 /* Check that the target hasn't already presented in the list. */
3457 c = offload_targets;
3460 n = strchr (c, ':');
3461 if (n == NULL)
3462 n = strchr (c, '\0');
3464 if (next - cur == n - c && strncmp (c, target, n - c) == 0)
3465 break;
3467 c = n + 1;
3469 while (*n);
3471 /* If duplicate is not found, append the target to the list. */
3472 if (c > n)
3474 size_t offload_targets_len = strlen (offload_targets);
3475 offload_targets
3476 = XRESIZEVEC (char, offload_targets,
3477 offload_targets_len + next - cur + 2);
3478 if (offload_targets_len)
3479 offload_targets[offload_targets_len++] = ':';
3480 memcpy (offload_targets + offload_targets_len, target, next - cur);
3484 cur = next + 1;
3485 XDELETEVEC (target);
3489 /* Handle a driver option; arguments and return value as for
3490 handle_option. */
3492 static bool
3493 driver_handle_option (struct gcc_options *opts,
3494 struct gcc_options *opts_set,
3495 const struct cl_decoded_option *decoded,
3496 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3497 location_t loc,
3498 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3499 diagnostic_context *dc)
3501 size_t opt_index = decoded->opt_index;
3502 const char *arg = decoded->arg;
3503 const char *compare_debug_replacement_opt;
3504 int value = decoded->value;
3505 bool validated = false;
3506 bool do_save = true;
3508 gcc_assert (opts == &global_options);
3509 gcc_assert (opts_set == &global_options_set);
3510 gcc_assert (kind == DK_UNSPECIFIED);
3511 gcc_assert (loc == UNKNOWN_LOCATION);
3512 gcc_assert (dc == global_dc);
3514 switch (opt_index)
3516 case OPT_dumpspecs:
3518 struct spec_list *sl;
3519 init_spec ();
3520 for (sl = specs; sl; sl = sl->next)
3521 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3522 if (link_command_spec)
3523 printf ("*link_command:\n%s\n\n", link_command_spec);
3524 exit (0);
3527 case OPT_dumpversion:
3528 printf ("%s\n", spec_version);
3529 exit (0);
3531 case OPT_dumpmachine:
3532 printf ("%s\n", spec_machine);
3533 exit (0);
3535 case OPT__version:
3536 print_version = 1;
3538 /* CPP driver cannot obtain switch from cc1_options. */
3539 if (is_cpp_driver)
3540 add_preprocessor_option ("--version", strlen ("--version"));
3541 add_assembler_option ("--version", strlen ("--version"));
3542 add_linker_option ("--version", strlen ("--version"));
3543 break;
3545 case OPT__help:
3546 print_help_list = 1;
3548 /* CPP driver cannot obtain switch from cc1_options. */
3549 if (is_cpp_driver)
3550 add_preprocessor_option ("--help", 6);
3551 add_assembler_option ("--help", 6);
3552 add_linker_option ("--help", 6);
3553 break;
3555 case OPT__help_:
3556 print_subprocess_help = 2;
3557 break;
3559 case OPT__target_help:
3560 print_subprocess_help = 1;
3562 /* CPP driver cannot obtain switch from cc1_options. */
3563 if (is_cpp_driver)
3564 add_preprocessor_option ("--target-help", 13);
3565 add_assembler_option ("--target-help", 13);
3566 add_linker_option ("--target-help", 13);
3567 break;
3569 case OPT__no_sysroot_suffix:
3570 case OPT_pass_exit_codes:
3571 case OPT_print_search_dirs:
3572 case OPT_print_file_name_:
3573 case OPT_print_prog_name_:
3574 case OPT_print_multi_lib:
3575 case OPT_print_multi_directory:
3576 case OPT_print_sysroot:
3577 case OPT_print_multi_os_directory:
3578 case OPT_print_multiarch:
3579 case OPT_print_sysroot_headers_suffix:
3580 case OPT_time:
3581 case OPT_wrapper:
3582 /* These options set the variables specified in common.opt
3583 automatically, and do not need to be saved for spec
3584 processing. */
3585 do_save = false;
3586 break;
3588 case OPT_print_libgcc_file_name:
3589 print_file_name = "libgcc.a";
3590 do_save = false;
3591 break;
3593 case OPT_fuse_ld_bfd:
3594 use_ld = ".bfd";
3595 break;
3597 case OPT_fuse_ld_gold:
3598 use_ld = ".gold";
3599 break;
3601 case OPT_fcompare_debug_second:
3602 compare_debug_second = 1;
3603 break;
3605 case OPT_fcompare_debug:
3606 switch (value)
3608 case 0:
3609 compare_debug_replacement_opt = "-fcompare-debug=";
3610 arg = "";
3611 goto compare_debug_with_arg;
3613 case 1:
3614 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3615 arg = "-gtoggle";
3616 goto compare_debug_with_arg;
3618 default:
3619 gcc_unreachable ();
3621 break;
3623 case OPT_fcompare_debug_:
3624 compare_debug_replacement_opt = decoded->canonical_option[0];
3625 compare_debug_with_arg:
3626 gcc_assert (decoded->canonical_option_num_elements == 1);
3627 gcc_assert (arg != NULL);
3628 if (*arg)
3629 compare_debug = 1;
3630 else
3631 compare_debug = -1;
3632 if (compare_debug < 0)
3633 compare_debug_opt = NULL;
3634 else
3635 compare_debug_opt = arg;
3636 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3637 return true;
3639 case OPT_fdiagnostics_color_:
3640 diagnostic_color_init (dc, value);
3641 break;
3643 case OPT_Wa_:
3645 int prev, j;
3646 /* Pass the rest of this option to the assembler. */
3648 /* Split the argument at commas. */
3649 prev = 0;
3650 for (j = 0; arg[j]; j++)
3651 if (arg[j] == ',')
3653 add_assembler_option (arg + prev, j - prev);
3654 prev = j + 1;
3657 /* Record the part after the last comma. */
3658 add_assembler_option (arg + prev, j - prev);
3660 do_save = false;
3661 break;
3663 case OPT_Wp_:
3665 int prev, j;
3666 /* Pass the rest of this option to the preprocessor. */
3668 /* Split the argument at commas. */
3669 prev = 0;
3670 for (j = 0; arg[j]; j++)
3671 if (arg[j] == ',')
3673 add_preprocessor_option (arg + prev, j - prev);
3674 prev = j + 1;
3677 /* Record the part after the last comma. */
3678 add_preprocessor_option (arg + prev, j - prev);
3680 do_save = false;
3681 break;
3683 case OPT_Wl_:
3685 int prev, j;
3686 /* Split the argument at commas. */
3687 prev = 0;
3688 for (j = 0; arg[j]; j++)
3689 if (arg[j] == ',')
3691 add_infile (save_string (arg + prev, j - prev), "*");
3692 prev = j + 1;
3694 /* Record the part after the last comma. */
3695 add_infile (arg + prev, "*");
3697 do_save = false;
3698 break;
3700 case OPT_Xlinker:
3701 add_infile (arg, "*");
3702 do_save = false;
3703 break;
3705 case OPT_Xpreprocessor:
3706 add_preprocessor_option (arg, strlen (arg));
3707 do_save = false;
3708 break;
3710 case OPT_Xassembler:
3711 add_assembler_option (arg, strlen (arg));
3712 do_save = false;
3713 break;
3715 case OPT_l:
3716 /* POSIX allows separation of -l and the lib arg; canonicalize
3717 by concatenating -l with its arg */
3718 add_infile (concat ("-l", arg, NULL), "*");
3719 do_save = false;
3720 break;
3722 case OPT_L:
3723 /* Similarly, canonicalize -L for linkers that may not accept
3724 separate arguments. */
3725 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
3726 return true;
3728 case OPT_F:
3729 /* Likewise -F. */
3730 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
3731 return true;
3733 case OPT_save_temps:
3734 save_temps_flag = SAVE_TEMPS_CWD;
3735 validated = true;
3736 break;
3738 case OPT_save_temps_:
3739 if (strcmp (arg, "cwd") == 0)
3740 save_temps_flag = SAVE_TEMPS_CWD;
3741 else if (strcmp (arg, "obj") == 0
3742 || strcmp (arg, "object") == 0)
3743 save_temps_flag = SAVE_TEMPS_OBJ;
3744 else
3745 fatal_error ("%qs is an unknown -save-temps option",
3746 decoded->orig_option_with_args_text);
3747 break;
3749 case OPT_no_canonical_prefixes:
3750 /* Already handled as a special case, so ignored here. */
3751 do_save = false;
3752 break;
3754 case OPT_pipe:
3755 validated = true;
3756 /* These options set the variables specified in common.opt
3757 automatically, but do need to be saved for spec
3758 processing. */
3759 break;
3761 case OPT_specs_:
3763 struct user_specs *user = XNEW (struct user_specs);
3765 user->next = (struct user_specs *) 0;
3766 user->filename = arg;
3767 if (user_specs_tail)
3768 user_specs_tail->next = user;
3769 else
3770 user_specs_head = user;
3771 user_specs_tail = user;
3773 validated = true;
3774 break;
3776 case OPT__sysroot_:
3777 target_system_root = arg;
3778 target_system_root_changed = 1;
3779 do_save = false;
3780 break;
3782 case OPT_time_:
3783 if (report_times_to_file)
3784 fclose (report_times_to_file);
3785 report_times_to_file = fopen (arg, "a");
3786 do_save = false;
3787 break;
3789 case OPT____:
3790 /* "-###"
3791 This is similar to -v except that there is no execution
3792 of the commands and the echoed arguments are quoted. It
3793 is intended for use in shell scripts to capture the
3794 driver-generated command line. */
3795 verbose_only_flag++;
3796 verbose_flag = 1;
3797 do_save = false;
3798 break;
3800 case OPT_B:
3802 size_t len = strlen (arg);
3804 /* Catch the case where the user has forgotten to append a
3805 directory separator to the path. Note, they may be using
3806 -B to add an executable name prefix, eg "i386-elf-", in
3807 order to distinguish between multiple installations of
3808 GCC in the same directory. Hence we must check to see
3809 if appending a directory separator actually makes a
3810 valid directory name. */
3811 if (!IS_DIR_SEPARATOR (arg[len - 1])
3812 && is_directory (arg, false))
3814 char *tmp = XNEWVEC (char, len + 2);
3815 strcpy (tmp, arg);
3816 tmp[len] = DIR_SEPARATOR;
3817 tmp[++len] = 0;
3818 arg = tmp;
3821 add_prefix (&exec_prefixes, arg, NULL,
3822 PREFIX_PRIORITY_B_OPT, 0, 0);
3823 add_prefix (&startfile_prefixes, arg, NULL,
3824 PREFIX_PRIORITY_B_OPT, 0, 0);
3825 add_prefix (&include_prefixes, arg, NULL,
3826 PREFIX_PRIORITY_B_OPT, 0, 0);
3828 validated = true;
3829 break;
3831 case OPT_x:
3832 spec_lang = arg;
3833 if (!strcmp (spec_lang, "none"))
3834 /* Suppress the warning if -xnone comes after the last input
3835 file, because alternate command interfaces like g++ might
3836 find it useful to place -xnone after each input file. */
3837 spec_lang = 0;
3838 else
3839 last_language_n_infiles = n_infiles;
3840 do_save = false;
3841 break;
3843 case OPT_o:
3844 have_o = 1;
3845 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3846 arg = convert_filename (arg, ! have_c, 0);
3847 #endif
3848 output_file = arg;
3849 /* Save the output name in case -save-temps=obj was used. */
3850 save_temps_prefix = xstrdup (arg);
3851 /* On some systems, ld cannot handle "-o" without a space. So
3852 split the option from its argument. */
3853 save_switch ("-o", 1, &arg, validated, true);
3854 return true;
3856 case OPT_static_libgcc:
3857 case OPT_shared_libgcc:
3858 case OPT_static_libgfortran:
3859 case OPT_static_libstdc__:
3860 /* These are always valid, since gcc.c itself understands the
3861 first two, gfortranspec.c understands -static-libgfortran and
3862 g++spec.c understands -static-libstdc++ */
3863 validated = true;
3864 break;
3866 case OPT_fwpa:
3867 flag_wpa = "";
3868 break;
3870 case OPT_foffload_:
3871 handle_foffload_option (arg);
3872 break;
3874 default:
3875 /* Various driver options need no special processing at this
3876 point, having been handled in a prescan above or being
3877 handled by specs. */
3878 break;
3881 if (do_save)
3882 save_switch (decoded->canonical_option[0],
3883 decoded->canonical_option_num_elements - 1,
3884 &decoded->canonical_option[1], validated, true);
3885 return true;
3888 /* Put the driver's standard set of option handlers in *HANDLERS. */
3890 static void
3891 set_option_handlers (struct cl_option_handlers *handlers)
3893 handlers->unknown_option_callback = driver_unknown_option_callback;
3894 handlers->wrong_lang_callback = driver_wrong_lang_callback;
3895 handlers->num_handlers = 3;
3896 handlers->handlers[0].handler = driver_handle_option;
3897 handlers->handlers[0].mask = CL_DRIVER;
3898 handlers->handlers[1].handler = common_handle_option;
3899 handlers->handlers[1].mask = CL_COMMON;
3900 handlers->handlers[2].handler = target_handle_option;
3901 handlers->handlers[2].mask = CL_TARGET;
3904 /* Create the vector `switches' and its contents.
3905 Store its length in `n_switches'. */
3907 static void
3908 process_command (unsigned int decoded_options_count,
3909 struct cl_decoded_option *decoded_options)
3911 const char *temp;
3912 char *temp1;
3913 char *tooldir_prefix, *tooldir_prefix2;
3914 char *(*get_relative_prefix) (const char *, const char *,
3915 const char *) = NULL;
3916 struct cl_option_handlers handlers;
3917 unsigned int j;
3919 gcc_exec_prefix = getenv ("GCC_EXEC_PREFIX");
3921 n_switches = 0;
3922 n_infiles = 0;
3923 added_libraries = 0;
3925 /* Figure compiler version from version string. */
3927 compiler_version = temp1 = xstrdup (version_string);
3929 for (; *temp1; ++temp1)
3931 if (*temp1 == ' ')
3933 *temp1 = '\0';
3934 break;
3938 /* Handle any -no-canonical-prefixes flag early, to assign the function
3939 that builds relative prefixes. This function creates default search
3940 paths that are needed later in normal option handling. */
3942 for (j = 1; j < decoded_options_count; j++)
3944 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
3946 get_relative_prefix = make_relative_prefix_ignore_links;
3947 break;
3950 if (! get_relative_prefix)
3951 get_relative_prefix = make_relative_prefix;
3953 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3954 see if we can create it from the pathname specified in
3955 decoded_options[0].arg. */
3957 gcc_libexec_prefix = standard_libexec_prefix;
3958 #ifndef VMS
3959 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3960 if (!gcc_exec_prefix)
3962 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
3963 standard_bindir_prefix,
3964 standard_exec_prefix);
3965 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
3966 standard_bindir_prefix,
3967 standard_libexec_prefix);
3968 if (gcc_exec_prefix)
3969 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3971 else
3973 /* make_relative_prefix requires a program name, but
3974 GCC_EXEC_PREFIX is typically a directory name with a trailing
3975 / (which is ignored by make_relative_prefix), so append a
3976 program name. */
3977 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
3978 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
3979 standard_exec_prefix,
3980 standard_libexec_prefix);
3982 /* The path is unrelocated, so fallback to the original setting. */
3983 if (!gcc_libexec_prefix)
3984 gcc_libexec_prefix = standard_libexec_prefix;
3986 free (tmp_prefix);
3988 #else
3989 #endif
3990 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
3991 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
3992 or an automatically created GCC_EXEC_PREFIX from
3993 decoded_options[0].arg. */
3995 /* Do language-specific adjustment/addition of flags. */
3996 lang_specific_driver (&decoded_options, &decoded_options_count,
3997 &added_libraries);
3999 if (gcc_exec_prefix)
4001 int len = strlen (gcc_exec_prefix);
4003 if (len > (int) sizeof ("/lib/gcc/") - 1
4004 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
4006 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
4007 if (IS_DIR_SEPARATOR (*temp)
4008 && filename_ncmp (temp + 1, "lib", 3) == 0
4009 && IS_DIR_SEPARATOR (temp[4])
4010 && filename_ncmp (temp + 5, "gcc", 3) == 0)
4011 len -= sizeof ("/lib/gcc/") - 1;
4014 set_std_prefix (gcc_exec_prefix, len);
4015 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
4016 PREFIX_PRIORITY_LAST, 0, 0);
4017 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
4018 PREFIX_PRIORITY_LAST, 0, 0);
4021 /* COMPILER_PATH and LIBRARY_PATH have values
4022 that are lists of directory names with colons. */
4024 temp = getenv ("COMPILER_PATH");
4025 if (temp)
4027 const char *startp, *endp;
4028 char *nstore = (char *) alloca (strlen (temp) + 3);
4030 startp = endp = temp;
4031 while (1)
4033 if (*endp == PATH_SEPARATOR || *endp == 0)
4035 strncpy (nstore, startp, endp - startp);
4036 if (endp == startp)
4037 strcpy (nstore, concat (".", dir_separator_str, NULL));
4038 else if (!IS_DIR_SEPARATOR (endp[-1]))
4040 nstore[endp - startp] = DIR_SEPARATOR;
4041 nstore[endp - startp + 1] = 0;
4043 else
4044 nstore[endp - startp] = 0;
4045 add_prefix (&exec_prefixes, nstore, 0,
4046 PREFIX_PRIORITY_LAST, 0, 0);
4047 add_prefix (&include_prefixes, nstore, 0,
4048 PREFIX_PRIORITY_LAST, 0, 0);
4049 if (*endp == 0)
4050 break;
4051 endp = startp = endp + 1;
4053 else
4054 endp++;
4058 temp = getenv (LIBRARY_PATH_ENV);
4059 if (temp && *cross_compile == '0')
4061 const char *startp, *endp;
4062 char *nstore = (char *) alloca (strlen (temp) + 3);
4064 startp = endp = temp;
4065 while (1)
4067 if (*endp == PATH_SEPARATOR || *endp == 0)
4069 strncpy (nstore, startp, endp - startp);
4070 if (endp == startp)
4071 strcpy (nstore, concat (".", dir_separator_str, NULL));
4072 else if (!IS_DIR_SEPARATOR (endp[-1]))
4074 nstore[endp - startp] = DIR_SEPARATOR;
4075 nstore[endp - startp + 1] = 0;
4077 else
4078 nstore[endp - startp] = 0;
4079 add_prefix (&startfile_prefixes, nstore, NULL,
4080 PREFIX_PRIORITY_LAST, 0, 1);
4081 if (*endp == 0)
4082 break;
4083 endp = startp = endp + 1;
4085 else
4086 endp++;
4090 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
4091 temp = getenv ("LPATH");
4092 if (temp && *cross_compile == '0')
4094 const char *startp, *endp;
4095 char *nstore = (char *) alloca (strlen (temp) + 3);
4097 startp = endp = temp;
4098 while (1)
4100 if (*endp == PATH_SEPARATOR || *endp == 0)
4102 strncpy (nstore, startp, endp - startp);
4103 if (endp == startp)
4104 strcpy (nstore, concat (".", dir_separator_str, NULL));
4105 else if (!IS_DIR_SEPARATOR (endp[-1]))
4107 nstore[endp - startp] = DIR_SEPARATOR;
4108 nstore[endp - startp + 1] = 0;
4110 else
4111 nstore[endp - startp] = 0;
4112 add_prefix (&startfile_prefixes, nstore, NULL,
4113 PREFIX_PRIORITY_LAST, 0, 1);
4114 if (*endp == 0)
4115 break;
4116 endp = startp = endp + 1;
4118 else
4119 endp++;
4123 /* Process the options and store input files and switches in their
4124 vectors. */
4126 last_language_n_infiles = -1;
4128 set_option_handlers (&handlers);
4130 for (j = 1; j < decoded_options_count; j++)
4132 switch (decoded_options[j].opt_index)
4134 case OPT_S:
4135 case OPT_c:
4136 case OPT_E:
4137 have_c = 1;
4138 break;
4140 if (have_c)
4141 break;
4144 for (j = 1; j < decoded_options_count; j++)
4146 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
4148 const char *arg = decoded_options[j].arg;
4149 const char *p = strrchr (arg, '@');
4150 char *fname;
4151 long offset;
4152 int consumed;
4153 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4154 arg = convert_filename (arg, 0, access (arg, F_OK));
4155 #endif
4156 /* For LTO static archive support we handle input file
4157 specifications that are composed of a filename and
4158 an offset like FNAME@OFFSET. */
4159 if (p
4160 && p != arg
4161 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
4162 && strlen (p) == (unsigned int)consumed)
4164 fname = (char *)xmalloc (p - arg + 1);
4165 memcpy (fname, arg, p - arg);
4166 fname[p - arg] = '\0';
4167 /* Only accept non-stdin and existing FNAME parts, otherwise
4168 try with the full name. */
4169 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
4171 free (fname);
4172 fname = xstrdup (arg);
4175 else
4176 fname = xstrdup (arg);
4178 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
4179 perror_with_name (fname);
4180 else
4181 add_infile (arg, spec_lang);
4183 free (fname);
4184 continue;
4187 read_cmdline_option (&global_options, &global_options_set,
4188 decoded_options + j, UNKNOWN_LOCATION,
4189 CL_DRIVER, &handlers, global_dc);
4192 if (output_file
4193 && strcmp (output_file, "-") != 0
4194 && strcmp (output_file, HOST_BIT_BUCKET) != 0)
4196 int i;
4197 for (i = 0; i < n_infiles; i++)
4198 if ((!infiles[i].language || infiles[i].language[0] != '*')
4199 && canonical_filename_eq (infiles[i].name, output_file))
4200 fatal_error ("input file %qs is the same as output file",
4201 output_file);
4204 /* If -save-temps=obj and -o name, create the prefix to use for %b.
4205 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
4206 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
4208 save_temps_length = strlen (save_temps_prefix);
4209 temp = strrchr (lbasename (save_temps_prefix), '.');
4210 if (temp)
4212 save_temps_length -= strlen (temp);
4213 save_temps_prefix[save_temps_length] = '\0';
4217 else if (save_temps_prefix != NULL)
4219 free (save_temps_prefix);
4220 save_temps_prefix = NULL;
4223 if (save_temps_flag && use_pipes)
4225 /* -save-temps overrides -pipe, so that temp files are produced */
4226 if (save_temps_flag)
4227 warning (0, "-pipe ignored because -save-temps specified");
4228 use_pipes = 0;
4231 if (!compare_debug)
4233 const char *gcd = getenv ("GCC_COMPARE_DEBUG");
4235 if (gcd && gcd[0] == '-')
4237 compare_debug = 2;
4238 compare_debug_opt = gcd;
4240 else if (gcd && *gcd && strcmp (gcd, "0"))
4242 compare_debug = 3;
4243 compare_debug_opt = "-gtoggle";
4246 else if (compare_debug < 0)
4248 compare_debug = 0;
4249 gcc_assert (!compare_debug_opt);
4252 /* Set up the search paths. We add directories that we expect to
4253 contain GNU Toolchain components before directories specified by
4254 the machine description so that we will find GNU components (like
4255 the GNU assembler) before those of the host system. */
4257 /* If we don't know where the toolchain has been installed, use the
4258 configured-in locations. */
4259 if (!gcc_exec_prefix)
4261 #ifndef OS2
4262 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
4263 PREFIX_PRIORITY_LAST, 1, 0);
4264 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
4265 PREFIX_PRIORITY_LAST, 2, 0);
4266 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
4267 PREFIX_PRIORITY_LAST, 2, 0);
4268 #endif
4269 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
4270 PREFIX_PRIORITY_LAST, 1, 0);
4273 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
4274 tooldir_prefix2 = concat (tooldir_base_prefix, spec_host_machine,
4275 dir_separator_str, NULL);
4277 /* Look for tools relative to the location from which the driver is
4278 running, or, if that is not available, the configured prefix. */
4279 tooldir_prefix
4280 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4281 spec_host_machine, dir_separator_str, spec_version,
4282 accel_dir_suffix, dir_separator_str, tooldir_prefix2, NULL);
4283 free (tooldir_prefix2);
4285 add_prefix (&exec_prefixes,
4286 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4287 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4288 add_prefix (&startfile_prefixes,
4289 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4290 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4291 free (tooldir_prefix);
4293 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4294 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4295 then consider it to relocate with the rest of the GCC installation
4296 if GCC_EXEC_PREFIX is set.
4297 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4298 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
4300 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
4301 standard_bindir_prefix,
4302 target_system_root);
4303 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4305 target_system_root = tmp_prefix;
4306 target_system_root_changed = 1;
4309 #endif
4311 /* More prefixes are enabled in main, after we read the specs file
4312 and determine whether this is cross-compilation or not. */
4314 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4315 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
4317 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
4318 environment variable. */
4319 if (compare_debug == 2 || compare_debug == 3)
4321 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
4322 save_switch (opt, 0, NULL, false, true);
4323 compare_debug = 1;
4326 /* Ensure we only invoke each subprocess once. */
4327 if (print_subprocess_help || print_help_list || print_version)
4329 n_infiles = 0;
4331 /* Create a dummy input file, so that we can pass
4332 the help option on to the various sub-processes. */
4333 add_infile ("help-dummy", "c");
4336 alloc_switch ();
4337 switches[n_switches].part1 = 0;
4338 alloc_infile ();
4339 infiles[n_infiles].name = 0;
4342 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4343 and place that in the environment. */
4345 static void
4346 set_collect_gcc_options (void)
4348 int i;
4349 int first_time;
4351 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4352 the compiler. */
4353 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4354 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4356 first_time = TRUE;
4357 for (i = 0; (int) i < n_switches; i++)
4359 const char *const *args;
4360 const char *p, *q;
4361 if (!first_time)
4362 obstack_grow (&collect_obstack, " ", 1);
4364 first_time = FALSE;
4366 /* Ignore elided switches. */
4367 if ((switches[i].live_cond
4368 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4369 == SWITCH_IGNORE)
4370 continue;
4372 obstack_grow (&collect_obstack, "'-", 2);
4373 q = switches[i].part1;
4374 while ((p = strchr (q, '\'')))
4376 obstack_grow (&collect_obstack, q, p - q);
4377 obstack_grow (&collect_obstack, "'\\''", 4);
4378 q = ++p;
4380 obstack_grow (&collect_obstack, q, strlen (q));
4381 obstack_grow (&collect_obstack, "'", 1);
4383 for (args = switches[i].args; args && *args; args++)
4385 obstack_grow (&collect_obstack, " '", 2);
4386 q = *args;
4387 while ((p = strchr (q, '\'')))
4389 obstack_grow (&collect_obstack, q, p - q);
4390 obstack_grow (&collect_obstack, "'\\''", 4);
4391 q = ++p;
4393 obstack_grow (&collect_obstack, q, strlen (q));
4394 obstack_grow (&collect_obstack, "'", 1);
4397 obstack_grow (&collect_obstack, "\0", 1);
4398 xputenv (XOBFINISH (&collect_obstack, char *));
4401 /* Process a spec string, accumulating and running commands. */
4403 /* These variables describe the input file name.
4404 input_file_number is the index on outfiles of this file,
4405 so that the output file name can be stored for later use by %o.
4406 input_basename is the start of the part of the input file
4407 sans all directory names, and basename_length is the number
4408 of characters starting there excluding the suffix .c or whatever. */
4410 static const char *gcc_input_filename;
4411 static int input_file_number;
4412 size_t input_filename_length;
4413 static int basename_length;
4414 static int suffixed_basename_length;
4415 static const char *input_basename;
4416 static const char *input_suffix;
4417 #ifndef HOST_LACKS_INODE_NUMBERS
4418 static struct stat input_stat;
4419 #endif
4420 static int input_stat_set;
4422 /* The compiler used to process the current input file. */
4423 static struct compiler *input_file_compiler;
4425 /* These are variables used within do_spec and do_spec_1. */
4427 /* Nonzero if an arg has been started and not yet terminated
4428 (with space, tab or newline). */
4429 static int arg_going;
4431 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4432 is a temporary file name. */
4433 static int delete_this_arg;
4435 /* Nonzero means %w has been seen; the next arg to be terminated
4436 is the output file name of this compilation. */
4437 static int this_is_output_file;
4439 /* Nonzero means %s has been seen; the next arg to be terminated
4440 is the name of a library file and we should try the standard
4441 search dirs for it. */
4442 static int this_is_library_file;
4444 /* Nonzero means %T has been seen; the next arg to be terminated
4445 is the name of a linker script and we should try all of the
4446 standard search dirs for it. If it is found insert a --script
4447 command line switch and then substitute the full path in place,
4448 otherwise generate an error message. */
4449 static int this_is_linker_script;
4451 /* Nonzero means that the input of this command is coming from a pipe. */
4452 static int input_from_pipe;
4454 /* Nonnull means substitute this for any suffix when outputting a switches
4455 arguments. */
4456 static const char *suffix_subst;
4458 /* If there is an argument being accumulated, terminate it and store it. */
4460 static void
4461 end_going_arg (void)
4463 if (arg_going)
4465 const char *string;
4467 obstack_1grow (&obstack, 0);
4468 string = XOBFINISH (&obstack, const char *);
4469 if (this_is_library_file)
4470 string = find_file (string);
4471 if (this_is_linker_script)
4473 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4475 if (full_script_path == NULL)
4477 error ("unable to locate default linker script %qs in the library search paths", string);
4478 /* Script was not found on search path. */
4479 return;
4481 store_arg ("--script", false, false);
4482 string = full_script_path;
4484 store_arg (string, delete_this_arg, this_is_output_file);
4485 if (this_is_output_file)
4486 outfiles[input_file_number] = string;
4487 arg_going = 0;
4492 /* Parse the WRAPPER string which is a comma separated list of the command line
4493 and insert them into the beginning of argbuf. */
4495 static void
4496 insert_wrapper (const char *wrapper)
4498 int n = 0;
4499 int i;
4500 char *buf = xstrdup (wrapper);
4501 char *p = buf;
4502 unsigned int old_length = argbuf.length ();
4506 n++;
4507 while (*p == ',')
4508 p++;
4510 while ((p = strchr (p, ',')) != NULL);
4512 argbuf.safe_grow (old_length + n);
4513 memmove (argbuf.address () + n,
4514 argbuf.address (),
4515 old_length * sizeof (const_char_p));
4517 i = 0;
4518 p = buf;
4521 while (*p == ',')
4523 *p = 0;
4524 p++;
4526 argbuf[i] = p;
4527 i++;
4529 while ((p = strchr (p, ',')) != NULL);
4530 gcc_assert (i == n);
4533 /* Process the spec SPEC and run the commands specified therein.
4534 Returns 0 if the spec is successfully processed; -1 if failed. */
4537 do_spec (const char *spec)
4539 int value;
4541 value = do_spec_2 (spec);
4543 /* Force out any unfinished command.
4544 If -pipe, this forces out the last command if it ended in `|'. */
4545 if (value == 0)
4547 if (argbuf.length () > 0
4548 && !strcmp (argbuf.last (), "|"))
4549 argbuf.pop ();
4551 set_collect_gcc_options ();
4553 if (argbuf.length () > 0)
4554 value = execute ();
4557 return value;
4560 static int
4561 do_spec_2 (const char *spec)
4563 int result;
4565 clear_args ();
4566 arg_going = 0;
4567 delete_this_arg = 0;
4568 this_is_output_file = 0;
4569 this_is_library_file = 0;
4570 this_is_linker_script = 0;
4571 input_from_pipe = 0;
4572 suffix_subst = NULL;
4574 result = do_spec_1 (spec, 0, NULL);
4576 end_going_arg ();
4578 return result;
4582 /* Process the given spec string and add any new options to the end
4583 of the switches/n_switches array. */
4585 static void
4586 do_option_spec (const char *name, const char *spec)
4588 unsigned int i, value_count, value_len;
4589 const char *p, *q, *value;
4590 char *tmp_spec, *tmp_spec_p;
4592 if (configure_default_options[0].name == NULL)
4593 return;
4595 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4596 if (strcmp (configure_default_options[i].name, name) == 0)
4597 break;
4598 if (i == ARRAY_SIZE (configure_default_options))
4599 return;
4601 value = configure_default_options[i].value;
4602 value_len = strlen (value);
4604 /* Compute the size of the final spec. */
4605 value_count = 0;
4606 p = spec;
4607 while ((p = strstr (p, "%(VALUE)")) != NULL)
4609 p ++;
4610 value_count ++;
4613 /* Replace each %(VALUE) by the specified value. */
4614 tmp_spec = (char *) alloca (strlen (spec) + 1
4615 + value_count * (value_len - strlen ("%(VALUE)")));
4616 tmp_spec_p = tmp_spec;
4617 q = spec;
4618 while ((p = strstr (q, "%(VALUE)")) != NULL)
4620 memcpy (tmp_spec_p, q, p - q);
4621 tmp_spec_p = tmp_spec_p + (p - q);
4622 memcpy (tmp_spec_p, value, value_len);
4623 tmp_spec_p += value_len;
4624 q = p + strlen ("%(VALUE)");
4626 strcpy (tmp_spec_p, q);
4628 do_self_spec (tmp_spec);
4631 /* Process the given spec string and add any new options to the end
4632 of the switches/n_switches array. */
4634 static void
4635 do_self_spec (const char *spec)
4637 int i;
4639 do_spec_2 (spec);
4640 do_spec_1 (" ", 0, NULL);
4642 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4643 do_self_specs adds the replacements to switches array, so it shouldn't
4644 be processed afterwards. */
4645 for (i = 0; i < n_switches; i++)
4646 if ((switches[i].live_cond & SWITCH_IGNORE))
4647 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4649 if (argbuf.length () > 0)
4651 const char **argbuf_copy;
4652 struct cl_decoded_option *decoded_options;
4653 struct cl_option_handlers handlers;
4654 unsigned int decoded_options_count;
4655 unsigned int j;
4657 /* Create a copy of argbuf with a dummy argv[0] entry for
4658 decode_cmdline_options_to_array. */
4659 argbuf_copy = XNEWVEC (const char *,
4660 argbuf.length () + 1);
4661 argbuf_copy[0] = "";
4662 memcpy (argbuf_copy + 1, argbuf.address (),
4663 argbuf.length () * sizeof (const char *));
4665 decode_cmdline_options_to_array (argbuf.length () + 1,
4666 argbuf_copy,
4667 CL_DRIVER, &decoded_options,
4668 &decoded_options_count);
4669 free (argbuf_copy);
4671 set_option_handlers (&handlers);
4673 for (j = 1; j < decoded_options_count; j++)
4675 switch (decoded_options[j].opt_index)
4677 case OPT_SPECIAL_input_file:
4678 /* Specs should only generate options, not input
4679 files. */
4680 if (strcmp (decoded_options[j].arg, "-") != 0)
4681 fatal_error ("switch %qs does not start with %<-%>",
4682 decoded_options[j].arg);
4683 else
4684 fatal_error ("spec-generated switch is just %<-%>");
4685 break;
4687 case OPT_fcompare_debug_second:
4688 case OPT_fcompare_debug:
4689 case OPT_fcompare_debug_:
4690 case OPT_o:
4691 /* Avoid duplicate processing of some options from
4692 compare-debug specs; just save them here. */
4693 save_switch (decoded_options[j].canonical_option[0],
4694 (decoded_options[j].canonical_option_num_elements
4695 - 1),
4696 &decoded_options[j].canonical_option[1], false, true);
4697 break;
4699 default:
4700 read_cmdline_option (&global_options, &global_options_set,
4701 decoded_options + j, UNKNOWN_LOCATION,
4702 CL_DRIVER, &handlers, global_dc);
4703 break;
4707 alloc_switch ();
4708 switches[n_switches].part1 = 0;
4712 /* Callback for processing %D and %I specs. */
4714 struct spec_path_info {
4715 const char *option;
4716 const char *append;
4717 size_t append_len;
4718 bool omit_relative;
4719 bool separate_options;
4722 static void *
4723 spec_path (char *path, void *data)
4725 struct spec_path_info *info = (struct spec_path_info *) data;
4726 size_t len = 0;
4727 char save = 0;
4729 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4730 return NULL;
4732 if (info->append_len != 0)
4734 len = strlen (path);
4735 memcpy (path + len, info->append, info->append_len + 1);
4738 if (!is_directory (path, true))
4739 return NULL;
4741 do_spec_1 (info->option, 1, NULL);
4742 if (info->separate_options)
4743 do_spec_1 (" ", 0, NULL);
4745 if (info->append_len == 0)
4747 len = strlen (path);
4748 save = path[len - 1];
4749 if (IS_DIR_SEPARATOR (path[len - 1]))
4750 path[len - 1] = '\0';
4753 do_spec_1 (path, 1, NULL);
4754 do_spec_1 (" ", 0, NULL);
4756 /* Must not damage the original path. */
4757 if (info->append_len == 0)
4758 path[len - 1] = save;
4760 return NULL;
4763 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
4764 argument list. */
4766 static void
4767 create_at_file (char **argv)
4769 char *temp_file = make_temp_file ("");
4770 char *at_argument = concat ("@", temp_file, NULL);
4771 FILE *f = fopen (temp_file, "w");
4772 int status;
4774 if (f == NULL)
4775 fatal_error ("could not open temporary response file %s",
4776 temp_file);
4778 status = writeargv (argv, f);
4780 if (status)
4781 fatal_error ("could not write to temporary response file %s",
4782 temp_file);
4784 status = fclose (f);
4786 if (EOF == status)
4787 fatal_error ("could not close temporary response file %s",
4788 temp_file);
4790 store_arg (at_argument, 0, 0);
4792 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
4795 /* True if we should compile INFILE. */
4797 static bool
4798 compile_input_file_p (struct infile *infile)
4800 if ((!infile->language) || (infile->language[0] != '*'))
4801 if (infile->incompiler == input_file_compiler)
4802 return true;
4803 return false;
4806 /* Process each member of VEC as a spec. */
4808 static void
4809 do_specs_vec (vec<char_p> vec)
4811 unsigned ix;
4812 char *opt;
4814 FOR_EACH_VEC_ELT (vec, ix, opt)
4816 do_spec_1 (opt, 1, NULL);
4817 /* Make each accumulated option a separate argument. */
4818 do_spec_1 (" ", 0, NULL);
4822 /* Process the sub-spec SPEC as a portion of a larger spec.
4823 This is like processing a whole spec except that we do
4824 not initialize at the beginning and we do not supply a
4825 newline by default at the end.
4826 INSWITCH nonzero means don't process %-sequences in SPEC;
4827 in this case, % is treated as an ordinary character.
4828 This is used while substituting switches.
4829 INSWITCH nonzero also causes SPC not to terminate an argument.
4831 Value is zero unless a line was finished
4832 and the command on that line reported an error. */
4834 static int
4835 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4837 const char *p = spec;
4838 int c;
4839 int i;
4840 int value;
4842 /* If it's an empty string argument to a switch, keep it as is. */
4843 if (inswitch && !*p)
4844 arg_going = 1;
4846 while ((c = *p++))
4847 /* If substituting a switch, treat all chars like letters.
4848 Otherwise, NL, SPC, TAB and % are special. */
4849 switch (inswitch ? 'a' : c)
4851 case '\n':
4852 end_going_arg ();
4854 if (argbuf.length () > 0
4855 && !strcmp (argbuf.last (), "|"))
4857 /* A `|' before the newline means use a pipe here,
4858 but only if -pipe was specified.
4859 Otherwise, execute now and don't pass the `|' as an arg. */
4860 if (use_pipes)
4862 input_from_pipe = 1;
4863 break;
4865 else
4866 argbuf.pop ();
4869 set_collect_gcc_options ();
4871 if (argbuf.length () > 0)
4873 value = execute ();
4874 if (value)
4875 return value;
4877 /* Reinitialize for a new command, and for a new argument. */
4878 clear_args ();
4879 arg_going = 0;
4880 delete_this_arg = 0;
4881 this_is_output_file = 0;
4882 this_is_library_file = 0;
4883 this_is_linker_script = 0;
4884 input_from_pipe = 0;
4885 break;
4887 case '|':
4888 end_going_arg ();
4890 /* Use pipe */
4891 obstack_1grow (&obstack, c);
4892 arg_going = 1;
4893 break;
4895 case '\t':
4896 case ' ':
4897 end_going_arg ();
4899 /* Reinitialize for a new argument. */
4900 delete_this_arg = 0;
4901 this_is_output_file = 0;
4902 this_is_library_file = 0;
4903 this_is_linker_script = 0;
4904 break;
4906 case '%':
4907 switch (c = *p++)
4909 case 0:
4910 fatal_error ("spec %qs invalid", spec);
4912 case 'b':
4913 if (save_temps_length)
4914 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4915 else
4916 obstack_grow (&obstack, input_basename, basename_length);
4917 if (compare_debug < 0)
4918 obstack_grow (&obstack, ".gk", 3);
4919 arg_going = 1;
4920 break;
4922 case 'B':
4923 if (save_temps_length)
4924 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4925 else
4926 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4927 if (compare_debug < 0)
4928 obstack_grow (&obstack, ".gk", 3);
4929 arg_going = 1;
4930 break;
4932 case 'd':
4933 delete_this_arg = 2;
4934 break;
4936 /* Dump out the directories specified with LIBRARY_PATH,
4937 followed by the absolute directories
4938 that we search for startfiles. */
4939 case 'D':
4941 struct spec_path_info info;
4943 info.option = "-L";
4944 info.append_len = 0;
4945 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4946 /* Used on systems which record the specified -L dirs
4947 and use them to search for dynamic linking.
4948 Relative directories always come from -B,
4949 and it is better not to use them for searching
4950 at run time. In particular, stage1 loses. */
4951 info.omit_relative = true;
4952 #else
4953 info.omit_relative = false;
4954 #endif
4955 info.separate_options = false;
4957 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
4959 break;
4961 case 'e':
4962 /* %efoo means report an error with `foo' as error message
4963 and don't execute any more commands for this file. */
4965 const char *q = p;
4966 char *buf;
4967 while (*p != 0 && *p != '\n')
4968 p++;
4969 buf = (char *) alloca (p - q + 1);
4970 strncpy (buf, q, p - q);
4971 buf[p - q] = 0;
4972 error ("%s", _(buf));
4973 return -1;
4975 break;
4976 case 'n':
4977 /* %nfoo means report a notice with `foo' on stderr. */
4979 const char *q = p;
4980 char *buf;
4981 while (*p != 0 && *p != '\n')
4982 p++;
4983 buf = (char *) alloca (p - q + 1);
4984 strncpy (buf, q, p - q);
4985 buf[p - q] = 0;
4986 inform (0, "%s", _(buf));
4987 if (*p)
4988 p++;
4990 break;
4992 case 'j':
4994 struct stat st;
4996 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4997 defined, and it is not a directory, and it is
4998 writable, use it. Otherwise, treat this like any
4999 other temporary file. */
5001 if ((!save_temps_flag)
5002 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
5003 && (access (HOST_BIT_BUCKET, W_OK) == 0))
5005 obstack_grow (&obstack, HOST_BIT_BUCKET,
5006 strlen (HOST_BIT_BUCKET));
5007 delete_this_arg = 0;
5008 arg_going = 1;
5009 break;
5012 goto create_temp_file;
5013 case '|':
5014 if (use_pipes)
5016 obstack_1grow (&obstack, '-');
5017 delete_this_arg = 0;
5018 arg_going = 1;
5020 /* consume suffix */
5021 while (*p == '.' || ISALNUM ((unsigned char) *p))
5022 p++;
5023 if (p[0] == '%' && p[1] == 'O')
5024 p += 2;
5026 break;
5028 goto create_temp_file;
5029 case 'm':
5030 if (use_pipes)
5032 /* consume suffix */
5033 while (*p == '.' || ISALNUM ((unsigned char) *p))
5034 p++;
5035 if (p[0] == '%' && p[1] == 'O')
5036 p += 2;
5038 break;
5040 goto create_temp_file;
5041 case 'g':
5042 case 'u':
5043 case 'U':
5044 create_temp_file:
5046 struct temp_name *t;
5047 int suffix_length;
5048 const char *suffix = p;
5049 char *saved_suffix = NULL;
5051 while (*p == '.' || ISALNUM ((unsigned char) *p))
5052 p++;
5053 suffix_length = p - suffix;
5054 if (p[0] == '%' && p[1] == 'O')
5056 p += 2;
5057 /* We don't support extra suffix characters after %O. */
5058 if (*p == '.' || ISALNUM ((unsigned char) *p))
5059 fatal_error ("spec %qs has invalid %<%%0%c%>", spec, *p);
5060 if (suffix_length == 0)
5061 suffix = TARGET_OBJECT_SUFFIX;
5062 else
5064 saved_suffix
5065 = XNEWVEC (char, suffix_length
5066 + strlen (TARGET_OBJECT_SUFFIX) + 1);
5067 strncpy (saved_suffix, suffix, suffix_length);
5068 strcpy (saved_suffix + suffix_length,
5069 TARGET_OBJECT_SUFFIX);
5071 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
5074 if (compare_debug < 0)
5076 suffix = concat (".gk", suffix, NULL);
5077 suffix_length += 3;
5080 /* If -save-temps=obj and -o were specified, use that for the
5081 temp file. */
5082 if (save_temps_length)
5084 char *tmp;
5085 temp_filename_length
5086 = save_temps_length + suffix_length + 1;
5087 tmp = (char *) alloca (temp_filename_length);
5088 memcpy (tmp, save_temps_prefix, save_temps_length);
5089 memcpy (tmp + save_temps_length, suffix, suffix_length);
5090 tmp[save_temps_length + suffix_length] = '\0';
5091 temp_filename = save_string (tmp, save_temps_length
5092 + suffix_length);
5093 obstack_grow (&obstack, temp_filename,
5094 temp_filename_length);
5095 arg_going = 1;
5096 delete_this_arg = 0;
5097 break;
5100 /* If the gcc_input_filename has the same suffix specified
5101 for the %g, %u, or %U, and -save-temps is specified,
5102 we could end up using that file as an intermediate
5103 thus clobbering the user's source file (.e.g.,
5104 gcc -save-temps foo.s would clobber foo.s with the
5105 output of cpp0). So check for this condition and
5106 generate a temp file as the intermediate. */
5108 if (save_temps_flag)
5110 char *tmp;
5111 temp_filename_length = basename_length + suffix_length + 1;
5112 tmp = (char *) alloca (temp_filename_length);
5113 memcpy (tmp, input_basename, basename_length);
5114 memcpy (tmp + basename_length, suffix, suffix_length);
5115 tmp[basename_length + suffix_length] = '\0';
5116 temp_filename = tmp;
5118 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
5120 #ifndef HOST_LACKS_INODE_NUMBERS
5121 struct stat st_temp;
5123 /* Note, set_input() resets input_stat_set to 0. */
5124 if (input_stat_set == 0)
5126 input_stat_set = stat (gcc_input_filename,
5127 &input_stat);
5128 if (input_stat_set >= 0)
5129 input_stat_set = 1;
5132 /* If we have the stat for the gcc_input_filename
5133 and we can do the stat for the temp_filename
5134 then the they could still refer to the same
5135 file if st_dev/st_ino's are the same. */
5136 if (input_stat_set != 1
5137 || stat (temp_filename, &st_temp) < 0
5138 || input_stat.st_dev != st_temp.st_dev
5139 || input_stat.st_ino != st_temp.st_ino)
5140 #else
5141 /* Just compare canonical pathnames. */
5142 char* input_realname = lrealpath (gcc_input_filename);
5143 char* temp_realname = lrealpath (temp_filename);
5144 bool files_differ = filename_cmp (input_realname, temp_realname);
5145 free (input_realname);
5146 free (temp_realname);
5147 if (files_differ)
5148 #endif
5150 temp_filename = save_string (temp_filename,
5151 temp_filename_length + 1);
5152 obstack_grow (&obstack, temp_filename,
5153 temp_filename_length);
5154 arg_going = 1;
5155 delete_this_arg = 0;
5156 break;
5161 /* See if we already have an association of %g/%u/%U and
5162 suffix. */
5163 for (t = temp_names; t; t = t->next)
5164 if (t->length == suffix_length
5165 && strncmp (t->suffix, suffix, suffix_length) == 0
5166 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
5167 break;
5169 /* Make a new association if needed. %u and %j
5170 require one. */
5171 if (t == 0 || c == 'u' || c == 'j')
5173 if (t == 0)
5175 t = XNEW (struct temp_name);
5176 t->next = temp_names;
5177 temp_names = t;
5179 t->length = suffix_length;
5180 if (saved_suffix)
5182 t->suffix = saved_suffix;
5183 saved_suffix = NULL;
5185 else
5186 t->suffix = save_string (suffix, suffix_length);
5187 t->unique = (c == 'u' || c == 'U' || c == 'j');
5188 temp_filename = make_temp_file (t->suffix);
5189 temp_filename_length = strlen (temp_filename);
5190 t->filename = temp_filename;
5191 t->filename_length = temp_filename_length;
5194 free (saved_suffix);
5196 obstack_grow (&obstack, t->filename, t->filename_length);
5197 delete_this_arg = 1;
5199 arg_going = 1;
5200 break;
5202 case 'i':
5203 if (combine_inputs)
5205 if (at_file_supplied)
5207 /* We are going to expand `%i' to `@FILE', where FILE
5208 is a newly-created temporary filename. The filenames
5209 that would usually be expanded in place of %o will be
5210 written to the temporary file. */
5211 char **argv;
5212 int n_files = 0;
5213 int j;
5215 for (i = 0; i < n_infiles; i++)
5216 if (compile_input_file_p (&infiles[i]))
5217 n_files++;
5219 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5221 /* Copy the strings over. */
5222 for (i = 0, j = 0; i < n_infiles; i++)
5223 if (compile_input_file_p (&infiles[i]))
5225 argv[j] = CONST_CAST (char *, infiles[i].name);
5226 infiles[i].compiled = true;
5227 j++;
5229 argv[j] = NULL;
5231 create_at_file (argv);
5233 else
5234 for (i = 0; (int) i < n_infiles; i++)
5235 if (compile_input_file_p (&infiles[i]))
5237 store_arg (infiles[i].name, 0, 0);
5238 infiles[i].compiled = true;
5241 else
5243 obstack_grow (&obstack, gcc_input_filename,
5244 input_filename_length);
5245 arg_going = 1;
5247 break;
5249 case 'I':
5251 struct spec_path_info info;
5253 if (multilib_dir)
5255 do_spec_1 ("-imultilib", 1, NULL);
5256 /* Make this a separate argument. */
5257 do_spec_1 (" ", 0, NULL);
5258 do_spec_1 (multilib_dir, 1, NULL);
5259 do_spec_1 (" ", 0, NULL);
5262 if (multiarch_dir)
5264 do_spec_1 ("-imultiarch", 1, NULL);
5265 /* Make this a separate argument. */
5266 do_spec_1 (" ", 0, NULL);
5267 do_spec_1 (multiarch_dir, 1, NULL);
5268 do_spec_1 (" ", 0, NULL);
5271 if (gcc_exec_prefix)
5273 do_spec_1 ("-iprefix", 1, NULL);
5274 /* Make this a separate argument. */
5275 do_spec_1 (" ", 0, NULL);
5276 do_spec_1 (gcc_exec_prefix, 1, NULL);
5277 do_spec_1 (" ", 0, NULL);
5280 if (target_system_root_changed ||
5281 (target_system_root && target_sysroot_hdrs_suffix))
5283 do_spec_1 ("-isysroot", 1, NULL);
5284 /* Make this a separate argument. */
5285 do_spec_1 (" ", 0, NULL);
5286 do_spec_1 (target_system_root, 1, NULL);
5287 if (target_sysroot_hdrs_suffix)
5288 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
5289 do_spec_1 (" ", 0, NULL);
5292 info.option = "-isystem";
5293 info.append = "include";
5294 info.append_len = strlen (info.append);
5295 info.omit_relative = false;
5296 info.separate_options = true;
5298 for_each_path (&include_prefixes, false, info.append_len,
5299 spec_path, &info);
5301 info.append = "include-fixed";
5302 if (*sysroot_hdrs_suffix_spec)
5303 info.append = concat (info.append, dir_separator_str,
5304 multilib_dir, NULL);
5305 info.append_len = strlen (info.append);
5306 for_each_path (&include_prefixes, false, info.append_len,
5307 spec_path, &info);
5309 break;
5311 case 'o':
5313 int max = n_infiles;
5314 max += lang_specific_extra_outfiles;
5316 if (HAVE_GNU_LD && at_file_supplied)
5318 /* We are going to expand `%o' to `@FILE', where FILE
5319 is a newly-created temporary filename. The filenames
5320 that would usually be expanded in place of %o will be
5321 written to the temporary file. */
5323 char **argv;
5324 int n_files, j;
5326 /* Convert OUTFILES into a form suitable for writeargv. */
5328 /* Determine how many are non-NULL. */
5329 for (n_files = 0, i = 0; i < max; i++)
5330 n_files += outfiles[i] != NULL;
5332 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5334 /* Copy the strings over. */
5335 for (i = 0, j = 0; i < max; i++)
5336 if (outfiles[i])
5338 argv[j] = CONST_CAST (char *, outfiles[i]);
5339 j++;
5341 argv[j] = NULL;
5343 create_at_file (argv);
5345 else
5346 for (i = 0; i < max; i++)
5347 if (outfiles[i])
5348 store_arg (outfiles[i], 0, 0);
5349 break;
5352 case 'O':
5353 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5354 arg_going = 1;
5355 break;
5357 case 's':
5358 this_is_library_file = 1;
5359 break;
5361 case 'T':
5362 this_is_linker_script = 1;
5363 break;
5365 case 'V':
5366 outfiles[input_file_number] = NULL;
5367 break;
5369 case 'w':
5370 this_is_output_file = 1;
5371 break;
5373 case 'W':
5375 unsigned int cur_index = argbuf.length ();
5376 /* Handle the {...} following the %W. */
5377 if (*p != '{')
5378 fatal_error ("spec %qs has invalid %<%%W%c%>", spec, *p);
5379 p = handle_braces (p + 1);
5380 if (p == 0)
5381 return -1;
5382 end_going_arg ();
5383 /* If any args were output, mark the last one for deletion
5384 on failure. */
5385 if (argbuf.length () != cur_index)
5386 record_temp_file (argbuf.last (), 0, 1);
5387 break;
5390 /* %x{OPTION} records OPTION for %X to output. */
5391 case 'x':
5393 const char *p1 = p;
5394 char *string;
5395 char *opt;
5396 unsigned ix;
5398 /* Skip past the option value and make a copy. */
5399 if (*p != '{')
5400 fatal_error ("spec %qs has invalid %<%%x%c%>", spec, *p);
5401 while (*p++ != '}')
5403 string = save_string (p1 + 1, p - p1 - 2);
5405 /* See if we already recorded this option. */
5406 FOR_EACH_VEC_ELT (linker_options, ix, opt)
5407 if (! strcmp (string, opt))
5409 free (string);
5410 return 0;
5413 /* This option is new; add it. */
5414 add_linker_option (string, strlen (string));
5415 free (string);
5417 break;
5419 /* Dump out the options accumulated previously using %x. */
5420 case 'X':
5421 do_specs_vec (linker_options);
5422 break;
5424 /* Dump out the options accumulated previously using -Wa,. */
5425 case 'Y':
5426 do_specs_vec (assembler_options);
5427 break;
5429 /* Dump out the options accumulated previously using -Wp,. */
5430 case 'Z':
5431 do_specs_vec (preprocessor_options);
5432 break;
5434 /* Here are digits and numbers that just process
5435 a certain constant string as a spec. */
5437 case '1':
5438 value = do_spec_1 (cc1_spec, 0, NULL);
5439 if (value != 0)
5440 return value;
5441 break;
5443 case '2':
5444 value = do_spec_1 (cc1plus_spec, 0, NULL);
5445 if (value != 0)
5446 return value;
5447 break;
5449 case 'a':
5450 value = do_spec_1 (asm_spec, 0, NULL);
5451 if (value != 0)
5452 return value;
5453 break;
5455 case 'A':
5456 value = do_spec_1 (asm_final_spec, 0, NULL);
5457 if (value != 0)
5458 return value;
5459 break;
5461 case 'C':
5463 const char *const spec
5464 = (input_file_compiler->cpp_spec
5465 ? input_file_compiler->cpp_spec
5466 : cpp_spec);
5467 value = do_spec_1 (spec, 0, NULL);
5468 if (value != 0)
5469 return value;
5471 break;
5473 case 'E':
5474 value = do_spec_1 (endfile_spec, 0, NULL);
5475 if (value != 0)
5476 return value;
5477 break;
5479 case 'l':
5480 value = do_spec_1 (link_spec, 0, NULL);
5481 if (value != 0)
5482 return value;
5483 break;
5485 case 'L':
5486 value = do_spec_1 (lib_spec, 0, NULL);
5487 if (value != 0)
5488 return value;
5489 break;
5491 case 'M':
5492 if (multilib_os_dir == NULL)
5493 obstack_1grow (&obstack, '.');
5494 else
5495 obstack_grow (&obstack, multilib_os_dir,
5496 strlen (multilib_os_dir));
5497 break;
5499 case 'G':
5500 value = do_spec_1 (libgcc_spec, 0, NULL);
5501 if (value != 0)
5502 return value;
5503 break;
5505 case 'R':
5506 /* We assume there is a directory
5507 separator at the end of this string. */
5508 if (target_system_root)
5510 obstack_grow (&obstack, target_system_root,
5511 strlen (target_system_root));
5512 if (target_sysroot_suffix)
5513 obstack_grow (&obstack, target_sysroot_suffix,
5514 strlen (target_sysroot_suffix));
5516 break;
5518 case 'S':
5519 value = do_spec_1 (startfile_spec, 0, NULL);
5520 if (value != 0)
5521 return value;
5522 break;
5524 /* Here we define characters other than letters and digits. */
5526 case '{':
5527 p = handle_braces (p);
5528 if (p == 0)
5529 return -1;
5530 break;
5532 case ':':
5533 p = handle_spec_function (p, NULL);
5534 if (p == 0)
5535 return -1;
5536 break;
5538 case '%':
5539 obstack_1grow (&obstack, '%');
5540 break;
5542 case '.':
5544 unsigned len = 0;
5546 while (p[len] && p[len] != ' ' && p[len] != '%')
5547 len++;
5548 suffix_subst = save_string (p - 1, len + 1);
5549 p += len;
5551 break;
5553 /* Henceforth ignore the option(s) matching the pattern
5554 after the %<. */
5555 case '<':
5556 case '>':
5558 unsigned len = 0;
5559 int have_wildcard = 0;
5560 int i;
5561 int switch_option;
5563 if (c == '>')
5564 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5565 else
5566 switch_option = SWITCH_IGNORE;
5568 while (p[len] && p[len] != ' ' && p[len] != '\t')
5569 len++;
5571 if (p[len-1] == '*')
5572 have_wildcard = 1;
5574 for (i = 0; i < n_switches; i++)
5575 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5576 && (have_wildcard || switches[i].part1[len] == '\0'))
5578 switches[i].live_cond |= switch_option;
5579 /* User switch be validated from validate_all_switches.
5580 when the definition is seen from the spec file.
5581 If not defined anywhere, will be rejected. */
5582 if (switches[i].known)
5583 switches[i].validated = true;
5586 p += len;
5588 break;
5590 case '*':
5591 if (soft_matched_part)
5593 if (soft_matched_part[0])
5594 do_spec_1 (soft_matched_part, 1, NULL);
5595 /* Only insert a space after the substitution if it is at the
5596 end of the current sequence. So if:
5598 "%{foo=*:bar%*}%{foo=*:one%*two}"
5600 matches -foo=hello then it will produce:
5602 barhello onehellotwo
5604 if (*p == 0 || *p == '}')
5605 do_spec_1 (" ", 0, NULL);
5607 else
5608 /* Catch the case where a spec string contains something like
5609 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5610 hand side of the :. */
5611 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5612 break;
5614 /* Process a string found as the value of a spec given by name.
5615 This feature allows individual machine descriptions
5616 to add and use their own specs. */
5617 case '(':
5619 const char *name = p;
5620 struct spec_list *sl;
5621 int len;
5623 /* The string after the S/P is the name of a spec that is to be
5624 processed. */
5625 while (*p && *p != ')')
5626 p++;
5628 /* See if it's in the list. */
5629 for (len = p - name, sl = specs; sl; sl = sl->next)
5630 if (sl->name_len == len && !strncmp (sl->name, name, len))
5632 name = *(sl->ptr_spec);
5633 #ifdef DEBUG_SPECS
5634 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5635 sl->name, name);
5636 #endif
5637 break;
5640 if (sl)
5642 value = do_spec_1 (name, 0, NULL);
5643 if (value != 0)
5644 return value;
5647 /* Discard the closing paren. */
5648 if (*p)
5649 p++;
5651 break;
5653 default:
5654 error ("spec failure: unrecognized spec option %qc", c);
5655 break;
5657 break;
5659 case '\\':
5660 /* Backslash: treat next character as ordinary. */
5661 c = *p++;
5663 /* Fall through. */
5664 default:
5665 /* Ordinary character: put it into the current argument. */
5666 obstack_1grow (&obstack, c);
5667 arg_going = 1;
5670 /* End of string. If we are processing a spec function, we need to
5671 end any pending argument. */
5672 if (processing_spec_function)
5673 end_going_arg ();
5675 return 0;
5678 /* Look up a spec function. */
5680 static const struct spec_function *
5681 lookup_spec_function (const char *name)
5683 const struct spec_function *sf;
5685 for (sf = static_spec_functions; sf->name != NULL; sf++)
5686 if (strcmp (sf->name, name) == 0)
5687 return sf;
5689 return NULL;
5692 /* Evaluate a spec function. */
5694 static const char *
5695 eval_spec_function (const char *func, const char *args)
5697 const struct spec_function *sf;
5698 const char *funcval;
5700 /* Saved spec processing context. */
5701 vec<const_char_p> save_argbuf;
5703 int save_arg_going;
5704 int save_delete_this_arg;
5705 int save_this_is_output_file;
5706 int save_this_is_library_file;
5707 int save_input_from_pipe;
5708 int save_this_is_linker_script;
5709 const char *save_suffix_subst;
5711 int save_growing_size;
5712 void *save_growing_value = NULL;
5714 sf = lookup_spec_function (func);
5715 if (sf == NULL)
5716 fatal_error ("unknown spec function %qs", func);
5718 /* Push the spec processing context. */
5719 save_argbuf = argbuf;
5721 save_arg_going = arg_going;
5722 save_delete_this_arg = delete_this_arg;
5723 save_this_is_output_file = this_is_output_file;
5724 save_this_is_library_file = this_is_library_file;
5725 save_this_is_linker_script = this_is_linker_script;
5726 save_input_from_pipe = input_from_pipe;
5727 save_suffix_subst = suffix_subst;
5729 /* If we have some object growing now, finalize it so the args and function
5730 eval proceed from a cleared context. This is needed to prevent the first
5731 constructed arg from mistakenly including the growing value. We'll push
5732 this value back on the obstack once the function evaluation is done, to
5733 restore a consistent processing context for our caller. This is fine as
5734 the address of growing objects isn't guaranteed to remain stable until
5735 they are finalized, and we expect this situation to be rare enough for
5736 the extra copy not to be an issue. */
5737 save_growing_size = obstack_object_size (&obstack);
5738 if (save_growing_size > 0)
5739 save_growing_value = obstack_finish (&obstack);
5741 /* Create a new spec processing context, and build the function
5742 arguments. */
5744 alloc_args ();
5745 if (do_spec_2 (args) < 0)
5746 fatal_error ("error in args to spec function %qs", func);
5748 /* argbuf_index is an index for the next argument to be inserted, and
5749 so contains the count of the args already inserted. */
5751 funcval = (*sf->func) (argbuf.length (),
5752 argbuf.address ());
5754 /* Pop the spec processing context. */
5755 argbuf.release ();
5756 argbuf = save_argbuf;
5758 arg_going = save_arg_going;
5759 delete_this_arg = save_delete_this_arg;
5760 this_is_output_file = save_this_is_output_file;
5761 this_is_library_file = save_this_is_library_file;
5762 this_is_linker_script = save_this_is_linker_script;
5763 input_from_pipe = save_input_from_pipe;
5764 suffix_subst = save_suffix_subst;
5766 if (save_growing_size > 0)
5767 obstack_grow (&obstack, save_growing_value, save_growing_size);
5769 return funcval;
5772 /* Handle a spec function call of the form:
5774 %:function(args)
5776 ARGS is processed as a spec in a separate context and split into an
5777 argument vector in the normal fashion. The function returns a string
5778 containing a spec which we then process in the caller's context, or
5779 NULL if no processing is required.
5781 If RETVAL_NONNULL is not NULL, then store a bool whether function
5782 returned non-NULL. */
5784 static const char *
5785 handle_spec_function (const char *p, bool *retval_nonnull)
5787 char *func, *args;
5788 const char *endp, *funcval;
5789 int count;
5791 processing_spec_function++;
5793 /* Get the function name. */
5794 for (endp = p; *endp != '\0'; endp++)
5796 if (*endp == '(') /* ) */
5797 break;
5798 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5799 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5800 fatal_error ("malformed spec function name");
5802 if (*endp != '(') /* ) */
5803 fatal_error ("no arguments for spec function");
5804 func = save_string (p, endp - p);
5805 p = ++endp;
5807 /* Get the arguments. */
5808 for (count = 0; *endp != '\0'; endp++)
5810 /* ( */
5811 if (*endp == ')')
5813 if (count == 0)
5814 break;
5815 count--;
5817 else if (*endp == '(') /* ) */
5818 count++;
5820 /* ( */
5821 if (*endp != ')')
5822 fatal_error ("malformed spec function arguments");
5823 args = save_string (p, endp - p);
5824 p = ++endp;
5826 /* p now points to just past the end of the spec function expression. */
5828 funcval = eval_spec_function (func, args);
5829 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5830 p = NULL;
5831 if (retval_nonnull)
5832 *retval_nonnull = funcval != NULL;
5834 free (func);
5835 free (args);
5837 processing_spec_function--;
5839 return p;
5842 /* Inline subroutine of handle_braces. Returns true if the current
5843 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5844 static inline bool
5845 input_suffix_matches (const char *atom, const char *end_atom)
5847 return (input_suffix
5848 && !strncmp (input_suffix, atom, end_atom - atom)
5849 && input_suffix[end_atom - atom] == '\0');
5852 /* Subroutine of handle_braces. Returns true if the current
5853 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
5854 static bool
5855 input_spec_matches (const char *atom, const char *end_atom)
5857 return (input_file_compiler
5858 && input_file_compiler->suffix
5859 && input_file_compiler->suffix[0] != '\0'
5860 && !strncmp (input_file_compiler->suffix + 1, atom,
5861 end_atom - atom)
5862 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
5865 /* Subroutine of handle_braces. Returns true if a switch
5866 matching the atom bracketed by ATOM and END_ATOM appeared on the
5867 command line. */
5868 static bool
5869 switch_matches (const char *atom, const char *end_atom, int starred)
5871 int i;
5872 int len = end_atom - atom;
5873 int plen = starred ? len : -1;
5875 for (i = 0; i < n_switches; i++)
5876 if (!strncmp (switches[i].part1, atom, len)
5877 && (starred || switches[i].part1[len] == '\0')
5878 && check_live_switch (i, plen))
5879 return true;
5881 /* Check if a switch with separated form matching the atom.
5882 We check -D and -U switches. */
5883 else if (switches[i].args != 0)
5885 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
5886 && *switches[i].part1 == atom[0])
5888 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
5889 && (starred || (switches[i].part1[1] == '\0'
5890 && switches[i].args[0][len - 1] == '\0'))
5891 && check_live_switch (i, (starred ? 1 : -1)))
5892 return true;
5896 return false;
5899 /* Inline subroutine of handle_braces. Mark all of the switches which
5900 match ATOM (extends to END_ATOM; STARRED indicates whether there
5901 was a star after the atom) for later processing. */
5902 static inline void
5903 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5905 int i;
5906 int len = end_atom - atom;
5907 int plen = starred ? len : -1;
5909 for (i = 0; i < n_switches; i++)
5910 if (!strncmp (switches[i].part1, atom, len)
5911 && (starred || switches[i].part1[len] == '\0')
5912 && check_live_switch (i, plen))
5913 switches[i].ordering = 1;
5916 /* Inline subroutine of handle_braces. Process all the currently
5917 marked switches through give_switch, and clear the marks. */
5918 static inline void
5919 process_marked_switches (void)
5921 int i;
5923 for (i = 0; i < n_switches; i++)
5924 if (switches[i].ordering == 1)
5926 switches[i].ordering = 0;
5927 give_switch (i, 0);
5931 /* Handle a %{ ... } construct. P points just inside the leading {.
5932 Returns a pointer one past the end of the brace block, or 0
5933 if we call do_spec_1 and that returns -1. */
5935 static const char *
5936 handle_braces (const char *p)
5938 const char *atom, *end_atom;
5939 const char *d_atom = NULL, *d_end_atom = NULL;
5940 const char *orig = p;
5942 bool a_is_suffix;
5943 bool a_is_spectype;
5944 bool a_is_starred;
5945 bool a_is_negated;
5946 bool a_matched;
5948 bool a_must_be_last = false;
5949 bool ordered_set = false;
5950 bool disjunct_set = false;
5951 bool disj_matched = false;
5952 bool disj_starred = true;
5953 bool n_way_choice = false;
5954 bool n_way_matched = false;
5956 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5960 if (a_must_be_last)
5961 goto invalid;
5963 /* Scan one "atom" (S in the description above of %{}, possibly
5964 with '!', '.', '@', ',', or '*' modifiers). */
5965 a_matched = false;
5966 a_is_suffix = false;
5967 a_is_starred = false;
5968 a_is_negated = false;
5969 a_is_spectype = false;
5971 SKIP_WHITE ();
5972 if (*p == '!')
5973 p++, a_is_negated = true;
5975 SKIP_WHITE ();
5976 if (*p == '%' && p[1] == ':')
5978 atom = NULL;
5979 end_atom = NULL;
5980 p = handle_spec_function (p + 2, &a_matched);
5982 else
5984 if (*p == '.')
5985 p++, a_is_suffix = true;
5986 else if (*p == ',')
5987 p++, a_is_spectype = true;
5989 atom = p;
5990 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
5991 || *p == ',' || *p == '.' || *p == '@')
5992 p++;
5993 end_atom = p;
5995 if (*p == '*')
5996 p++, a_is_starred = 1;
5999 SKIP_WHITE ();
6000 switch (*p)
6002 case '&': case '}':
6003 /* Substitute the switch(es) indicated by the current atom. */
6004 ordered_set = true;
6005 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
6006 || a_is_spectype || atom == end_atom)
6007 goto invalid;
6009 mark_matching_switches (atom, end_atom, a_is_starred);
6011 if (*p == '}')
6012 process_marked_switches ();
6013 break;
6015 case '|': case ':':
6016 /* Substitute some text if the current atom appears as a switch
6017 or suffix. */
6018 disjunct_set = true;
6019 if (ordered_set)
6020 goto invalid;
6022 if (atom && atom == end_atom)
6024 if (!n_way_choice || disj_matched || *p == '|'
6025 || a_is_negated || a_is_suffix || a_is_spectype
6026 || a_is_starred)
6027 goto invalid;
6029 /* An empty term may appear as the last choice of an
6030 N-way choice set; it means "otherwise". */
6031 a_must_be_last = true;
6032 disj_matched = !n_way_matched;
6033 disj_starred = false;
6035 else
6037 if ((a_is_suffix || a_is_spectype) && a_is_starred)
6038 goto invalid;
6040 if (!a_is_starred)
6041 disj_starred = false;
6043 /* Don't bother testing this atom if we already have a
6044 match. */
6045 if (!disj_matched && !n_way_matched)
6047 if (atom == NULL)
6048 /* a_matched is already set by handle_spec_function. */;
6049 else if (a_is_suffix)
6050 a_matched = input_suffix_matches (atom, end_atom);
6051 else if (a_is_spectype)
6052 a_matched = input_spec_matches (atom, end_atom);
6053 else
6054 a_matched = switch_matches (atom, end_atom, a_is_starred);
6056 if (a_matched != a_is_negated)
6058 disj_matched = true;
6059 d_atom = atom;
6060 d_end_atom = end_atom;
6065 if (*p == ':')
6067 /* Found the body, that is, the text to substitute if the
6068 current disjunction matches. */
6069 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
6070 disj_matched && !n_way_matched);
6071 if (p == 0)
6072 return 0;
6074 /* If we have an N-way choice, reset state for the next
6075 disjunction. */
6076 if (*p == ';')
6078 n_way_choice = true;
6079 n_way_matched |= disj_matched;
6080 disj_matched = false;
6081 disj_starred = true;
6082 d_atom = d_end_atom = NULL;
6085 break;
6087 default:
6088 goto invalid;
6091 while (*p++ != '}');
6093 return p;
6095 invalid:
6096 fatal_error ("braced spec %qs is invalid at %qc", orig, *p);
6098 #undef SKIP_WHITE
6101 /* Subroutine of handle_braces. Scan and process a brace substitution body
6102 (X in the description of %{} syntax). P points one past the colon;
6103 ATOM and END_ATOM bracket the first atom which was found to be true
6104 (present) in the current disjunction; STARRED indicates whether all
6105 the atoms in the current disjunction were starred (for syntax validation);
6106 MATCHED indicates whether the disjunction matched or not, and therefore
6107 whether or not the body is to be processed through do_spec_1 or just
6108 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
6109 returns -1. */
6111 static const char *
6112 process_brace_body (const char *p, const char *atom, const char *end_atom,
6113 int starred, int matched)
6115 const char *body, *end_body;
6116 unsigned int nesting_level;
6117 bool have_subst = false;
6119 /* Locate the closing } or ;, honoring nested braces.
6120 Trim trailing whitespace. */
6121 body = p;
6122 nesting_level = 1;
6123 for (;;)
6125 if (*p == '{')
6126 nesting_level++;
6127 else if (*p == '}')
6129 if (!--nesting_level)
6130 break;
6132 else if (*p == ';' && nesting_level == 1)
6133 break;
6134 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
6135 have_subst = true;
6136 else if (*p == '\0')
6137 goto invalid;
6138 p++;
6141 end_body = p;
6142 while (end_body[-1] == ' ' || end_body[-1] == '\t')
6143 end_body--;
6145 if (have_subst && !starred)
6146 goto invalid;
6148 if (matched)
6150 /* Copy the substitution body to permanent storage and execute it.
6151 If have_subst is false, this is a simple matter of running the
6152 body through do_spec_1... */
6153 char *string = save_string (body, end_body - body);
6154 if (!have_subst)
6156 if (do_spec_1 (string, 0, NULL) < 0)
6157 return 0;
6159 else
6161 /* ... but if have_subst is true, we have to process the
6162 body once for each matching switch, with %* set to the
6163 variant part of the switch. */
6164 unsigned int hard_match_len = end_atom - atom;
6165 int i;
6167 for (i = 0; i < n_switches; i++)
6168 if (!strncmp (switches[i].part1, atom, hard_match_len)
6169 && check_live_switch (i, hard_match_len))
6171 if (do_spec_1 (string, 0,
6172 &switches[i].part1[hard_match_len]) < 0)
6173 return 0;
6174 /* Pass any arguments this switch has. */
6175 give_switch (i, 1);
6176 suffix_subst = NULL;
6181 return p;
6183 invalid:
6184 fatal_error ("braced spec body %qs is invalid", body);
6187 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
6188 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
6189 spec, or -1 if either exact match or %* is used.
6191 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
6192 whose value does not begin with "no-" is obsoleted by the same value
6193 with the "no-", similarly for a switch with the "no-" prefix. */
6195 static int
6196 check_live_switch (int switchnum, int prefix_length)
6198 const char *name = switches[switchnum].part1;
6199 int i;
6201 /* If we already processed this switch and determined if it was
6202 live or not, return our past determination. */
6203 if (switches[switchnum].live_cond != 0)
6204 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
6205 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
6206 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
6207 == 0);
6209 /* In the common case of {<at-most-one-letter>*}, a negating
6210 switch would always match, so ignore that case. We will just
6211 send the conflicting switches to the compiler phase. */
6212 if (prefix_length >= 0 && prefix_length <= 1)
6213 return 1;
6215 /* Now search for duplicate in a manner that depends on the name. */
6216 switch (*name)
6218 case 'O':
6219 for (i = switchnum + 1; i < n_switches; i++)
6220 if (switches[i].part1[0] == 'O')
6222 switches[switchnum].validated = true;
6223 switches[switchnum].live_cond = SWITCH_FALSE;
6224 return 0;
6226 break;
6228 case 'W': case 'f': case 'm': case 'g':
6229 if (! strncmp (name + 1, "no-", 3))
6231 /* We have Xno-YYY, search for XYYY. */
6232 for (i = switchnum + 1; i < n_switches; i++)
6233 if (switches[i].part1[0] == name[0]
6234 && ! strcmp (&switches[i].part1[1], &name[4]))
6236 /* --specs are validated with the validate_switches mechanism. */
6237 if (switches[switchnum].known)
6238 switches[switchnum].validated = true;
6239 switches[switchnum].live_cond = SWITCH_FALSE;
6240 return 0;
6243 else
6245 /* We have XYYY, search for Xno-YYY. */
6246 for (i = switchnum + 1; i < n_switches; i++)
6247 if (switches[i].part1[0] == name[0]
6248 && switches[i].part1[1] == 'n'
6249 && switches[i].part1[2] == 'o'
6250 && switches[i].part1[3] == '-'
6251 && !strcmp (&switches[i].part1[4], &name[1]))
6253 /* --specs are validated with the validate_switches mechanism. */
6254 if (switches[switchnum].known)
6255 switches[switchnum].validated = true;
6256 switches[switchnum].live_cond = SWITCH_FALSE;
6257 return 0;
6260 break;
6263 /* Otherwise the switch is live. */
6264 switches[switchnum].live_cond |= SWITCH_LIVE;
6265 return 1;
6268 /* Pass a switch to the current accumulating command
6269 in the same form that we received it.
6270 SWITCHNUM identifies the switch; it is an index into
6271 the vector of switches gcc received, which is `switches'.
6272 This cannot fail since it never finishes a command line.
6274 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
6276 static void
6277 give_switch (int switchnum, int omit_first_word)
6279 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
6280 return;
6282 if (!omit_first_word)
6284 do_spec_1 ("-", 0, NULL);
6285 do_spec_1 (switches[switchnum].part1, 1, NULL);
6288 if (switches[switchnum].args != 0)
6290 const char **p;
6291 for (p = switches[switchnum].args; *p; p++)
6293 const char *arg = *p;
6295 do_spec_1 (" ", 0, NULL);
6296 if (suffix_subst)
6298 unsigned length = strlen (arg);
6299 int dot = 0;
6301 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
6302 if (arg[length] == '.')
6304 (CONST_CAST (char *, arg))[length] = 0;
6305 dot = 1;
6306 break;
6308 do_spec_1 (arg, 1, NULL);
6309 if (dot)
6310 (CONST_CAST (char *, arg))[length] = '.';
6311 do_spec_1 (suffix_subst, 1, NULL);
6313 else
6314 do_spec_1 (arg, 1, NULL);
6318 do_spec_1 (" ", 0, NULL);
6319 switches[switchnum].validated = true;
6322 /* Print GCC configuration (e.g. version, thread model, target,
6323 configuration_arguments) to a given FILE. */
6325 static void
6326 print_configuration (FILE *file)
6328 int n;
6329 const char *thrmod;
6331 fnotice (file, "Target: %s\n", spec_machine);
6332 fnotice (file, "Configured with: %s\n", configuration_arguments);
6334 #ifdef THREAD_MODEL_SPEC
6335 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6336 but there's no point in doing all this processing just to get
6337 thread_model back. */
6338 obstack_init (&obstack);
6339 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6340 obstack_1grow (&obstack, '\0');
6341 thrmod = XOBFINISH (&obstack, const char *);
6342 #else
6343 thrmod = thread_model;
6344 #endif
6346 fnotice (file, "Thread model: %s\n", thrmod);
6348 /* compiler_version is truncated at the first space when initialized
6349 from version string, so truncate version_string at the first space
6350 before comparing. */
6351 for (n = 0; version_string[n]; n++)
6352 if (version_string[n] == ' ')
6353 break;
6355 if (! strncmp (version_string, compiler_version, n)
6356 && compiler_version[n] == 0)
6357 fnotice (file, "gcc version %s %s\n\n", version_string,
6358 pkgversion_string);
6359 else
6360 fnotice (file, "gcc driver version %s %sexecuting gcc version %s\n\n",
6361 version_string, pkgversion_string, compiler_version);
6365 #define RETRY_ICE_ATTEMPTS 3
6367 /* Returns true if FILE1 and FILE2 contain equivalent data, 0 otherwise. */
6369 static bool
6370 files_equal_p (char *file1, char *file2)
6372 struct stat st1, st2;
6373 off_t n, len;
6374 int fd1, fd2;
6375 const int bufsize = 8192;
6376 char *buf = XNEWVEC (char, bufsize);
6378 fd1 = open (file1, O_RDONLY);
6379 fd2 = open (file2, O_RDONLY);
6381 if (fd1 < 0 || fd2 < 0)
6382 goto error;
6384 if (fstat (fd1, &st1) < 0 || fstat (fd2, &st2) < 0)
6385 goto error;
6387 if (st1.st_size != st2.st_size)
6388 goto error;
6390 for (n = st1.st_size; n; n -= len)
6392 len = n;
6393 if ((int) len > bufsize / 2)
6394 len = bufsize / 2;
6396 if (read (fd1, buf, len) != (int) len
6397 || read (fd2, buf + bufsize / 2, len) != (int) len)
6399 goto error;
6402 if (memcmp (buf, buf + bufsize / 2, len) != 0)
6403 goto error;
6406 free (buf);
6407 close (fd1);
6408 close (fd2);
6410 return 1;
6412 error:
6413 free (buf);
6414 close (fd1);
6415 close (fd2);
6416 return 0;
6419 /* Check that compiler's output doesn't differ across runs.
6420 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are arrays of files, containing
6421 stdout and stderr for each compiler run. Return true if all of
6422 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are equivalent. */
6424 static bool
6425 check_repro (char **temp_stdout_files, char **temp_stderr_files)
6427 int i;
6428 for (i = 0; i < RETRY_ICE_ATTEMPTS - 2; ++i)
6430 if (!files_equal_p (temp_stdout_files[i], temp_stdout_files[i + 1])
6431 || !files_equal_p (temp_stderr_files[i], temp_stderr_files[i + 1]))
6433 fnotice (stderr, "The bug is not reproducible, so it is"
6434 " likely a hardware or OS problem.\n");
6435 break;
6438 return i == RETRY_ICE_ATTEMPTS - 2;
6441 enum attempt_status {
6442 ATTEMPT_STATUS_FAIL_TO_RUN,
6443 ATTEMPT_STATUS_SUCCESS,
6444 ATTEMPT_STATUS_ICE
6448 /* Run compiler with arguments NEW_ARGV to reproduce the ICE, storing stdout
6449 to OUT_TEMP and stderr to ERR_TEMP. If APPEND is TRUE, append to OUT_TEMP
6450 and ERR_TEMP instead of truncating. If EMIT_SYSTEM_INFO is TRUE, also write
6451 GCC configuration into to ERR_TEMP. Return ATTEMPT_STATUS_FAIL_TO_RUN if
6452 compiler failed to run, ATTEMPT_STATUS_ICE if compiled ICE-ed and
6453 ATTEMPT_STATUS_SUCCESS otherwise. */
6455 static enum attempt_status
6456 run_attempt (const char **new_argv, const char *out_temp,
6457 const char *err_temp, int emit_system_info, int append)
6460 if (emit_system_info)
6462 FILE *file_out = fopen (err_temp, "a");
6463 print_configuration (file_out);
6464 fclose (file_out);
6467 int exit_status;
6468 const char *errmsg;
6469 struct pex_obj *pex;
6470 int err;
6471 int pex_flags = PEX_USE_PIPES | PEX_LAST;
6472 enum attempt_status status = ATTEMPT_STATUS_FAIL_TO_RUN;
6474 if (append)
6475 pex_flags |= PEX_STDOUT_APPEND | PEX_STDERR_APPEND;
6477 pex = pex_init (PEX_USE_PIPES, new_argv[0], NULL);
6478 if (!pex)
6479 fatal_error ("pex_init failed: %m");
6481 errmsg = pex_run (pex, pex_flags, new_argv[0],
6482 CONST_CAST2 (char *const *, const char **, &new_argv[1]), out_temp,
6483 err_temp, &err);
6484 if (errmsg != NULL)
6486 if (err == 0)
6487 fatal_error (errmsg);
6488 else
6490 errno = err;
6491 pfatal_with_name (errmsg);
6495 if (!pex_get_status (pex, 1, &exit_status))
6496 goto out;
6498 switch (WEXITSTATUS (exit_status))
6500 case ICE_EXIT_CODE:
6501 status = ATTEMPT_STATUS_ICE;
6502 break;
6504 case SUCCESS_EXIT_CODE:
6505 status = ATTEMPT_STATUS_SUCCESS;
6506 break;
6508 default:
6512 out:
6513 pex_free (pex);
6514 return status;
6517 /* This routine adds preprocessed source code into the given ERR_FILE.
6518 To do this, it adds "-E" to NEW_ARGV and execute RUN_ATTEMPT routine to
6519 add information in report file. RUN_ATTEMPT should return
6520 ATTEMPT_STATUS_SUCCESS, in other case we cannot generate the report. */
6522 static void
6523 do_report_bug (const char **new_argv, const int nargs,
6524 char **out_file, char **err_file)
6526 int i, status;
6527 int fd = open (*out_file, O_RDWR | O_APPEND);
6528 if (fd < 0)
6529 return;
6530 write (fd, "\n//", 3);
6531 for (i = 0; i < nargs; i++)
6533 write (fd, " ", 1);
6534 write (fd, new_argv[i], strlen (new_argv[i]));
6536 write (fd, "\n\n", 2);
6537 close (fd);
6538 new_argv[nargs] = "-E";
6539 new_argv[nargs + 1] = NULL;
6541 status = run_attempt (new_argv, *out_file, *err_file, 0, 1);
6543 if (status == ATTEMPT_STATUS_SUCCESS)
6545 fnotice (stderr, "Preprocessed source stored into %s file,"
6546 " please attach this to your bugreport.\n", *out_file);
6547 /* Make sure it is not deleted. */
6548 free (*out_file);
6549 *out_file = NULL;
6553 /* Append string STR to file FILE. */
6555 static void
6556 append_text (char *file, const char *str)
6558 int fd = open (file, O_RDWR | O_APPEND);
6559 if (fd < 0)
6560 return;
6562 write (fd, str, strlen (str));
6563 close (fd);
6566 /* Try to reproduce ICE. If bug is reproducible, generate report .err file
6567 containing GCC configuration, backtrace, compiler's command line options
6568 and preprocessed source code. */
6570 static void
6571 try_generate_repro (const char **argv)
6573 int i, nargs, out_arg = -1, quiet = 0, attempt;
6574 const char **new_argv;
6575 char *temp_files[RETRY_ICE_ATTEMPTS * 2];
6576 char **temp_stdout_files = &temp_files[0];
6577 char **temp_stderr_files = &temp_files[RETRY_ICE_ATTEMPTS];
6579 if (gcc_input_filename == NULL || ! strcmp (gcc_input_filename, "-"))
6580 return;
6582 for (nargs = 0; argv[nargs] != NULL; ++nargs)
6583 /* Only retry compiler ICEs, not preprocessor ones. */
6584 if (! strcmp (argv[nargs], "-E"))
6585 return;
6586 else if (argv[nargs][0] == '-' && argv[nargs][1] == 'o')
6588 if (out_arg == -1)
6589 out_arg = nargs;
6590 else
6591 return;
6593 /* If the compiler is going to output any time information,
6594 it might varry between invocations. */
6595 else if (! strcmp (argv[nargs], "-quiet"))
6596 quiet = 1;
6597 else if (! strcmp (argv[nargs], "-ftime-report"))
6598 return;
6600 if (out_arg == -1 || !quiet)
6601 return;
6603 memset (temp_files, '\0', sizeof (temp_files));
6604 new_argv = XALLOCAVEC (const char *, nargs + 4);
6605 memcpy (new_argv, argv, (nargs + 1) * sizeof (const char *));
6606 new_argv[nargs++] = "-frandom-seed=0";
6607 new_argv[nargs++] = "-fdump-noaddr";
6608 new_argv[nargs] = NULL;
6609 if (new_argv[out_arg][2] == '\0')
6610 new_argv[out_arg + 1] = "-";
6611 else
6612 new_argv[out_arg] = "-o-";
6614 int status;
6615 for (attempt = 0; attempt < RETRY_ICE_ATTEMPTS; ++attempt)
6617 int emit_system_info = 0;
6618 int append = 0;
6619 temp_stdout_files[attempt] = make_temp_file (".out");
6620 temp_stderr_files[attempt] = make_temp_file (".err");
6622 if (attempt == RETRY_ICE_ATTEMPTS - 1)
6624 append = 1;
6625 emit_system_info = 1;
6628 if (emit_system_info)
6629 append_text (temp_stderr_files[attempt], "/*\n");
6631 status = run_attempt (new_argv, temp_stdout_files[attempt],
6632 temp_stderr_files[attempt], emit_system_info,
6633 append);
6635 if (emit_system_info)
6636 append_text (temp_stderr_files[attempt], "*/\n");
6638 if (status != ATTEMPT_STATUS_ICE)
6640 fnotice (stderr, "The bug is not reproducible, so it is"
6641 " likely a hardware or OS problem.\n");
6642 goto out;
6646 if (!check_repro (temp_stdout_files, temp_stderr_files))
6647 goto out;
6649 /* In final attempt we append compiler options and preprocesssed code to last
6650 generated .err file with configuration and backtrace. */
6651 do_report_bug (new_argv, nargs,
6652 &temp_stderr_files[RETRY_ICE_ATTEMPTS - 1],
6653 &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1]);
6655 out:
6656 for (i = 0; i < RETRY_ICE_ATTEMPTS * 2; i++)
6657 if (temp_files[i])
6659 unlink (temp_stdout_files[i]);
6660 free (temp_stdout_files[i]);
6664 /* Search for a file named NAME trying various prefixes including the
6665 user's -B prefix and some standard ones.
6666 Return the absolute file name found. If nothing is found, return NAME. */
6668 static const char *
6669 find_file (const char *name)
6671 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
6672 return newname ? newname : name;
6675 /* Determine whether a directory exists. If LINKER, return 0 for
6676 certain fixed names not needed by the linker. */
6678 static int
6679 is_directory (const char *path1, bool linker)
6681 int len1;
6682 char *path;
6683 char *cp;
6684 struct stat st;
6686 /* Ensure the string ends with "/.". The resulting path will be a
6687 directory even if the given path is a symbolic link. */
6688 len1 = strlen (path1);
6689 path = (char *) alloca (3 + len1);
6690 memcpy (path, path1, len1);
6691 cp = path + len1;
6692 if (!IS_DIR_SEPARATOR (cp[-1]))
6693 *cp++ = DIR_SEPARATOR;
6694 *cp++ = '.';
6695 *cp = '\0';
6697 /* Exclude directories that the linker is known to search. */
6698 if (linker
6699 && IS_DIR_SEPARATOR (path[0])
6700 && ((cp - path == 6
6701 && filename_ncmp (path + 1, "lib", 3) == 0)
6702 || (cp - path == 10
6703 && filename_ncmp (path + 1, "usr", 3) == 0
6704 && IS_DIR_SEPARATOR (path[4])
6705 && filename_ncmp (path + 5, "lib", 3) == 0)))
6706 return 0;
6708 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
6711 /* Set up the various global variables to indicate that we're processing
6712 the input file named FILENAME. */
6714 void
6715 set_input (const char *filename)
6717 const char *p;
6719 gcc_input_filename = filename;
6720 input_filename_length = strlen (gcc_input_filename);
6721 input_basename = lbasename (gcc_input_filename);
6723 /* Find a suffix starting with the last period,
6724 and set basename_length to exclude that suffix. */
6725 basename_length = strlen (input_basename);
6726 suffixed_basename_length = basename_length;
6727 p = input_basename + basename_length;
6728 while (p != input_basename && *p != '.')
6729 --p;
6730 if (*p == '.' && p != input_basename)
6732 basename_length = p - input_basename;
6733 input_suffix = p + 1;
6735 else
6736 input_suffix = "";
6738 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6739 we will need to do a stat on the gcc_input_filename. The
6740 INPUT_STAT_SET signals that the stat is needed. */
6741 input_stat_set = 0;
6744 /* On fatal signals, delete all the temporary files. */
6746 static void
6747 fatal_signal (int signum)
6749 signal (signum, SIG_DFL);
6750 delete_failure_queue ();
6751 delete_temp_files ();
6752 /* Get the same signal again, this time not handled,
6753 so its normal effect occurs. */
6754 kill (getpid (), signum);
6757 /* Compare the contents of the two files named CMPFILE[0] and
6758 CMPFILE[1]. Return zero if they're identical, nonzero
6759 otherwise. */
6761 static int
6762 compare_files (char *cmpfile[])
6764 int ret = 0;
6765 FILE *temp[2] = { NULL, NULL };
6766 int i;
6768 #if HAVE_MMAP_FILE
6770 size_t length[2];
6771 void *map[2] = { NULL, NULL };
6773 for (i = 0; i < 2; i++)
6775 struct stat st;
6777 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
6779 error ("%s: could not determine length of compare-debug file %s",
6780 gcc_input_filename, cmpfile[i]);
6781 ret = 1;
6782 break;
6785 length[i] = st.st_size;
6788 if (!ret && length[0] != length[1])
6790 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
6791 ret = 1;
6794 if (!ret)
6795 for (i = 0; i < 2; i++)
6797 int fd = open (cmpfile[i], O_RDONLY);
6798 if (fd < 0)
6800 error ("%s: could not open compare-debug file %s",
6801 gcc_input_filename, cmpfile[i]);
6802 ret = 1;
6803 break;
6806 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
6807 close (fd);
6809 if (map[i] == (void *) MAP_FAILED)
6811 ret = -1;
6812 break;
6816 if (!ret)
6818 if (memcmp (map[0], map[1], length[0]) != 0)
6820 error ("%s: -fcompare-debug failure", gcc_input_filename);
6821 ret = 1;
6825 for (i = 0; i < 2; i++)
6826 if (map[i])
6827 munmap ((caddr_t) map[i], length[i]);
6829 if (ret >= 0)
6830 return ret;
6832 ret = 0;
6834 #endif
6836 for (i = 0; i < 2; i++)
6838 temp[i] = fopen (cmpfile[i], "r");
6839 if (!temp[i])
6841 error ("%s: could not open compare-debug file %s",
6842 gcc_input_filename, cmpfile[i]);
6843 ret = 1;
6844 break;
6848 if (!ret && temp[0] && temp[1])
6849 for (;;)
6851 int c0, c1;
6852 c0 = fgetc (temp[0]);
6853 c1 = fgetc (temp[1]);
6855 if (c0 != c1)
6857 error ("%s: -fcompare-debug failure",
6858 gcc_input_filename);
6859 ret = 1;
6860 break;
6863 if (c0 == EOF)
6864 break;
6867 for (i = 1; i >= 0; i--)
6869 if (temp[i])
6870 fclose (temp[i]);
6873 return ret;
6876 /* The top-level "main" within the driver would be ~1000 lines long.
6877 This class breaks it up into smaller functions and contains some
6878 state shared by them. */
6880 class driver
6882 public:
6883 int main (int argc, char **argv);
6885 private:
6886 void set_progname (const char *argv0) const;
6887 void expand_at_files (int *argc, char ***argv) const;
6888 void decode_argv (int argc, const char **argv);
6889 void global_initializations ();
6890 void build_multilib_strings () const;
6891 void set_up_specs () const;
6892 void putenv_COLLECT_GCC (const char *argv0) const;
6893 void maybe_putenv_COLLECT_LTO_WRAPPER () const;
6894 void maybe_putenv_OFFLOAD_TARGETS () const;
6895 void handle_unrecognized_options () const;
6896 int maybe_print_and_exit () const;
6897 bool prepare_infiles ();
6898 void do_spec_on_infiles () const;
6899 void maybe_run_linker (const char *argv0) const;
6900 void final_actions () const;
6901 int get_exit_code () const;
6903 private:
6904 char *explicit_link_files;
6905 struct cl_decoded_option *decoded_options;
6906 unsigned int decoded_options_count;
6909 /* Implement the top-level "main" within the driver in terms of
6910 driver::main. */
6912 extern int main (int, char **);
6915 main (int argc, char **argv)
6917 driver d;
6919 return d.main (argc, argv);
6922 /* driver::main is implemented as a series of driver:: method calls. */
6925 driver::main (int argc, char **argv)
6927 bool early_exit;
6929 set_progname (argv[0]);
6930 expand_at_files (&argc, &argv);
6931 decode_argv (argc, const_cast <const char **> (argv));
6932 global_initializations ();
6933 build_multilib_strings ();
6934 set_up_specs ();
6935 putenv_COLLECT_GCC (argv[0]);
6936 maybe_putenv_COLLECT_LTO_WRAPPER ();
6937 maybe_putenv_OFFLOAD_TARGETS ();
6938 handle_unrecognized_options ();
6940 if (!maybe_print_and_exit ())
6941 return 0;
6943 early_exit = prepare_infiles ();
6944 if (early_exit)
6945 return get_exit_code ();
6947 do_spec_on_infiles ();
6948 maybe_run_linker (argv[0]);
6949 final_actions ();
6950 return get_exit_code ();
6953 /* Locate the final component of argv[0] after any leading path, and set
6954 the program name accordingly. */
6956 void
6957 driver::set_progname (const char *argv0) const
6959 const char *p = argv0 + strlen (argv0);
6960 while (p != argv0 && !IS_DIR_SEPARATOR (p[-1]))
6961 --p;
6962 progname = p;
6964 xmalloc_set_program_name (progname);
6967 /* Expand any @ files within the command-line args,
6968 setting at_file_supplied if any were expanded. */
6970 void
6971 driver::expand_at_files (int *argc, char ***argv) const
6973 char **old_argv = *argv;
6975 expandargv (argc, argv);
6977 /* Determine if any expansions were made. */
6978 if (*argv != old_argv)
6979 at_file_supplied = true;
6982 /* Decode the command-line arguments from argc/argv into the
6983 decoded_options array. */
6985 void
6986 driver::decode_argv (int argc, const char **argv)
6988 /* Register the language-independent parameters. */
6989 global_init_params ();
6990 finish_params ();
6992 init_options_struct (&global_options, &global_options_set);
6994 decode_cmdline_options_to_array (argc, argv,
6995 CL_DRIVER,
6996 &decoded_options, &decoded_options_count);
6999 /* Perform various initializations and setup. */
7001 void
7002 driver::global_initializations ()
7004 /* Unlock the stdio streams. */
7005 unlock_std_streams ();
7007 gcc_init_libintl ();
7009 diagnostic_initialize (global_dc, 0);
7010 diagnostic_color_init (global_dc);
7012 #ifdef GCC_DRIVER_HOST_INITIALIZATION
7013 /* Perform host dependent initialization when needed. */
7014 GCC_DRIVER_HOST_INITIALIZATION;
7015 #endif
7017 if (atexit (delete_temp_files) != 0)
7018 fatal_error ("atexit failed");
7020 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
7021 signal (SIGINT, fatal_signal);
7022 #ifdef SIGHUP
7023 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
7024 signal (SIGHUP, fatal_signal);
7025 #endif
7026 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
7027 signal (SIGTERM, fatal_signal);
7028 #ifdef SIGPIPE
7029 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
7030 signal (SIGPIPE, fatal_signal);
7031 #endif
7032 #ifdef SIGCHLD
7033 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
7034 receive the signal. A different setting is inheritable */
7035 signal (SIGCHLD, SIG_DFL);
7036 #endif
7038 /* Parsing and gimplification sometimes need quite large stack.
7039 Increase stack size limits if possible. */
7040 stack_limit_increase (64 * 1024 * 1024);
7042 /* Allocate the argument vector. */
7043 alloc_args ();
7045 obstack_init (&obstack);
7048 /* Build multilib_select, et. al from the separate lines that make up each
7049 multilib selection. */
7051 void
7052 driver::build_multilib_strings () const
7055 const char *p;
7056 const char *const *q = multilib_raw;
7057 int need_space;
7059 obstack_init (&multilib_obstack);
7060 while ((p = *q++) != (char *) 0)
7061 obstack_grow (&multilib_obstack, p, strlen (p));
7063 obstack_1grow (&multilib_obstack, 0);
7064 multilib_select = XOBFINISH (&multilib_obstack, const char *);
7066 q = multilib_matches_raw;
7067 while ((p = *q++) != (char *) 0)
7068 obstack_grow (&multilib_obstack, p, strlen (p));
7070 obstack_1grow (&multilib_obstack, 0);
7071 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
7073 q = multilib_exclusions_raw;
7074 while ((p = *q++) != (char *) 0)
7075 obstack_grow (&multilib_obstack, p, strlen (p));
7077 obstack_1grow (&multilib_obstack, 0);
7078 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
7080 q = multilib_reuse_raw;
7081 while ((p = *q++) != (char *) 0)
7082 obstack_grow (&multilib_obstack, p, strlen (p));
7084 obstack_1grow (&multilib_obstack, 0);
7085 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
7087 need_space = FALSE;
7088 for (size_t i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
7090 if (need_space)
7091 obstack_1grow (&multilib_obstack, ' ');
7092 obstack_grow (&multilib_obstack,
7093 multilib_defaults_raw[i],
7094 strlen (multilib_defaults_raw[i]));
7095 need_space = TRUE;
7098 obstack_1grow (&multilib_obstack, 0);
7099 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
7103 /* Set up the spec-handling machinery. */
7105 void
7106 driver::set_up_specs () const
7108 const char *spec_machine_suffix;
7109 char *specs_file;
7110 size_t i;
7112 #ifdef INIT_ENVIRONMENT
7113 /* Set up any other necessary machine specific environment variables. */
7114 xputenv (INIT_ENVIRONMENT);
7115 #endif
7117 /* Make a table of what switches there are (switches, n_switches).
7118 Make a table of specified input files (infiles, n_infiles).
7119 Decode switches that are handled locally. */
7121 process_command (decoded_options_count, decoded_options);
7123 /* Initialize the vector of specs to just the default.
7124 This means one element containing 0s, as a terminator. */
7126 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
7127 memcpy (compilers, default_compilers, sizeof default_compilers);
7128 n_compilers = n_default_compilers;
7130 /* Read specs from a file if there is one. */
7132 machine_suffix = concat (spec_host_machine, dir_separator_str, spec_version,
7133 accel_dir_suffix, dir_separator_str, NULL);
7134 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
7136 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
7137 /* Read the specs file unless it is a default one. */
7138 if (specs_file != 0 && strcmp (specs_file, "specs"))
7139 read_specs (specs_file, true, false);
7140 else
7141 init_spec ();
7143 #ifdef ACCEL_COMPILER
7144 spec_machine_suffix = machine_suffix;
7145 #else
7146 spec_machine_suffix = just_machine_suffix;
7147 #endif
7149 /* We need to check standard_exec_prefix/spec_machine_suffix/specs
7150 for any override of as, ld and libraries. */
7151 specs_file = (char *) alloca (strlen (standard_exec_prefix)
7152 + strlen (spec_machine_suffix) + sizeof ("specs"));
7153 strcpy (specs_file, standard_exec_prefix);
7154 strcat (specs_file, spec_machine_suffix);
7155 strcat (specs_file, "specs");
7156 if (access (specs_file, R_OK) == 0)
7157 read_specs (specs_file, true, false);
7159 /* Process any configure-time defaults specified for the command line
7160 options, via OPTION_DEFAULT_SPECS. */
7161 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
7162 do_option_spec (option_default_specs[i].name,
7163 option_default_specs[i].spec);
7165 /* Process DRIVER_SELF_SPECS, adding any new options to the end
7166 of the command line. */
7168 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
7169 do_self_spec (driver_self_specs[i]);
7171 /* If not cross-compiling, look for executables in the standard
7172 places. */
7173 if (*cross_compile == '0')
7175 if (*md_exec_prefix)
7177 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
7178 PREFIX_PRIORITY_LAST, 0, 0);
7182 /* Process sysroot_suffix_spec. */
7183 if (*sysroot_suffix_spec != 0
7184 && !no_sysroot_suffix
7185 && do_spec_2 (sysroot_suffix_spec) == 0)
7187 if (argbuf.length () > 1)
7188 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
7189 else if (argbuf.length () == 1)
7190 target_sysroot_suffix = xstrdup (argbuf.last ());
7193 #ifdef HAVE_LD_SYSROOT
7194 /* Pass the --sysroot option to the linker, if it supports that. If
7195 there is a sysroot_suffix_spec, it has already been processed by
7196 this point, so target_system_root really is the system root we
7197 should be using. */
7198 if (target_system_root)
7200 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
7201 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
7202 set_spec ("link", XOBFINISH (&obstack, const char *), false);
7204 #endif
7206 /* Process sysroot_hdrs_suffix_spec. */
7207 if (*sysroot_hdrs_suffix_spec != 0
7208 && !no_sysroot_suffix
7209 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
7211 if (argbuf.length () > 1)
7212 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
7213 else if (argbuf.length () == 1)
7214 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
7217 /* Look for startfiles in the standard places. */
7218 if (*startfile_prefix_spec != 0
7219 && do_spec_2 (startfile_prefix_spec) == 0
7220 && do_spec_1 (" ", 0, NULL) == 0)
7222 const char *arg;
7223 int ndx;
7224 FOR_EACH_VEC_ELT (argbuf, ndx, arg)
7225 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
7226 PREFIX_PRIORITY_LAST, 0, 1);
7228 /* We should eventually get rid of all these and stick to
7229 startfile_prefix_spec exclusively. */
7230 else if (*cross_compile == '0' || target_system_root)
7232 if (*md_startfile_prefix)
7233 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
7234 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7236 if (*md_startfile_prefix_1)
7237 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
7238 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7240 /* If standard_startfile_prefix is relative, base it on
7241 standard_exec_prefix. This lets us move the installed tree
7242 as a unit. If GCC_EXEC_PREFIX is defined, base
7243 standard_startfile_prefix on that as well.
7245 If the prefix is relative, only search it for native compilers;
7246 otherwise we will search a directory containing host libraries. */
7247 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
7248 add_sysrooted_prefix (&startfile_prefixes,
7249 standard_startfile_prefix, "BINUTILS",
7250 PREFIX_PRIORITY_LAST, 0, 1);
7251 else if (*cross_compile == '0')
7253 add_prefix (&startfile_prefixes,
7254 concat (gcc_exec_prefix
7255 ? gcc_exec_prefix : standard_exec_prefix,
7256 machine_suffix,
7257 standard_startfile_prefix, NULL),
7258 NULL, PREFIX_PRIORITY_LAST, 0, 1);
7261 /* Sysrooted prefixes are relocated because target_system_root is
7262 also relocated by gcc_exec_prefix. */
7263 if (*standard_startfile_prefix_1)
7264 add_sysrooted_prefix (&startfile_prefixes,
7265 standard_startfile_prefix_1, "BINUTILS",
7266 PREFIX_PRIORITY_LAST, 0, 1);
7267 if (*standard_startfile_prefix_2)
7268 add_sysrooted_prefix (&startfile_prefixes,
7269 standard_startfile_prefix_2, "BINUTILS",
7270 PREFIX_PRIORITY_LAST, 0, 1);
7273 /* Process any user specified specs in the order given on the command
7274 line. */
7275 for (struct user_specs *uptr = user_specs_head; uptr; uptr = uptr->next)
7277 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
7278 R_OK, true);
7279 read_specs (filename ? filename : uptr->filename, false, true);
7282 /* Process any user self specs. */
7284 struct spec_list *sl;
7285 for (sl = specs; sl; sl = sl->next)
7286 if (sl->name_len == sizeof "self_spec" - 1
7287 && !strcmp (sl->name, "self_spec"))
7288 do_self_spec (*sl->ptr_spec);
7291 if (compare_debug)
7293 enum save_temps save;
7295 if (!compare_debug_second)
7297 n_switches_debug_check[1] = n_switches;
7298 n_switches_alloc_debug_check[1] = n_switches_alloc;
7299 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
7300 n_switches_alloc);
7302 do_self_spec ("%:compare-debug-self-opt()");
7303 n_switches_debug_check[0] = n_switches;
7304 n_switches_alloc_debug_check[0] = n_switches_alloc;
7305 switches_debug_check[0] = switches;
7307 n_switches = n_switches_debug_check[1];
7308 n_switches_alloc = n_switches_alloc_debug_check[1];
7309 switches = switches_debug_check[1];
7312 /* Avoid crash when computing %j in this early. */
7313 save = save_temps_flag;
7314 save_temps_flag = SAVE_TEMPS_NONE;
7316 compare_debug = -compare_debug;
7317 do_self_spec ("%:compare-debug-self-opt()");
7319 save_temps_flag = save;
7321 if (!compare_debug_second)
7323 n_switches_debug_check[1] = n_switches;
7324 n_switches_alloc_debug_check[1] = n_switches_alloc;
7325 switches_debug_check[1] = switches;
7326 compare_debug = -compare_debug;
7327 n_switches = n_switches_debug_check[0];
7328 n_switches_alloc = n_switches_debug_check[0];
7329 switches = switches_debug_check[0];
7334 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
7335 if (gcc_exec_prefix)
7336 gcc_exec_prefix = concat (gcc_exec_prefix, spec_host_machine,
7337 dir_separator_str, spec_version,
7338 accel_dir_suffix, dir_separator_str, NULL);
7340 /* Now we have the specs.
7341 Set the `valid' bits for switches that match anything in any spec. */
7343 validate_all_switches ();
7345 /* Now that we have the switches and the specs, set
7346 the subdirectory based on the options. */
7347 set_multilib_dir ();
7350 /* Set up to remember the pathname of gcc and any options
7351 needed for collect. We use argv[0] instead of progname because
7352 we need the complete pathname. */
7354 void
7355 driver::putenv_COLLECT_GCC (const char *argv0) const
7357 obstack_init (&collect_obstack);
7358 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
7359 obstack_grow (&collect_obstack, argv0, strlen (argv0) + 1);
7360 xputenv (XOBFINISH (&collect_obstack, char *));
7363 /* Set up to remember the pathname of the lto wrapper. */
7365 void
7366 driver::maybe_putenv_COLLECT_LTO_WRAPPER () const
7368 char *lto_wrapper_file;
7370 if (have_c)
7371 lto_wrapper_file = NULL;
7372 else
7373 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
7374 X_OK, false);
7375 if (lto_wrapper_file)
7377 lto_wrapper_file = convert_white_space (lto_wrapper_file);
7378 lto_wrapper_spec = lto_wrapper_file;
7379 obstack_init (&collect_obstack);
7380 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
7381 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
7382 obstack_grow (&collect_obstack, lto_wrapper_spec,
7383 strlen (lto_wrapper_spec) + 1);
7384 xputenv (XOBFINISH (&collect_obstack, char *));
7389 /* Set up to remember the names of offload targets. */
7391 void
7392 driver::maybe_putenv_OFFLOAD_TARGETS () const
7394 const char *targets = offload_targets;
7396 /* If no targets specified by -foffload, use all available targets. */
7397 if (!targets)
7398 targets = OFFLOAD_TARGETS;
7400 if (strlen (targets) > 0)
7402 obstack_grow (&collect_obstack, "OFFLOAD_TARGET_NAMES=",
7403 sizeof ("OFFLOAD_TARGET_NAMES=") - 1);
7404 obstack_grow (&collect_obstack, targets,
7405 strlen (targets) + 1);
7406 xputenv (XOBFINISH (&collect_obstack, char *));
7409 free (offload_targets);
7412 /* Reject switches that no pass was interested in. */
7414 void
7415 driver::handle_unrecognized_options () const
7417 for (size_t i = 0; (int) i < n_switches; i++)
7418 if (! switches[i].validated)
7419 error ("unrecognized command line option %<-%s%>", switches[i].part1);
7422 /* Handle the various -print-* options, returning 0 if the driver
7423 should exit, or nonzero if the driver should continue. */
7426 driver::maybe_print_and_exit () const
7428 if (print_search_dirs)
7430 printf (_("install: %s%s\n"),
7431 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
7432 gcc_exec_prefix ? "" : machine_suffix);
7433 printf (_("programs: %s\n"),
7434 build_search_list (&exec_prefixes, "", false, false));
7435 printf (_("libraries: %s\n"),
7436 build_search_list (&startfile_prefixes, "", false, true));
7437 return (0);
7440 if (print_file_name)
7442 printf ("%s\n", find_file (print_file_name));
7443 return (0);
7446 if (print_prog_name)
7448 if (use_ld != NULL && ! strcmp (print_prog_name, "ld"))
7450 /* Append USE_LD to to the default linker. */
7451 #ifdef DEFAULT_LINKER
7452 char *ld;
7453 # ifdef HAVE_HOST_EXECUTABLE_SUFFIX
7454 int len = (sizeof (DEFAULT_LINKER)
7455 - sizeof (HOST_EXECUTABLE_SUFFIX));
7456 ld = NULL;
7457 if (len > 0)
7459 char *default_linker = xstrdup (DEFAULT_LINKER);
7460 /* Strip HOST_EXECUTABLE_SUFFIX if DEFAULT_LINKER contains
7461 HOST_EXECUTABLE_SUFFIX. */
7462 if (! strcmp (&default_linker[len], HOST_EXECUTABLE_SUFFIX))
7464 default_linker[len] = '\0';
7465 ld = concat (default_linker, use_ld,
7466 HOST_EXECUTABLE_SUFFIX, NULL);
7469 if (ld == NULL)
7470 # endif
7471 ld = concat (DEFAULT_LINKER, use_ld, NULL);
7472 if (access (ld, X_OK) == 0)
7474 printf ("%s\n", ld);
7475 return (0);
7477 #endif
7478 print_prog_name = concat (print_prog_name, use_ld, NULL);
7480 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
7481 printf ("%s\n", (newname ? newname : print_prog_name));
7482 return (0);
7485 if (print_multi_lib)
7487 print_multilib_info ();
7488 return (0);
7491 if (print_multi_directory)
7493 if (multilib_dir == NULL)
7494 printf (".\n");
7495 else
7496 printf ("%s\n", multilib_dir);
7497 return (0);
7500 if (print_multiarch)
7502 if (multiarch_dir == NULL)
7503 printf ("\n");
7504 else
7505 printf ("%s\n", multiarch_dir);
7506 return (0);
7509 if (print_sysroot)
7511 if (target_system_root)
7513 if (target_sysroot_suffix)
7514 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
7515 else
7516 printf ("%s\n", target_system_root);
7518 return (0);
7521 if (print_multi_os_directory)
7523 if (multilib_os_dir == NULL)
7524 printf (".\n");
7525 else
7526 printf ("%s\n", multilib_os_dir);
7527 return (0);
7530 if (print_sysroot_headers_suffix)
7532 if (*sysroot_hdrs_suffix_spec)
7534 printf("%s\n", (target_sysroot_hdrs_suffix
7535 ? target_sysroot_hdrs_suffix
7536 : ""));
7537 return (0);
7539 else
7540 /* The error status indicates that only one set of fixed
7541 headers should be built. */
7542 fatal_error ("not configured with sysroot headers suffix");
7545 if (print_help_list)
7547 display_help ();
7549 if (! verbose_flag)
7551 printf (_("\nFor bug reporting instructions, please see:\n"));
7552 printf ("%s.\n", bug_report_url);
7554 return (0);
7557 /* We do not exit here. Instead we have created a fake input file
7558 called 'help-dummy' which needs to be compiled, and we pass this
7559 on the various sub-processes, along with the --help switch.
7560 Ensure their output appears after ours. */
7561 fputc ('\n', stdout);
7562 fflush (stdout);
7565 if (print_version)
7567 printf (_("%s %s%s\n"), progname, pkgversion_string,
7568 version_string);
7569 printf ("Copyright %s 2014 Free Software Foundation, Inc.\n",
7570 _("(C)"));
7571 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
7572 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
7573 stdout);
7574 if (! verbose_flag)
7575 return 0;
7577 /* We do not exit here. We use the same mechanism of --help to print
7578 the version of the sub-processes. */
7579 fputc ('\n', stdout);
7580 fflush (stdout);
7583 if (verbose_flag)
7585 print_configuration (stderr);
7586 if (n_infiles == 0)
7587 return (0);
7590 return 1;
7593 /* Figure out what to do with each input file.
7594 Return true if we need to exit early from "main", false otherwise. */
7596 bool
7597 driver::prepare_infiles ()
7599 size_t i;
7600 int lang_n_infiles = 0;
7602 if (n_infiles == added_libraries)
7603 fatal_error ("no input files");
7605 if (seen_error ())
7606 /* Early exit needed from main. */
7607 return true;
7609 /* Make a place to record the compiler output file names
7610 that correspond to the input files. */
7612 i = n_infiles;
7613 i += lang_specific_extra_outfiles;
7614 outfiles = XCNEWVEC (const char *, i);
7616 /* Record which files were specified explicitly as link input. */
7618 explicit_link_files = XCNEWVEC (char, n_infiles);
7620 combine_inputs = have_o || flag_wpa;
7622 for (i = 0; (int) i < n_infiles; i++)
7624 const char *name = infiles[i].name;
7625 struct compiler *compiler = lookup_compiler (name,
7626 strlen (name),
7627 infiles[i].language);
7629 if (compiler && !(compiler->combinable))
7630 combine_inputs = false;
7632 if (lang_n_infiles > 0 && compiler != input_file_compiler
7633 && infiles[i].language && infiles[i].language[0] != '*')
7634 infiles[i].incompiler = compiler;
7635 else if (compiler)
7637 lang_n_infiles++;
7638 input_file_compiler = compiler;
7639 infiles[i].incompiler = compiler;
7641 else
7643 /* Since there is no compiler for this input file, assume it is a
7644 linker file. */
7645 explicit_link_files[i] = 1;
7646 infiles[i].incompiler = NULL;
7648 infiles[i].compiled = false;
7649 infiles[i].preprocessed = false;
7652 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
7653 fatal_error ("cannot specify -o with -c, -S or -E with multiple files");
7655 /* No early exit needed from main; we can continue. */
7656 return false;
7659 /* Run the spec machinery on each input file. */
7661 void
7662 driver::do_spec_on_infiles () const
7664 size_t i;
7666 for (i = 0; (int) i < n_infiles; i++)
7668 int this_file_error = 0;
7670 /* Tell do_spec what to substitute for %i. */
7672 input_file_number = i;
7673 set_input (infiles[i].name);
7675 if (infiles[i].compiled)
7676 continue;
7678 /* Use the same thing in %o, unless cp->spec says otherwise. */
7680 outfiles[i] = gcc_input_filename;
7682 /* Figure out which compiler from the file's suffix. */
7684 input_file_compiler
7685 = lookup_compiler (infiles[i].name, input_filename_length,
7686 infiles[i].language);
7688 if (input_file_compiler)
7690 /* Ok, we found an applicable compiler. Run its spec. */
7692 if (input_file_compiler->spec[0] == '#')
7694 error ("%s: %s compiler not installed on this system",
7695 gcc_input_filename, &input_file_compiler->spec[1]);
7696 this_file_error = 1;
7698 else
7700 int value;
7702 if (compare_debug)
7704 free (debug_check_temp_file[0]);
7705 debug_check_temp_file[0] = NULL;
7707 free (debug_check_temp_file[1]);
7708 debug_check_temp_file[1] = NULL;
7711 value = do_spec (input_file_compiler->spec);
7712 infiles[i].compiled = true;
7713 if (value < 0)
7714 this_file_error = 1;
7715 else if (compare_debug && debug_check_temp_file[0])
7717 if (verbose_flag)
7718 inform (0, "recompiling with -fcompare-debug");
7720 compare_debug = -compare_debug;
7721 n_switches = n_switches_debug_check[1];
7722 n_switches_alloc = n_switches_alloc_debug_check[1];
7723 switches = switches_debug_check[1];
7725 value = do_spec (input_file_compiler->spec);
7727 compare_debug = -compare_debug;
7728 n_switches = n_switches_debug_check[0];
7729 n_switches_alloc = n_switches_alloc_debug_check[0];
7730 switches = switches_debug_check[0];
7732 if (value < 0)
7734 error ("during -fcompare-debug recompilation");
7735 this_file_error = 1;
7738 gcc_assert (debug_check_temp_file[1]
7739 && filename_cmp (debug_check_temp_file[0],
7740 debug_check_temp_file[1]));
7742 if (verbose_flag)
7743 inform (0, "comparing final insns dumps");
7745 if (compare_files (debug_check_temp_file))
7746 this_file_error = 1;
7749 if (compare_debug)
7751 free (debug_check_temp_file[0]);
7752 debug_check_temp_file[0] = NULL;
7754 free (debug_check_temp_file[1]);
7755 debug_check_temp_file[1] = NULL;
7760 /* If this file's name does not contain a recognized suffix,
7761 record it as explicit linker input. */
7763 else
7764 explicit_link_files[i] = 1;
7766 /* Clear the delete-on-failure queue, deleting the files in it
7767 if this compilation failed. */
7769 if (this_file_error)
7771 delete_failure_queue ();
7772 errorcount++;
7774 /* If this compilation succeeded, don't delete those files later. */
7775 clear_failure_queue ();
7778 /* Reset the input file name to the first compile/object file name, for use
7779 with %b in LINK_SPEC. We use the first input file that we can find
7780 a compiler to compile it instead of using infiles.language since for
7781 languages other than C we use aliases that we then lookup later. */
7782 if (n_infiles > 0)
7784 int i;
7786 for (i = 0; i < n_infiles ; i++)
7787 if (infiles[i].incompiler
7788 || (infiles[i].language && infiles[i].language[0] != '*'))
7790 set_input (infiles[i].name);
7791 break;
7795 if (!seen_error ())
7797 /* Make sure INPUT_FILE_NUMBER points to first available open
7798 slot. */
7799 input_file_number = n_infiles;
7800 if (lang_specific_pre_link ())
7801 errorcount++;
7805 /* If we have to run the linker, do it now. */
7807 void
7808 driver::maybe_run_linker (const char *argv0) const
7810 size_t i;
7811 int linker_was_run = 0;
7812 int num_linker_inputs;
7814 /* Determine if there are any linker input files. */
7815 num_linker_inputs = 0;
7816 for (i = 0; (int) i < n_infiles; i++)
7817 if (explicit_link_files[i] || outfiles[i] != NULL)
7818 num_linker_inputs++;
7820 /* Run ld to link all the compiler output files. */
7822 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
7824 int tmp = execution_count;
7826 if (! have_c)
7828 #if HAVE_LTO_PLUGIN > 0
7829 #if HAVE_LTO_PLUGIN == 2
7830 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
7831 #else
7832 const char *fuse_linker_plugin = "fuse-linker-plugin";
7833 #endif
7834 #endif
7836 /* We'll use ld if we can't find collect2. */
7837 if (! strcmp (linker_name_spec, "collect2"))
7839 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
7840 if (s == NULL)
7841 linker_name_spec = "ld";
7844 #if HAVE_LTO_PLUGIN > 0
7845 #if HAVE_LTO_PLUGIN == 2
7846 if (!switch_matches (fno_use_linker_plugin,
7847 fno_use_linker_plugin
7848 + strlen (fno_use_linker_plugin), 0))
7849 #else
7850 if (switch_matches (fuse_linker_plugin,
7851 fuse_linker_plugin
7852 + strlen (fuse_linker_plugin), 0))
7853 #endif
7855 char *temp_spec = find_a_file (&exec_prefixes,
7856 LTOPLUGINSONAME, R_OK,
7857 false);
7858 if (!temp_spec)
7859 fatal_error ("-fuse-linker-plugin, but %s not found",
7860 LTOPLUGINSONAME);
7861 linker_plugin_file_spec = convert_white_space (temp_spec);
7863 #endif
7864 lto_gcc_spec = argv0;
7867 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
7868 for collect. */
7869 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
7870 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
7872 if (print_subprocess_help == 1)
7874 printf (_("\nLinker options\n==============\n\n"));
7875 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
7876 " to the linker.\n\n"));
7877 fflush (stdout);
7879 int value = do_spec (link_command_spec);
7880 if (value < 0)
7881 errorcount = 1;
7882 linker_was_run = (tmp != execution_count);
7885 /* If options said don't run linker,
7886 complain about input files to be given to the linker. */
7888 if (! linker_was_run && !seen_error ())
7889 for (i = 0; (int) i < n_infiles; i++)
7890 if (explicit_link_files[i]
7891 && !(infiles[i].language && infiles[i].language[0] == '*'))
7892 warning (0, "%s: linker input file unused because linking not done",
7893 outfiles[i]);
7896 /* The end of "main". */
7898 void
7899 driver::final_actions () const
7901 /* Delete some or all of the temporary files we made. */
7903 if (seen_error ())
7904 delete_failure_queue ();
7905 delete_temp_files ();
7907 if (print_help_list)
7909 printf (("\nFor bug reporting instructions, please see:\n"));
7910 printf ("%s\n", bug_report_url);
7914 /* Determine what the exit code of the driver should be. */
7917 driver::get_exit_code () const
7919 return (signal_count != 0 ? 2
7920 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
7921 : 0);
7924 /* Find the proper compilation spec for the file name NAME,
7925 whose length is LENGTH. LANGUAGE is the specified language,
7926 or 0 if this file is to be passed to the linker. */
7928 static struct compiler *
7929 lookup_compiler (const char *name, size_t length, const char *language)
7931 struct compiler *cp;
7933 /* If this was specified by the user to be a linker input, indicate that. */
7934 if (language != 0 && language[0] == '*')
7935 return 0;
7937 /* Otherwise, look for the language, if one is spec'd. */
7938 if (language != 0)
7940 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7941 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
7942 return cp;
7944 error ("language %s not recognized", language);
7945 return 0;
7948 /* Look for a suffix. */
7949 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7951 if (/* The suffix `-' matches only the file name `-'. */
7952 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7953 || (strlen (cp->suffix) < length
7954 /* See if the suffix matches the end of NAME. */
7955 && !strcmp (cp->suffix,
7956 name + length - strlen (cp->suffix))
7958 break;
7961 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
7962 /* Look again, but case-insensitively this time. */
7963 if (cp < compilers)
7964 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7966 if (/* The suffix `-' matches only the file name `-'. */
7967 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7968 || (strlen (cp->suffix) < length
7969 /* See if the suffix matches the end of NAME. */
7970 && ((!strcmp (cp->suffix,
7971 name + length - strlen (cp->suffix))
7972 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
7973 && !strcasecmp (cp->suffix,
7974 name + length - strlen (cp->suffix)))
7976 break;
7978 #endif
7980 if (cp >= compilers)
7982 if (cp->spec[0] != '@')
7983 /* A non-alias entry: return it. */
7984 return cp;
7986 /* An alias entry maps a suffix to a language.
7987 Search for the language; pass 0 for NAME and LENGTH
7988 to avoid infinite recursion if language not found. */
7989 return lookup_compiler (NULL, 0, cp->spec + 1);
7991 return 0;
7994 static char *
7995 save_string (const char *s, int len)
7997 char *result = XNEWVEC (char, len + 1);
7999 memcpy (result, s, len);
8000 result[len] = 0;
8001 return result;
8004 void
8005 pfatal_with_name (const char *name)
8007 perror_with_name (name);
8008 delete_temp_files ();
8009 exit (1);
8012 static void
8013 perror_with_name (const char *name)
8015 error ("%s: %m", name);
8018 static inline void
8019 validate_switches_from_spec (const char *spec, bool user)
8021 const char *p = spec;
8022 char c;
8023 while ((c = *p++))
8024 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
8025 /* We have a switch spec. */
8026 p = validate_switches (p + 1, user);
8029 static void
8030 validate_all_switches (void)
8032 struct compiler *comp;
8033 struct spec_list *spec;
8035 for (comp = compilers; comp->spec; comp++)
8036 validate_switches_from_spec (comp->spec, false);
8038 /* Look through the linked list of specs read from the specs file. */
8039 for (spec = specs; spec; spec = spec->next)
8040 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
8042 validate_switches_from_spec (link_command_spec, false);
8045 /* Look at the switch-name that comes after START
8046 and mark as valid all supplied switches that match it. */
8048 static const char *
8049 validate_switches (const char *start, bool user_spec)
8051 const char *p = start;
8052 const char *atom;
8053 size_t len;
8054 int i;
8055 bool suffix = false;
8056 bool starred = false;
8058 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
8060 next_member:
8061 SKIP_WHITE ();
8063 if (*p == '!')
8064 p++;
8066 SKIP_WHITE ();
8067 if (*p == '.' || *p == ',')
8068 suffix = true, p++;
8070 atom = p;
8071 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
8072 || *p == ',' || *p == '.' || *p == '@')
8073 p++;
8074 len = p - atom;
8076 if (*p == '*')
8077 starred = true, p++;
8079 SKIP_WHITE ();
8081 if (!suffix)
8083 /* Mark all matching switches as valid. */
8084 for (i = 0; i < n_switches; i++)
8085 if (!strncmp (switches[i].part1, atom, len)
8086 && (starred || switches[i].part1[len] == '\0')
8087 && (switches[i].known || user_spec))
8088 switches[i].validated = true;
8091 if (*p) p++;
8092 if (*p && (p[-1] == '|' || p[-1] == '&'))
8093 goto next_member;
8095 if (*p && p[-1] == ':')
8097 while (*p && *p != ';' && *p != '}')
8099 if (*p == '%')
8101 p++;
8102 if (*p == '{' || *p == '<')
8103 p = validate_switches (p+1, user_spec);
8104 else if (p[0] == 'W' && p[1] == '{')
8105 p = validate_switches (p+2, user_spec);
8107 else
8108 p++;
8111 if (*p) p++;
8112 if (*p && p[-1] == ';')
8113 goto next_member;
8116 return p;
8117 #undef SKIP_WHITE
8120 struct mdswitchstr
8122 const char *str;
8123 int len;
8126 static struct mdswitchstr *mdswitches;
8127 static int n_mdswitches;
8129 /* Check whether a particular argument was used. The first time we
8130 canonicalize the switches to keep only the ones we care about. */
8132 static int
8133 used_arg (const char *p, int len)
8135 struct mswitchstr
8137 const char *str;
8138 const char *replace;
8139 int len;
8140 int rep_len;
8143 static struct mswitchstr *mswitches;
8144 static int n_mswitches;
8145 int i, j;
8147 if (!mswitches)
8149 struct mswitchstr *matches;
8150 const char *q;
8151 int cnt = 0;
8153 /* Break multilib_matches into the component strings of string
8154 and replacement string. */
8155 for (q = multilib_matches; *q != '\0'; q++)
8156 if (*q == ';')
8157 cnt++;
8159 matches
8160 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
8161 i = 0;
8162 q = multilib_matches;
8163 while (*q != '\0')
8165 matches[i].str = q;
8166 while (*q != ' ')
8168 if (*q == '\0')
8170 invalid_matches:
8171 fatal_error ("multilib spec %qs is invalid",
8172 multilib_matches);
8174 q++;
8176 matches[i].len = q - matches[i].str;
8178 matches[i].replace = ++q;
8179 while (*q != ';' && *q != '\0')
8181 if (*q == ' ')
8182 goto invalid_matches;
8183 q++;
8185 matches[i].rep_len = q - matches[i].replace;
8186 i++;
8187 if (*q == ';')
8188 q++;
8191 /* Now build a list of the replacement string for switches that we care
8192 about. Make sure we allocate at least one entry. This prevents
8193 xmalloc from calling fatal, and prevents us from re-executing this
8194 block of code. */
8195 mswitches
8196 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
8197 for (i = 0; i < n_switches; i++)
8198 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
8200 int xlen = strlen (switches[i].part1);
8201 for (j = 0; j < cnt; j++)
8202 if (xlen == matches[j].len
8203 && ! strncmp (switches[i].part1, matches[j].str, xlen))
8205 mswitches[n_mswitches].str = matches[j].replace;
8206 mswitches[n_mswitches].len = matches[j].rep_len;
8207 mswitches[n_mswitches].replace = (char *) 0;
8208 mswitches[n_mswitches].rep_len = 0;
8209 n_mswitches++;
8210 break;
8214 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
8215 on the command line nor any options mutually incompatible with
8216 them. */
8217 for (i = 0; i < n_mdswitches; i++)
8219 const char *r;
8221 for (q = multilib_options; *q != '\0'; *q && q++)
8223 while (*q == ' ')
8224 q++;
8226 r = q;
8227 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
8228 || strchr (" /", q[mdswitches[i].len]) == NULL)
8230 while (*q != ' ' && *q != '/' && *q != '\0')
8231 q++;
8232 if (*q != '/')
8233 break;
8234 q++;
8237 if (*q != ' ' && *q != '\0')
8239 while (*r != ' ' && *r != '\0')
8241 q = r;
8242 while (*q != ' ' && *q != '/' && *q != '\0')
8243 q++;
8245 if (used_arg (r, q - r))
8246 break;
8248 if (*q != '/')
8250 mswitches[n_mswitches].str = mdswitches[i].str;
8251 mswitches[n_mswitches].len = mdswitches[i].len;
8252 mswitches[n_mswitches].replace = (char *) 0;
8253 mswitches[n_mswitches].rep_len = 0;
8254 n_mswitches++;
8255 break;
8258 r = q + 1;
8260 break;
8266 for (i = 0; i < n_mswitches; i++)
8267 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
8268 return 1;
8270 return 0;
8273 static int
8274 default_arg (const char *p, int len)
8276 int i;
8278 for (i = 0; i < n_mdswitches; i++)
8279 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
8280 return 1;
8282 return 0;
8285 /* Work out the subdirectory to use based on the options. The format of
8286 multilib_select is a list of elements. Each element is a subdirectory
8287 name followed by a list of options followed by a semicolon. The format
8288 of multilib_exclusions is the same, but without the preceding
8289 directory. First gcc will check the exclusions, if none of the options
8290 beginning with an exclamation point are present, and all of the other
8291 options are present, then we will ignore this completely. Passing
8292 that, gcc will consider each multilib_select in turn using the same
8293 rules for matching the options. If a match is found, that subdirectory
8294 will be used.
8295 A subdirectory name is optionally followed by a colon and the corresponding
8296 multiarch name. */
8298 static void
8299 set_multilib_dir (void)
8301 const char *p;
8302 unsigned int this_path_len;
8303 const char *this_path, *this_arg;
8304 const char *start, *end;
8305 int not_arg;
8306 int ok, ndfltok, first;
8308 n_mdswitches = 0;
8309 start = multilib_defaults;
8310 while (*start == ' ' || *start == '\t')
8311 start++;
8312 while (*start != '\0')
8314 n_mdswitches++;
8315 while (*start != ' ' && *start != '\t' && *start != '\0')
8316 start++;
8317 while (*start == ' ' || *start == '\t')
8318 start++;
8321 if (n_mdswitches)
8323 int i = 0;
8325 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
8326 for (start = multilib_defaults; *start != '\0'; start = end + 1)
8328 while (*start == ' ' || *start == '\t')
8329 start++;
8331 if (*start == '\0')
8332 break;
8334 for (end = start + 1;
8335 *end != ' ' && *end != '\t' && *end != '\0'; end++)
8338 obstack_grow (&multilib_obstack, start, end - start);
8339 obstack_1grow (&multilib_obstack, 0);
8340 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
8341 mdswitches[i++].len = end - start;
8343 if (*end == '\0')
8344 break;
8348 p = multilib_exclusions;
8349 while (*p != '\0')
8351 /* Ignore newlines. */
8352 if (*p == '\n')
8354 ++p;
8355 continue;
8358 /* Check the arguments. */
8359 ok = 1;
8360 while (*p != ';')
8362 if (*p == '\0')
8364 invalid_exclusions:
8365 fatal_error ("multilib exclusions %qs is invalid",
8366 multilib_exclusions);
8369 if (! ok)
8371 ++p;
8372 continue;
8375 this_arg = p;
8376 while (*p != ' ' && *p != ';')
8378 if (*p == '\0')
8379 goto invalid_exclusions;
8380 ++p;
8383 if (*this_arg != '!')
8384 not_arg = 0;
8385 else
8387 not_arg = 1;
8388 ++this_arg;
8391 ok = used_arg (this_arg, p - this_arg);
8392 if (not_arg)
8393 ok = ! ok;
8395 if (*p == ' ')
8396 ++p;
8399 if (ok)
8400 return;
8402 ++p;
8405 first = 1;
8406 p = multilib_select;
8408 /* Append multilib reuse rules if any. With those rules, we can reuse
8409 one multilib for certain different options sets. */
8410 if (strlen (multilib_reuse) > 0)
8411 p = concat (p, multilib_reuse, NULL);
8413 while (*p != '\0')
8415 /* Ignore newlines. */
8416 if (*p == '\n')
8418 ++p;
8419 continue;
8422 /* Get the initial path. */
8423 this_path = p;
8424 while (*p != ' ')
8426 if (*p == '\0')
8428 invalid_select:
8429 fatal_error ("multilib select %qs %qs is invalid",
8430 multilib_select, multilib_reuse);
8432 ++p;
8434 this_path_len = p - this_path;
8436 /* Check the arguments. */
8437 ok = 1;
8438 ndfltok = 1;
8439 ++p;
8440 while (*p != ';')
8442 if (*p == '\0')
8443 goto invalid_select;
8445 if (! ok)
8447 ++p;
8448 continue;
8451 this_arg = p;
8452 while (*p != ' ' && *p != ';')
8454 if (*p == '\0')
8455 goto invalid_select;
8456 ++p;
8459 if (*this_arg != '!')
8460 not_arg = 0;
8461 else
8463 not_arg = 1;
8464 ++this_arg;
8467 /* If this is a default argument, we can just ignore it.
8468 This is true even if this_arg begins with '!'. Beginning
8469 with '!' does not mean that this argument is necessarily
8470 inappropriate for this library: it merely means that
8471 there is a more specific library which uses this
8472 argument. If this argument is a default, we need not
8473 consider that more specific library. */
8474 ok = used_arg (this_arg, p - this_arg);
8475 if (not_arg)
8476 ok = ! ok;
8478 if (! ok)
8479 ndfltok = 0;
8481 if (default_arg (this_arg, p - this_arg))
8482 ok = 1;
8484 if (*p == ' ')
8485 ++p;
8488 if (ok && first)
8490 if (this_path_len != 1
8491 || this_path[0] != '.')
8493 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
8494 char *q;
8496 strncpy (new_multilib_dir, this_path, this_path_len);
8497 new_multilib_dir[this_path_len] = '\0';
8498 q = strchr (new_multilib_dir, ':');
8499 if (q != NULL)
8500 *q = '\0';
8501 multilib_dir = new_multilib_dir;
8503 first = 0;
8506 if (ndfltok)
8508 const char *q = this_path, *end = this_path + this_path_len;
8510 while (q < end && *q != ':')
8511 q++;
8512 if (q < end)
8514 const char *q2 = q + 1, *ml_end = end;
8515 char *new_multilib_os_dir;
8517 while (q2 < end && *q2 != ':')
8518 q2++;
8519 if (*q2 == ':')
8520 ml_end = q2;
8521 if (ml_end - q == 1)
8522 multilib_os_dir = xstrdup (".");
8523 else
8525 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
8526 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
8527 new_multilib_os_dir[ml_end - q - 1] = '\0';
8528 multilib_os_dir = new_multilib_os_dir;
8531 if (q2 < end && *q2 == ':')
8533 char *new_multiarch_dir = XNEWVEC (char, end - q2);
8534 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
8535 new_multiarch_dir[end - q2 - 1] = '\0';
8536 multiarch_dir = new_multiarch_dir;
8538 break;
8542 ++p;
8545 if (multilib_dir == NULL && multilib_os_dir != NULL
8546 && strcmp (multilib_os_dir, ".") == 0)
8548 free (CONST_CAST (char *, multilib_os_dir));
8549 multilib_os_dir = NULL;
8551 else if (multilib_dir != NULL && multilib_os_dir == NULL)
8552 multilib_os_dir = multilib_dir;
8555 /* Print out the multiple library subdirectory selection
8556 information. This prints out a series of lines. Each line looks
8557 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
8558 required. Only the desired options are printed out, the negative
8559 matches. The options are print without a leading dash. There are
8560 no spaces to make it easy to use the information in the shell.
8561 Each subdirectory is printed only once. This assumes the ordering
8562 generated by the genmultilib script. Also, we leave out ones that match
8563 the exclusions. */
8565 static void
8566 print_multilib_info (void)
8568 const char *p = multilib_select;
8569 const char *last_path = 0, *this_path;
8570 int skip;
8571 unsigned int last_path_len = 0;
8573 while (*p != '\0')
8575 skip = 0;
8576 /* Ignore newlines. */
8577 if (*p == '\n')
8579 ++p;
8580 continue;
8583 /* Get the initial path. */
8584 this_path = p;
8585 while (*p != ' ')
8587 if (*p == '\0')
8589 invalid_select:
8590 fatal_error ("multilib select %qs is invalid", multilib_select);
8593 ++p;
8596 /* When --disable-multilib was used but target defines
8597 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
8598 with .:: for multiarch configurations) are there just to find
8599 multilib_os_dir, so skip them from output. */
8600 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
8601 skip = 1;
8603 /* Check for matches with the multilib_exclusions. We don't bother
8604 with the '!' in either list. If any of the exclusion rules match
8605 all of its options with the select rule, we skip it. */
8607 const char *e = multilib_exclusions;
8608 const char *this_arg;
8610 while (*e != '\0')
8612 int m = 1;
8613 /* Ignore newlines. */
8614 if (*e == '\n')
8616 ++e;
8617 continue;
8620 /* Check the arguments. */
8621 while (*e != ';')
8623 const char *q;
8624 int mp = 0;
8626 if (*e == '\0')
8628 invalid_exclusion:
8629 fatal_error ("multilib exclusion %qs is invalid",
8630 multilib_exclusions);
8633 if (! m)
8635 ++e;
8636 continue;
8639 this_arg = e;
8641 while (*e != ' ' && *e != ';')
8643 if (*e == '\0')
8644 goto invalid_exclusion;
8645 ++e;
8648 q = p + 1;
8649 while (*q != ';')
8651 const char *arg;
8652 int len = e - this_arg;
8654 if (*q == '\0')
8655 goto invalid_select;
8657 arg = q;
8659 while (*q != ' ' && *q != ';')
8661 if (*q == '\0')
8662 goto invalid_select;
8663 ++q;
8666 if (! strncmp (arg, this_arg,
8667 (len < q - arg) ? q - arg : len)
8668 || default_arg (this_arg, e - this_arg))
8670 mp = 1;
8671 break;
8674 if (*q == ' ')
8675 ++q;
8678 if (! mp)
8679 m = 0;
8681 if (*e == ' ')
8682 ++e;
8685 if (m)
8687 skip = 1;
8688 break;
8691 if (*e != '\0')
8692 ++e;
8696 if (! skip)
8698 /* If this is a duplicate, skip it. */
8699 skip = (last_path != 0
8700 && (unsigned int) (p - this_path) == last_path_len
8701 && ! filename_ncmp (last_path, this_path, last_path_len));
8703 last_path = this_path;
8704 last_path_len = p - this_path;
8707 /* If this directory requires any default arguments, we can skip
8708 it. We will already have printed a directory identical to
8709 this one which does not require that default argument. */
8710 if (! skip)
8712 const char *q;
8714 q = p + 1;
8715 while (*q != ';')
8717 const char *arg;
8719 if (*q == '\0')
8720 goto invalid_select;
8722 if (*q == '!')
8723 arg = NULL;
8724 else
8725 arg = q;
8727 while (*q != ' ' && *q != ';')
8729 if (*q == '\0')
8730 goto invalid_select;
8731 ++q;
8734 if (arg != NULL
8735 && default_arg (arg, q - arg))
8737 skip = 1;
8738 break;
8741 if (*q == ' ')
8742 ++q;
8746 if (! skip)
8748 const char *p1;
8750 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
8751 putchar (*p1);
8752 putchar (';');
8755 ++p;
8756 while (*p != ';')
8758 int use_arg;
8760 if (*p == '\0')
8761 goto invalid_select;
8763 if (skip)
8765 ++p;
8766 continue;
8769 use_arg = *p != '!';
8771 if (use_arg)
8772 putchar ('@');
8774 while (*p != ' ' && *p != ';')
8776 if (*p == '\0')
8777 goto invalid_select;
8778 if (use_arg)
8779 putchar (*p);
8780 ++p;
8783 if (*p == ' ')
8784 ++p;
8787 if (! skip)
8789 /* If there are extra options, print them now. */
8790 if (multilib_extra && *multilib_extra)
8792 int print_at = TRUE;
8793 const char *q;
8795 for (q = multilib_extra; *q != '\0'; q++)
8797 if (*q == ' ')
8798 print_at = TRUE;
8799 else
8801 if (print_at)
8802 putchar ('@');
8803 putchar (*q);
8804 print_at = FALSE;
8809 putchar ('\n');
8812 ++p;
8816 /* getenv built-in spec function.
8818 Returns the value of the environment variable given by its first
8819 argument, concatenated with the second argument. If the
8820 environment variable is not defined, a fatal error is issued. */
8822 static const char *
8823 getenv_spec_function (int argc, const char **argv)
8825 char *value;
8826 char *result;
8827 char *ptr;
8828 size_t len;
8830 if (argc != 2)
8831 return NULL;
8833 value = getenv (argv[0]);
8834 if (!value)
8835 fatal_error ("environment variable %qs not defined", argv[0]);
8837 /* We have to escape every character of the environment variable so
8838 they are not interpreted as active spec characters. A
8839 particularly painful case is when we are reading a variable
8840 holding a windows path complete with \ separators. */
8841 len = strlen (value) * 2 + strlen (argv[1]) + 1;
8842 result = XNEWVAR (char, len);
8843 for (ptr = result; *value; ptr += 2)
8845 ptr[0] = '\\';
8846 ptr[1] = *value++;
8849 strcpy (ptr, argv[1]);
8851 return result;
8854 /* if-exists built-in spec function.
8856 Checks to see if the file specified by the absolute pathname in
8857 ARGS exists. Returns that pathname if found.
8859 The usual use for this function is to check for a library file
8860 (whose name has been expanded with %s). */
8862 static const char *
8863 if_exists_spec_function (int argc, const char **argv)
8865 /* Must have only one argument. */
8866 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8867 return argv[0];
8869 return NULL;
8872 /* if-exists-else built-in spec function.
8874 This is like if-exists, but takes an additional argument which
8875 is returned if the first argument does not exist. */
8877 static const char *
8878 if_exists_else_spec_function (int argc, const char **argv)
8880 /* Must have exactly two arguments. */
8881 if (argc != 2)
8882 return NULL;
8884 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8885 return argv[0];
8887 return argv[1];
8890 /* sanitize built-in spec function.
8892 This returns non-NULL, if sanitizing address, thread or
8893 any of the undefined behavior sanitizers. */
8895 static const char *
8896 sanitize_spec_function (int argc, const char **argv)
8898 if (argc != 1)
8899 return NULL;
8901 if (strcmp (argv[0], "address") == 0)
8902 return (flag_sanitize & SANITIZE_USER_ADDRESS) ? "" : NULL;
8903 if (strcmp (argv[0], "kernel-address") == 0)
8904 return (flag_sanitize & SANITIZE_KERNEL_ADDRESS) ? "" : NULL;
8905 if (strcmp (argv[0], "thread") == 0)
8906 return (flag_sanitize & SANITIZE_THREAD) ? "" : NULL;
8907 if (strcmp (argv[0], "undefined") == 0)
8908 return ((flag_sanitize & (SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT))
8909 && !flag_sanitize_undefined_trap_on_error) ? "" : NULL;
8910 if (strcmp (argv[0], "leak") == 0)
8911 return ((flag_sanitize
8912 & (SANITIZE_ADDRESS | SANITIZE_LEAK | SANITIZE_THREAD))
8913 == SANITIZE_LEAK) ? "" : NULL;
8914 return NULL;
8917 /* replace-outfile built-in spec function.
8919 This looks for the first argument in the outfiles array's name and
8920 replaces it with the second argument. */
8922 static const char *
8923 replace_outfile_spec_function (int argc, const char **argv)
8925 int i;
8926 /* Must have exactly two arguments. */
8927 if (argc != 2)
8928 abort ();
8930 for (i = 0; i < n_infiles; i++)
8932 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8933 outfiles[i] = xstrdup (argv[1]);
8935 return NULL;
8938 /* remove-outfile built-in spec function.
8940 * This looks for the first argument in the outfiles array's name and
8941 * removes it. */
8943 static const char *
8944 remove_outfile_spec_function (int argc, const char **argv)
8946 int i;
8947 /* Must have exactly one argument. */
8948 if (argc != 1)
8949 abort ();
8951 for (i = 0; i < n_infiles; i++)
8953 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8954 outfiles[i] = NULL;
8956 return NULL;
8959 /* Given two version numbers, compares the two numbers.
8960 A version number must match the regular expression
8961 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
8963 static int
8964 compare_version_strings (const char *v1, const char *v2)
8966 int rresult;
8967 regex_t r;
8969 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
8970 REG_EXTENDED | REG_NOSUB) != 0)
8971 abort ();
8972 rresult = regexec (&r, v1, 0, NULL, 0);
8973 if (rresult == REG_NOMATCH)
8974 fatal_error ("invalid version number %qs", v1);
8975 else if (rresult != 0)
8976 abort ();
8977 rresult = regexec (&r, v2, 0, NULL, 0);
8978 if (rresult == REG_NOMATCH)
8979 fatal_error ("invalid version number %qs", v2);
8980 else if (rresult != 0)
8981 abort ();
8983 return strverscmp (v1, v2);
8987 /* version_compare built-in spec function.
8989 This takes an argument of the following form:
8991 <comparison-op> <arg1> [<arg2>] <switch> <result>
8993 and produces "result" if the comparison evaluates to true,
8994 and nothing if it doesn't.
8996 The supported <comparison-op> values are:
8998 >= true if switch is a later (or same) version than arg1
8999 !> opposite of >=
9000 < true if switch is an earlier version than arg1
9001 !< opposite of <
9002 >< true if switch is arg1 or later, and earlier than arg2
9003 <> true if switch is earlier than arg1 or is arg2 or later
9005 If the switch is not present, the condition is false unless
9006 the first character of the <comparison-op> is '!'.
9008 For example,
9009 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
9010 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
9012 static const char *
9013 version_compare_spec_function (int argc, const char **argv)
9015 int comp1, comp2;
9016 size_t switch_len;
9017 const char *switch_value = NULL;
9018 int nargs = 1, i;
9019 bool result;
9021 if (argc < 3)
9022 fatal_error ("too few arguments to %%:version-compare");
9023 if (argv[0][0] == '\0')
9024 abort ();
9025 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
9026 nargs = 2;
9027 if (argc != nargs + 3)
9028 fatal_error ("too many arguments to %%:version-compare");
9030 switch_len = strlen (argv[nargs + 1]);
9031 for (i = 0; i < n_switches; i++)
9032 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
9033 && check_live_switch (i, switch_len))
9034 switch_value = switches[i].part1 + switch_len;
9036 if (switch_value == NULL)
9037 comp1 = comp2 = -1;
9038 else
9040 comp1 = compare_version_strings (switch_value, argv[1]);
9041 if (nargs == 2)
9042 comp2 = compare_version_strings (switch_value, argv[2]);
9043 else
9044 comp2 = -1; /* This value unused. */
9047 switch (argv[0][0] << 8 | argv[0][1])
9049 case '>' << 8 | '=':
9050 result = comp1 >= 0;
9051 break;
9052 case '!' << 8 | '<':
9053 result = comp1 >= 0 || switch_value == NULL;
9054 break;
9055 case '<' << 8:
9056 result = comp1 < 0;
9057 break;
9058 case '!' << 8 | '>':
9059 result = comp1 < 0 || switch_value == NULL;
9060 break;
9061 case '>' << 8 | '<':
9062 result = comp1 >= 0 && comp2 < 0;
9063 break;
9064 case '<' << 8 | '>':
9065 result = comp1 < 0 || comp2 >= 0;
9066 break;
9068 default:
9069 fatal_error ("unknown operator %qs in %%:version-compare", argv[0]);
9071 if (! result)
9072 return NULL;
9074 return argv[nargs + 2];
9077 /* %:include builtin spec function. This differs from %include in that it
9078 can be nested inside a spec, and thus be conditionalized. It takes
9079 one argument, the filename, and looks for it in the startfile path.
9080 The result is always NULL, i.e. an empty expansion. */
9082 static const char *
9083 include_spec_function (int argc, const char **argv)
9085 char *file;
9087 if (argc != 1)
9088 abort ();
9090 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
9091 read_specs (file ? file : argv[0], false, false);
9093 return NULL;
9096 /* %:find-file spec function. This function replaces its argument by
9097 the file found through find_file, that is the -print-file-name gcc
9098 program option. */
9099 static const char *
9100 find_file_spec_function (int argc, const char **argv)
9102 const char *file;
9104 if (argc != 1)
9105 abort ();
9107 file = find_file (argv[0]);
9108 return file;
9112 /* %:find-plugindir spec function. This function replaces its argument
9113 by the -iplugindir=<dir> option. `dir' is found through find_file, that
9114 is the -print-file-name gcc program option. */
9115 static const char *
9116 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
9118 const char *option;
9120 if (argc != 0)
9121 abort ();
9123 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
9124 return option;
9128 /* %:print-asm-header spec function. Print a banner to say that the
9129 following output is from the assembler. */
9131 static const char *
9132 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
9133 const char **argv ATTRIBUTE_UNUSED)
9135 printf (_("Assembler options\n=================\n\n"));
9136 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
9137 fflush (stdout);
9138 return NULL;
9141 /* Get a random number for -frandom-seed */
9143 static unsigned HOST_WIDE_INT
9144 get_random_number (void)
9146 unsigned HOST_WIDE_INT ret = 0;
9147 int fd;
9149 fd = open ("/dev/urandom", O_RDONLY);
9150 if (fd >= 0)
9152 read (fd, &ret, sizeof (HOST_WIDE_INT));
9153 close (fd);
9154 if (ret)
9155 return ret;
9158 /* Get some more or less random data. */
9159 #ifdef HAVE_GETTIMEOFDAY
9161 struct timeval tv;
9163 gettimeofday (&tv, NULL);
9164 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
9166 #else
9168 time_t now = time (NULL);
9170 if (now != (time_t)-1)
9171 ret = (unsigned) now;
9173 #endif
9175 return ret ^ getpid ();
9178 /* %:compare-debug-dump-opt spec function. Save the last argument,
9179 expected to be the last -fdump-final-insns option, or generate a
9180 temporary. */
9182 static const char *
9183 compare_debug_dump_opt_spec_function (int arg,
9184 const char **argv ATTRIBUTE_UNUSED)
9186 char *ret;
9187 char *name;
9188 int which;
9189 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
9191 if (arg != 0)
9192 fatal_error ("too many arguments to %%:compare-debug-dump-opt");
9194 do_spec_2 ("%{fdump-final-insns=*:%*}");
9195 do_spec_1 (" ", 0, NULL);
9197 if (argbuf.length () > 0
9198 && strcmp (argv[argbuf.length () - 1], "."))
9200 if (!compare_debug)
9201 return NULL;
9203 name = xstrdup (argv[argbuf.length () - 1]);
9204 ret = NULL;
9206 else
9208 const char *ext = NULL;
9210 if (argbuf.length () > 0)
9212 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
9213 ext = ".gkd";
9215 else if (!compare_debug)
9216 return NULL;
9217 else
9218 do_spec_2 ("%g.gkd");
9220 do_spec_1 (" ", 0, NULL);
9222 gcc_assert (argbuf.length () > 0);
9224 name = concat (argbuf.last (), ext, NULL);
9226 ret = concat ("-fdump-final-insns=", name, NULL);
9229 which = compare_debug < 0;
9230 debug_check_temp_file[which] = name;
9232 if (!which)
9234 unsigned HOST_WIDE_INT value = get_random_number ();
9236 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
9239 if (*random_seed)
9241 char *tmp = ret;
9242 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
9243 ret, NULL);
9244 free (tmp);
9247 if (which)
9248 *random_seed = 0;
9250 return ret;
9253 static const char *debug_auxbase_opt;
9255 /* %:compare-debug-self-opt spec function. Expands to the options
9256 that are to be passed in the second compilation of
9257 compare-debug. */
9259 static const char *
9260 compare_debug_self_opt_spec_function (int arg,
9261 const char **argv ATTRIBUTE_UNUSED)
9263 if (arg != 0)
9264 fatal_error ("too many arguments to %%:compare-debug-self-opt");
9266 if (compare_debug >= 0)
9267 return NULL;
9269 do_spec_2 ("%{c|S:%{o*:%*}}");
9270 do_spec_1 (" ", 0, NULL);
9272 if (argbuf.length () > 0)
9273 debug_auxbase_opt = concat ("-auxbase-strip ",
9274 argbuf.last (),
9275 NULL);
9276 else
9277 debug_auxbase_opt = NULL;
9279 return concat ("\
9280 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
9281 %<fdump-final-insns=* -w -S -o %j \
9282 %{!fcompare-debug-second:-fcompare-debug-second} \
9283 ", compare_debug_opt, NULL);
9286 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
9287 options that are to be passed in the second compilation of
9288 compare-debug. It expects, as an argument, the basename of the
9289 current input file name, with the .gk suffix appended to it. */
9291 static const char *
9292 compare_debug_auxbase_opt_spec_function (int arg,
9293 const char **argv)
9295 char *name;
9296 int len;
9298 if (arg == 0)
9299 fatal_error ("too few arguments to %%:compare-debug-auxbase-opt");
9301 if (arg != 1)
9302 fatal_error ("too many arguments to %%:compare-debug-auxbase-opt");
9304 if (compare_debug >= 0)
9305 return NULL;
9307 len = strlen (argv[0]);
9308 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
9309 fatal_error ("argument to %%:compare-debug-auxbase-opt "
9310 "does not end in .gk");
9312 if (debug_auxbase_opt)
9313 return debug_auxbase_opt;
9315 #define OPT "-auxbase "
9317 len -= 3;
9318 name = (char*) xmalloc (sizeof (OPT) + len);
9319 memcpy (name, OPT, sizeof (OPT) - 1);
9320 memcpy (name + sizeof (OPT) - 1, argv[0], len);
9321 name[sizeof (OPT) - 1 + len] = '\0';
9323 #undef OPT
9325 return name;
9328 /* %:pass-through-libs spec function. Finds all -l options and input
9329 file names in the lib spec passed to it, and makes a list of them
9330 prepended with the plugin option to cause them to be passed through
9331 to the final link after all the new object files have been added. */
9333 const char *
9334 pass_through_libs_spec_func (int argc, const char **argv)
9336 char *prepended = xstrdup (" ");
9337 int n;
9338 /* Shlemiel the painter's algorithm. Innately horrible, but at least
9339 we know that there will never be more than a handful of strings to
9340 concat, and it's only once per run, so it's not worth optimising. */
9341 for (n = 0; n < argc; n++)
9343 char *old = prepended;
9344 /* Anything that isn't an option is a full path to an output
9345 file; pass it through if it ends in '.a'. Among options,
9346 pass only -l. */
9347 if (argv[n][0] == '-' && argv[n][1] == 'l')
9349 const char *lopt = argv[n] + 2;
9350 /* Handle both joined and non-joined -l options. If for any
9351 reason there's a trailing -l with no joined or following
9352 arg just discard it. */
9353 if (!*lopt && ++n >= argc)
9354 break;
9355 else if (!*lopt)
9356 lopt = argv[n];
9357 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
9358 lopt, " ", NULL);
9360 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
9362 prepended = concat (prepended, "-plugin-opt=-pass-through=",
9363 argv[n], " ", NULL);
9365 if (prepended != old)
9366 free (old);
9368 return prepended;
9371 /* %:replace-extension spec function. Replaces the extension of the
9372 first argument with the second argument. */
9374 const char *
9375 replace_extension_spec_func (int argc, const char **argv)
9377 char *name;
9378 char *p;
9379 char *result;
9380 int i;
9382 if (argc != 2)
9383 fatal_error ("too few arguments to %%:replace-extension");
9385 name = xstrdup (argv[0]);
9387 for (i = strlen (name) - 1; i >= 0; i--)
9388 if (IS_DIR_SEPARATOR (name[i]))
9389 break;
9391 p = strrchr (name + i + 1, '.');
9392 if (p != NULL)
9393 *p = '\0';
9395 result = concat (name, argv[1], NULL);
9397 free (name);
9398 return result;
9401 /* Insert backslash before spaces in ORIG (usually a file path), to
9402 avoid being broken by spec parser.
9404 This function is needed as do_spec_1 treats white space (' ' and '\t')
9405 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
9406 the file name should be treated as a single argument rather than being
9407 broken into multiple. Solution is to insert '\\' before the space in a
9408 file name.
9410 This function converts and only converts all occurrence of ' '
9411 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
9412 "a b" -> "a\\ b"
9413 "a b" -> "a\\ \\ b"
9414 "a\tb" -> "a\\\tb"
9415 "a\\ b" -> "a\\\\ b"
9417 orig: input null-terminating string that was allocated by xalloc. The
9418 memory it points to might be freed in this function. Behavior undefined
9419 if ORIG wasn't xalloced or was freed already at entry.
9421 Return: ORIG if no conversion needed. Otherwise a newly allocated string
9422 that was converted from ORIG. */
9424 static char *
9425 convert_white_space (char *orig)
9427 int len, number_of_space = 0;
9429 for (len = 0; orig[len]; len++)
9430 if (orig[len] == ' ' || orig[len] == '\t') number_of_space++;
9432 if (number_of_space)
9434 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
9435 int j, k;
9436 for (j = 0, k = 0; j <= len; j++, k++)
9438 if (orig[j] == ' ' || orig[j] == '\t')
9439 new_spec[k++] = '\\';
9440 new_spec[k] = orig[j];
9442 free (orig);
9443 return new_spec;
9445 else
9446 return orig;