2015-08-04 Thomas Preud'homme <thomas.preudhomme@arm.com>
[official-gcc.git] / gcc / gcc.c
blob290ec78d08872095d269135c1be7fafab7b86c0c
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987-2015 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 "filenames.h"
46 /* By default there is no special suffix for target executables. */
47 /* FIXME: when autoconf is fixed, remove the host check - dj */
48 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
49 #define HAVE_TARGET_EXECUTABLE_SUFFIX
50 #endif
52 /* By default there is no special suffix for host executables. */
53 #ifdef HOST_EXECUTABLE_SUFFIX
54 #define HAVE_HOST_EXECUTABLE_SUFFIX
55 #else
56 #define HOST_EXECUTABLE_SUFFIX ""
57 #endif
59 /* By default, the suffix for target object files is ".o". */
60 #ifdef TARGET_OBJECT_SUFFIX
61 #define HAVE_TARGET_OBJECT_SUFFIX
62 #else
63 #define TARGET_OBJECT_SUFFIX ".o"
64 #endif
66 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
68 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
69 #ifndef LIBRARY_PATH_ENV
70 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
71 #endif
73 /* If a stage of compilation returns an exit status >= 1,
74 compilation of that file ceases. */
76 #define MIN_FATAL_STATUS 1
78 /* Flag set by cppspec.c to 1. */
79 int is_cpp_driver;
81 /* Flag set to nonzero if an @file argument has been supplied to gcc. */
82 static bool at_file_supplied;
84 /* Definition of string containing the arguments given to configure. */
85 #include "configargs.h"
87 /* Flag saying to print the command line options understood by gcc and its
88 sub-processes. */
90 static int print_help_list;
92 /* Flag saying to print the version of gcc and its sub-processes. */
94 static int print_version;
96 /* Flag indicating whether we should ONLY print the command and
97 arguments (like verbose_flag) without executing the command.
98 Displayed arguments are quoted so that the generated command
99 line is suitable for execution. This is intended for use in
100 shell scripts to capture the driver-generated command line. */
101 static int verbose_only_flag;
103 /* Flag indicating how to print command line options of sub-processes. */
105 static int print_subprocess_help;
107 /* Linker suffix passed to -fuse-ld=... */
108 static const char *use_ld;
110 /* Whether we should report subprocess execution times to a file. */
112 FILE *report_times_to_file = NULL;
114 /* Nonzero means place this string before uses of /, so that include
115 and library files can be found in an alternate location. */
117 #ifdef TARGET_SYSTEM_ROOT
118 static const char *target_system_root = TARGET_SYSTEM_ROOT;
119 #else
120 static const char *target_system_root = 0;
121 #endif
123 /* Nonzero means pass the updated target_system_root to the compiler. */
125 static int target_system_root_changed;
127 /* Nonzero means append this string to target_system_root. */
129 static const char *target_sysroot_suffix = 0;
131 /* Nonzero means append this string to target_system_root for headers. */
133 static const char *target_sysroot_hdrs_suffix = 0;
135 /* Nonzero means write "temp" files in source directory
136 and use the source file's name in them, and don't delete them. */
138 static enum save_temps {
139 SAVE_TEMPS_NONE, /* no -save-temps */
140 SAVE_TEMPS_CWD, /* -save-temps in current directory */
141 SAVE_TEMPS_OBJ /* -save-temps in object directory */
142 } save_temps_flag;
144 /* Output file to use to get the object directory for -save-temps=obj */
145 static char *save_temps_prefix = 0;
146 static size_t save_temps_length = 0;
148 /* The compiler version. */
150 static const char *compiler_version;
152 /* The target version. */
154 static const char *const spec_version = DEFAULT_TARGET_VERSION;
156 /* The target machine. */
158 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
159 static const char *spec_host_machine = DEFAULT_REAL_TARGET_MACHINE;
161 /* List of offload targets. */
163 static char *offload_targets = NULL;
165 /* Nonzero if cross-compiling.
166 When -b is used, the value comes from the `specs' file. */
168 #ifdef CROSS_DIRECTORY_STRUCTURE
169 static const char *cross_compile = "1";
170 #else
171 static const char *cross_compile = "0";
172 #endif
174 /* Greatest exit code of sub-processes that has been encountered up to
175 now. */
176 static int greatest_status = 1;
178 /* This is the obstack which we use to allocate many strings. */
180 static struct obstack obstack;
182 /* This is the obstack to build an environment variable to pass to
183 collect2 that describes all of the relevant switches of what to
184 pass the compiler in building the list of pointers to constructors
185 and destructors. */
187 static struct obstack collect_obstack;
189 /* Forward declaration for prototypes. */
190 struct path_prefix;
191 struct prefix_list;
193 static void init_spec (void);
194 static void store_arg (const char *, int, int);
195 static void insert_wrapper (const char *);
196 static char *load_specs (const char *);
197 static void read_specs (const char *, bool, bool);
198 static void set_spec (const char *, const char *, bool);
199 static struct compiler *lookup_compiler (const char *, size_t, const char *);
200 static char *build_search_list (const struct path_prefix *, const char *,
201 bool, bool);
202 static void xputenv (const char *);
203 static void putenv_from_prefixes (const struct path_prefix *, const char *,
204 bool);
205 static int access_check (const char *, int);
206 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
207 static void add_prefix (struct path_prefix *, const char *, const char *,
208 int, int, int);
209 static void add_sysrooted_prefix (struct path_prefix *, const char *,
210 const char *, int, int, int);
211 static char *skip_whitespace (char *);
212 static void delete_if_ordinary (const char *);
213 static void delete_temp_files (void);
214 static void delete_failure_queue (void);
215 static void clear_failure_queue (void);
216 static int check_live_switch (int, int);
217 static const char *handle_braces (const char *);
218 static inline bool input_suffix_matches (const char *, const char *);
219 static inline bool switch_matches (const char *, const char *, int);
220 static inline void mark_matching_switches (const char *, const char *, int);
221 static inline void process_marked_switches (void);
222 static const char *process_brace_body (const char *, const char *, const char *, int, int);
223 static const struct spec_function *lookup_spec_function (const char *);
224 static const char *eval_spec_function (const char *, const char *);
225 static const char *handle_spec_function (const char *, bool *);
226 static char *save_string (const char *, int);
227 static void set_collect_gcc_options (void);
228 static int do_spec_1 (const char *, int, const char *);
229 static int do_spec_2 (const char *);
230 static void do_option_spec (const char *, const char *);
231 static void do_self_spec (const char *);
232 static const char *find_file (const char *);
233 static int is_directory (const char *, bool);
234 static const char *validate_switches (const char *, bool);
235 static void validate_all_switches (void);
236 static inline void validate_switches_from_spec (const char *, bool);
237 static void give_switch (int, int);
238 static int used_arg (const char *, int);
239 static int default_arg (const char *, int);
240 static void set_multilib_dir (void);
241 static void print_multilib_info (void);
242 static void perror_with_name (const char *);
243 static void display_help (void);
244 static void add_preprocessor_option (const char *, int);
245 static void add_assembler_option (const char *, int);
246 static void add_linker_option (const char *, int);
247 static void process_command (unsigned int, struct cl_decoded_option *);
248 static int execute (void);
249 static void alloc_args (void);
250 static void clear_args (void);
251 static void fatal_signal (int);
252 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
253 static void init_gcc_specs (struct obstack *, const char *, const char *,
254 const char *);
255 #endif
256 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
257 static const char *convert_filename (const char *, int, int);
258 #endif
260 static void try_generate_repro (const char **argv);
261 static const char *getenv_spec_function (int, const char **);
262 static const char *if_exists_spec_function (int, const char **);
263 static const char *if_exists_else_spec_function (int, const char **);
264 static const char *sanitize_spec_function (int, const char **);
265 static const char *replace_outfile_spec_function (int, const char **);
266 static const char *remove_outfile_spec_function (int, const char **);
267 static const char *version_compare_spec_function (int, const char **);
268 static const char *include_spec_function (int, const char **);
269 static const char *find_file_spec_function (int, const char **);
270 static const char *find_plugindir_spec_function (int, const char **);
271 static const char *print_asm_header_spec_function (int, const char **);
272 static const char *compare_debug_dump_opt_spec_function (int, const char **);
273 static const char *compare_debug_self_opt_spec_function (int, const char **);
274 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
275 static const char *pass_through_libs_spec_func (int, const char **);
276 static const char *replace_extension_spec_func (int, const char **);
277 static const char *greater_than_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 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|fstack-protector-all" \
732 "|fstack-protector-strong|fstack-protector-explicit:}"
733 #else
734 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
735 "|fstack-protector-strong|fstack-protector-explicit" \
736 ":-lssp_nonshared -lssp}"
737 #endif
738 #endif
740 #ifdef ENABLE_DEFAULT_PIE
741 #define NO_PIE_SPEC "no-pie|static"
742 #define PIE_SPEC NO_PIE_SPEC "|r|shared:;"
743 #define NO_FPIE1_SPEC "fno-pie"
744 #define FPIE1_SPEC NO_FPIE1_SPEC ":;"
745 #define NO_FPIE2_SPEC "fno-PIE"
746 #define FPIE2_SPEC NO_FPIE2_SPEC ":;"
747 #define NO_FPIE_SPEC NO_FPIE1_SPEC "|" NO_FPIE2_SPEC
748 #define FPIE_SPEC NO_FPIE_SPEC ":;"
749 #define NO_FPIC1_SPEC "fno-pic"
750 #define FPIC1_SPEC NO_FPIC1_SPEC ":;"
751 #define NO_FPIC2_SPEC "fno-PIC"
752 #define FPIC2_SPEC NO_FPIC2_SPEC ":;"
753 #define NO_FPIC_SPEC NO_FPIC1_SPEC "|" NO_FPIC2_SPEC
754 #define FPIC_SPEC NO_FPIC_SPEC ":;"
755 #define NO_FPIE1_AND_FPIC1_SPEC NO_FPIE1_SPEC "|" NO_FPIC1_SPEC
756 #define FPIE1_OR_FPIC1_SPEC NO_FPIE1_AND_FPIC1_SPEC ":;"
757 #define NO_FPIE2_AND_FPIC2_SPEC NO_FPIE2_SPEC "|" NO_FPIC2_SPEC
758 #define FPIE2_OR_FPIC2_SPEC NO_FPIE2_AND_FPIC2_SPEC ":;"
759 #define NO_FPIE_AND_FPIC_SPEC NO_FPIE_SPEC "|" NO_FPIC_SPEC
760 #define FPIE_OR_FPIC_SPEC NO_FPIE_AND_FPIC_SPEC ":;"
761 #else
762 #define PIE_SPEC "pie"
763 #define NO_PIE_SPEC PIE_SPEC "|r|shared:;"
764 #define FPIE1_SPEC "fpie"
765 #define NO_FPIE1_SPEC FPIE1_SPEC ":;"
766 #define FPIE2_SPEC "fPIE"
767 #define NO_FPIE2_SPEC FPIE2_SPEC ":;"
768 #define FPIE_SPEC FPIE1_SPEC "|" FPIE2_SPEC
769 #define NO_FPIE_SPEC FPIE_SPEC ":;"
770 #define FPIC1_SPEC "fpic"
771 #define NO_FPIC1_SPEC FPIC1_SPEC ":;"
772 #define FPIC2_SPEC "fPIC"
773 #define NO_FPIC2_SPEC FPIC2_SPEC ":;"
774 #define FPIC_SPEC FPIC1_SPEC "|" FPIC2_SPEC
775 #define NO_FPIC_SPEC FPIC_SPEC ":;"
776 #define FPIE1_OR_FPIC1_SPEC FPIE1_SPEC "|" FPIC1_SPEC
777 #define NO_FPIE1_AND_FPIC1_SPEC FPIE1_OR_FPIC1_SPEC ":;"
778 #define FPIE2_OR_FPIC2_SPEC FPIE2_SPEC "|" FPIC2_SPEC
779 #define NO_FPIE2_AND_FPIC2_SPEC FPIE1_OR_FPIC2_SPEC ":;"
780 #define FPIE_OR_FPIC_SPEC FPIE_SPEC "|" FPIC_SPEC
781 #define NO_FPIE_AND_FPIC_SPEC FPIE_OR_FPIC_SPEC ":;"
782 #endif
784 #ifndef LINK_PIE_SPEC
785 #ifdef HAVE_LD_PIE
786 #define LD_PIE_SPEC "-pie"
787 #else
788 #define LD_PIE_SPEC ""
789 #endif
790 #define LINK_PIE_SPEC "%{no-pie:} " "%{" PIE_SPEC ":" LD_PIE_SPEC "} "
791 #endif
793 #ifndef LINK_BUILDID_SPEC
794 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
795 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
796 # endif
797 #endif
799 /* Conditional to test whether the LTO plugin is used or not.
800 FIXME: For slim LTO we will need to enable plugin unconditionally. This
801 still cause problems with PLUGIN_LD != LD and when plugin is built but
802 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
803 plugin only when LTO is enabled. We still honor explicit
804 -fuse-linker-plugin if the linker used understands -plugin. */
806 /* The linker has some plugin support. */
807 #if HAVE_LTO_PLUGIN > 0
808 /* The linker used has full plugin support, use LTO plugin by default. */
809 #if HAVE_LTO_PLUGIN == 2
810 #define PLUGIN_COND "!fno-use-linker-plugin:%{!fno-lto"
811 #define PLUGIN_COND_CLOSE "}"
812 #else
813 /* The linker used has limited plugin support, use LTO plugin with explicit
814 -fuse-linker-plugin. */
815 #define PLUGIN_COND "fuse-linker-plugin"
816 #define PLUGIN_COND_CLOSE ""
817 #endif
818 #define LINK_PLUGIN_SPEC \
819 "%{" PLUGIN_COND": \
820 -plugin %(linker_plugin_file) \
821 -plugin-opt=%(lto_wrapper) \
822 -plugin-opt=-fresolution=%u.res \
823 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
824 }" PLUGIN_COND_CLOSE
825 #else
826 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
827 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
828 %e-fuse-linker-plugin is not supported in this configuration}"
829 #endif
831 /* Linker command line options for -fsanitize= early on the command line. */
832 #ifndef SANITIZER_EARLY_SPEC
833 #define SANITIZER_EARLY_SPEC "\
834 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_EARLY_SPEC "} \
835 %{%:sanitize(thread):" LIBTSAN_EARLY_SPEC "} \
836 %{%:sanitize(leak):" LIBLSAN_EARLY_SPEC "}}}"
837 #endif
839 /* Linker command line options for -fsanitize= late on the command line. */
840 #ifndef SANITIZER_SPEC
841 #define SANITIZER_SPEC "\
842 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_SPEC "\
843 %{static:%ecannot specify -static with -fsanitize=address}}\
844 %{%:sanitize(thread):" LIBTSAN_SPEC "\
845 %{static:%ecannot specify -static with -fsanitize=thread}}\
846 %{%:sanitize(undefined):" LIBUBSAN_SPEC "}\
847 %{%:sanitize(leak):" LIBLSAN_SPEC "}}}"
848 #endif
850 /* This is the spec to use, once the code for creating the vtable
851 verification runtime library, libvtv.so, has been created. Currently
852 the vtable verification runtime functions are in libstdc++, so we use
853 the spec just below this one. */
854 #ifndef VTABLE_VERIFICATION_SPEC
855 #define VTABLE_VERIFICATION_SPEC "\
856 %{!nostdlib:%{fvtable-verify=std: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}\
857 %{fvtable-verify=preinit: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}}"
858 #endif
860 #ifndef CHKP_SPEC
861 #define CHKP_SPEC ""
862 #endif
864 /* -u* was put back because both BSD and SysV seem to support it. */
865 /* %{static:} simply prevents an error message if the target machine
866 doesn't handle -static. */
867 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
868 scripts which exist in user specified directories, or in standard
869 directories. */
870 /* We pass any -flto flags on to the linker, which is expected
871 to understand them. In practice, this means it had better be collect2. */
872 /* %{e*} includes -export-dynamic; see comment in common.opt. */
873 #ifndef LINK_COMMAND_SPEC
874 #define LINK_COMMAND_SPEC "\
875 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
876 %(linker) " \
877 LINK_PLUGIN_SPEC \
878 "%{flto|flto=*:%<fcompare-debug*} \
879 %{flto} %{fno-lto} %{flto=*} %l " LINK_PIE_SPEC \
880 "%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
881 "%X %{o*} %{e*} %{N} %{n} %{r}\
882 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}} " VTABLE_VERIFICATION_SPEC " \
883 %{static:} %{L*} %(mfwrap) %(link_libgcc) " SANITIZER_EARLY_SPEC " %o\
884 " CHKP_SPEC " \
885 %{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*} 1):\
886 %:include(libgomp.spec)%(link_gomp)}\
887 %{fcilkplus:%:include(libcilkrts.spec)%(link_cilkrts)}\
888 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
889 %(mflib) " STACK_SPLIT_SPEC "\
890 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
891 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
892 %{!nostdlib:%{!nostartfiles:%E}} %{T*} }}}}}}"
893 #endif
895 #ifndef LINK_LIBGCC_SPEC
896 /* Generate -L options for startfile prefix list. */
897 # define LINK_LIBGCC_SPEC "%D"
898 #endif
900 #ifndef STARTFILE_PREFIX_SPEC
901 # define STARTFILE_PREFIX_SPEC ""
902 #endif
904 #ifndef SYSROOT_SPEC
905 # define SYSROOT_SPEC "--sysroot=%R"
906 #endif
908 #ifndef SYSROOT_SUFFIX_SPEC
909 # define SYSROOT_SUFFIX_SPEC ""
910 #endif
912 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
913 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
914 #endif
916 static const char *asm_debug = ASM_DEBUG_SPEC;
917 static const char *cpp_spec = CPP_SPEC;
918 static const char *cc1_spec = CC1_SPEC;
919 static const char *cc1plus_spec = CC1PLUS_SPEC;
920 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
921 static const char *link_ssp_spec = LINK_SSP_SPEC;
922 static const char *asm_spec = ASM_SPEC;
923 static const char *asm_final_spec = ASM_FINAL_SPEC;
924 static const char *link_spec = LINK_SPEC;
925 static const char *lib_spec = LIB_SPEC;
926 static const char *link_gomp_spec = "";
927 static const char *libgcc_spec = LIBGCC_SPEC;
928 static const char *endfile_spec = ENDFILE_SPEC;
929 static const char *startfile_spec = STARTFILE_SPEC;
930 static const char *linker_name_spec = LINKER_NAME;
931 static const char *linker_plugin_file_spec = "";
932 static const char *lto_wrapper_spec = "";
933 static const char *lto_gcc_spec = "";
934 static const char *link_command_spec = LINK_COMMAND_SPEC;
935 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
936 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
937 static const char *sysroot_spec = SYSROOT_SPEC;
938 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
939 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
940 static const char *self_spec = "";
942 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
943 There should be no need to override these in target dependent files,
944 but we need to copy them to the specs file so that newer versions
945 of the GCC driver can correctly drive older tool chains with the
946 appropriate -B options. */
948 /* When cpplib handles traditional preprocessing, get rid of this, and
949 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
950 that we default the front end language better. */
951 static const char *trad_capable_cpp =
952 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
954 /* We don't wrap .d files in %W{} since a missing .d file, and
955 therefore no dependency entry, confuses make into thinking a .o
956 file that happens to exist is up-to-date. */
957 static const char *cpp_unique_options =
958 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
959 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
960 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
961 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
962 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
963 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
964 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
965 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
966 %{E|M|MM:%W{o*}}";
968 /* This contains cpp options which are common with cc1_options and are passed
969 only when preprocessing only to avoid duplication. We pass the cc1 spec
970 options to the preprocessor so that it the cc1 spec may manipulate
971 options used to set target flags. Those special target flags settings may
972 in turn cause preprocessor symbols to be defined specially. */
973 static const char *cpp_options =
974 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
975 %{f*} %{g*:%{!g0:%{g*} %{!fno-working-directory:-fworking-directory}}} %{O*}\
976 %{undef} %{save-temps*:-fpch-preprocess}";
978 /* This contains cpp options which are not passed when the preprocessor
979 output will be used by another program. */
980 static const char *cpp_debug_options = "%{d*}";
982 /* NB: This is shared amongst all front-ends, except for Ada. */
983 static const char *cc1_options =
984 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
985 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
986 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
987 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
988 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
989 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
990 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
991 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
992 %{-target-help:--target-help}\
993 %{-version:--version}\
994 %{-help=*:--help=%*}\
995 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
996 %{fsyntax-only:-o %j} %{-param*}\
997 %{coverage:-fprofile-arcs -ftest-coverage}";
999 static const char *asm_options =
1000 "%{-target-help:%:print-asm-header()} "
1001 #if HAVE_GNU_AS
1002 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
1003 to the assembler equivalents. */
1004 "%{v} %{w:-W} %{I*} "
1005 #endif
1006 ASM_COMPRESS_DEBUG_SPEC
1007 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
1009 static const char *invoke_as =
1010 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1011 "%{!fwpa*:\
1012 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1013 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
1015 #else
1016 "%{!fwpa*:\
1017 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1018 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
1020 #endif
1022 /* Some compilers have limits on line lengths, and the multilib_select
1023 and/or multilib_matches strings can be very long, so we build them at
1024 run time. */
1025 static struct obstack multilib_obstack;
1026 static const char *multilib_select;
1027 static const char *multilib_matches;
1028 static const char *multilib_defaults;
1029 static const char *multilib_exclusions;
1030 static const char *multilib_reuse;
1032 /* Check whether a particular argument is a default argument. */
1034 #ifndef MULTILIB_DEFAULTS
1035 #define MULTILIB_DEFAULTS { "" }
1036 #endif
1038 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
1040 #ifndef DRIVER_SELF_SPECS
1041 #define DRIVER_SELF_SPECS ""
1042 #endif
1044 /* Linking to libgomp implies pthreads. This is particularly important
1045 for targets that use different start files and suchlike. */
1046 #ifndef GOMP_SELF_SPECS
1047 #define GOMP_SELF_SPECS \
1048 "%{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*} 1): " \
1049 "-pthread}"
1050 #endif
1052 /* Likewise for -fgnu-tm. */
1053 #ifndef GTM_SELF_SPECS
1054 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
1055 #endif
1057 /* Likewise for -fcilkplus. */
1058 #ifndef CILK_SELF_SPECS
1059 #define CILK_SELF_SPECS "%{fcilkplus: -pthread}"
1060 #endif
1062 static const char *const driver_self_specs[] = {
1063 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
1064 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS,
1065 CILK_SELF_SPECS
1068 #ifndef OPTION_DEFAULT_SPECS
1069 #define OPTION_DEFAULT_SPECS { "", "" }
1070 #endif
1072 struct default_spec
1074 const char *name;
1075 const char *spec;
1078 static const struct default_spec
1079 option_default_specs[] = { OPTION_DEFAULT_SPECS };
1081 struct user_specs
1083 struct user_specs *next;
1084 const char *filename;
1087 static struct user_specs *user_specs_head, *user_specs_tail;
1090 /* Record the mapping from file suffixes for compilation specs. */
1092 struct compiler
1094 const char *suffix; /* Use this compiler for input files
1095 whose names end in this suffix. */
1097 const char *spec; /* To use this compiler, run this spec. */
1099 const char *cpp_spec; /* If non-NULL, substitute this spec
1100 for `%C', rather than the usual
1101 cpp_spec. */
1102 const int combinable; /* If nonzero, compiler can deal with
1103 multiple source files at once (IMA). */
1104 const int needs_preprocessing; /* If nonzero, source files need to
1105 be run through a preprocessor. */
1108 /* Pointer to a vector of `struct compiler' that gives the spec for
1109 compiling a file, based on its suffix.
1110 A file that does not end in any of these suffixes will be passed
1111 unchanged to the loader and nothing else will be done to it.
1113 An entry containing two 0s is used to terminate the vector.
1115 If multiple entries match a file, the last matching one is used. */
1117 static struct compiler *compilers;
1119 /* Number of entries in `compilers', not counting the null terminator. */
1121 static int n_compilers;
1123 /* The default list of file name suffixes and their compilation specs. */
1125 static const struct compiler default_compilers[] =
1127 /* Add lists of suffixes of known languages here. If those languages
1128 were not present when we built the driver, we will hit these copies
1129 and be given a more meaningful error than "file not used since
1130 linking is not done". */
1131 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
1132 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
1133 {".mii", "#Objective-C++", 0, 0, 0},
1134 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
1135 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
1136 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
1137 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
1138 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
1139 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
1140 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
1141 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
1142 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
1143 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
1144 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
1145 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1146 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1147 {".r", "#Ratfor", 0, 0, 0},
1148 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
1149 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
1150 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
1151 {".go", "#Go", 0, 1, 0},
1152 /* Next come the entries for C. */
1153 {".c", "@c", 0, 0, 1},
1154 {"@c",
1155 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1156 external preprocessor if -save-temps is given. */
1157 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1158 %{!E:%{!M:%{!MM:\
1159 %{traditional:\
1160 %eGNU C no longer supports -traditional without -E}\
1161 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1162 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1163 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1164 %(cc1_options)}\
1165 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1166 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1167 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1168 {"-",
1169 "%{!E:%e-E or -x required when input is from standard input}\
1170 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1171 {".h", "@c-header", 0, 0, 0},
1172 {"@c-header",
1173 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1174 external preprocessor if -save-temps is given. */
1175 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1176 %{!E:%{!M:%{!MM:\
1177 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1178 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1179 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1180 %(cc1_options)\
1181 %{!fsyntax-only:-o %g.s \
1182 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1183 %W{o*:--output-pch=%*}}%V}}\
1184 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1185 cc1 %(cpp_unique_options) %(cc1_options)\
1186 %{!fsyntax-only:-o %g.s \
1187 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1188 %W{o*:--output-pch=%*}}%V}}}}}}}", 0, 0, 0},
1189 {".i", "@cpp-output", 0, 0, 0},
1190 {"@cpp-output",
1191 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1192 {".s", "@assembler", 0, 0, 0},
1193 {"@assembler",
1194 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1195 {".sx", "@assembler-with-cpp", 0, 0, 0},
1196 {".S", "@assembler-with-cpp", 0, 0, 0},
1197 {"@assembler-with-cpp",
1198 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1199 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1200 %{E|M|MM:%(cpp_debug_options)}\
1201 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1202 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1203 #else
1204 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1205 %{E|M|MM:%(cpp_debug_options)}\
1206 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1207 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1208 #endif
1209 , 0, 0, 0},
1211 #include "specs.h"
1212 /* Mark end of table. */
1213 {0, 0, 0, 0, 0}
1216 /* Number of elements in default_compilers, not counting the terminator. */
1218 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1220 typedef char *char_p; /* For DEF_VEC_P. */
1222 /* A vector of options to give to the linker.
1223 These options are accumulated by %x,
1224 and substituted into the linker command with %X. */
1225 static vec<char_p> linker_options;
1227 /* A vector of options to give to the assembler.
1228 These options are accumulated by -Wa,
1229 and substituted into the assembler command with %Y. */
1230 static vec<char_p> assembler_options;
1232 /* A vector of options to give to the preprocessor.
1233 These options are accumulated by -Wp,
1234 and substituted into the preprocessor command with %Z. */
1235 static vec<char_p> preprocessor_options;
1237 static char *
1238 skip_whitespace (char *p)
1240 while (1)
1242 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1243 be considered whitespace. */
1244 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1245 return p + 1;
1246 else if (*p == '\n' || *p == ' ' || *p == '\t')
1247 p++;
1248 else if (*p == '#')
1250 while (*p != '\n')
1251 p++;
1252 p++;
1254 else
1255 break;
1258 return p;
1260 /* Structures to keep track of prefixes to try when looking for files. */
1262 struct prefix_list
1264 const char *prefix; /* String to prepend to the path. */
1265 struct prefix_list *next; /* Next in linked list. */
1266 int require_machine_suffix; /* Don't use without machine_suffix. */
1267 /* 2 means try both machine_suffix and just_machine_suffix. */
1268 int priority; /* Sort key - priority within list. */
1269 int os_multilib; /* 1 if OS multilib scheme should be used,
1270 0 for GCC multilib scheme. */
1273 struct path_prefix
1275 struct prefix_list *plist; /* List of prefixes to try */
1276 int max_len; /* Max length of a prefix in PLIST */
1277 const char *name; /* Name of this list (used in config stuff) */
1280 /* List of prefixes to try when looking for executables. */
1282 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1284 /* List of prefixes to try when looking for startup (crt0) files. */
1286 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1288 /* List of prefixes to try when looking for include files. */
1290 static struct path_prefix include_prefixes = { 0, 0, "include" };
1292 /* Suffix to attach to directories searched for commands.
1293 This looks like `MACHINE/VERSION/'. */
1295 static const char *machine_suffix = 0;
1297 /* Suffix to attach to directories searched for commands.
1298 This is just `MACHINE/'. */
1300 static const char *just_machine_suffix = 0;
1302 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1304 static const char *gcc_exec_prefix;
1306 /* Adjusted value of standard_libexec_prefix. */
1308 static const char *gcc_libexec_prefix;
1310 /* Default prefixes to attach to command names. */
1312 #ifndef STANDARD_STARTFILE_PREFIX_1
1313 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1314 #endif
1315 #ifndef STANDARD_STARTFILE_PREFIX_2
1316 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1317 #endif
1319 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1320 #undef MD_EXEC_PREFIX
1321 #undef MD_STARTFILE_PREFIX
1322 #undef MD_STARTFILE_PREFIX_1
1323 #endif
1325 /* If no prefixes defined, use the null string, which will disable them. */
1326 #ifndef MD_EXEC_PREFIX
1327 #define MD_EXEC_PREFIX ""
1328 #endif
1329 #ifndef MD_STARTFILE_PREFIX
1330 #define MD_STARTFILE_PREFIX ""
1331 #endif
1332 #ifndef MD_STARTFILE_PREFIX_1
1333 #define MD_STARTFILE_PREFIX_1 ""
1334 #endif
1336 /* These directories are locations set at configure-time based on the
1337 --prefix option provided to configure. Their initializers are
1338 defined in Makefile.in. These paths are not *directly* used when
1339 gcc_exec_prefix is set because, in that case, we know where the
1340 compiler has been installed, and use paths relative to that
1341 location instead. */
1342 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1343 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1344 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1345 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1347 /* For native compilers, these are well-known paths containing
1348 components that may be provided by the system. For cross
1349 compilers, these paths are not used. */
1350 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1351 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1352 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1353 static const char *const standard_startfile_prefix_1
1354 = STANDARD_STARTFILE_PREFIX_1;
1355 static const char *const standard_startfile_prefix_2
1356 = STANDARD_STARTFILE_PREFIX_2;
1358 /* A relative path to be used in finding the location of tools
1359 relative to the driver. */
1360 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1362 /* A prefix to be used when this is an accelerator compiler. */
1363 static const char *const accel_dir_suffix = ACCEL_DIR_SUFFIX;
1365 /* Subdirectory to use for locating libraries. Set by
1366 set_multilib_dir based on the compilation options. */
1368 static const char *multilib_dir;
1370 /* Subdirectory to use for locating libraries in OS conventions. Set by
1371 set_multilib_dir based on the compilation options. */
1373 static const char *multilib_os_dir;
1375 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1376 set_multilib_dir based on the compilation options. */
1378 static const char *multiarch_dir;
1380 /* Structure to keep track of the specs that have been defined so far.
1381 These are accessed using %(specname) in a compiler or link
1382 spec. */
1384 struct spec_list
1386 /* The following 2 fields must be first */
1387 /* to allow EXTRA_SPECS to be initialized */
1388 const char *name; /* name of the spec. */
1389 const char *ptr; /* available ptr if no static pointer */
1391 /* The following fields are not initialized */
1392 /* by EXTRA_SPECS */
1393 const char **ptr_spec; /* pointer to the spec itself. */
1394 struct spec_list *next; /* Next spec in linked list. */
1395 int name_len; /* length of the name */
1396 bool user_p; /* whether string come from file spec. */
1397 bool alloc_p; /* whether string was allocated */
1400 #define INIT_STATIC_SPEC(NAME,PTR) \
1401 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false }
1403 /* List of statically defined specs. */
1404 static struct spec_list static_specs[] =
1406 INIT_STATIC_SPEC ("asm", &asm_spec),
1407 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1408 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1409 INIT_STATIC_SPEC ("asm_options", &asm_options),
1410 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1411 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1412 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1413 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1414 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1415 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1416 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1417 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1418 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1419 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1420 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1421 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1422 INIT_STATIC_SPEC ("link", &link_spec),
1423 INIT_STATIC_SPEC ("lib", &lib_spec),
1424 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1425 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1426 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1427 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1428 INIT_STATIC_SPEC ("version", &compiler_version),
1429 INIT_STATIC_SPEC ("multilib", &multilib_select),
1430 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1431 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1432 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1433 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1434 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1435 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1436 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1437 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1438 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1439 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1440 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1441 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1442 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1443 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1444 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1445 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1446 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1447 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1448 INIT_STATIC_SPEC ("self_spec", &self_spec),
1451 #ifdef EXTRA_SPECS /* additional specs needed */
1452 /* Structure to keep track of just the first two args of a spec_list.
1453 That is all that the EXTRA_SPECS macro gives us. */
1454 struct spec_list_1
1456 const char *const name;
1457 const char *const ptr;
1460 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1461 static struct spec_list *extra_specs = (struct spec_list *) 0;
1462 #endif
1464 /* List of dynamically allocates specs that have been defined so far. */
1466 static struct spec_list *specs = (struct spec_list *) 0;
1468 /* List of static spec functions. */
1470 static const struct spec_function static_spec_functions[] =
1472 { "getenv", getenv_spec_function },
1473 { "if-exists", if_exists_spec_function },
1474 { "if-exists-else", if_exists_else_spec_function },
1475 { "sanitize", sanitize_spec_function },
1476 { "replace-outfile", replace_outfile_spec_function },
1477 { "remove-outfile", remove_outfile_spec_function },
1478 { "version-compare", version_compare_spec_function },
1479 { "include", include_spec_function },
1480 { "find-file", find_file_spec_function },
1481 { "find-plugindir", find_plugindir_spec_function },
1482 { "print-asm-header", print_asm_header_spec_function },
1483 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1484 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1485 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1486 { "pass-through-libs", pass_through_libs_spec_func },
1487 { "replace-extension", replace_extension_spec_func },
1488 { "gt", greater_than_spec_func },
1489 #ifdef EXTRA_SPEC_FUNCTIONS
1490 EXTRA_SPEC_FUNCTIONS
1491 #endif
1492 { 0, 0 }
1495 static int processing_spec_function;
1497 /* Add appropriate libgcc specs to OBSTACK, taking into account
1498 various permutations of -shared-libgcc, -shared, and such. */
1500 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1502 #ifndef USE_LD_AS_NEEDED
1503 #define USE_LD_AS_NEEDED 0
1504 #endif
1506 static void
1507 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1508 const char *static_name, const char *eh_name)
1510 char *buf;
1512 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1513 "%{!static:%{!static-libgcc:"
1514 #if USE_LD_AS_NEEDED
1515 "%{!shared-libgcc:",
1516 static_name, " " LD_AS_NEEDED_OPTION " ",
1517 shared_name, " " LD_NO_AS_NEEDED_OPTION
1519 "%{shared-libgcc:",
1520 shared_name, "%{!shared: ", static_name, "}"
1522 #else
1523 "%{!shared:"
1524 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1525 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1527 #ifdef LINK_EH_SPEC
1528 "%{shared:"
1529 "%{shared-libgcc:", shared_name, "}"
1530 "%{!shared-libgcc:", static_name, "}"
1532 #else
1533 "%{shared:", shared_name, "}"
1534 #endif
1535 #endif
1536 "}}", NULL);
1538 obstack_grow (obstack, buf, strlen (buf));
1539 free (buf);
1541 #endif /* ENABLE_SHARED_LIBGCC */
1543 /* Initialize the specs lookup routines. */
1545 static void
1546 init_spec (void)
1548 struct spec_list *next = (struct spec_list *) 0;
1549 struct spec_list *sl = (struct spec_list *) 0;
1550 int i;
1552 if (specs)
1553 return; /* Already initialized. */
1555 if (verbose_flag)
1556 fnotice (stderr, "Using built-in specs.\n");
1558 #ifdef EXTRA_SPECS
1559 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1561 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1563 sl = &extra_specs[i];
1564 sl->name = extra_specs_1[i].name;
1565 sl->ptr = extra_specs_1[i].ptr;
1566 sl->next = next;
1567 sl->name_len = strlen (sl->name);
1568 sl->ptr_spec = &sl->ptr;
1569 next = sl;
1571 #endif
1573 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1575 sl = &static_specs[i];
1576 sl->next = next;
1577 next = sl;
1580 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1581 /* ??? If neither -shared-libgcc nor --static-libgcc was
1582 seen, then we should be making an educated guess. Some proposed
1583 heuristics for ELF include:
1585 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1586 program will be doing dynamic loading, which will likely
1587 need the shared libgcc.
1589 (2) If "-ldl", then it's also a fair bet that we're doing
1590 dynamic loading.
1592 (3) For each ET_DYN we're linking against (either through -lfoo
1593 or /some/path/foo.so), check to see whether it or one of
1594 its dependencies depends on a shared libgcc.
1596 (4) If "-shared"
1598 If the runtime is fixed to look for program headers instead
1599 of calling __register_frame_info at all, for each object,
1600 use the shared libgcc if any EH symbol referenced.
1602 If crtstuff is fixed to not invoke __register_frame_info
1603 automatically, for each object, use the shared libgcc if
1604 any non-empty unwind section found.
1606 Doing any of this probably requires invoking an external program to
1607 do the actual object file scanning. */
1609 const char *p = libgcc_spec;
1610 int in_sep = 1;
1612 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1613 when given the proper command line arguments. */
1614 while (*p)
1616 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1618 init_gcc_specs (&obstack,
1619 "-lgcc_s"
1620 #ifdef USE_LIBUNWIND_EXCEPTIONS
1621 " -lunwind"
1622 #endif
1624 "-lgcc",
1625 "-lgcc_eh"
1626 #ifdef USE_LIBUNWIND_EXCEPTIONS
1627 # ifdef HAVE_LD_STATIC_DYNAMIC
1628 " %{!static:" LD_STATIC_OPTION "} -lunwind"
1629 " %{!static:" LD_DYNAMIC_OPTION "}"
1630 # else
1631 " -lunwind"
1632 # endif
1633 #endif
1636 p += 5;
1637 in_sep = 0;
1639 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1641 /* Ug. We don't know shared library extensions. Hope that
1642 systems that use this form don't do shared libraries. */
1643 init_gcc_specs (&obstack,
1644 "-lgcc_s",
1645 "libgcc.a%s",
1646 "libgcc_eh.a%s"
1647 #ifdef USE_LIBUNWIND_EXCEPTIONS
1648 " -lunwind"
1649 #endif
1651 p += 10;
1652 in_sep = 0;
1654 else
1656 obstack_1grow (&obstack, *p);
1657 in_sep = (*p == ' ');
1658 p += 1;
1662 obstack_1grow (&obstack, '\0');
1663 libgcc_spec = XOBFINISH (&obstack, const char *);
1665 #endif
1666 #ifdef USE_AS_TRADITIONAL_FORMAT
1667 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1669 static const char tf[] = "--traditional-format ";
1670 obstack_grow (&obstack, tf, sizeof (tf) - 1);
1671 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1672 asm_spec = XOBFINISH (&obstack, const char *);
1674 #endif
1676 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1677 defined LINKER_HASH_STYLE
1678 # ifdef LINK_BUILDID_SPEC
1679 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1680 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof (LINK_BUILDID_SPEC) - 1);
1681 # endif
1682 # ifdef LINK_EH_SPEC
1683 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1684 obstack_grow (&obstack, LINK_EH_SPEC, sizeof (LINK_EH_SPEC) - 1);
1685 # endif
1686 # ifdef LINKER_HASH_STYLE
1687 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1688 before. */
1690 static const char hash_style[] = "--hash-style=";
1691 obstack_grow (&obstack, hash_style, sizeof (hash_style) - 1);
1692 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof (LINKER_HASH_STYLE) - 1);
1693 obstack_1grow (&obstack, ' ');
1695 # endif
1696 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1697 link_spec = XOBFINISH (&obstack, const char *);
1698 #endif
1700 specs = sl;
1703 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1704 removed; If the spec starts with a + then SPEC is added to the end of the
1705 current spec. */
1707 static void
1708 set_spec (const char *name, const char *spec, bool user_p)
1710 struct spec_list *sl;
1711 const char *old_spec;
1712 int name_len = strlen (name);
1713 int i;
1715 /* If this is the first call, initialize the statically allocated specs. */
1716 if (!specs)
1718 struct spec_list *next = (struct spec_list *) 0;
1719 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1721 sl = &static_specs[i];
1722 sl->next = next;
1723 next = sl;
1725 specs = sl;
1728 /* See if the spec already exists. */
1729 for (sl = specs; sl; sl = sl->next)
1730 if (name_len == sl->name_len && !strcmp (sl->name, name))
1731 break;
1733 if (!sl)
1735 /* Not found - make it. */
1736 sl = XNEW (struct spec_list);
1737 sl->name = xstrdup (name);
1738 sl->name_len = name_len;
1739 sl->ptr_spec = &sl->ptr;
1740 sl->alloc_p = 0;
1741 *(sl->ptr_spec) = "";
1742 sl->next = specs;
1743 specs = sl;
1746 old_spec = *(sl->ptr_spec);
1747 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1748 ? concat (old_spec, spec + 1, NULL)
1749 : xstrdup (spec));
1751 #ifdef DEBUG_SPECS
1752 if (verbose_flag)
1753 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1754 #endif
1756 /* Free the old spec. */
1757 if (old_spec && sl->alloc_p)
1758 free (CONST_CAST (char *, old_spec));
1760 sl->user_p = user_p;
1761 sl->alloc_p = true;
1764 /* Accumulate a command (program name and args), and run it. */
1766 typedef const char *const_char_p; /* For DEF_VEC_P. */
1768 /* Vector of pointers to arguments in the current line of specifications. */
1770 static vec<const_char_p> argbuf;
1772 /* Were the options -c, -S or -E passed. */
1773 static int have_c = 0;
1775 /* Was the option -o passed. */
1776 static int have_o = 0;
1778 /* Pointer to output file name passed in with -o. */
1779 static const char *output_file = 0;
1781 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1782 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1783 it here. */
1785 static struct temp_name {
1786 const char *suffix; /* suffix associated with the code. */
1787 int length; /* strlen (suffix). */
1788 int unique; /* Indicates whether %g or %u/%U was used. */
1789 const char *filename; /* associated filename. */
1790 int filename_length; /* strlen (filename). */
1791 struct temp_name *next;
1792 } *temp_names;
1794 /* Number of commands executed so far. */
1796 static int execution_count;
1798 /* Number of commands that exited with a signal. */
1800 static int signal_count;
1802 /* Allocate the argument vector. */
1804 static void
1805 alloc_args (void)
1807 argbuf.create (10);
1810 /* Clear out the vector of arguments (after a command is executed). */
1812 static void
1813 clear_args (void)
1815 argbuf.truncate (0);
1818 /* Add one argument to the vector at the end.
1819 This is done when a space is seen or at the end of the line.
1820 If DELETE_ALWAYS is nonzero, the arg is a filename
1821 and the file should be deleted eventually.
1822 If DELETE_FAILURE is nonzero, the arg is a filename
1823 and the file should be deleted if this compilation fails. */
1825 static void
1826 store_arg (const char *arg, int delete_always, int delete_failure)
1828 argbuf.safe_push (arg);
1830 if (delete_always || delete_failure)
1832 const char *p;
1833 /* If the temporary file we should delete is specified as
1834 part of a joined argument extract the filename. */
1835 if (arg[0] == '-'
1836 && (p = strrchr (arg, '=')))
1837 arg = p + 1;
1838 record_temp_file (arg, delete_always, delete_failure);
1842 /* Load specs from a file name named FILENAME, replacing occurrences of
1843 various different types of line-endings, \r\n, \n\r and just \r, with
1844 a single \n. */
1846 static char *
1847 load_specs (const char *filename)
1849 int desc;
1850 int readlen;
1851 struct stat statbuf;
1852 char *buffer;
1853 char *buffer_p;
1854 char *specs;
1855 char *specs_p;
1857 if (verbose_flag)
1858 fnotice (stderr, "Reading specs from %s\n", filename);
1860 /* Open and stat the file. */
1861 desc = open (filename, O_RDONLY, 0);
1862 if (desc < 0)
1863 pfatal_with_name (filename);
1864 if (stat (filename, &statbuf) < 0)
1865 pfatal_with_name (filename);
1867 /* Read contents of file into BUFFER. */
1868 buffer = XNEWVEC (char, statbuf.st_size + 1);
1869 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1870 if (readlen < 0)
1871 pfatal_with_name (filename);
1872 buffer[readlen] = 0;
1873 close (desc);
1875 specs = XNEWVEC (char, readlen + 1);
1876 specs_p = specs;
1877 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1879 int skip = 0;
1880 char c = *buffer_p;
1881 if (c == '\r')
1883 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1884 skip = 1;
1885 else if (*(buffer_p + 1) == '\n') /* \r\n */
1886 skip = 1;
1887 else /* \r */
1888 c = '\n';
1890 if (! skip)
1891 *specs_p++ = c;
1893 *specs_p = '\0';
1895 free (buffer);
1896 return (specs);
1899 /* Read compilation specs from a file named FILENAME,
1900 replacing the default ones.
1902 A suffix which starts with `*' is a definition for
1903 one of the machine-specific sub-specs. The "suffix" should be
1904 *asm, *cc1, *cpp, *link, *startfile, etc.
1905 The corresponding spec is stored in asm_spec, etc.,
1906 rather than in the `compilers' vector.
1908 Anything invalid in the file is a fatal error. */
1910 static void
1911 read_specs (const char *filename, bool main_p, bool user_p)
1913 char *buffer;
1914 char *p;
1916 buffer = load_specs (filename);
1918 /* Scan BUFFER for specs, putting them in the vector. */
1919 p = buffer;
1920 while (1)
1922 char *suffix;
1923 char *spec;
1924 char *in, *out, *p1, *p2, *p3;
1926 /* Advance P in BUFFER to the next nonblank nocomment line. */
1927 p = skip_whitespace (p);
1928 if (*p == 0)
1929 break;
1931 /* Is this a special command that starts with '%'? */
1932 /* Don't allow this for the main specs file, since it would
1933 encourage people to overwrite it. */
1934 if (*p == '%' && !main_p)
1936 p1 = p;
1937 while (*p && *p != '\n')
1938 p++;
1940 /* Skip '\n'. */
1941 p++;
1943 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1944 && (p1[sizeof "%include" - 1] == ' '
1945 || p1[sizeof "%include" - 1] == '\t'))
1947 char *new_filename;
1949 p1 += sizeof ("%include");
1950 while (*p1 == ' ' || *p1 == '\t')
1951 p1++;
1953 if (*p1++ != '<' || p[-2] != '>')
1954 fatal_error (input_location,
1955 "specs %%include syntax malformed after "
1956 "%ld characters",
1957 (long) (p1 - buffer + 1));
1959 p[-2] = '\0';
1960 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1961 read_specs (new_filename ? new_filename : p1, false, user_p);
1962 continue;
1964 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1965 && (p1[sizeof "%include_noerr" - 1] == ' '
1966 || p1[sizeof "%include_noerr" - 1] == '\t'))
1968 char *new_filename;
1970 p1 += sizeof "%include_noerr";
1971 while (*p1 == ' ' || *p1 == '\t')
1972 p1++;
1974 if (*p1++ != '<' || p[-2] != '>')
1975 fatal_error (input_location,
1976 "specs %%include syntax malformed after "
1977 "%ld characters",
1978 (long) (p1 - buffer + 1));
1980 p[-2] = '\0';
1981 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1982 if (new_filename)
1983 read_specs (new_filename, false, user_p);
1984 else if (verbose_flag)
1985 fnotice (stderr, "could not find specs file %s\n", p1);
1986 continue;
1988 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1989 && (p1[sizeof "%rename" - 1] == ' '
1990 || p1[sizeof "%rename" - 1] == '\t'))
1992 int name_len;
1993 struct spec_list *sl;
1994 struct spec_list *newsl;
1996 /* Get original name. */
1997 p1 += sizeof "%rename";
1998 while (*p1 == ' ' || *p1 == '\t')
1999 p1++;
2001 if (! ISALPHA ((unsigned char) *p1))
2002 fatal_error (input_location,
2003 "specs %%rename syntax malformed after "
2004 "%ld characters",
2005 (long) (p1 - buffer));
2007 p2 = p1;
2008 while (*p2 && !ISSPACE ((unsigned char) *p2))
2009 p2++;
2011 if (*p2 != ' ' && *p2 != '\t')
2012 fatal_error (input_location,
2013 "specs %%rename syntax malformed after "
2014 "%ld characters",
2015 (long) (p2 - buffer));
2017 name_len = p2 - p1;
2018 *p2++ = '\0';
2019 while (*p2 == ' ' || *p2 == '\t')
2020 p2++;
2022 if (! ISALPHA ((unsigned char) *p2))
2023 fatal_error (input_location,
2024 "specs %%rename syntax malformed after "
2025 "%ld characters",
2026 (long) (p2 - buffer));
2028 /* Get new spec name. */
2029 p3 = p2;
2030 while (*p3 && !ISSPACE ((unsigned char) *p3))
2031 p3++;
2033 if (p3 != p - 1)
2034 fatal_error (input_location,
2035 "specs %%rename syntax malformed after "
2036 "%ld characters",
2037 (long) (p3 - buffer));
2038 *p3 = '\0';
2040 for (sl = specs; sl; sl = sl->next)
2041 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2042 break;
2044 if (!sl)
2045 fatal_error (input_location,
2046 "specs %s spec was not found to be renamed", p1);
2048 if (strcmp (p1, p2) == 0)
2049 continue;
2051 for (newsl = specs; newsl; newsl = newsl->next)
2052 if (strcmp (newsl->name, p2) == 0)
2053 fatal_error (input_location,
2054 "%s: attempt to rename spec %qs to "
2055 "already defined spec %qs",
2056 filename, p1, p2);
2058 if (verbose_flag)
2060 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
2061 #ifdef DEBUG_SPECS
2062 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
2063 #endif
2066 set_spec (p2, *(sl->ptr_spec), user_p);
2067 if (sl->alloc_p)
2068 free (CONST_CAST (char *, *(sl->ptr_spec)));
2070 *(sl->ptr_spec) = "";
2071 sl->alloc_p = 0;
2072 continue;
2074 else
2075 fatal_error (input_location,
2076 "specs unknown %% command after %ld characters",
2077 (long) (p1 - buffer));
2080 /* Find the colon that should end the suffix. */
2081 p1 = p;
2082 while (*p1 && *p1 != ':' && *p1 != '\n')
2083 p1++;
2085 /* The colon shouldn't be missing. */
2086 if (*p1 != ':')
2087 fatal_error (input_location,
2088 "specs file malformed after %ld characters",
2089 (long) (p1 - buffer));
2091 /* Skip back over trailing whitespace. */
2092 p2 = p1;
2093 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2094 p2--;
2096 /* Copy the suffix to a string. */
2097 suffix = save_string (p, p2 - p);
2098 /* Find the next line. */
2099 p = skip_whitespace (p1 + 1);
2100 if (p[1] == 0)
2101 fatal_error (input_location,
2102 "specs file malformed after %ld characters",
2103 (long) (p - buffer));
2105 p1 = p;
2106 /* Find next blank line or end of string. */
2107 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2108 p1++;
2110 /* Specs end at the blank line and do not include the newline. */
2111 spec = save_string (p, p1 - p);
2112 p = p1;
2114 /* Delete backslash-newline sequences from the spec. */
2115 in = spec;
2116 out = spec;
2117 while (*in != 0)
2119 if (in[0] == '\\' && in[1] == '\n')
2120 in += 2;
2121 else if (in[0] == '#')
2122 while (*in && *in != '\n')
2123 in++;
2125 else
2126 *out++ = *in++;
2128 *out = 0;
2130 if (suffix[0] == '*')
2132 if (! strcmp (suffix, "*link_command"))
2133 link_command_spec = spec;
2134 else
2135 set_spec (suffix + 1, spec, user_p);
2137 else
2139 /* Add this pair to the vector. */
2140 compilers
2141 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
2143 compilers[n_compilers].suffix = suffix;
2144 compilers[n_compilers].spec = spec;
2145 n_compilers++;
2146 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2149 if (*suffix == 0)
2150 link_command_spec = spec;
2153 if (link_command_spec == 0)
2154 fatal_error (input_location, "spec file has no spec for linking");
2157 /* Record the names of temporary files we tell compilers to write,
2158 and delete them at the end of the run. */
2160 /* This is the common prefix we use to make temp file names.
2161 It is chosen once for each run of this program.
2162 It is substituted into a spec by %g or %j.
2163 Thus, all temp file names contain this prefix.
2164 In practice, all temp file names start with this prefix.
2166 This prefix comes from the envvar TMPDIR if it is defined;
2167 otherwise, from the P_tmpdir macro if that is defined;
2168 otherwise, in /usr/tmp or /tmp;
2169 or finally the current directory if all else fails. */
2171 static const char *temp_filename;
2173 /* Length of the prefix. */
2175 static int temp_filename_length;
2177 /* Define the list of temporary files to delete. */
2179 struct temp_file
2181 const char *name;
2182 struct temp_file *next;
2185 /* Queue of files to delete on success or failure of compilation. */
2186 static struct temp_file *always_delete_queue;
2187 /* Queue of files to delete on failure of compilation. */
2188 static struct temp_file *failure_delete_queue;
2190 /* Record FILENAME as a file to be deleted automatically.
2191 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2192 otherwise delete it in any case.
2193 FAIL_DELETE nonzero means delete it if a compilation step fails;
2194 otherwise delete it in any case. */
2196 void
2197 record_temp_file (const char *filename, int always_delete, int fail_delete)
2199 char *const name = xstrdup (filename);
2201 if (always_delete)
2203 struct temp_file *temp;
2204 for (temp = always_delete_queue; temp; temp = temp->next)
2205 if (! filename_cmp (name, temp->name))
2206 goto already1;
2208 temp = XNEW (struct temp_file);
2209 temp->next = always_delete_queue;
2210 temp->name = name;
2211 always_delete_queue = temp;
2213 already1:;
2216 if (fail_delete)
2218 struct temp_file *temp;
2219 for (temp = failure_delete_queue; temp; temp = temp->next)
2220 if (! filename_cmp (name, temp->name))
2222 free (name);
2223 goto already2;
2226 temp = XNEW (struct temp_file);
2227 temp->next = failure_delete_queue;
2228 temp->name = name;
2229 failure_delete_queue = temp;
2231 already2:;
2235 /* Delete all the temporary files whose names we previously recorded. */
2237 #ifndef DELETE_IF_ORDINARY
2238 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2239 do \
2241 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2242 if (unlink (NAME) < 0) \
2243 if (VERBOSE_FLAG) \
2244 perror_with_name (NAME); \
2245 } while (0)
2246 #endif
2248 static void
2249 delete_if_ordinary (const char *name)
2251 struct stat st;
2252 #ifdef DEBUG
2253 int i, c;
2255 printf ("Delete %s? (y or n) ", name);
2256 fflush (stdout);
2257 i = getchar ();
2258 if (i != '\n')
2259 while ((c = getchar ()) != '\n' && c != EOF)
2262 if (i == 'y' || i == 'Y')
2263 #endif /* DEBUG */
2264 DELETE_IF_ORDINARY (name, st, verbose_flag);
2267 static void
2268 delete_temp_files (void)
2270 struct temp_file *temp;
2272 for (temp = always_delete_queue; temp; temp = temp->next)
2273 delete_if_ordinary (temp->name);
2274 always_delete_queue = 0;
2277 /* Delete all the files to be deleted on error. */
2279 static void
2280 delete_failure_queue (void)
2282 struct temp_file *temp;
2284 for (temp = failure_delete_queue; temp; temp = temp->next)
2285 delete_if_ordinary (temp->name);
2288 static void
2289 clear_failure_queue (void)
2291 failure_delete_queue = 0;
2294 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2295 returns non-NULL.
2296 If DO_MULTI is true iterate over the paths twice, first with multilib
2297 suffix then without, otherwise iterate over the paths once without
2298 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2299 to avoid visiting the same path twice, but we could do better. For
2300 instance, /usr/lib/../lib is considered different from /usr/lib.
2301 At least EXTRA_SPACE chars past the end of the path passed to
2302 CALLBACK are available for use by the callback.
2303 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2305 Returns the value returned by CALLBACK. */
2307 static void *
2308 for_each_path (const struct path_prefix *paths,
2309 bool do_multi,
2310 size_t extra_space,
2311 void *(*callback) (char *, void *),
2312 void *callback_info)
2314 struct prefix_list *pl;
2315 const char *multi_dir = NULL;
2316 const char *multi_os_dir = NULL;
2317 const char *multiarch_suffix = NULL;
2318 const char *multi_suffix;
2319 const char *just_multi_suffix;
2320 char *path = NULL;
2321 void *ret = NULL;
2322 bool skip_multi_dir = false;
2323 bool skip_multi_os_dir = false;
2325 multi_suffix = machine_suffix;
2326 just_multi_suffix = just_machine_suffix;
2327 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2329 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2330 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2331 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2333 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2334 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2335 if (multiarch_dir)
2336 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2338 while (1)
2340 size_t multi_dir_len = 0;
2341 size_t multi_os_dir_len = 0;
2342 size_t multiarch_len = 0;
2343 size_t suffix_len;
2344 size_t just_suffix_len;
2345 size_t len;
2347 if (multi_dir)
2348 multi_dir_len = strlen (multi_dir);
2349 if (multi_os_dir)
2350 multi_os_dir_len = strlen (multi_os_dir);
2351 if (multiarch_suffix)
2352 multiarch_len = strlen (multiarch_suffix);
2353 suffix_len = strlen (multi_suffix);
2354 just_suffix_len = strlen (just_multi_suffix);
2356 if (path == NULL)
2358 len = paths->max_len + extra_space + 1;
2359 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2360 path = XNEWVEC (char, len);
2363 for (pl = paths->plist; pl != 0; pl = pl->next)
2365 len = strlen (pl->prefix);
2366 memcpy (path, pl->prefix, len);
2368 /* Look first in MACHINE/VERSION subdirectory. */
2369 if (!skip_multi_dir)
2371 memcpy (path + len, multi_suffix, suffix_len + 1);
2372 ret = callback (path, callback_info);
2373 if (ret)
2374 break;
2377 /* Some paths are tried with just the machine (ie. target)
2378 subdir. This is used for finding as, ld, etc. */
2379 if (!skip_multi_dir
2380 && pl->require_machine_suffix == 2)
2382 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2383 ret = callback (path, callback_info);
2384 if (ret)
2385 break;
2388 /* Now try the multiarch path. */
2389 if (!skip_multi_dir
2390 && !pl->require_machine_suffix && multiarch_dir)
2392 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2393 ret = callback (path, callback_info);
2394 if (ret)
2395 break;
2398 /* Now try the base path. */
2399 if (!pl->require_machine_suffix
2400 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2402 const char *this_multi;
2403 size_t this_multi_len;
2405 if (pl->os_multilib)
2407 this_multi = multi_os_dir;
2408 this_multi_len = multi_os_dir_len;
2410 else
2412 this_multi = multi_dir;
2413 this_multi_len = multi_dir_len;
2416 if (this_multi_len)
2417 memcpy (path + len, this_multi, this_multi_len + 1);
2418 else
2419 path[len] = '\0';
2421 ret = callback (path, callback_info);
2422 if (ret)
2423 break;
2426 if (pl)
2427 break;
2429 if (multi_dir == NULL && multi_os_dir == NULL)
2430 break;
2432 /* Run through the paths again, this time without multilibs.
2433 Don't repeat any we have already seen. */
2434 if (multi_dir)
2436 free (CONST_CAST (char *, multi_dir));
2437 multi_dir = NULL;
2438 free (CONST_CAST (char *, multi_suffix));
2439 multi_suffix = machine_suffix;
2440 free (CONST_CAST (char *, just_multi_suffix));
2441 just_multi_suffix = just_machine_suffix;
2443 else
2444 skip_multi_dir = true;
2445 if (multi_os_dir)
2447 free (CONST_CAST (char *, multi_os_dir));
2448 multi_os_dir = NULL;
2450 else
2451 skip_multi_os_dir = true;
2454 if (multi_dir)
2456 free (CONST_CAST (char *, multi_dir));
2457 free (CONST_CAST (char *, multi_suffix));
2458 free (CONST_CAST (char *, just_multi_suffix));
2460 if (multi_os_dir)
2461 free (CONST_CAST (char *, multi_os_dir));
2462 if (ret != path)
2463 free (path);
2464 return ret;
2467 /* Callback for build_search_list. Adds path to obstack being built. */
2469 struct add_to_obstack_info {
2470 struct obstack *ob;
2471 bool check_dir;
2472 bool first_time;
2475 static void *
2476 add_to_obstack (char *path, void *data)
2478 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2480 if (info->check_dir && !is_directory (path, false))
2481 return NULL;
2483 if (!info->first_time)
2484 obstack_1grow (info->ob, PATH_SEPARATOR);
2486 obstack_grow (info->ob, path, strlen (path));
2488 info->first_time = false;
2489 return NULL;
2492 /* Add or change the value of an environment variable, outputting the
2493 change to standard error if in verbose mode. */
2494 static void
2495 xputenv (const char *string)
2497 if (verbose_flag)
2498 fnotice (stderr, "%s\n", string);
2499 putenv (CONST_CAST (char *, string));
2502 /* Build a list of search directories from PATHS.
2503 PREFIX is a string to prepend to the list.
2504 If CHECK_DIR_P is true we ensure the directory exists.
2505 If DO_MULTI is true, multilib paths are output first, then
2506 non-multilib paths.
2507 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2508 It is also used by the --print-search-dirs flag. */
2510 static char *
2511 build_search_list (const struct path_prefix *paths, const char *prefix,
2512 bool check_dir, bool do_multi)
2514 struct add_to_obstack_info info;
2516 info.ob = &collect_obstack;
2517 info.check_dir = check_dir;
2518 info.first_time = true;
2520 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2521 obstack_1grow (&collect_obstack, '=');
2523 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2525 obstack_1grow (&collect_obstack, '\0');
2526 return XOBFINISH (&collect_obstack, char *);
2529 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2530 for collect. */
2532 static void
2533 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2534 bool do_multi)
2536 xputenv (build_search_list (paths, env_var, true, do_multi));
2539 /* Check whether NAME can be accessed in MODE. This is like access,
2540 except that it never considers directories to be executable. */
2542 static int
2543 access_check (const char *name, int mode)
2545 if (mode == X_OK)
2547 struct stat st;
2549 if (stat (name, &st) < 0
2550 || S_ISDIR (st.st_mode))
2551 return -1;
2554 return access (name, mode);
2557 /* Callback for find_a_file. Appends the file name to the directory
2558 path. If the resulting file exists in the right mode, return the
2559 full pathname to the file. */
2561 struct file_at_path_info {
2562 const char *name;
2563 const char *suffix;
2564 int name_len;
2565 int suffix_len;
2566 int mode;
2569 static void *
2570 file_at_path (char *path, void *data)
2572 struct file_at_path_info *info = (struct file_at_path_info *) data;
2573 size_t len = strlen (path);
2575 memcpy (path + len, info->name, info->name_len);
2576 len += info->name_len;
2578 /* Some systems have a suffix for executable files.
2579 So try appending that first. */
2580 if (info->suffix_len)
2582 memcpy (path + len, info->suffix, info->suffix_len + 1);
2583 if (access_check (path, info->mode) == 0)
2584 return path;
2587 path[len] = '\0';
2588 if (access_check (path, info->mode) == 0)
2589 return path;
2591 return NULL;
2594 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2595 access to check permissions. If DO_MULTI is true, search multilib
2596 paths then non-multilib paths, otherwise do not search multilib paths.
2597 Return 0 if not found, otherwise return its name, allocated with malloc. */
2599 static char *
2600 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2601 bool do_multi)
2603 struct file_at_path_info info;
2605 #ifdef DEFAULT_ASSEMBLER
2606 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2607 return xstrdup (DEFAULT_ASSEMBLER);
2608 #endif
2610 #ifdef DEFAULT_LINKER
2611 if (! strcmp (name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2612 return xstrdup (DEFAULT_LINKER);
2613 #endif
2615 /* Determine the filename to execute (special case for absolute paths). */
2617 if (IS_ABSOLUTE_PATH (name))
2619 if (access (name, mode) == 0)
2620 return xstrdup (name);
2622 return NULL;
2625 info.name = name;
2626 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2627 info.name_len = strlen (info.name);
2628 info.suffix_len = strlen (info.suffix);
2629 info.mode = mode;
2631 return (char*) for_each_path (pprefix, do_multi,
2632 info.name_len + info.suffix_len,
2633 file_at_path, &info);
2636 /* Ranking of prefixes in the sort list. -B prefixes are put before
2637 all others. */
2639 enum path_prefix_priority
2641 PREFIX_PRIORITY_B_OPT,
2642 PREFIX_PRIORITY_LAST
2645 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2646 order according to PRIORITY. Within each PRIORITY, new entries are
2647 appended.
2649 If WARN is nonzero, we will warn if no file is found
2650 through this prefix. WARN should point to an int
2651 which will be set to 1 if this entry is used.
2653 COMPONENT is the value to be passed to update_path.
2655 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2656 the complete value of machine_suffix.
2657 2 means try both machine_suffix and just_machine_suffix. */
2659 static void
2660 add_prefix (struct path_prefix *pprefix, const char *prefix,
2661 const char *component, /* enum prefix_priority */ int priority,
2662 int require_machine_suffix, int os_multilib)
2664 struct prefix_list *pl, **prev;
2665 int len;
2667 for (prev = &pprefix->plist;
2668 (*prev) != NULL && (*prev)->priority <= priority;
2669 prev = &(*prev)->next)
2672 /* Keep track of the longest prefix. */
2674 prefix = update_path (prefix, component);
2675 len = strlen (prefix);
2676 if (len > pprefix->max_len)
2677 pprefix->max_len = len;
2679 pl = XNEW (struct prefix_list);
2680 pl->prefix = prefix;
2681 pl->require_machine_suffix = require_machine_suffix;
2682 pl->priority = priority;
2683 pl->os_multilib = os_multilib;
2685 /* Insert after PREV. */
2686 pl->next = (*prev);
2687 (*prev) = pl;
2690 /* Same as add_prefix, but prepending target_system_root to prefix. */
2691 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2692 static void
2693 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2694 const char *component,
2695 /* enum prefix_priority */ int priority,
2696 int require_machine_suffix, int os_multilib)
2698 if (!IS_ABSOLUTE_PATH (prefix))
2699 fatal_error (input_location, "system path %qs is not absolute", prefix);
2701 if (target_system_root)
2703 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2704 size_t sysroot_len = strlen (target_system_root);
2706 if (sysroot_len > 0
2707 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2708 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2710 if (target_sysroot_suffix)
2711 prefix = concat (sysroot_no_trailing_dir_separator,
2712 target_sysroot_suffix, prefix, NULL);
2713 else
2714 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2716 free (sysroot_no_trailing_dir_separator);
2718 /* We have to override this because GCC's notion of sysroot
2719 moves along with GCC. */
2720 component = "GCC";
2723 add_prefix (pprefix, prefix, component, priority,
2724 require_machine_suffix, os_multilib);
2727 /* Execute the command specified by the arguments on the current line of spec.
2728 When using pipes, this includes several piped-together commands
2729 with `|' between them.
2731 Return 0 if successful, -1 if failed. */
2733 static int
2734 execute (void)
2736 int i;
2737 int n_commands; /* # of command. */
2738 char *string;
2739 struct pex_obj *pex;
2740 struct command
2742 const char *prog; /* program name. */
2743 const char **argv; /* vector of args. */
2745 const char *arg;
2747 struct command *commands; /* each command buffer with above info. */
2749 gcc_assert (!processing_spec_function);
2751 if (wrapper_string)
2753 string = find_a_file (&exec_prefixes,
2754 argbuf[0], X_OK, false);
2755 if (string)
2756 argbuf[0] = string;
2757 insert_wrapper (wrapper_string);
2760 /* Count # of piped commands. */
2761 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2762 if (strcmp (arg, "|") == 0)
2763 n_commands++;
2765 /* Get storage for each command. */
2766 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2768 /* Split argbuf into its separate piped processes,
2769 and record info about each one.
2770 Also search for the programs that are to be run. */
2772 argbuf.safe_push (0);
2774 commands[0].prog = argbuf[0]; /* first command. */
2775 commands[0].argv = argbuf.address ();
2777 if (!wrapper_string)
2779 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2780 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2783 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2784 if (arg && strcmp (arg, "|") == 0)
2785 { /* each command. */
2786 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2787 fatal_error (input_location, "-pipe not supported");
2788 #endif
2789 argbuf[i] = 0; /* Termination of
2790 command args. */
2791 commands[n_commands].prog = argbuf[i + 1];
2792 commands[n_commands].argv
2793 = &(argbuf.address ())[i + 1];
2794 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2795 X_OK, false);
2796 if (string)
2797 commands[n_commands].argv[0] = string;
2798 n_commands++;
2801 /* If -v, print what we are about to do, and maybe query. */
2803 if (verbose_flag)
2805 /* For help listings, put a blank line between sub-processes. */
2806 if (print_help_list)
2807 fputc ('\n', stderr);
2809 /* Print each piped command as a separate line. */
2810 for (i = 0; i < n_commands; i++)
2812 const char *const *j;
2814 if (verbose_only_flag)
2816 for (j = commands[i].argv; *j; j++)
2818 const char *p;
2819 for (p = *j; *p; ++p)
2820 if (!ISALNUM ((unsigned char) *p)
2821 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2822 break;
2823 if (*p || !*j)
2825 fprintf (stderr, " \"");
2826 for (p = *j; *p; ++p)
2828 if (*p == '"' || *p == '\\' || *p == '$')
2829 fputc ('\\', stderr);
2830 fputc (*p, stderr);
2832 fputc ('"', stderr);
2834 /* If it's empty, print "". */
2835 else if (!**j)
2836 fprintf (stderr, " \"\"");
2837 else
2838 fprintf (stderr, " %s", *j);
2841 else
2842 for (j = commands[i].argv; *j; j++)
2843 /* If it's empty, print "". */
2844 if (!**j)
2845 fprintf (stderr, " \"\"");
2846 else
2847 fprintf (stderr, " %s", *j);
2849 /* Print a pipe symbol after all but the last command. */
2850 if (i + 1 != n_commands)
2851 fprintf (stderr, " |");
2852 fprintf (stderr, "\n");
2854 fflush (stderr);
2855 if (verbose_only_flag != 0)
2857 /* verbose_only_flag should act as if the spec was
2858 executed, so increment execution_count before
2859 returning. This prevents spurious warnings about
2860 unused linker input files, etc. */
2861 execution_count++;
2862 return 0;
2864 #ifdef DEBUG
2865 fnotice (stderr, "\nGo ahead? (y or n) ");
2866 fflush (stderr);
2867 i = getchar ();
2868 if (i != '\n')
2869 while (getchar () != '\n')
2872 if (i != 'y' && i != 'Y')
2873 return 0;
2874 #endif /* DEBUG */
2877 #ifdef ENABLE_VALGRIND_CHECKING
2878 /* Run the each command through valgrind. To simplify prepending the
2879 path to valgrind and the option "-q" (for quiet operation unless
2880 something triggers), we allocate a separate argv array. */
2882 for (i = 0; i < n_commands; i++)
2884 const char **argv;
2885 int argc;
2886 int j;
2888 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2891 argv = XALLOCAVEC (const char *, argc + 3);
2893 argv[0] = VALGRIND_PATH;
2894 argv[1] = "-q";
2895 for (j = 2; j < argc + 2; j++)
2896 argv[j] = commands[i].argv[j - 2];
2897 argv[j] = NULL;
2899 commands[i].argv = argv;
2900 commands[i].prog = argv[0];
2902 #endif
2904 /* Run each piped subprocess. */
2906 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
2907 ? PEX_RECORD_TIMES : 0),
2908 progname, temp_filename);
2909 if (pex == NULL)
2910 fatal_error (input_location, "pex_init failed: %m");
2912 for (i = 0; i < n_commands; i++)
2914 const char *errmsg;
2915 int err;
2916 const char *string = commands[i].argv[0];
2918 errmsg = pex_run (pex,
2919 ((i + 1 == n_commands ? PEX_LAST : 0)
2920 | (string == commands[i].prog ? PEX_SEARCH : 0)),
2921 string, CONST_CAST (char **, commands[i].argv),
2922 NULL, NULL, &err);
2923 if (errmsg != NULL)
2925 if (err == 0)
2926 fatal_error (input_location, errmsg);
2927 else
2929 errno = err;
2930 pfatal_with_name (errmsg);
2934 if (i && string != commands[i].prog)
2935 free (CONST_CAST (char *, string));
2938 execution_count++;
2940 /* Wait for all the subprocesses to finish. */
2943 int *statuses;
2944 struct pex_time *times = NULL;
2945 int ret_code = 0;
2947 statuses = (int *) alloca (n_commands * sizeof (int));
2948 if (!pex_get_status (pex, n_commands, statuses))
2949 fatal_error (input_location, "failed to get exit status: %m");
2951 if (report_times || report_times_to_file)
2953 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
2954 if (!pex_get_times (pex, n_commands, times))
2955 fatal_error (input_location, "failed to get process times: %m");
2958 pex_free (pex);
2960 for (i = 0; i < n_commands; ++i)
2962 int status = statuses[i];
2964 if (WIFSIGNALED (status))
2966 #ifdef SIGPIPE
2967 /* SIGPIPE is a special case. It happens in -pipe mode
2968 when the compiler dies before the preprocessor is done,
2969 or the assembler dies before the compiler is done.
2970 There's generally been an error already, and this is
2971 just fallout. So don't generate another error unless
2972 we would otherwise have succeeded. */
2973 if (WTERMSIG (status) == SIGPIPE
2974 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2976 signal_count++;
2977 ret_code = -1;
2979 else
2980 #endif
2981 internal_error_no_backtrace ("%s (program %s)",
2982 strsignal (WTERMSIG (status)),
2983 commands[i].prog);
2985 else if (WIFEXITED (status)
2986 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2988 /* For ICEs in cc1, cc1obj, cc1plus see if it is
2989 reproducible or not. */
2990 const char *p;
2991 if (flag_report_bug
2992 && WEXITSTATUS (status) == ICE_EXIT_CODE
2993 && i == 0
2994 && (p = strrchr (commands[0].argv[0], DIR_SEPARATOR))
2995 && ! strncmp (p + 1, "cc1", 3))
2996 try_generate_repro (commands[0].argv);
2997 if (WEXITSTATUS (status) > greatest_status)
2998 greatest_status = WEXITSTATUS (status);
2999 ret_code = -1;
3002 if (report_times || report_times_to_file)
3004 struct pex_time *pt = &times[i];
3005 double ut, st;
3007 ut = ((double) pt->user_seconds
3008 + (double) pt->user_microseconds / 1.0e6);
3009 st = ((double) pt->system_seconds
3010 + (double) pt->system_microseconds / 1.0e6);
3012 if (ut + st != 0)
3014 if (report_times)
3015 fnotice (stderr, "# %s %.2f %.2f\n",
3016 commands[i].prog, ut, st);
3018 if (report_times_to_file)
3020 int c = 0;
3021 const char *const *j;
3023 fprintf (report_times_to_file, "%g %g", ut, st);
3025 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
3027 const char *p;
3028 for (p = *j; *p; ++p)
3029 if (*p == '"' || *p == '\\' || *p == '$'
3030 || ISSPACE (*p))
3031 break;
3033 if (*p)
3035 fprintf (report_times_to_file, " \"");
3036 for (p = *j; *p; ++p)
3038 if (*p == '"' || *p == '\\' || *p == '$')
3039 fputc ('\\', report_times_to_file);
3040 fputc (*p, report_times_to_file);
3042 fputc ('"', report_times_to_file);
3044 else
3045 fprintf (report_times_to_file, " %s", *j);
3048 fputc ('\n', report_times_to_file);
3054 if (commands[0].argv[0] != commands[0].prog)
3055 free (CONST_CAST (char *, commands[0].argv[0]));
3057 return ret_code;
3061 /* Find all the switches given to us
3062 and make a vector describing them.
3063 The elements of the vector are strings, one per switch given.
3064 If a switch uses following arguments, then the `part1' field
3065 is the switch itself and the `args' field
3066 is a null-terminated vector containing the following arguments.
3067 Bits in the `live_cond' field are:
3068 SWITCH_LIVE to indicate this switch is true in a conditional spec.
3069 SWITCH_FALSE to indicate this switch is overridden by a later switch.
3070 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
3071 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored
3072 in all do_spec calls afterwards. Used for %<S from self specs.
3073 The `validated' field is nonzero if any spec has looked at this switch;
3074 if it remains zero at the end of the run, it must be meaningless. */
3076 #define SWITCH_LIVE (1 << 0)
3077 #define SWITCH_FALSE (1 << 1)
3078 #define SWITCH_IGNORE (1 << 2)
3079 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
3080 #define SWITCH_KEEP_FOR_GCC (1 << 4)
3082 struct switchstr
3084 const char *part1;
3085 const char **args;
3086 unsigned int live_cond;
3087 bool known;
3088 bool validated;
3089 bool ordering;
3092 static struct switchstr *switches;
3094 static int n_switches;
3096 static int n_switches_alloc;
3098 /* Set to zero if -fcompare-debug is disabled, positive if it's
3099 enabled and we're running the first compilation, negative if it's
3100 enabled and we're running the second compilation. For most of the
3101 time, it's in the range -1..1, but it can be temporarily set to 2
3102 or 3 to indicate that the -fcompare-debug flags didn't come from
3103 the command-line, but rather from the GCC_COMPARE_DEBUG environment
3104 variable, until a synthesized -fcompare-debug flag is added to the
3105 command line. */
3106 int compare_debug;
3108 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
3109 int compare_debug_second;
3111 /* Set to the flags that should be passed to the second compilation in
3112 a -fcompare-debug compilation. */
3113 const char *compare_debug_opt;
3115 static struct switchstr *switches_debug_check[2];
3117 static int n_switches_debug_check[2];
3119 static int n_switches_alloc_debug_check[2];
3121 static char *debug_check_temp_file[2];
3123 /* Language is one of three things:
3125 1) The name of a real programming language.
3126 2) NULL, indicating that no one has figured out
3127 what it is yet.
3128 3) '*', indicating that the file should be passed
3129 to the linker. */
3130 struct infile
3132 const char *name;
3133 const char *language;
3134 struct compiler *incompiler;
3135 bool compiled;
3136 bool preprocessed;
3139 /* Also a vector of input files specified. */
3141 static struct infile *infiles;
3143 int n_infiles;
3145 static int n_infiles_alloc;
3147 /* True if multiple input files are being compiled to a single
3148 assembly file. */
3150 static bool combine_inputs;
3152 /* This counts the number of libraries added by lang_specific_driver, so that
3153 we can tell if there were any user supplied any files or libraries. */
3155 static int added_libraries;
3157 /* And a vector of corresponding output files is made up later. */
3159 const char **outfiles;
3161 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3163 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3164 is true if we should look for an executable suffix. DO_OBJ
3165 is true if we should look for an object suffix. */
3167 static const char *
3168 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3169 int do_obj ATTRIBUTE_UNUSED)
3171 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3172 int i;
3173 #endif
3174 int len;
3176 if (name == NULL)
3177 return NULL;
3179 len = strlen (name);
3181 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3182 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3183 if (do_obj && len > 2
3184 && name[len - 2] == '.'
3185 && name[len - 1] == 'o')
3187 obstack_grow (&obstack, name, len - 2);
3188 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3189 name = XOBFINISH (&obstack, const char *);
3191 #endif
3193 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3194 /* If there is no filetype, make it the executable suffix (which includes
3195 the "."). But don't get confused if we have just "-o". */
3196 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3197 return name;
3199 for (i = len - 1; i >= 0; i--)
3200 if (IS_DIR_SEPARATOR (name[i]))
3201 break;
3203 for (i++; i < len; i++)
3204 if (name[i] == '.')
3205 return name;
3207 obstack_grow (&obstack, name, len);
3208 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3209 strlen (TARGET_EXECUTABLE_SUFFIX));
3210 name = XOBFINISH (&obstack, const char *);
3211 #endif
3213 return name;
3215 #endif
3217 /* Display the command line switches accepted by gcc. */
3218 static void
3219 display_help (void)
3221 printf (_("Usage: %s [options] file...\n"), progname);
3222 fputs (_("Options:\n"), stdout);
3224 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3225 fputs (_(" --help Display this information\n"), stdout);
3226 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3227 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...]\n"), stdout);
3228 fputs (_(" Display specific types of command line options\n"), stdout);
3229 if (! verbose_flag)
3230 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3231 fputs (_(" --version Display compiler version information\n"), stdout);
3232 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3233 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3234 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3235 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3236 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3237 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3238 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3239 fputs (_("\
3240 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3241 a component in the library path\n"), stdout);
3242 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3243 fputs (_("\
3244 -print-multi-lib Display the mapping between command line options and\n\
3245 multiple library search directories\n"), stdout);
3246 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3247 fputs (_(" -print-sysroot Display the target libraries directory\n"), stdout);
3248 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
3249 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3250 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3251 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3252 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3253 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3254 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3255 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3256 fputs (_(" -save-temps=<arg> Do not delete intermediate files\n"), stdout);
3257 fputs (_("\
3258 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3259 prefixes to other gcc components\n"), stdout);
3260 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3261 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3262 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3263 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3264 fputs (_("\
3265 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3266 and libraries\n"), stdout);
3267 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3268 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3269 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3270 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3271 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3272 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3273 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3274 fputs (_(" -pie Create a position independent executable\n"), stdout);
3275 fputs (_(" -shared Create a shared library\n"), stdout);
3276 fputs (_("\
3277 -x <language> Specify the language of the following input files\n\
3278 Permissible languages include: c c++ assembler none\n\
3279 'none' means revert to the default behavior of\n\
3280 guessing the language based on the file's extension\n\
3281 "), stdout);
3283 printf (_("\
3284 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3285 passed on to the various sub-processes invoked by %s. In order to pass\n\
3286 other options on to these processes the -W<letter> options must be used.\n\
3287 "), progname);
3289 /* The rest of the options are displayed by invocations of the various
3290 sub-processes. */
3293 static void
3294 add_preprocessor_option (const char *option, int len)
3296 preprocessor_options.safe_push (save_string (option, len));
3299 static void
3300 add_assembler_option (const char *option, int len)
3302 assembler_options.safe_push (save_string (option, len));
3305 static void
3306 add_linker_option (const char *option, int len)
3308 linker_options.safe_push (save_string (option, len));
3311 /* Allocate space for an input file in infiles. */
3313 static void
3314 alloc_infile (void)
3316 if (n_infiles_alloc == 0)
3318 n_infiles_alloc = 16;
3319 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3321 else if (n_infiles_alloc == n_infiles)
3323 n_infiles_alloc *= 2;
3324 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3328 /* Store an input file with the given NAME and LANGUAGE in
3329 infiles. */
3331 static void
3332 add_infile (const char *name, const char *language)
3334 alloc_infile ();
3335 infiles[n_infiles].name = name;
3336 infiles[n_infiles++].language = language;
3339 /* Allocate space for a switch in switches. */
3341 static void
3342 alloc_switch (void)
3344 if (n_switches_alloc == 0)
3346 n_switches_alloc = 16;
3347 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3349 else if (n_switches_alloc == n_switches)
3351 n_switches_alloc *= 2;
3352 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3356 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3357 as validated if VALIDATED and KNOWN if it is an internal switch. */
3359 static void
3360 save_switch (const char *opt, size_t n_args, const char *const *args,
3361 bool validated, bool known)
3363 alloc_switch ();
3364 switches[n_switches].part1 = opt + 1;
3365 if (n_args == 0)
3366 switches[n_switches].args = 0;
3367 else
3369 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3370 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3371 switches[n_switches].args[n_args] = NULL;
3374 switches[n_switches].live_cond = 0;
3375 switches[n_switches].validated = validated;
3376 switches[n_switches].known = known;
3377 switches[n_switches].ordering = 0;
3378 n_switches++;
3381 /* Handle an option DECODED that is unknown to the option-processing
3382 machinery. */
3384 static bool
3385 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3387 const char *opt = decoded->arg;
3388 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3389 && !(decoded->errors & CL_ERR_NEGATIVE))
3391 /* Leave unknown -Wno-* options for the compiler proper, to be
3392 diagnosed only if there are warnings. */
3393 save_switch (decoded->canonical_option[0],
3394 decoded->canonical_option_num_elements - 1,
3395 &decoded->canonical_option[1], false, true);
3396 return false;
3398 if (decoded->opt_index == OPT_SPECIAL_unknown)
3400 /* Give it a chance to define it a spec file. */
3401 save_switch (decoded->canonical_option[0],
3402 decoded->canonical_option_num_elements - 1,
3403 &decoded->canonical_option[1], false, false);
3404 return false;
3406 else
3407 return true;
3410 /* Handle an option DECODED that is not marked as CL_DRIVER.
3411 LANG_MASK will always be CL_DRIVER. */
3413 static void
3414 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3415 unsigned int lang_mask ATTRIBUTE_UNUSED)
3417 /* At this point, non-driver options are accepted (and expected to
3418 be passed down by specs) unless marked to be rejected by the
3419 driver. Options to be rejected by the driver but accepted by the
3420 compilers proper are treated just like completely unknown
3421 options. */
3422 const struct cl_option *option = &cl_options[decoded->opt_index];
3424 if (option->cl_reject_driver)
3425 error ("unrecognized command line option %qs",
3426 decoded->orig_option_with_args_text);
3427 else
3428 save_switch (decoded->canonical_option[0],
3429 decoded->canonical_option_num_elements - 1,
3430 &decoded->canonical_option[1], false, true);
3433 static const char *spec_lang = 0;
3434 static int last_language_n_infiles;
3436 /* Parse -foffload option argument. */
3438 static void
3439 handle_foffload_option (const char *arg)
3441 const char *c, *cur, *n, *next, *end;
3442 char *target;
3444 /* If option argument starts with '-' then no target is specified and we
3445 do not need to parse it. */
3446 if (arg[0] == '-')
3447 return;
3449 end = strchr (arg, '=');
3450 if (end == NULL)
3451 end = strchr (arg, '\0');
3452 cur = arg;
3454 while (cur < end)
3456 next = strchr (cur, ',');
3457 if (next == NULL)
3458 next = end;
3459 next = (next > end) ? end : next;
3461 target = XNEWVEC (char, next - cur + 1);
3462 memcpy (target, cur, next - cur);
3463 target[next - cur] = '\0';
3465 /* If 'disable' is passed to the option, stop parsing the option and clean
3466 the list of offload targets. */
3467 if (strcmp (target, "disable") == 0)
3469 free (offload_targets);
3470 offload_targets = xstrdup ("");
3471 break;
3474 /* Check that GCC is configured to support the offload target. */
3475 c = OFFLOAD_TARGETS;
3476 while (c)
3478 n = strchr (c, ',');
3479 if (n == NULL)
3480 n = strchr (c, '\0');
3482 if (next - cur == n - c && strncmp (target, c, n - c) == 0)
3483 break;
3485 c = *n ? n + 1 : NULL;
3488 if (!c)
3489 fatal_error (input_location,
3490 "GCC is not configured to support %s as offload target",
3491 target);
3493 if (!offload_targets)
3495 offload_targets = target;
3496 target = NULL;
3498 else
3500 /* Check that the target hasn't already presented in the list. */
3501 c = offload_targets;
3504 n = strchr (c, ':');
3505 if (n == NULL)
3506 n = strchr (c, '\0');
3508 if (next - cur == n - c && strncmp (c, target, n - c) == 0)
3509 break;
3511 c = n + 1;
3513 while (*n);
3515 /* If duplicate is not found, append the target to the list. */
3516 if (c > n)
3518 size_t offload_targets_len = strlen (offload_targets);
3519 offload_targets
3520 = XRESIZEVEC (char, offload_targets,
3521 offload_targets_len + next - cur + 2);
3522 if (offload_targets_len)
3523 offload_targets[offload_targets_len++] = ':';
3524 memcpy (offload_targets + offload_targets_len, target, next - cur);
3528 cur = next + 1;
3529 XDELETEVEC (target);
3533 /* Handle a driver option; arguments and return value as for
3534 handle_option. */
3536 static bool
3537 driver_handle_option (struct gcc_options *opts,
3538 struct gcc_options *opts_set,
3539 const struct cl_decoded_option *decoded,
3540 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3541 location_t loc,
3542 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3543 diagnostic_context *dc)
3545 size_t opt_index = decoded->opt_index;
3546 const char *arg = decoded->arg;
3547 const char *compare_debug_replacement_opt;
3548 int value = decoded->value;
3549 bool validated = false;
3550 bool do_save = true;
3552 gcc_assert (opts == &global_options);
3553 gcc_assert (opts_set == &global_options_set);
3554 gcc_assert (kind == DK_UNSPECIFIED);
3555 gcc_assert (loc == UNKNOWN_LOCATION);
3556 gcc_assert (dc == global_dc);
3558 switch (opt_index)
3560 case OPT_dumpspecs:
3562 struct spec_list *sl;
3563 init_spec ();
3564 for (sl = specs; sl; sl = sl->next)
3565 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3566 if (link_command_spec)
3567 printf ("*link_command:\n%s\n\n", link_command_spec);
3568 exit (0);
3571 case OPT_dumpversion:
3572 printf ("%s\n", spec_version);
3573 exit (0);
3575 case OPT_dumpmachine:
3576 printf ("%s\n", spec_machine);
3577 exit (0);
3579 case OPT__version:
3580 print_version = 1;
3582 /* CPP driver cannot obtain switch from cc1_options. */
3583 if (is_cpp_driver)
3584 add_preprocessor_option ("--version", strlen ("--version"));
3585 add_assembler_option ("--version", strlen ("--version"));
3586 add_linker_option ("--version", strlen ("--version"));
3587 break;
3589 case OPT__help:
3590 print_help_list = 1;
3592 /* CPP driver cannot obtain switch from cc1_options. */
3593 if (is_cpp_driver)
3594 add_preprocessor_option ("--help", 6);
3595 add_assembler_option ("--help", 6);
3596 add_linker_option ("--help", 6);
3597 break;
3599 case OPT__help_:
3600 print_subprocess_help = 2;
3601 break;
3603 case OPT__target_help:
3604 print_subprocess_help = 1;
3606 /* CPP driver cannot obtain switch from cc1_options. */
3607 if (is_cpp_driver)
3608 add_preprocessor_option ("--target-help", 13);
3609 add_assembler_option ("--target-help", 13);
3610 add_linker_option ("--target-help", 13);
3611 break;
3613 case OPT__no_sysroot_suffix:
3614 case OPT_pass_exit_codes:
3615 case OPT_print_search_dirs:
3616 case OPT_print_file_name_:
3617 case OPT_print_prog_name_:
3618 case OPT_print_multi_lib:
3619 case OPT_print_multi_directory:
3620 case OPT_print_sysroot:
3621 case OPT_print_multi_os_directory:
3622 case OPT_print_multiarch:
3623 case OPT_print_sysroot_headers_suffix:
3624 case OPT_time:
3625 case OPT_wrapper:
3626 /* These options set the variables specified in common.opt
3627 automatically, and do not need to be saved for spec
3628 processing. */
3629 do_save = false;
3630 break;
3632 case OPT_print_libgcc_file_name:
3633 print_file_name = "libgcc.a";
3634 do_save = false;
3635 break;
3637 case OPT_fuse_ld_bfd:
3638 use_ld = ".bfd";
3639 break;
3641 case OPT_fuse_ld_gold:
3642 use_ld = ".gold";
3643 break;
3645 case OPT_fcompare_debug_second:
3646 compare_debug_second = 1;
3647 break;
3649 case OPT_fcompare_debug:
3650 switch (value)
3652 case 0:
3653 compare_debug_replacement_opt = "-fcompare-debug=";
3654 arg = "";
3655 goto compare_debug_with_arg;
3657 case 1:
3658 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3659 arg = "-gtoggle";
3660 goto compare_debug_with_arg;
3662 default:
3663 gcc_unreachable ();
3665 break;
3667 case OPT_fcompare_debug_:
3668 compare_debug_replacement_opt = decoded->canonical_option[0];
3669 compare_debug_with_arg:
3670 gcc_assert (decoded->canonical_option_num_elements == 1);
3671 gcc_assert (arg != NULL);
3672 if (*arg)
3673 compare_debug = 1;
3674 else
3675 compare_debug = -1;
3676 if (compare_debug < 0)
3677 compare_debug_opt = NULL;
3678 else
3679 compare_debug_opt = arg;
3680 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3681 return true;
3683 case OPT_fdiagnostics_color_:
3684 diagnostic_color_init (dc, value);
3685 break;
3687 case OPT_Wa_:
3689 int prev, j;
3690 /* Pass the rest of this option to the assembler. */
3692 /* Split the argument at commas. */
3693 prev = 0;
3694 for (j = 0; arg[j]; j++)
3695 if (arg[j] == ',')
3697 add_assembler_option (arg + prev, j - prev);
3698 prev = j + 1;
3701 /* Record the part after the last comma. */
3702 add_assembler_option (arg + prev, j - prev);
3704 do_save = false;
3705 break;
3707 case OPT_Wp_:
3709 int prev, j;
3710 /* Pass the rest of this option to the preprocessor. */
3712 /* Split the argument at commas. */
3713 prev = 0;
3714 for (j = 0; arg[j]; j++)
3715 if (arg[j] == ',')
3717 add_preprocessor_option (arg + prev, j - prev);
3718 prev = j + 1;
3721 /* Record the part after the last comma. */
3722 add_preprocessor_option (arg + prev, j - prev);
3724 do_save = false;
3725 break;
3727 case OPT_Wl_:
3729 int prev, j;
3730 /* Split the argument at commas. */
3731 prev = 0;
3732 for (j = 0; arg[j]; j++)
3733 if (arg[j] == ',')
3735 add_infile (save_string (arg + prev, j - prev), "*");
3736 prev = j + 1;
3738 /* Record the part after the last comma. */
3739 add_infile (arg + prev, "*");
3741 do_save = false;
3742 break;
3744 case OPT_Xlinker:
3745 add_infile (arg, "*");
3746 do_save = false;
3747 break;
3749 case OPT_Xpreprocessor:
3750 add_preprocessor_option (arg, strlen (arg));
3751 do_save = false;
3752 break;
3754 case OPT_Xassembler:
3755 add_assembler_option (arg, strlen (arg));
3756 do_save = false;
3757 break;
3759 case OPT_l:
3760 /* POSIX allows separation of -l and the lib arg; canonicalize
3761 by concatenating -l with its arg */
3762 add_infile (concat ("-l", arg, NULL), "*");
3763 do_save = false;
3764 break;
3766 case OPT_L:
3767 /* Similarly, canonicalize -L for linkers that may not accept
3768 separate arguments. */
3769 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
3770 return true;
3772 case OPT_F:
3773 /* Likewise -F. */
3774 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
3775 return true;
3777 case OPT_save_temps:
3778 save_temps_flag = SAVE_TEMPS_CWD;
3779 validated = true;
3780 break;
3782 case OPT_save_temps_:
3783 if (strcmp (arg, "cwd") == 0)
3784 save_temps_flag = SAVE_TEMPS_CWD;
3785 else if (strcmp (arg, "obj") == 0
3786 || strcmp (arg, "object") == 0)
3787 save_temps_flag = SAVE_TEMPS_OBJ;
3788 else
3789 fatal_error (input_location, "%qs is an unknown -save-temps option",
3790 decoded->orig_option_with_args_text);
3791 break;
3793 case OPT_no_canonical_prefixes:
3794 /* Already handled as a special case, so ignored here. */
3795 do_save = false;
3796 break;
3798 case OPT_pipe:
3799 validated = true;
3800 /* These options set the variables specified in common.opt
3801 automatically, but do need to be saved for spec
3802 processing. */
3803 break;
3805 case OPT_specs_:
3807 struct user_specs *user = XNEW (struct user_specs);
3809 user->next = (struct user_specs *) 0;
3810 user->filename = arg;
3811 if (user_specs_tail)
3812 user_specs_tail->next = user;
3813 else
3814 user_specs_head = user;
3815 user_specs_tail = user;
3817 validated = true;
3818 break;
3820 case OPT__sysroot_:
3821 target_system_root = arg;
3822 target_system_root_changed = 1;
3823 do_save = false;
3824 break;
3826 case OPT_time_:
3827 if (report_times_to_file)
3828 fclose (report_times_to_file);
3829 report_times_to_file = fopen (arg, "a");
3830 do_save = false;
3831 break;
3833 case OPT____:
3834 /* "-###"
3835 This is similar to -v except that there is no execution
3836 of the commands and the echoed arguments are quoted. It
3837 is intended for use in shell scripts to capture the
3838 driver-generated command line. */
3839 verbose_only_flag++;
3840 verbose_flag = 1;
3841 do_save = false;
3842 break;
3844 case OPT_B:
3846 size_t len = strlen (arg);
3848 /* Catch the case where the user has forgotten to append a
3849 directory separator to the path. Note, they may be using
3850 -B to add an executable name prefix, eg "i386-elf-", in
3851 order to distinguish between multiple installations of
3852 GCC in the same directory. Hence we must check to see
3853 if appending a directory separator actually makes a
3854 valid directory name. */
3855 if (!IS_DIR_SEPARATOR (arg[len - 1])
3856 && is_directory (arg, false))
3858 char *tmp = XNEWVEC (char, len + 2);
3859 strcpy (tmp, arg);
3860 tmp[len] = DIR_SEPARATOR;
3861 tmp[++len] = 0;
3862 arg = tmp;
3865 add_prefix (&exec_prefixes, arg, NULL,
3866 PREFIX_PRIORITY_B_OPT, 0, 0);
3867 add_prefix (&startfile_prefixes, arg, NULL,
3868 PREFIX_PRIORITY_B_OPT, 0, 0);
3869 add_prefix (&include_prefixes, arg, NULL,
3870 PREFIX_PRIORITY_B_OPT, 0, 0);
3872 validated = true;
3873 break;
3875 case OPT_x:
3876 spec_lang = arg;
3877 if (!strcmp (spec_lang, "none"))
3878 /* Suppress the warning if -xnone comes after the last input
3879 file, because alternate command interfaces like g++ might
3880 find it useful to place -xnone after each input file. */
3881 spec_lang = 0;
3882 else
3883 last_language_n_infiles = n_infiles;
3884 do_save = false;
3885 break;
3887 case OPT_o:
3888 have_o = 1;
3889 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3890 arg = convert_filename (arg, ! have_c, 0);
3891 #endif
3892 output_file = arg;
3893 /* Save the output name in case -save-temps=obj was used. */
3894 save_temps_prefix = xstrdup (arg);
3895 /* On some systems, ld cannot handle "-o" without a space. So
3896 split the option from its argument. */
3897 save_switch ("-o", 1, &arg, validated, true);
3898 return true;
3900 #ifdef ENABLE_DEFAULT_PIE
3901 case OPT_pie:
3902 /* -pie is turned on by default. */
3903 #endif
3905 case OPT_static_libgcc:
3906 case OPT_shared_libgcc:
3907 case OPT_static_libgfortran:
3908 case OPT_static_libstdc__:
3909 /* These are always valid, since gcc.c itself understands the
3910 first two, gfortranspec.c understands -static-libgfortran and
3911 g++spec.c understands -static-libstdc++ */
3912 validated = true;
3913 break;
3915 case OPT_fwpa:
3916 flag_wpa = "";
3917 break;
3919 case OPT_foffload_:
3920 handle_foffload_option (arg);
3921 break;
3923 default:
3924 /* Various driver options need no special processing at this
3925 point, having been handled in a prescan above or being
3926 handled by specs. */
3927 break;
3930 if (do_save)
3931 save_switch (decoded->canonical_option[0],
3932 decoded->canonical_option_num_elements - 1,
3933 &decoded->canonical_option[1], validated, true);
3934 return true;
3937 /* Put the driver's standard set of option handlers in *HANDLERS. */
3939 static void
3940 set_option_handlers (struct cl_option_handlers *handlers)
3942 handlers->unknown_option_callback = driver_unknown_option_callback;
3943 handlers->wrong_lang_callback = driver_wrong_lang_callback;
3944 handlers->num_handlers = 3;
3945 handlers->handlers[0].handler = driver_handle_option;
3946 handlers->handlers[0].mask = CL_DRIVER;
3947 handlers->handlers[1].handler = common_handle_option;
3948 handlers->handlers[1].mask = CL_COMMON;
3949 handlers->handlers[2].handler = target_handle_option;
3950 handlers->handlers[2].mask = CL_TARGET;
3953 /* Create the vector `switches' and its contents.
3954 Store its length in `n_switches'. */
3956 static void
3957 process_command (unsigned int decoded_options_count,
3958 struct cl_decoded_option *decoded_options)
3960 const char *temp;
3961 char *temp1;
3962 char *tooldir_prefix, *tooldir_prefix2;
3963 char *(*get_relative_prefix) (const char *, const char *,
3964 const char *) = NULL;
3965 struct cl_option_handlers handlers;
3966 unsigned int j;
3968 gcc_exec_prefix = getenv ("GCC_EXEC_PREFIX");
3970 n_switches = 0;
3971 n_infiles = 0;
3972 added_libraries = 0;
3974 /* Figure compiler version from version string. */
3976 compiler_version = temp1 = xstrdup (version_string);
3978 for (; *temp1; ++temp1)
3980 if (*temp1 == ' ')
3982 *temp1 = '\0';
3983 break;
3987 /* Handle any -no-canonical-prefixes flag early, to assign the function
3988 that builds relative prefixes. This function creates default search
3989 paths that are needed later in normal option handling. */
3991 for (j = 1; j < decoded_options_count; j++)
3993 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
3995 get_relative_prefix = make_relative_prefix_ignore_links;
3996 break;
3999 if (! get_relative_prefix)
4000 get_relative_prefix = make_relative_prefix;
4002 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
4003 see if we can create it from the pathname specified in
4004 decoded_options[0].arg. */
4006 gcc_libexec_prefix = standard_libexec_prefix;
4007 #ifndef VMS
4008 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
4009 if (!gcc_exec_prefix)
4011 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
4012 standard_bindir_prefix,
4013 standard_exec_prefix);
4014 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
4015 standard_bindir_prefix,
4016 standard_libexec_prefix);
4017 if (gcc_exec_prefix)
4018 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
4020 else
4022 /* make_relative_prefix requires a program name, but
4023 GCC_EXEC_PREFIX is typically a directory name with a trailing
4024 / (which is ignored by make_relative_prefix), so append a
4025 program name. */
4026 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
4027 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
4028 standard_exec_prefix,
4029 standard_libexec_prefix);
4031 /* The path is unrelocated, so fallback to the original setting. */
4032 if (!gcc_libexec_prefix)
4033 gcc_libexec_prefix = standard_libexec_prefix;
4035 free (tmp_prefix);
4037 #else
4038 #endif
4039 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
4040 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
4041 or an automatically created GCC_EXEC_PREFIX from
4042 decoded_options[0].arg. */
4044 /* Do language-specific adjustment/addition of flags. */
4045 lang_specific_driver (&decoded_options, &decoded_options_count,
4046 &added_libraries);
4048 if (gcc_exec_prefix)
4050 int len = strlen (gcc_exec_prefix);
4052 if (len > (int) sizeof ("/lib/gcc/") - 1
4053 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
4055 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
4056 if (IS_DIR_SEPARATOR (*temp)
4057 && filename_ncmp (temp + 1, "lib", 3) == 0
4058 && IS_DIR_SEPARATOR (temp[4])
4059 && filename_ncmp (temp + 5, "gcc", 3) == 0)
4060 len -= sizeof ("/lib/gcc/") - 1;
4063 set_std_prefix (gcc_exec_prefix, len);
4064 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
4065 PREFIX_PRIORITY_LAST, 0, 0);
4066 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
4067 PREFIX_PRIORITY_LAST, 0, 0);
4070 /* COMPILER_PATH and LIBRARY_PATH have values
4071 that are lists of directory names with colons. */
4073 temp = getenv ("COMPILER_PATH");
4074 if (temp)
4076 const char *startp, *endp;
4077 char *nstore = (char *) alloca (strlen (temp) + 3);
4079 startp = endp = temp;
4080 while (1)
4082 if (*endp == PATH_SEPARATOR || *endp == 0)
4084 strncpy (nstore, startp, endp - startp);
4085 if (endp == startp)
4086 strcpy (nstore, concat (".", dir_separator_str, NULL));
4087 else if (!IS_DIR_SEPARATOR (endp[-1]))
4089 nstore[endp - startp] = DIR_SEPARATOR;
4090 nstore[endp - startp + 1] = 0;
4092 else
4093 nstore[endp - startp] = 0;
4094 add_prefix (&exec_prefixes, nstore, 0,
4095 PREFIX_PRIORITY_LAST, 0, 0);
4096 add_prefix (&include_prefixes, nstore, 0,
4097 PREFIX_PRIORITY_LAST, 0, 0);
4098 if (*endp == 0)
4099 break;
4100 endp = startp = endp + 1;
4102 else
4103 endp++;
4107 temp = getenv (LIBRARY_PATH_ENV);
4108 if (temp && *cross_compile == '0')
4110 const char *startp, *endp;
4111 char *nstore = (char *) alloca (strlen (temp) + 3);
4113 startp = endp = temp;
4114 while (1)
4116 if (*endp == PATH_SEPARATOR || *endp == 0)
4118 strncpy (nstore, startp, endp - startp);
4119 if (endp == startp)
4120 strcpy (nstore, concat (".", dir_separator_str, NULL));
4121 else if (!IS_DIR_SEPARATOR (endp[-1]))
4123 nstore[endp - startp] = DIR_SEPARATOR;
4124 nstore[endp - startp + 1] = 0;
4126 else
4127 nstore[endp - startp] = 0;
4128 add_prefix (&startfile_prefixes, nstore, NULL,
4129 PREFIX_PRIORITY_LAST, 0, 1);
4130 if (*endp == 0)
4131 break;
4132 endp = startp = endp + 1;
4134 else
4135 endp++;
4139 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
4140 temp = getenv ("LPATH");
4141 if (temp && *cross_compile == '0')
4143 const char *startp, *endp;
4144 char *nstore = (char *) alloca (strlen (temp) + 3);
4146 startp = endp = temp;
4147 while (1)
4149 if (*endp == PATH_SEPARATOR || *endp == 0)
4151 strncpy (nstore, startp, endp - startp);
4152 if (endp == startp)
4153 strcpy (nstore, concat (".", dir_separator_str, NULL));
4154 else if (!IS_DIR_SEPARATOR (endp[-1]))
4156 nstore[endp - startp] = DIR_SEPARATOR;
4157 nstore[endp - startp + 1] = 0;
4159 else
4160 nstore[endp - startp] = 0;
4161 add_prefix (&startfile_prefixes, nstore, NULL,
4162 PREFIX_PRIORITY_LAST, 0, 1);
4163 if (*endp == 0)
4164 break;
4165 endp = startp = endp + 1;
4167 else
4168 endp++;
4172 /* Process the options and store input files and switches in their
4173 vectors. */
4175 last_language_n_infiles = -1;
4177 set_option_handlers (&handlers);
4179 for (j = 1; j < decoded_options_count; j++)
4181 switch (decoded_options[j].opt_index)
4183 case OPT_S:
4184 case OPT_c:
4185 case OPT_E:
4186 have_c = 1;
4187 break;
4189 if (have_c)
4190 break;
4193 for (j = 1; j < decoded_options_count; j++)
4195 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
4197 const char *arg = decoded_options[j].arg;
4198 const char *p = strrchr (arg, '@');
4199 char *fname;
4200 long offset;
4201 int consumed;
4202 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4203 arg = convert_filename (arg, 0, access (arg, F_OK));
4204 #endif
4205 /* For LTO static archive support we handle input file
4206 specifications that are composed of a filename and
4207 an offset like FNAME@OFFSET. */
4208 if (p
4209 && p != arg
4210 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
4211 && strlen (p) == (unsigned int)consumed)
4213 fname = (char *)xmalloc (p - arg + 1);
4214 memcpy (fname, arg, p - arg);
4215 fname[p - arg] = '\0';
4216 /* Only accept non-stdin and existing FNAME parts, otherwise
4217 try with the full name. */
4218 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
4220 free (fname);
4221 fname = xstrdup (arg);
4224 else
4225 fname = xstrdup (arg);
4227 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
4228 perror_with_name (fname);
4229 else
4230 add_infile (arg, spec_lang);
4232 free (fname);
4233 continue;
4236 read_cmdline_option (&global_options, &global_options_set,
4237 decoded_options + j, UNKNOWN_LOCATION,
4238 CL_DRIVER, &handlers, global_dc);
4241 if (output_file
4242 && strcmp (output_file, "-") != 0
4243 && strcmp (output_file, HOST_BIT_BUCKET) != 0)
4245 int i;
4246 for (i = 0; i < n_infiles; i++)
4247 if ((!infiles[i].language || infiles[i].language[0] != '*')
4248 && canonical_filename_eq (infiles[i].name, output_file))
4249 fatal_error (input_location,
4250 "input file %qs is the same as output file",
4251 output_file);
4254 /* If -save-temps=obj and -o name, create the prefix to use for %b.
4255 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
4256 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
4258 save_temps_length = strlen (save_temps_prefix);
4259 temp = strrchr (lbasename (save_temps_prefix), '.');
4260 if (temp)
4262 save_temps_length -= strlen (temp);
4263 save_temps_prefix[save_temps_length] = '\0';
4267 else if (save_temps_prefix != NULL)
4269 free (save_temps_prefix);
4270 save_temps_prefix = NULL;
4273 if (save_temps_flag && use_pipes)
4275 /* -save-temps overrides -pipe, so that temp files are produced */
4276 if (save_temps_flag)
4277 warning (0, "-pipe ignored because -save-temps specified");
4278 use_pipes = 0;
4281 if (!compare_debug)
4283 const char *gcd = getenv ("GCC_COMPARE_DEBUG");
4285 if (gcd && gcd[0] == '-')
4287 compare_debug = 2;
4288 compare_debug_opt = gcd;
4290 else if (gcd && *gcd && strcmp (gcd, "0"))
4292 compare_debug = 3;
4293 compare_debug_opt = "-gtoggle";
4296 else if (compare_debug < 0)
4298 compare_debug = 0;
4299 gcc_assert (!compare_debug_opt);
4302 /* Set up the search paths. We add directories that we expect to
4303 contain GNU Toolchain components before directories specified by
4304 the machine description so that we will find GNU components (like
4305 the GNU assembler) before those of the host system. */
4307 /* If we don't know where the toolchain has been installed, use the
4308 configured-in locations. */
4309 if (!gcc_exec_prefix)
4311 #ifndef OS2
4312 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
4313 PREFIX_PRIORITY_LAST, 1, 0);
4314 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
4315 PREFIX_PRIORITY_LAST, 2, 0);
4316 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
4317 PREFIX_PRIORITY_LAST, 2, 0);
4318 #endif
4319 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
4320 PREFIX_PRIORITY_LAST, 1, 0);
4323 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
4324 tooldir_prefix2 = concat (tooldir_base_prefix, spec_host_machine,
4325 dir_separator_str, NULL);
4327 /* Look for tools relative to the location from which the driver is
4328 running, or, if that is not available, the configured prefix. */
4329 tooldir_prefix
4330 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4331 spec_host_machine, dir_separator_str, spec_version,
4332 accel_dir_suffix, dir_separator_str, tooldir_prefix2, NULL);
4333 free (tooldir_prefix2);
4335 add_prefix (&exec_prefixes,
4336 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4337 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4338 add_prefix (&startfile_prefixes,
4339 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4340 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4341 free (tooldir_prefix);
4343 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4344 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4345 then consider it to relocate with the rest of the GCC installation
4346 if GCC_EXEC_PREFIX is set.
4347 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4348 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
4350 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
4351 standard_bindir_prefix,
4352 target_system_root);
4353 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4355 target_system_root = tmp_prefix;
4356 target_system_root_changed = 1;
4359 #endif
4361 /* More prefixes are enabled in main, after we read the specs file
4362 and determine whether this is cross-compilation or not. */
4364 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4365 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
4367 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
4368 environment variable. */
4369 if (compare_debug == 2 || compare_debug == 3)
4371 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
4372 save_switch (opt, 0, NULL, false, true);
4373 compare_debug = 1;
4376 /* Ensure we only invoke each subprocess once. */
4377 if (print_subprocess_help || print_help_list || print_version)
4379 n_infiles = 0;
4381 /* Create a dummy input file, so that we can pass
4382 the help option on to the various sub-processes. */
4383 add_infile ("help-dummy", "c");
4386 alloc_switch ();
4387 switches[n_switches].part1 = 0;
4388 alloc_infile ();
4389 infiles[n_infiles].name = 0;
4392 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4393 and place that in the environment. */
4395 static void
4396 set_collect_gcc_options (void)
4398 int i;
4399 int first_time;
4401 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4402 the compiler. */
4403 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4404 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4406 first_time = TRUE;
4407 for (i = 0; (int) i < n_switches; i++)
4409 const char *const *args;
4410 const char *p, *q;
4411 if (!first_time)
4412 obstack_grow (&collect_obstack, " ", 1);
4414 first_time = FALSE;
4416 /* Ignore elided switches. */
4417 if ((switches[i].live_cond
4418 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4419 == SWITCH_IGNORE)
4420 continue;
4422 obstack_grow (&collect_obstack, "'-", 2);
4423 q = switches[i].part1;
4424 while ((p = strchr (q, '\'')))
4426 obstack_grow (&collect_obstack, q, p - q);
4427 obstack_grow (&collect_obstack, "'\\''", 4);
4428 q = ++p;
4430 obstack_grow (&collect_obstack, q, strlen (q));
4431 obstack_grow (&collect_obstack, "'", 1);
4433 for (args = switches[i].args; args && *args; args++)
4435 obstack_grow (&collect_obstack, " '", 2);
4436 q = *args;
4437 while ((p = strchr (q, '\'')))
4439 obstack_grow (&collect_obstack, q, p - q);
4440 obstack_grow (&collect_obstack, "'\\''", 4);
4441 q = ++p;
4443 obstack_grow (&collect_obstack, q, strlen (q));
4444 obstack_grow (&collect_obstack, "'", 1);
4447 obstack_grow (&collect_obstack, "\0", 1);
4448 xputenv (XOBFINISH (&collect_obstack, char *));
4451 /* Process a spec string, accumulating and running commands. */
4453 /* These variables describe the input file name.
4454 input_file_number is the index on outfiles of this file,
4455 so that the output file name can be stored for later use by %o.
4456 input_basename is the start of the part of the input file
4457 sans all directory names, and basename_length is the number
4458 of characters starting there excluding the suffix .c or whatever. */
4460 static const char *gcc_input_filename;
4461 static int input_file_number;
4462 size_t input_filename_length;
4463 static int basename_length;
4464 static int suffixed_basename_length;
4465 static const char *input_basename;
4466 static const char *input_suffix;
4467 #ifndef HOST_LACKS_INODE_NUMBERS
4468 static struct stat input_stat;
4469 #endif
4470 static int input_stat_set;
4472 /* The compiler used to process the current input file. */
4473 static struct compiler *input_file_compiler;
4475 /* These are variables used within do_spec and do_spec_1. */
4477 /* Nonzero if an arg has been started and not yet terminated
4478 (with space, tab or newline). */
4479 static int arg_going;
4481 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4482 is a temporary file name. */
4483 static int delete_this_arg;
4485 /* Nonzero means %w has been seen; the next arg to be terminated
4486 is the output file name of this compilation. */
4487 static int this_is_output_file;
4489 /* Nonzero means %s has been seen; the next arg to be terminated
4490 is the name of a library file and we should try the standard
4491 search dirs for it. */
4492 static int this_is_library_file;
4494 /* Nonzero means %T has been seen; the next arg to be terminated
4495 is the name of a linker script and we should try all of the
4496 standard search dirs for it. If it is found insert a --script
4497 command line switch and then substitute the full path in place,
4498 otherwise generate an error message. */
4499 static int this_is_linker_script;
4501 /* Nonzero means that the input of this command is coming from a pipe. */
4502 static int input_from_pipe;
4504 /* Nonnull means substitute this for any suffix when outputting a switches
4505 arguments. */
4506 static const char *suffix_subst;
4508 /* If there is an argument being accumulated, terminate it and store it. */
4510 static void
4511 end_going_arg (void)
4513 if (arg_going)
4515 const char *string;
4517 obstack_1grow (&obstack, 0);
4518 string = XOBFINISH (&obstack, const char *);
4519 if (this_is_library_file)
4520 string = find_file (string);
4521 if (this_is_linker_script)
4523 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4525 if (full_script_path == NULL)
4527 error ("unable to locate default linker script %qs in the library search paths", string);
4528 /* Script was not found on search path. */
4529 return;
4531 store_arg ("--script", false, false);
4532 string = full_script_path;
4534 store_arg (string, delete_this_arg, this_is_output_file);
4535 if (this_is_output_file)
4536 outfiles[input_file_number] = string;
4537 arg_going = 0;
4542 /* Parse the WRAPPER string which is a comma separated list of the command line
4543 and insert them into the beginning of argbuf. */
4545 static void
4546 insert_wrapper (const char *wrapper)
4548 int n = 0;
4549 int i;
4550 char *buf = xstrdup (wrapper);
4551 char *p = buf;
4552 unsigned int old_length = argbuf.length ();
4556 n++;
4557 while (*p == ',')
4558 p++;
4560 while ((p = strchr (p, ',')) != NULL);
4562 argbuf.safe_grow (old_length + n);
4563 memmove (argbuf.address () + n,
4564 argbuf.address (),
4565 old_length * sizeof (const_char_p));
4567 i = 0;
4568 p = buf;
4571 while (*p == ',')
4573 *p = 0;
4574 p++;
4576 argbuf[i] = p;
4577 i++;
4579 while ((p = strchr (p, ',')) != NULL);
4580 gcc_assert (i == n);
4583 /* Process the spec SPEC and run the commands specified therein.
4584 Returns 0 if the spec is successfully processed; -1 if failed. */
4587 do_spec (const char *spec)
4589 int value;
4591 value = do_spec_2 (spec);
4593 /* Force out any unfinished command.
4594 If -pipe, this forces out the last command if it ended in `|'. */
4595 if (value == 0)
4597 if (argbuf.length () > 0
4598 && !strcmp (argbuf.last (), "|"))
4599 argbuf.pop ();
4601 set_collect_gcc_options ();
4603 if (argbuf.length () > 0)
4604 value = execute ();
4607 return value;
4610 static int
4611 do_spec_2 (const char *spec)
4613 int result;
4615 clear_args ();
4616 arg_going = 0;
4617 delete_this_arg = 0;
4618 this_is_output_file = 0;
4619 this_is_library_file = 0;
4620 this_is_linker_script = 0;
4621 input_from_pipe = 0;
4622 suffix_subst = NULL;
4624 result = do_spec_1 (spec, 0, NULL);
4626 end_going_arg ();
4628 return result;
4632 /* Process the given spec string and add any new options to the end
4633 of the switches/n_switches array. */
4635 static void
4636 do_option_spec (const char *name, const char *spec)
4638 unsigned int i, value_count, value_len;
4639 const char *p, *q, *value;
4640 char *tmp_spec, *tmp_spec_p;
4642 if (configure_default_options[0].name == NULL)
4643 return;
4645 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4646 if (strcmp (configure_default_options[i].name, name) == 0)
4647 break;
4648 if (i == ARRAY_SIZE (configure_default_options))
4649 return;
4651 value = configure_default_options[i].value;
4652 value_len = strlen (value);
4654 /* Compute the size of the final spec. */
4655 value_count = 0;
4656 p = spec;
4657 while ((p = strstr (p, "%(VALUE)")) != NULL)
4659 p ++;
4660 value_count ++;
4663 /* Replace each %(VALUE) by the specified value. */
4664 tmp_spec = (char *) alloca (strlen (spec) + 1
4665 + value_count * (value_len - strlen ("%(VALUE)")));
4666 tmp_spec_p = tmp_spec;
4667 q = spec;
4668 while ((p = strstr (q, "%(VALUE)")) != NULL)
4670 memcpy (tmp_spec_p, q, p - q);
4671 tmp_spec_p = tmp_spec_p + (p - q);
4672 memcpy (tmp_spec_p, value, value_len);
4673 tmp_spec_p += value_len;
4674 q = p + strlen ("%(VALUE)");
4676 strcpy (tmp_spec_p, q);
4678 do_self_spec (tmp_spec);
4681 /* Process the given spec string and add any new options to the end
4682 of the switches/n_switches array. */
4684 static void
4685 do_self_spec (const char *spec)
4687 int i;
4689 do_spec_2 (spec);
4690 do_spec_1 (" ", 0, NULL);
4692 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4693 do_self_specs adds the replacements to switches array, so it shouldn't
4694 be processed afterwards. */
4695 for (i = 0; i < n_switches; i++)
4696 if ((switches[i].live_cond & SWITCH_IGNORE))
4697 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4699 if (argbuf.length () > 0)
4701 const char **argbuf_copy;
4702 struct cl_decoded_option *decoded_options;
4703 struct cl_option_handlers handlers;
4704 unsigned int decoded_options_count;
4705 unsigned int j;
4707 /* Create a copy of argbuf with a dummy argv[0] entry for
4708 decode_cmdline_options_to_array. */
4709 argbuf_copy = XNEWVEC (const char *,
4710 argbuf.length () + 1);
4711 argbuf_copy[0] = "";
4712 memcpy (argbuf_copy + 1, argbuf.address (),
4713 argbuf.length () * sizeof (const char *));
4715 decode_cmdline_options_to_array (argbuf.length () + 1,
4716 argbuf_copy,
4717 CL_DRIVER, &decoded_options,
4718 &decoded_options_count);
4719 free (argbuf_copy);
4721 set_option_handlers (&handlers);
4723 for (j = 1; j < decoded_options_count; j++)
4725 switch (decoded_options[j].opt_index)
4727 case OPT_SPECIAL_input_file:
4728 /* Specs should only generate options, not input
4729 files. */
4730 if (strcmp (decoded_options[j].arg, "-") != 0)
4731 fatal_error (input_location,
4732 "switch %qs does not start with %<-%>",
4733 decoded_options[j].arg);
4734 else
4735 fatal_error (input_location,
4736 "spec-generated switch is just %<-%>");
4737 break;
4739 case OPT_fcompare_debug_second:
4740 case OPT_fcompare_debug:
4741 case OPT_fcompare_debug_:
4742 case OPT_o:
4743 /* Avoid duplicate processing of some options from
4744 compare-debug specs; just save them here. */
4745 save_switch (decoded_options[j].canonical_option[0],
4746 (decoded_options[j].canonical_option_num_elements
4747 - 1),
4748 &decoded_options[j].canonical_option[1], false, true);
4749 break;
4751 default:
4752 read_cmdline_option (&global_options, &global_options_set,
4753 decoded_options + j, UNKNOWN_LOCATION,
4754 CL_DRIVER, &handlers, global_dc);
4755 break;
4759 free (decoded_options);
4761 alloc_switch ();
4762 switches[n_switches].part1 = 0;
4766 /* Callback for processing %D and %I specs. */
4768 struct spec_path_info {
4769 const char *option;
4770 const char *append;
4771 size_t append_len;
4772 bool omit_relative;
4773 bool separate_options;
4776 static void *
4777 spec_path (char *path, void *data)
4779 struct spec_path_info *info = (struct spec_path_info *) data;
4780 size_t len = 0;
4781 char save = 0;
4783 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4784 return NULL;
4786 if (info->append_len != 0)
4788 len = strlen (path);
4789 memcpy (path + len, info->append, info->append_len + 1);
4792 if (!is_directory (path, true))
4793 return NULL;
4795 do_spec_1 (info->option, 1, NULL);
4796 if (info->separate_options)
4797 do_spec_1 (" ", 0, NULL);
4799 if (info->append_len == 0)
4801 len = strlen (path);
4802 save = path[len - 1];
4803 if (IS_DIR_SEPARATOR (path[len - 1]))
4804 path[len - 1] = '\0';
4807 do_spec_1 (path, 1, NULL);
4808 do_spec_1 (" ", 0, NULL);
4810 /* Must not damage the original path. */
4811 if (info->append_len == 0)
4812 path[len - 1] = save;
4814 return NULL;
4817 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
4818 argument list. */
4820 static void
4821 create_at_file (char **argv)
4823 char *temp_file = make_temp_file ("");
4824 char *at_argument = concat ("@", temp_file, NULL);
4825 FILE *f = fopen (temp_file, "w");
4826 int status;
4828 if (f == NULL)
4829 fatal_error (input_location, "could not open temporary response file %s",
4830 temp_file);
4832 status = writeargv (argv, f);
4834 if (status)
4835 fatal_error (input_location,
4836 "could not write to temporary response file %s",
4837 temp_file);
4839 status = fclose (f);
4841 if (EOF == status)
4842 fatal_error (input_location, "could not close temporary response file %s",
4843 temp_file);
4845 store_arg (at_argument, 0, 0);
4847 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
4850 /* True if we should compile INFILE. */
4852 static bool
4853 compile_input_file_p (struct infile *infile)
4855 if ((!infile->language) || (infile->language[0] != '*'))
4856 if (infile->incompiler == input_file_compiler)
4857 return true;
4858 return false;
4861 /* Process each member of VEC as a spec. */
4863 static void
4864 do_specs_vec (vec<char_p> vec)
4866 unsigned ix;
4867 char *opt;
4869 FOR_EACH_VEC_ELT (vec, ix, opt)
4871 do_spec_1 (opt, 1, NULL);
4872 /* Make each accumulated option a separate argument. */
4873 do_spec_1 (" ", 0, NULL);
4877 /* Process the sub-spec SPEC as a portion of a larger spec.
4878 This is like processing a whole spec except that we do
4879 not initialize at the beginning and we do not supply a
4880 newline by default at the end.
4881 INSWITCH nonzero means don't process %-sequences in SPEC;
4882 in this case, % is treated as an ordinary character.
4883 This is used while substituting switches.
4884 INSWITCH nonzero also causes SPC not to terminate an argument.
4886 Value is zero unless a line was finished
4887 and the command on that line reported an error. */
4889 static int
4890 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4892 const char *p = spec;
4893 int c;
4894 int i;
4895 int value;
4897 /* If it's an empty string argument to a switch, keep it as is. */
4898 if (inswitch && !*p)
4899 arg_going = 1;
4901 while ((c = *p++))
4902 /* If substituting a switch, treat all chars like letters.
4903 Otherwise, NL, SPC, TAB and % are special. */
4904 switch (inswitch ? 'a' : c)
4906 case '\n':
4907 end_going_arg ();
4909 if (argbuf.length () > 0
4910 && !strcmp (argbuf.last (), "|"))
4912 /* A `|' before the newline means use a pipe here,
4913 but only if -pipe was specified.
4914 Otherwise, execute now and don't pass the `|' as an arg. */
4915 if (use_pipes)
4917 input_from_pipe = 1;
4918 break;
4920 else
4921 argbuf.pop ();
4924 set_collect_gcc_options ();
4926 if (argbuf.length () > 0)
4928 value = execute ();
4929 if (value)
4930 return value;
4932 /* Reinitialize for a new command, and for a new argument. */
4933 clear_args ();
4934 arg_going = 0;
4935 delete_this_arg = 0;
4936 this_is_output_file = 0;
4937 this_is_library_file = 0;
4938 this_is_linker_script = 0;
4939 input_from_pipe = 0;
4940 break;
4942 case '|':
4943 end_going_arg ();
4945 /* Use pipe */
4946 obstack_1grow (&obstack, c);
4947 arg_going = 1;
4948 break;
4950 case '\t':
4951 case ' ':
4952 end_going_arg ();
4954 /* Reinitialize for a new argument. */
4955 delete_this_arg = 0;
4956 this_is_output_file = 0;
4957 this_is_library_file = 0;
4958 this_is_linker_script = 0;
4959 break;
4961 case '%':
4962 switch (c = *p++)
4964 case 0:
4965 fatal_error (input_location, "spec %qs invalid", spec);
4967 case 'b':
4968 if (save_temps_length)
4969 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4970 else
4971 obstack_grow (&obstack, input_basename, basename_length);
4972 if (compare_debug < 0)
4973 obstack_grow (&obstack, ".gk", 3);
4974 arg_going = 1;
4975 break;
4977 case 'B':
4978 if (save_temps_length)
4979 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4980 else
4981 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4982 if (compare_debug < 0)
4983 obstack_grow (&obstack, ".gk", 3);
4984 arg_going = 1;
4985 break;
4987 case 'd':
4988 delete_this_arg = 2;
4989 break;
4991 /* Dump out the directories specified with LIBRARY_PATH,
4992 followed by the absolute directories
4993 that we search for startfiles. */
4994 case 'D':
4996 struct spec_path_info info;
4998 info.option = "-L";
4999 info.append_len = 0;
5000 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
5001 /* Used on systems which record the specified -L dirs
5002 and use them to search for dynamic linking.
5003 Relative directories always come from -B,
5004 and it is better not to use them for searching
5005 at run time. In particular, stage1 loses. */
5006 info.omit_relative = true;
5007 #else
5008 info.omit_relative = false;
5009 #endif
5010 info.separate_options = false;
5012 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
5014 break;
5016 case 'e':
5017 /* %efoo means report an error with `foo' as error message
5018 and don't execute any more commands for this file. */
5020 const char *q = p;
5021 char *buf;
5022 while (*p != 0 && *p != '\n')
5023 p++;
5024 buf = (char *) alloca (p - q + 1);
5025 strncpy (buf, q, p - q);
5026 buf[p - q] = 0;
5027 error ("%s", _(buf));
5028 return -1;
5030 break;
5031 case 'n':
5032 /* %nfoo means report a notice with `foo' on stderr. */
5034 const char *q = p;
5035 char *buf;
5036 while (*p != 0 && *p != '\n')
5037 p++;
5038 buf = (char *) alloca (p - q + 1);
5039 strncpy (buf, q, p - q);
5040 buf[p - q] = 0;
5041 inform (0, "%s", _(buf));
5042 if (*p)
5043 p++;
5045 break;
5047 case 'j':
5049 struct stat st;
5051 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
5052 defined, and it is not a directory, and it is
5053 writable, use it. Otherwise, treat this like any
5054 other temporary file. */
5056 if ((!save_temps_flag)
5057 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
5058 && (access (HOST_BIT_BUCKET, W_OK) == 0))
5060 obstack_grow (&obstack, HOST_BIT_BUCKET,
5061 strlen (HOST_BIT_BUCKET));
5062 delete_this_arg = 0;
5063 arg_going = 1;
5064 break;
5067 goto create_temp_file;
5068 case '|':
5069 if (use_pipes)
5071 obstack_1grow (&obstack, '-');
5072 delete_this_arg = 0;
5073 arg_going = 1;
5075 /* consume suffix */
5076 while (*p == '.' || ISALNUM ((unsigned char) *p))
5077 p++;
5078 if (p[0] == '%' && p[1] == 'O')
5079 p += 2;
5081 break;
5083 goto create_temp_file;
5084 case 'm':
5085 if (use_pipes)
5087 /* consume suffix */
5088 while (*p == '.' || ISALNUM ((unsigned char) *p))
5089 p++;
5090 if (p[0] == '%' && p[1] == 'O')
5091 p += 2;
5093 break;
5095 goto create_temp_file;
5096 case 'g':
5097 case 'u':
5098 case 'U':
5099 create_temp_file:
5101 struct temp_name *t;
5102 int suffix_length;
5103 const char *suffix = p;
5104 char *saved_suffix = NULL;
5106 while (*p == '.' || ISALNUM ((unsigned char) *p))
5107 p++;
5108 suffix_length = p - suffix;
5109 if (p[0] == '%' && p[1] == 'O')
5111 p += 2;
5112 /* We don't support extra suffix characters after %O. */
5113 if (*p == '.' || ISALNUM ((unsigned char) *p))
5114 fatal_error (input_location,
5115 "spec %qs has invalid %<%%0%c%>", spec, *p);
5116 if (suffix_length == 0)
5117 suffix = TARGET_OBJECT_SUFFIX;
5118 else
5120 saved_suffix
5121 = XNEWVEC (char, suffix_length
5122 + strlen (TARGET_OBJECT_SUFFIX) + 1);
5123 strncpy (saved_suffix, suffix, suffix_length);
5124 strcpy (saved_suffix + suffix_length,
5125 TARGET_OBJECT_SUFFIX);
5127 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
5130 if (compare_debug < 0)
5132 suffix = concat (".gk", suffix, NULL);
5133 suffix_length += 3;
5136 /* If -save-temps=obj and -o were specified, use that for the
5137 temp file. */
5138 if (save_temps_length)
5140 char *tmp;
5141 temp_filename_length
5142 = save_temps_length + suffix_length + 1;
5143 tmp = (char *) alloca (temp_filename_length);
5144 memcpy (tmp, save_temps_prefix, save_temps_length);
5145 memcpy (tmp + save_temps_length, suffix, suffix_length);
5146 tmp[save_temps_length + suffix_length] = '\0';
5147 temp_filename = save_string (tmp, save_temps_length
5148 + suffix_length);
5149 obstack_grow (&obstack, temp_filename,
5150 temp_filename_length);
5151 arg_going = 1;
5152 delete_this_arg = 0;
5153 break;
5156 /* If the gcc_input_filename has the same suffix specified
5157 for the %g, %u, or %U, and -save-temps is specified,
5158 we could end up using that file as an intermediate
5159 thus clobbering the user's source file (.e.g.,
5160 gcc -save-temps foo.s would clobber foo.s with the
5161 output of cpp0). So check for this condition and
5162 generate a temp file as the intermediate. */
5164 if (save_temps_flag)
5166 char *tmp;
5167 temp_filename_length = basename_length + suffix_length + 1;
5168 tmp = (char *) alloca (temp_filename_length);
5169 memcpy (tmp, input_basename, basename_length);
5170 memcpy (tmp + basename_length, suffix, suffix_length);
5171 tmp[basename_length + suffix_length] = '\0';
5172 temp_filename = tmp;
5174 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
5176 #ifndef HOST_LACKS_INODE_NUMBERS
5177 struct stat st_temp;
5179 /* Note, set_input() resets input_stat_set to 0. */
5180 if (input_stat_set == 0)
5182 input_stat_set = stat (gcc_input_filename,
5183 &input_stat);
5184 if (input_stat_set >= 0)
5185 input_stat_set = 1;
5188 /* If we have the stat for the gcc_input_filename
5189 and we can do the stat for the temp_filename
5190 then the they could still refer to the same
5191 file if st_dev/st_ino's are the same. */
5192 if (input_stat_set != 1
5193 || stat (temp_filename, &st_temp) < 0
5194 || input_stat.st_dev != st_temp.st_dev
5195 || input_stat.st_ino != st_temp.st_ino)
5196 #else
5197 /* Just compare canonical pathnames. */
5198 char* input_realname = lrealpath (gcc_input_filename);
5199 char* temp_realname = lrealpath (temp_filename);
5200 bool files_differ = filename_cmp (input_realname, temp_realname);
5201 free (input_realname);
5202 free (temp_realname);
5203 if (files_differ)
5204 #endif
5206 temp_filename = save_string (temp_filename,
5207 temp_filename_length + 1);
5208 obstack_grow (&obstack, temp_filename,
5209 temp_filename_length);
5210 arg_going = 1;
5211 delete_this_arg = 0;
5212 break;
5217 /* See if we already have an association of %g/%u/%U and
5218 suffix. */
5219 for (t = temp_names; t; t = t->next)
5220 if (t->length == suffix_length
5221 && strncmp (t->suffix, suffix, suffix_length) == 0
5222 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
5223 break;
5225 /* Make a new association if needed. %u and %j
5226 require one. */
5227 if (t == 0 || c == 'u' || c == 'j')
5229 if (t == 0)
5231 t = XNEW (struct temp_name);
5232 t->next = temp_names;
5233 temp_names = t;
5235 t->length = suffix_length;
5236 if (saved_suffix)
5238 t->suffix = saved_suffix;
5239 saved_suffix = NULL;
5241 else
5242 t->suffix = save_string (suffix, suffix_length);
5243 t->unique = (c == 'u' || c == 'U' || c == 'j');
5244 temp_filename = make_temp_file (t->suffix);
5245 temp_filename_length = strlen (temp_filename);
5246 t->filename = temp_filename;
5247 t->filename_length = temp_filename_length;
5250 free (saved_suffix);
5252 obstack_grow (&obstack, t->filename, t->filename_length);
5253 delete_this_arg = 1;
5255 arg_going = 1;
5256 break;
5258 case 'i':
5259 if (combine_inputs)
5261 if (at_file_supplied)
5263 /* We are going to expand `%i' to `@FILE', where FILE
5264 is a newly-created temporary filename. The filenames
5265 that would usually be expanded in place of %o will be
5266 written to the temporary file. */
5267 char **argv;
5268 int n_files = 0;
5269 int j;
5271 for (i = 0; i < n_infiles; i++)
5272 if (compile_input_file_p (&infiles[i]))
5273 n_files++;
5275 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5277 /* Copy the strings over. */
5278 for (i = 0, j = 0; i < n_infiles; i++)
5279 if (compile_input_file_p (&infiles[i]))
5281 argv[j] = CONST_CAST (char *, infiles[i].name);
5282 infiles[i].compiled = true;
5283 j++;
5285 argv[j] = NULL;
5287 create_at_file (argv);
5289 else
5290 for (i = 0; (int) i < n_infiles; i++)
5291 if (compile_input_file_p (&infiles[i]))
5293 store_arg (infiles[i].name, 0, 0);
5294 infiles[i].compiled = true;
5297 else
5299 obstack_grow (&obstack, gcc_input_filename,
5300 input_filename_length);
5301 arg_going = 1;
5303 break;
5305 case 'I':
5307 struct spec_path_info info;
5309 if (multilib_dir)
5311 do_spec_1 ("-imultilib", 1, NULL);
5312 /* Make this a separate argument. */
5313 do_spec_1 (" ", 0, NULL);
5314 do_spec_1 (multilib_dir, 1, NULL);
5315 do_spec_1 (" ", 0, NULL);
5318 if (multiarch_dir)
5320 do_spec_1 ("-imultiarch", 1, NULL);
5321 /* Make this a separate argument. */
5322 do_spec_1 (" ", 0, NULL);
5323 do_spec_1 (multiarch_dir, 1, NULL);
5324 do_spec_1 (" ", 0, NULL);
5327 if (gcc_exec_prefix)
5329 do_spec_1 ("-iprefix", 1, NULL);
5330 /* Make this a separate argument. */
5331 do_spec_1 (" ", 0, NULL);
5332 do_spec_1 (gcc_exec_prefix, 1, NULL);
5333 do_spec_1 (" ", 0, NULL);
5336 if (target_system_root_changed ||
5337 (target_system_root && target_sysroot_hdrs_suffix))
5339 do_spec_1 ("-isysroot", 1, NULL);
5340 /* Make this a separate argument. */
5341 do_spec_1 (" ", 0, NULL);
5342 do_spec_1 (target_system_root, 1, NULL);
5343 if (target_sysroot_hdrs_suffix)
5344 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
5345 do_spec_1 (" ", 0, NULL);
5348 info.option = "-isystem";
5349 info.append = "include";
5350 info.append_len = strlen (info.append);
5351 info.omit_relative = false;
5352 info.separate_options = true;
5354 for_each_path (&include_prefixes, false, info.append_len,
5355 spec_path, &info);
5357 info.append = "include-fixed";
5358 if (*sysroot_hdrs_suffix_spec)
5359 info.append = concat (info.append, dir_separator_str,
5360 multilib_dir, NULL);
5361 info.append_len = strlen (info.append);
5362 for_each_path (&include_prefixes, false, info.append_len,
5363 spec_path, &info);
5365 break;
5367 case 'o':
5369 int max = n_infiles;
5370 max += lang_specific_extra_outfiles;
5372 if (HAVE_GNU_LD && at_file_supplied)
5374 /* We are going to expand `%o' to `@FILE', where FILE
5375 is a newly-created temporary filename. The filenames
5376 that would usually be expanded in place of %o will be
5377 written to the temporary file. */
5379 char **argv;
5380 int n_files, j;
5382 /* Convert OUTFILES into a form suitable for writeargv. */
5384 /* Determine how many are non-NULL. */
5385 for (n_files = 0, i = 0; i < max; i++)
5386 n_files += outfiles[i] != NULL;
5388 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5390 /* Copy the strings over. */
5391 for (i = 0, j = 0; i < max; i++)
5392 if (outfiles[i])
5394 argv[j] = CONST_CAST (char *, outfiles[i]);
5395 j++;
5397 argv[j] = NULL;
5399 create_at_file (argv);
5401 else
5402 for (i = 0; i < max; i++)
5403 if (outfiles[i])
5404 store_arg (outfiles[i], 0, 0);
5405 break;
5408 case 'O':
5409 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5410 arg_going = 1;
5411 break;
5413 case 's':
5414 this_is_library_file = 1;
5415 break;
5417 case 'T':
5418 this_is_linker_script = 1;
5419 break;
5421 case 'V':
5422 outfiles[input_file_number] = NULL;
5423 break;
5425 case 'w':
5426 this_is_output_file = 1;
5427 break;
5429 case 'W':
5431 unsigned int cur_index = argbuf.length ();
5432 /* Handle the {...} following the %W. */
5433 if (*p != '{')
5434 fatal_error (input_location,
5435 "spec %qs has invalid %<%%W%c%>", spec, *p);
5436 p = handle_braces (p + 1);
5437 if (p == 0)
5438 return -1;
5439 end_going_arg ();
5440 /* If any args were output, mark the last one for deletion
5441 on failure. */
5442 if (argbuf.length () != cur_index)
5443 record_temp_file (argbuf.last (), 0, 1);
5444 break;
5447 /* %x{OPTION} records OPTION for %X to output. */
5448 case 'x':
5450 const char *p1 = p;
5451 char *string;
5452 char *opt;
5453 unsigned ix;
5455 /* Skip past the option value and make a copy. */
5456 if (*p != '{')
5457 fatal_error (input_location,
5458 "spec %qs has invalid %<%%x%c%>", spec, *p);
5459 while (*p++ != '}')
5461 string = save_string (p1 + 1, p - p1 - 2);
5463 /* See if we already recorded this option. */
5464 FOR_EACH_VEC_ELT (linker_options, ix, opt)
5465 if (! strcmp (string, opt))
5467 free (string);
5468 return 0;
5471 /* This option is new; add it. */
5472 add_linker_option (string, strlen (string));
5473 free (string);
5475 break;
5477 /* Dump out the options accumulated previously using %x. */
5478 case 'X':
5479 do_specs_vec (linker_options);
5480 break;
5482 /* Dump out the options accumulated previously using -Wa,. */
5483 case 'Y':
5484 do_specs_vec (assembler_options);
5485 break;
5487 /* Dump out the options accumulated previously using -Wp,. */
5488 case 'Z':
5489 do_specs_vec (preprocessor_options);
5490 break;
5492 /* Here are digits and numbers that just process
5493 a certain constant string as a spec. */
5495 case '1':
5496 value = do_spec_1 (cc1_spec, 0, NULL);
5497 if (value != 0)
5498 return value;
5499 break;
5501 case '2':
5502 value = do_spec_1 (cc1plus_spec, 0, NULL);
5503 if (value != 0)
5504 return value;
5505 break;
5507 case 'a':
5508 value = do_spec_1 (asm_spec, 0, NULL);
5509 if (value != 0)
5510 return value;
5511 break;
5513 case 'A':
5514 value = do_spec_1 (asm_final_spec, 0, NULL);
5515 if (value != 0)
5516 return value;
5517 break;
5519 case 'C':
5521 const char *const spec
5522 = (input_file_compiler->cpp_spec
5523 ? input_file_compiler->cpp_spec
5524 : cpp_spec);
5525 value = do_spec_1 (spec, 0, NULL);
5526 if (value != 0)
5527 return value;
5529 break;
5531 case 'E':
5532 value = do_spec_1 (endfile_spec, 0, NULL);
5533 if (value != 0)
5534 return value;
5535 break;
5537 case 'l':
5538 value = do_spec_1 (link_spec, 0, NULL);
5539 if (value != 0)
5540 return value;
5541 break;
5543 case 'L':
5544 value = do_spec_1 (lib_spec, 0, NULL);
5545 if (value != 0)
5546 return value;
5547 break;
5549 case 'M':
5550 if (multilib_os_dir == NULL)
5551 obstack_1grow (&obstack, '.');
5552 else
5553 obstack_grow (&obstack, multilib_os_dir,
5554 strlen (multilib_os_dir));
5555 break;
5557 case 'G':
5558 value = do_spec_1 (libgcc_spec, 0, NULL);
5559 if (value != 0)
5560 return value;
5561 break;
5563 case 'R':
5564 /* We assume there is a directory
5565 separator at the end of this string. */
5566 if (target_system_root)
5568 obstack_grow (&obstack, target_system_root,
5569 strlen (target_system_root));
5570 if (target_sysroot_suffix)
5571 obstack_grow (&obstack, target_sysroot_suffix,
5572 strlen (target_sysroot_suffix));
5574 break;
5576 case 'S':
5577 value = do_spec_1 (startfile_spec, 0, NULL);
5578 if (value != 0)
5579 return value;
5580 break;
5582 /* Here we define characters other than letters and digits. */
5584 case '{':
5585 p = handle_braces (p);
5586 if (p == 0)
5587 return -1;
5588 break;
5590 case ':':
5591 p = handle_spec_function (p, NULL);
5592 if (p == 0)
5593 return -1;
5594 break;
5596 case '%':
5597 obstack_1grow (&obstack, '%');
5598 break;
5600 case '.':
5602 unsigned len = 0;
5604 while (p[len] && p[len] != ' ' && p[len] != '%')
5605 len++;
5606 suffix_subst = save_string (p - 1, len + 1);
5607 p += len;
5609 break;
5611 /* Henceforth ignore the option(s) matching the pattern
5612 after the %<. */
5613 case '<':
5614 case '>':
5616 unsigned len = 0;
5617 int have_wildcard = 0;
5618 int i;
5619 int switch_option;
5621 if (c == '>')
5622 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5623 else
5624 switch_option = SWITCH_IGNORE;
5626 while (p[len] && p[len] != ' ' && p[len] != '\t')
5627 len++;
5629 if (p[len-1] == '*')
5630 have_wildcard = 1;
5632 for (i = 0; i < n_switches; i++)
5633 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5634 && (have_wildcard || switches[i].part1[len] == '\0'))
5636 switches[i].live_cond |= switch_option;
5637 /* User switch be validated from validate_all_switches.
5638 when the definition is seen from the spec file.
5639 If not defined anywhere, will be rejected. */
5640 if (switches[i].known)
5641 switches[i].validated = true;
5644 p += len;
5646 break;
5648 case '*':
5649 if (soft_matched_part)
5651 if (soft_matched_part[0])
5652 do_spec_1 (soft_matched_part, 1, NULL);
5653 /* Only insert a space after the substitution if it is at the
5654 end of the current sequence. So if:
5656 "%{foo=*:bar%*}%{foo=*:one%*two}"
5658 matches -foo=hello then it will produce:
5660 barhello onehellotwo
5662 if (*p == 0 || *p == '}')
5663 do_spec_1 (" ", 0, NULL);
5665 else
5666 /* Catch the case where a spec string contains something like
5667 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5668 hand side of the :. */
5669 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5670 break;
5672 /* Process a string found as the value of a spec given by name.
5673 This feature allows individual machine descriptions
5674 to add and use their own specs. */
5675 case '(':
5677 const char *name = p;
5678 struct spec_list *sl;
5679 int len;
5681 /* The string after the S/P is the name of a spec that is to be
5682 processed. */
5683 while (*p && *p != ')')
5684 p++;
5686 /* See if it's in the list. */
5687 for (len = p - name, sl = specs; sl; sl = sl->next)
5688 if (sl->name_len == len && !strncmp (sl->name, name, len))
5690 name = *(sl->ptr_spec);
5691 #ifdef DEBUG_SPECS
5692 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5693 sl->name, name);
5694 #endif
5695 break;
5698 if (sl)
5700 value = do_spec_1 (name, 0, NULL);
5701 if (value != 0)
5702 return value;
5705 /* Discard the closing paren. */
5706 if (*p)
5707 p++;
5709 break;
5711 default:
5712 error ("spec failure: unrecognized spec option %qc", c);
5713 break;
5715 break;
5717 case '\\':
5718 /* Backslash: treat next character as ordinary. */
5719 c = *p++;
5721 /* Fall through. */
5722 default:
5723 /* Ordinary character: put it into the current argument. */
5724 obstack_1grow (&obstack, c);
5725 arg_going = 1;
5728 /* End of string. If we are processing a spec function, we need to
5729 end any pending argument. */
5730 if (processing_spec_function)
5731 end_going_arg ();
5733 return 0;
5736 /* Look up a spec function. */
5738 static const struct spec_function *
5739 lookup_spec_function (const char *name)
5741 const struct spec_function *sf;
5743 for (sf = static_spec_functions; sf->name != NULL; sf++)
5744 if (strcmp (sf->name, name) == 0)
5745 return sf;
5747 return NULL;
5750 /* Evaluate a spec function. */
5752 static const char *
5753 eval_spec_function (const char *func, const char *args)
5755 const struct spec_function *sf;
5756 const char *funcval;
5758 /* Saved spec processing context. */
5759 vec<const_char_p> save_argbuf;
5761 int save_arg_going;
5762 int save_delete_this_arg;
5763 int save_this_is_output_file;
5764 int save_this_is_library_file;
5765 int save_input_from_pipe;
5766 int save_this_is_linker_script;
5767 const char *save_suffix_subst;
5769 int save_growing_size;
5770 void *save_growing_value = NULL;
5772 sf = lookup_spec_function (func);
5773 if (sf == NULL)
5774 fatal_error (input_location, "unknown spec function %qs", func);
5776 /* Push the spec processing context. */
5777 save_argbuf = argbuf;
5779 save_arg_going = arg_going;
5780 save_delete_this_arg = delete_this_arg;
5781 save_this_is_output_file = this_is_output_file;
5782 save_this_is_library_file = this_is_library_file;
5783 save_this_is_linker_script = this_is_linker_script;
5784 save_input_from_pipe = input_from_pipe;
5785 save_suffix_subst = suffix_subst;
5787 /* If we have some object growing now, finalize it so the args and function
5788 eval proceed from a cleared context. This is needed to prevent the first
5789 constructed arg from mistakenly including the growing value. We'll push
5790 this value back on the obstack once the function evaluation is done, to
5791 restore a consistent processing context for our caller. This is fine as
5792 the address of growing objects isn't guaranteed to remain stable until
5793 they are finalized, and we expect this situation to be rare enough for
5794 the extra copy not to be an issue. */
5795 save_growing_size = obstack_object_size (&obstack);
5796 if (save_growing_size > 0)
5797 save_growing_value = obstack_finish (&obstack);
5799 /* Create a new spec processing context, and build the function
5800 arguments. */
5802 alloc_args ();
5803 if (do_spec_2 (args) < 0)
5804 fatal_error (input_location, "error in args to spec function %qs", func);
5806 /* argbuf_index is an index for the next argument to be inserted, and
5807 so contains the count of the args already inserted. */
5809 funcval = (*sf->func) (argbuf.length (),
5810 argbuf.address ());
5812 /* Pop the spec processing context. */
5813 argbuf.release ();
5814 argbuf = save_argbuf;
5816 arg_going = save_arg_going;
5817 delete_this_arg = save_delete_this_arg;
5818 this_is_output_file = save_this_is_output_file;
5819 this_is_library_file = save_this_is_library_file;
5820 this_is_linker_script = save_this_is_linker_script;
5821 input_from_pipe = save_input_from_pipe;
5822 suffix_subst = save_suffix_subst;
5824 if (save_growing_size > 0)
5825 obstack_grow (&obstack, save_growing_value, save_growing_size);
5827 return funcval;
5830 /* Handle a spec function call of the form:
5832 %:function(args)
5834 ARGS is processed as a spec in a separate context and split into an
5835 argument vector in the normal fashion. The function returns a string
5836 containing a spec which we then process in the caller's context, or
5837 NULL if no processing is required.
5839 If RETVAL_NONNULL is not NULL, then store a bool whether function
5840 returned non-NULL. */
5842 static const char *
5843 handle_spec_function (const char *p, bool *retval_nonnull)
5845 char *func, *args;
5846 const char *endp, *funcval;
5847 int count;
5849 processing_spec_function++;
5851 /* Get the function name. */
5852 for (endp = p; *endp != '\0'; endp++)
5854 if (*endp == '(') /* ) */
5855 break;
5856 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5857 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5858 fatal_error (input_location, "malformed spec function name");
5860 if (*endp != '(') /* ) */
5861 fatal_error (input_location, "no arguments for spec function");
5862 func = save_string (p, endp - p);
5863 p = ++endp;
5865 /* Get the arguments. */
5866 for (count = 0; *endp != '\0'; endp++)
5868 /* ( */
5869 if (*endp == ')')
5871 if (count == 0)
5872 break;
5873 count--;
5875 else if (*endp == '(') /* ) */
5876 count++;
5878 /* ( */
5879 if (*endp != ')')
5880 fatal_error (input_location, "malformed spec function arguments");
5881 args = save_string (p, endp - p);
5882 p = ++endp;
5884 /* p now points to just past the end of the spec function expression. */
5886 funcval = eval_spec_function (func, args);
5887 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5888 p = NULL;
5889 if (retval_nonnull)
5890 *retval_nonnull = funcval != NULL;
5892 free (func);
5893 free (args);
5895 processing_spec_function--;
5897 return p;
5900 /* Inline subroutine of handle_braces. Returns true if the current
5901 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5902 static inline bool
5903 input_suffix_matches (const char *atom, const char *end_atom)
5905 return (input_suffix
5906 && !strncmp (input_suffix, atom, end_atom - atom)
5907 && input_suffix[end_atom - atom] == '\0');
5910 /* Subroutine of handle_braces. Returns true if the current
5911 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
5912 static bool
5913 input_spec_matches (const char *atom, const char *end_atom)
5915 return (input_file_compiler
5916 && input_file_compiler->suffix
5917 && input_file_compiler->suffix[0] != '\0'
5918 && !strncmp (input_file_compiler->suffix + 1, atom,
5919 end_atom - atom)
5920 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
5923 /* Subroutine of handle_braces. Returns true if a switch
5924 matching the atom bracketed by ATOM and END_ATOM appeared on the
5925 command line. */
5926 static bool
5927 switch_matches (const char *atom, const char *end_atom, int starred)
5929 int i;
5930 int len = end_atom - atom;
5931 int plen = starred ? len : -1;
5933 for (i = 0; i < n_switches; i++)
5934 if (!strncmp (switches[i].part1, atom, len)
5935 && (starred || switches[i].part1[len] == '\0')
5936 && check_live_switch (i, plen))
5937 return true;
5939 /* Check if a switch with separated form matching the atom.
5940 We check -D and -U switches. */
5941 else if (switches[i].args != 0)
5943 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
5944 && *switches[i].part1 == atom[0])
5946 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
5947 && (starred || (switches[i].part1[1] == '\0'
5948 && switches[i].args[0][len - 1] == '\0'))
5949 && check_live_switch (i, (starred ? 1 : -1)))
5950 return true;
5954 return false;
5957 /* Inline subroutine of handle_braces. Mark all of the switches which
5958 match ATOM (extends to END_ATOM; STARRED indicates whether there
5959 was a star after the atom) for later processing. */
5960 static inline void
5961 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5963 int i;
5964 int len = end_atom - atom;
5965 int plen = starred ? len : -1;
5967 for (i = 0; i < n_switches; i++)
5968 if (!strncmp (switches[i].part1, atom, len)
5969 && (starred || switches[i].part1[len] == '\0')
5970 && check_live_switch (i, plen))
5971 switches[i].ordering = 1;
5974 /* Inline subroutine of handle_braces. Process all the currently
5975 marked switches through give_switch, and clear the marks. */
5976 static inline void
5977 process_marked_switches (void)
5979 int i;
5981 for (i = 0; i < n_switches; i++)
5982 if (switches[i].ordering == 1)
5984 switches[i].ordering = 0;
5985 give_switch (i, 0);
5989 /* Handle a %{ ... } construct. P points just inside the leading {.
5990 Returns a pointer one past the end of the brace block, or 0
5991 if we call do_spec_1 and that returns -1. */
5993 static const char *
5994 handle_braces (const char *p)
5996 const char *atom, *end_atom;
5997 const char *d_atom = NULL, *d_end_atom = NULL;
5998 const char *orig = p;
6000 bool a_is_suffix;
6001 bool a_is_spectype;
6002 bool a_is_starred;
6003 bool a_is_negated;
6004 bool a_matched;
6006 bool a_must_be_last = false;
6007 bool ordered_set = false;
6008 bool disjunct_set = false;
6009 bool disj_matched = false;
6010 bool disj_starred = true;
6011 bool n_way_choice = false;
6012 bool n_way_matched = false;
6014 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
6018 if (a_must_be_last)
6019 goto invalid;
6021 /* Scan one "atom" (S in the description above of %{}, possibly
6022 with '!', '.', '@', ',', or '*' modifiers). */
6023 a_matched = false;
6024 a_is_suffix = false;
6025 a_is_starred = false;
6026 a_is_negated = false;
6027 a_is_spectype = false;
6029 SKIP_WHITE ();
6030 if (*p == '!')
6031 p++, a_is_negated = true;
6033 SKIP_WHITE ();
6034 if (*p == '%' && p[1] == ':')
6036 atom = NULL;
6037 end_atom = NULL;
6038 p = handle_spec_function (p + 2, &a_matched);
6040 else
6042 if (*p == '.')
6043 p++, a_is_suffix = true;
6044 else if (*p == ',')
6045 p++, a_is_spectype = true;
6047 atom = p;
6048 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
6049 || *p == ',' || *p == '.' || *p == '@')
6050 p++;
6051 end_atom = p;
6053 if (*p == '*')
6054 p++, a_is_starred = 1;
6057 SKIP_WHITE ();
6058 switch (*p)
6060 case '&': case '}':
6061 /* Substitute the switch(es) indicated by the current atom. */
6062 ordered_set = true;
6063 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
6064 || a_is_spectype || atom == end_atom)
6065 goto invalid;
6067 mark_matching_switches (atom, end_atom, a_is_starred);
6069 if (*p == '}')
6070 process_marked_switches ();
6071 break;
6073 case '|': case ':':
6074 /* Substitute some text if the current atom appears as a switch
6075 or suffix. */
6076 disjunct_set = true;
6077 if (ordered_set)
6078 goto invalid;
6080 if (atom && atom == end_atom)
6082 if (!n_way_choice || disj_matched || *p == '|'
6083 || a_is_negated || a_is_suffix || a_is_spectype
6084 || a_is_starred)
6085 goto invalid;
6087 /* An empty term may appear as the last choice of an
6088 N-way choice set; it means "otherwise". */
6089 a_must_be_last = true;
6090 disj_matched = !n_way_matched;
6091 disj_starred = false;
6093 else
6095 if ((a_is_suffix || a_is_spectype) && a_is_starred)
6096 goto invalid;
6098 if (!a_is_starred)
6099 disj_starred = false;
6101 /* Don't bother testing this atom if we already have a
6102 match. */
6103 if (!disj_matched && !n_way_matched)
6105 if (atom == NULL)
6106 /* a_matched is already set by handle_spec_function. */;
6107 else if (a_is_suffix)
6108 a_matched = input_suffix_matches (atom, end_atom);
6109 else if (a_is_spectype)
6110 a_matched = input_spec_matches (atom, end_atom);
6111 else
6112 a_matched = switch_matches (atom, end_atom, a_is_starred);
6114 if (a_matched != a_is_negated)
6116 disj_matched = true;
6117 d_atom = atom;
6118 d_end_atom = end_atom;
6123 if (*p == ':')
6125 /* Found the body, that is, the text to substitute if the
6126 current disjunction matches. */
6127 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
6128 disj_matched && !n_way_matched);
6129 if (p == 0)
6130 return 0;
6132 /* If we have an N-way choice, reset state for the next
6133 disjunction. */
6134 if (*p == ';')
6136 n_way_choice = true;
6137 n_way_matched |= disj_matched;
6138 disj_matched = false;
6139 disj_starred = true;
6140 d_atom = d_end_atom = NULL;
6143 break;
6145 default:
6146 goto invalid;
6149 while (*p++ != '}');
6151 return p;
6153 invalid:
6154 fatal_error (input_location, "braced spec %qs is invalid at %qc", orig, *p);
6156 #undef SKIP_WHITE
6159 /* Subroutine of handle_braces. Scan and process a brace substitution body
6160 (X in the description of %{} syntax). P points one past the colon;
6161 ATOM and END_ATOM bracket the first atom which was found to be true
6162 (present) in the current disjunction; STARRED indicates whether all
6163 the atoms in the current disjunction were starred (for syntax validation);
6164 MATCHED indicates whether the disjunction matched or not, and therefore
6165 whether or not the body is to be processed through do_spec_1 or just
6166 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
6167 returns -1. */
6169 static const char *
6170 process_brace_body (const char *p, const char *atom, const char *end_atom,
6171 int starred, int matched)
6173 const char *body, *end_body;
6174 unsigned int nesting_level;
6175 bool have_subst = false;
6177 /* Locate the closing } or ;, honoring nested braces.
6178 Trim trailing whitespace. */
6179 body = p;
6180 nesting_level = 1;
6181 for (;;)
6183 if (*p == '{')
6184 nesting_level++;
6185 else if (*p == '}')
6187 if (!--nesting_level)
6188 break;
6190 else if (*p == ';' && nesting_level == 1)
6191 break;
6192 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
6193 have_subst = true;
6194 else if (*p == '\0')
6195 goto invalid;
6196 p++;
6199 end_body = p;
6200 while (end_body[-1] == ' ' || end_body[-1] == '\t')
6201 end_body--;
6203 if (have_subst && !starred)
6204 goto invalid;
6206 if (matched)
6208 /* Copy the substitution body to permanent storage and execute it.
6209 If have_subst is false, this is a simple matter of running the
6210 body through do_spec_1... */
6211 char *string = save_string (body, end_body - body);
6212 if (!have_subst)
6214 if (do_spec_1 (string, 0, NULL) < 0)
6215 return 0;
6217 else
6219 /* ... but if have_subst is true, we have to process the
6220 body once for each matching switch, with %* set to the
6221 variant part of the switch. */
6222 unsigned int hard_match_len = end_atom - atom;
6223 int i;
6225 for (i = 0; i < n_switches; i++)
6226 if (!strncmp (switches[i].part1, atom, hard_match_len)
6227 && check_live_switch (i, hard_match_len))
6229 if (do_spec_1 (string, 0,
6230 &switches[i].part1[hard_match_len]) < 0)
6231 return 0;
6232 /* Pass any arguments this switch has. */
6233 give_switch (i, 1);
6234 suffix_subst = NULL;
6239 return p;
6241 invalid:
6242 fatal_error (input_location, "braced spec body %qs is invalid", body);
6245 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
6246 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
6247 spec, or -1 if either exact match or %* is used.
6249 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
6250 whose value does not begin with "no-" is obsoleted by the same value
6251 with the "no-", similarly for a switch with the "no-" prefix. */
6253 static int
6254 check_live_switch (int switchnum, int prefix_length)
6256 const char *name = switches[switchnum].part1;
6257 int i;
6259 /* If we already processed this switch and determined if it was
6260 live or not, return our past determination. */
6261 if (switches[switchnum].live_cond != 0)
6262 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
6263 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
6264 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
6265 == 0);
6267 /* In the common case of {<at-most-one-letter>*}, a negating
6268 switch would always match, so ignore that case. We will just
6269 send the conflicting switches to the compiler phase. */
6270 if (prefix_length >= 0 && prefix_length <= 1)
6271 return 1;
6273 /* Now search for duplicate in a manner that depends on the name. */
6274 switch (*name)
6276 case 'O':
6277 for (i = switchnum + 1; i < n_switches; i++)
6278 if (switches[i].part1[0] == 'O')
6280 switches[switchnum].validated = true;
6281 switches[switchnum].live_cond = SWITCH_FALSE;
6282 return 0;
6284 break;
6286 case 'W': case 'f': case 'm': case 'g':
6287 if (! strncmp (name + 1, "no-", 3))
6289 /* We have Xno-YYY, search for XYYY. */
6290 for (i = switchnum + 1; i < n_switches; i++)
6291 if (switches[i].part1[0] == name[0]
6292 && ! strcmp (&switches[i].part1[1], &name[4]))
6294 /* --specs are validated with the validate_switches mechanism. */
6295 if (switches[switchnum].known)
6296 switches[switchnum].validated = true;
6297 switches[switchnum].live_cond = SWITCH_FALSE;
6298 return 0;
6301 else
6303 /* We have XYYY, search for Xno-YYY. */
6304 for (i = switchnum + 1; i < n_switches; i++)
6305 if (switches[i].part1[0] == name[0]
6306 && switches[i].part1[1] == 'n'
6307 && switches[i].part1[2] == 'o'
6308 && switches[i].part1[3] == '-'
6309 && !strcmp (&switches[i].part1[4], &name[1]))
6311 /* --specs are validated with the validate_switches mechanism. */
6312 if (switches[switchnum].known)
6313 switches[switchnum].validated = true;
6314 switches[switchnum].live_cond = SWITCH_FALSE;
6315 return 0;
6318 break;
6321 /* Otherwise the switch is live. */
6322 switches[switchnum].live_cond |= SWITCH_LIVE;
6323 return 1;
6326 /* Pass a switch to the current accumulating command
6327 in the same form that we received it.
6328 SWITCHNUM identifies the switch; it is an index into
6329 the vector of switches gcc received, which is `switches'.
6330 This cannot fail since it never finishes a command line.
6332 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
6334 static void
6335 give_switch (int switchnum, int omit_first_word)
6337 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
6338 return;
6340 if (!omit_first_word)
6342 do_spec_1 ("-", 0, NULL);
6343 do_spec_1 (switches[switchnum].part1, 1, NULL);
6346 if (switches[switchnum].args != 0)
6348 const char **p;
6349 for (p = switches[switchnum].args; *p; p++)
6351 const char *arg = *p;
6353 do_spec_1 (" ", 0, NULL);
6354 if (suffix_subst)
6356 unsigned length = strlen (arg);
6357 int dot = 0;
6359 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
6360 if (arg[length] == '.')
6362 (CONST_CAST (char *, arg))[length] = 0;
6363 dot = 1;
6364 break;
6366 do_spec_1 (arg, 1, NULL);
6367 if (dot)
6368 (CONST_CAST (char *, arg))[length] = '.';
6369 do_spec_1 (suffix_subst, 1, NULL);
6371 else
6372 do_spec_1 (arg, 1, NULL);
6376 do_spec_1 (" ", 0, NULL);
6377 switches[switchnum].validated = true;
6380 /* Print GCC configuration (e.g. version, thread model, target,
6381 configuration_arguments) to a given FILE. */
6383 static void
6384 print_configuration (FILE *file)
6386 int n;
6387 const char *thrmod;
6389 fnotice (file, "Target: %s\n", spec_machine);
6390 fnotice (file, "Configured with: %s\n", configuration_arguments);
6392 #ifdef THREAD_MODEL_SPEC
6393 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6394 but there's no point in doing all this processing just to get
6395 thread_model back. */
6396 obstack_init (&obstack);
6397 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6398 obstack_1grow (&obstack, '\0');
6399 thrmod = XOBFINISH (&obstack, const char *);
6400 #else
6401 thrmod = thread_model;
6402 #endif
6404 fnotice (file, "Thread model: %s\n", thrmod);
6406 /* compiler_version is truncated at the first space when initialized
6407 from version string, so truncate version_string at the first space
6408 before comparing. */
6409 for (n = 0; version_string[n]; n++)
6410 if (version_string[n] == ' ')
6411 break;
6413 if (! strncmp (version_string, compiler_version, n)
6414 && compiler_version[n] == 0)
6415 fnotice (file, "gcc version %s %s\n", version_string,
6416 pkgversion_string);
6417 else
6418 fnotice (file, "gcc driver version %s %sexecuting gcc version %s\n",
6419 version_string, pkgversion_string, compiler_version);
6423 #define RETRY_ICE_ATTEMPTS 3
6425 /* Returns true if FILE1 and FILE2 contain equivalent data, 0 otherwise. */
6427 static bool
6428 files_equal_p (char *file1, char *file2)
6430 struct stat st1, st2;
6431 off_t n, len;
6432 int fd1, fd2;
6433 const int bufsize = 8192;
6434 char *buf = XNEWVEC (char, bufsize);
6436 fd1 = open (file1, O_RDONLY);
6437 fd2 = open (file2, O_RDONLY);
6439 if (fd1 < 0 || fd2 < 0)
6440 goto error;
6442 if (fstat (fd1, &st1) < 0 || fstat (fd2, &st2) < 0)
6443 goto error;
6445 if (st1.st_size != st2.st_size)
6446 goto error;
6448 for (n = st1.st_size; n; n -= len)
6450 len = n;
6451 if ((int) len > bufsize / 2)
6452 len = bufsize / 2;
6454 if (read (fd1, buf, len) != (int) len
6455 || read (fd2, buf + bufsize / 2, len) != (int) len)
6457 goto error;
6460 if (memcmp (buf, buf + bufsize / 2, len) != 0)
6461 goto error;
6464 free (buf);
6465 close (fd1);
6466 close (fd2);
6468 return 1;
6470 error:
6471 free (buf);
6472 close (fd1);
6473 close (fd2);
6474 return 0;
6477 /* Check that compiler's output doesn't differ across runs.
6478 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are arrays of files, containing
6479 stdout and stderr for each compiler run. Return true if all of
6480 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are equivalent. */
6482 static bool
6483 check_repro (char **temp_stdout_files, char **temp_stderr_files)
6485 int i;
6486 for (i = 0; i < RETRY_ICE_ATTEMPTS - 2; ++i)
6488 if (!files_equal_p (temp_stdout_files[i], temp_stdout_files[i + 1])
6489 || !files_equal_p (temp_stderr_files[i], temp_stderr_files[i + 1]))
6491 fnotice (stderr, "The bug is not reproducible, so it is"
6492 " likely a hardware or OS problem.\n");
6493 break;
6496 return i == RETRY_ICE_ATTEMPTS - 2;
6499 enum attempt_status {
6500 ATTEMPT_STATUS_FAIL_TO_RUN,
6501 ATTEMPT_STATUS_SUCCESS,
6502 ATTEMPT_STATUS_ICE
6506 /* Run compiler with arguments NEW_ARGV to reproduce the ICE, storing stdout
6507 to OUT_TEMP and stderr to ERR_TEMP. If APPEND is TRUE, append to OUT_TEMP
6508 and ERR_TEMP instead of truncating. If EMIT_SYSTEM_INFO is TRUE, also write
6509 GCC configuration into to ERR_TEMP. Return ATTEMPT_STATUS_FAIL_TO_RUN if
6510 compiler failed to run, ATTEMPT_STATUS_ICE if compiled ICE-ed and
6511 ATTEMPT_STATUS_SUCCESS otherwise. */
6513 static enum attempt_status
6514 run_attempt (const char **new_argv, const char *out_temp,
6515 const char *err_temp, int emit_system_info, int append)
6518 if (emit_system_info)
6520 FILE *file_out = fopen (err_temp, "a");
6521 print_configuration (file_out);
6522 fputs ("\n", file_out);
6523 fclose (file_out);
6526 int exit_status;
6527 const char *errmsg;
6528 struct pex_obj *pex;
6529 int err;
6530 int pex_flags = PEX_USE_PIPES | PEX_LAST;
6531 enum attempt_status status = ATTEMPT_STATUS_FAIL_TO_RUN;
6533 if (append)
6534 pex_flags |= PEX_STDOUT_APPEND | PEX_STDERR_APPEND;
6536 pex = pex_init (PEX_USE_PIPES, new_argv[0], NULL);
6537 if (!pex)
6538 fatal_error (input_location, "pex_init failed: %m");
6540 errmsg = pex_run (pex, pex_flags, new_argv[0],
6541 CONST_CAST2 (char *const *, const char **, &new_argv[1]), out_temp,
6542 err_temp, &err);
6543 if (errmsg != NULL)
6545 if (err == 0)
6546 fatal_error (input_location, errmsg);
6547 else
6549 errno = err;
6550 pfatal_with_name (errmsg);
6554 if (!pex_get_status (pex, 1, &exit_status))
6555 goto out;
6557 switch (WEXITSTATUS (exit_status))
6559 case ICE_EXIT_CODE:
6560 status = ATTEMPT_STATUS_ICE;
6561 break;
6563 case SUCCESS_EXIT_CODE:
6564 status = ATTEMPT_STATUS_SUCCESS;
6565 break;
6567 default:
6571 out:
6572 pex_free (pex);
6573 return status;
6576 /* This routine reads lines from IN file, adds C++ style comments
6577 at the begining of each line and writes result into OUT. */
6579 static void
6580 insert_comments (const char *file_in, const char *file_out)
6582 FILE *in = fopen (file_in, "rb");
6583 FILE *out = fopen (file_out, "wb");
6584 char line[256];
6586 bool add_comment = true;
6587 while (fgets (line, sizeof (line), in))
6589 if (add_comment)
6590 fputs ("// ", out);
6591 fputs (line, out);
6592 add_comment = strchr (line, '\n') != NULL;
6595 fclose (in);
6596 fclose (out);
6599 /* This routine adds preprocessed source code into the given ERR_FILE.
6600 To do this, it adds "-E" to NEW_ARGV and execute RUN_ATTEMPT routine to
6601 add information in report file. RUN_ATTEMPT should return
6602 ATTEMPT_STATUS_SUCCESS, in other case we cannot generate the report. */
6604 static void
6605 do_report_bug (const char **new_argv, const int nargs,
6606 char **out_file, char **err_file)
6608 int i, status;
6609 int fd = open (*out_file, O_RDWR | O_APPEND);
6610 if (fd < 0)
6611 return;
6612 write (fd, "\n//", 3);
6613 for (i = 0; i < nargs; i++)
6615 write (fd, " ", 1);
6616 write (fd, new_argv[i], strlen (new_argv[i]));
6618 write (fd, "\n\n", 2);
6619 close (fd);
6620 new_argv[nargs] = "-E";
6621 new_argv[nargs + 1] = NULL;
6623 status = run_attempt (new_argv, *out_file, *err_file, 0, 1);
6625 if (status == ATTEMPT_STATUS_SUCCESS)
6627 fnotice (stderr, "Preprocessed source stored into %s file,"
6628 " please attach this to your bugreport.\n", *out_file);
6629 /* Make sure it is not deleted. */
6630 free (*out_file);
6631 *out_file = NULL;
6635 /* Try to reproduce ICE. If bug is reproducible, generate report .err file
6636 containing GCC configuration, backtrace, compiler's command line options
6637 and preprocessed source code. */
6639 static void
6640 try_generate_repro (const char **argv)
6642 int i, nargs, out_arg = -1, quiet = 0, attempt;
6643 const char **new_argv;
6644 char *temp_files[RETRY_ICE_ATTEMPTS * 2];
6645 char **temp_stdout_files = &temp_files[0];
6646 char **temp_stderr_files = &temp_files[RETRY_ICE_ATTEMPTS];
6648 if (gcc_input_filename == NULL || ! strcmp (gcc_input_filename, "-"))
6649 return;
6651 for (nargs = 0; argv[nargs] != NULL; ++nargs)
6652 /* Only retry compiler ICEs, not preprocessor ones. */
6653 if (! strcmp (argv[nargs], "-E"))
6654 return;
6655 else if (argv[nargs][0] == '-' && argv[nargs][1] == 'o')
6657 if (out_arg == -1)
6658 out_arg = nargs;
6659 else
6660 return;
6662 /* If the compiler is going to output any time information,
6663 it might varry between invocations. */
6664 else if (! strcmp (argv[nargs], "-quiet"))
6665 quiet = 1;
6666 else if (! strcmp (argv[nargs], "-ftime-report"))
6667 return;
6669 if (out_arg == -1 || !quiet)
6670 return;
6672 memset (temp_files, '\0', sizeof (temp_files));
6673 new_argv = XALLOCAVEC (const char *, nargs + 4);
6674 memcpy (new_argv, argv, (nargs + 1) * sizeof (const char *));
6675 new_argv[nargs++] = "-frandom-seed=0";
6676 new_argv[nargs++] = "-fdump-noaddr";
6677 new_argv[nargs] = NULL;
6678 if (new_argv[out_arg][2] == '\0')
6679 new_argv[out_arg + 1] = "-";
6680 else
6681 new_argv[out_arg] = "-o-";
6683 int status;
6684 for (attempt = 0; attempt < RETRY_ICE_ATTEMPTS; ++attempt)
6686 int emit_system_info = 0;
6687 int append = 0;
6688 temp_stdout_files[attempt] = make_temp_file (".out");
6689 temp_stderr_files[attempt] = make_temp_file (".err");
6691 if (attempt == RETRY_ICE_ATTEMPTS - 1)
6693 append = 1;
6694 emit_system_info = 1;
6697 status = run_attempt (new_argv, temp_stdout_files[attempt],
6698 temp_stderr_files[attempt], emit_system_info,
6699 append);
6701 if (status != ATTEMPT_STATUS_ICE)
6703 fnotice (stderr, "The bug is not reproducible, so it is"
6704 " likely a hardware or OS problem.\n");
6705 goto out;
6709 if (!check_repro (temp_stdout_files, temp_stderr_files))
6710 goto out;
6713 /* Insert commented out backtrace into report file. */
6714 char **stderr_commented = &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1];
6715 insert_comments (temp_stderr_files[RETRY_ICE_ATTEMPTS - 1],
6716 *stderr_commented);
6718 /* In final attempt we append compiler options and preprocesssed code to last
6719 generated .out file with configuration and backtrace. */
6720 char **output = &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1];
6721 do_report_bug (new_argv, nargs, stderr_commented, output);
6724 out:
6725 for (i = 0; i < RETRY_ICE_ATTEMPTS * 2; i++)
6726 if (temp_files[i])
6728 unlink (temp_stdout_files[i]);
6729 free (temp_stdout_files[i]);
6733 /* Search for a file named NAME trying various prefixes including the
6734 user's -B prefix and some standard ones.
6735 Return the absolute file name found. If nothing is found, return NAME. */
6737 static const char *
6738 find_file (const char *name)
6740 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
6741 return newname ? newname : name;
6744 /* Determine whether a directory exists. If LINKER, return 0 for
6745 certain fixed names not needed by the linker. */
6747 static int
6748 is_directory (const char *path1, bool linker)
6750 int len1;
6751 char *path;
6752 char *cp;
6753 struct stat st;
6755 /* Ensure the string ends with "/.". The resulting path will be a
6756 directory even if the given path is a symbolic link. */
6757 len1 = strlen (path1);
6758 path = (char *) alloca (3 + len1);
6759 memcpy (path, path1, len1);
6760 cp = path + len1;
6761 if (!IS_DIR_SEPARATOR (cp[-1]))
6762 *cp++ = DIR_SEPARATOR;
6763 *cp++ = '.';
6764 *cp = '\0';
6766 /* Exclude directories that the linker is known to search. */
6767 if (linker
6768 && IS_DIR_SEPARATOR (path[0])
6769 && ((cp - path == 6
6770 && filename_ncmp (path + 1, "lib", 3) == 0)
6771 || (cp - path == 10
6772 && filename_ncmp (path + 1, "usr", 3) == 0
6773 && IS_DIR_SEPARATOR (path[4])
6774 && filename_ncmp (path + 5, "lib", 3) == 0)))
6775 return 0;
6777 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
6780 /* Set up the various global variables to indicate that we're processing
6781 the input file named FILENAME. */
6783 void
6784 set_input (const char *filename)
6786 const char *p;
6788 gcc_input_filename = filename;
6789 input_filename_length = strlen (gcc_input_filename);
6790 input_basename = lbasename (gcc_input_filename);
6792 /* Find a suffix starting with the last period,
6793 and set basename_length to exclude that suffix. */
6794 basename_length = strlen (input_basename);
6795 suffixed_basename_length = basename_length;
6796 p = input_basename + basename_length;
6797 while (p != input_basename && *p != '.')
6798 --p;
6799 if (*p == '.' && p != input_basename)
6801 basename_length = p - input_basename;
6802 input_suffix = p + 1;
6804 else
6805 input_suffix = "";
6807 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6808 we will need to do a stat on the gcc_input_filename. The
6809 INPUT_STAT_SET signals that the stat is needed. */
6810 input_stat_set = 0;
6813 /* On fatal signals, delete all the temporary files. */
6815 static void
6816 fatal_signal (int signum)
6818 signal (signum, SIG_DFL);
6819 delete_failure_queue ();
6820 delete_temp_files ();
6821 /* Get the same signal again, this time not handled,
6822 so its normal effect occurs. */
6823 kill (getpid (), signum);
6826 /* Compare the contents of the two files named CMPFILE[0] and
6827 CMPFILE[1]. Return zero if they're identical, nonzero
6828 otherwise. */
6830 static int
6831 compare_files (char *cmpfile[])
6833 int ret = 0;
6834 FILE *temp[2] = { NULL, NULL };
6835 int i;
6837 #if HAVE_MMAP_FILE
6839 size_t length[2];
6840 void *map[2] = { NULL, NULL };
6842 for (i = 0; i < 2; i++)
6844 struct stat st;
6846 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
6848 error ("%s: could not determine length of compare-debug file %s",
6849 gcc_input_filename, cmpfile[i]);
6850 ret = 1;
6851 break;
6854 length[i] = st.st_size;
6857 if (!ret && length[0] != length[1])
6859 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
6860 ret = 1;
6863 if (!ret)
6864 for (i = 0; i < 2; i++)
6866 int fd = open (cmpfile[i], O_RDONLY);
6867 if (fd < 0)
6869 error ("%s: could not open compare-debug file %s",
6870 gcc_input_filename, cmpfile[i]);
6871 ret = 1;
6872 break;
6875 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
6876 close (fd);
6878 if (map[i] == (void *) MAP_FAILED)
6880 ret = -1;
6881 break;
6885 if (!ret)
6887 if (memcmp (map[0], map[1], length[0]) != 0)
6889 error ("%s: -fcompare-debug failure", gcc_input_filename);
6890 ret = 1;
6894 for (i = 0; i < 2; i++)
6895 if (map[i])
6896 munmap ((caddr_t) map[i], length[i]);
6898 if (ret >= 0)
6899 return ret;
6901 ret = 0;
6903 #endif
6905 for (i = 0; i < 2; i++)
6907 temp[i] = fopen (cmpfile[i], "r");
6908 if (!temp[i])
6910 error ("%s: could not open compare-debug file %s",
6911 gcc_input_filename, cmpfile[i]);
6912 ret = 1;
6913 break;
6917 if (!ret && temp[0] && temp[1])
6918 for (;;)
6920 int c0, c1;
6921 c0 = fgetc (temp[0]);
6922 c1 = fgetc (temp[1]);
6924 if (c0 != c1)
6926 error ("%s: -fcompare-debug failure",
6927 gcc_input_filename);
6928 ret = 1;
6929 break;
6932 if (c0 == EOF)
6933 break;
6936 for (i = 1; i >= 0; i--)
6938 if (temp[i])
6939 fclose (temp[i]);
6942 return ret;
6945 /* driver::main is implemented as a series of driver:: method calls. */
6948 driver::main (int argc, char **argv)
6950 bool early_exit;
6952 set_progname (argv[0]);
6953 expand_at_files (&argc, &argv);
6954 decode_argv (argc, const_cast <const char **> (argv));
6955 global_initializations ();
6956 build_multilib_strings ();
6957 set_up_specs ();
6958 putenv_COLLECT_GCC (argv[0]);
6959 maybe_putenv_COLLECT_LTO_WRAPPER ();
6960 maybe_putenv_OFFLOAD_TARGETS ();
6961 handle_unrecognized_options ();
6963 if (!maybe_print_and_exit ())
6964 return 0;
6966 early_exit = prepare_infiles ();
6967 if (early_exit)
6968 return get_exit_code ();
6970 do_spec_on_infiles ();
6971 maybe_run_linker (argv[0]);
6972 final_actions ();
6973 return get_exit_code ();
6976 /* Locate the final component of argv[0] after any leading path, and set
6977 the program name accordingly. */
6979 void
6980 driver::set_progname (const char *argv0) const
6982 const char *p = argv0 + strlen (argv0);
6983 while (p != argv0 && !IS_DIR_SEPARATOR (p[-1]))
6984 --p;
6985 progname = p;
6987 xmalloc_set_program_name (progname);
6990 /* Expand any @ files within the command-line args,
6991 setting at_file_supplied if any were expanded. */
6993 void
6994 driver::expand_at_files (int *argc, char ***argv) const
6996 char **old_argv = *argv;
6998 expandargv (argc, argv);
7000 /* Determine if any expansions were made. */
7001 if (*argv != old_argv)
7002 at_file_supplied = true;
7005 /* Decode the command-line arguments from argc/argv into the
7006 decoded_options array. */
7008 void
7009 driver::decode_argv (int argc, const char **argv)
7011 /* Register the language-independent parameters. */
7012 global_init_params ();
7013 finish_params ();
7015 init_options_struct (&global_options, &global_options_set);
7017 decode_cmdline_options_to_array (argc, argv,
7018 CL_DRIVER,
7019 &decoded_options, &decoded_options_count);
7022 /* Perform various initializations and setup. */
7024 void
7025 driver::global_initializations ()
7027 /* Unlock the stdio streams. */
7028 unlock_std_streams ();
7030 gcc_init_libintl ();
7032 diagnostic_initialize (global_dc, 0);
7033 diagnostic_color_init (global_dc);
7035 #ifdef GCC_DRIVER_HOST_INITIALIZATION
7036 /* Perform host dependent initialization when needed. */
7037 GCC_DRIVER_HOST_INITIALIZATION;
7038 #endif
7040 if (atexit (delete_temp_files) != 0)
7041 fatal_error (input_location, "atexit failed");
7043 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
7044 signal (SIGINT, fatal_signal);
7045 #ifdef SIGHUP
7046 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
7047 signal (SIGHUP, fatal_signal);
7048 #endif
7049 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
7050 signal (SIGTERM, fatal_signal);
7051 #ifdef SIGPIPE
7052 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
7053 signal (SIGPIPE, fatal_signal);
7054 #endif
7055 #ifdef SIGCHLD
7056 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
7057 receive the signal. A different setting is inheritable */
7058 signal (SIGCHLD, SIG_DFL);
7059 #endif
7061 /* Parsing and gimplification sometimes need quite large stack.
7062 Increase stack size limits if possible. */
7063 stack_limit_increase (64 * 1024 * 1024);
7065 /* Allocate the argument vector. */
7066 alloc_args ();
7068 obstack_init (&obstack);
7071 /* Build multilib_select, et. al from the separate lines that make up each
7072 multilib selection. */
7074 void
7075 driver::build_multilib_strings () const
7078 const char *p;
7079 const char *const *q = multilib_raw;
7080 int need_space;
7082 obstack_init (&multilib_obstack);
7083 while ((p = *q++) != (char *) 0)
7084 obstack_grow (&multilib_obstack, p, strlen (p));
7086 obstack_1grow (&multilib_obstack, 0);
7087 multilib_select = XOBFINISH (&multilib_obstack, const char *);
7089 q = multilib_matches_raw;
7090 while ((p = *q++) != (char *) 0)
7091 obstack_grow (&multilib_obstack, p, strlen (p));
7093 obstack_1grow (&multilib_obstack, 0);
7094 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
7096 q = multilib_exclusions_raw;
7097 while ((p = *q++) != (char *) 0)
7098 obstack_grow (&multilib_obstack, p, strlen (p));
7100 obstack_1grow (&multilib_obstack, 0);
7101 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
7103 q = multilib_reuse_raw;
7104 while ((p = *q++) != (char *) 0)
7105 obstack_grow (&multilib_obstack, p, strlen (p));
7107 obstack_1grow (&multilib_obstack, 0);
7108 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
7110 need_space = FALSE;
7111 for (size_t i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
7113 if (need_space)
7114 obstack_1grow (&multilib_obstack, ' ');
7115 obstack_grow (&multilib_obstack,
7116 multilib_defaults_raw[i],
7117 strlen (multilib_defaults_raw[i]));
7118 need_space = TRUE;
7121 obstack_1grow (&multilib_obstack, 0);
7122 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
7126 /* Set up the spec-handling machinery. */
7128 void
7129 driver::set_up_specs () const
7131 const char *spec_machine_suffix;
7132 char *specs_file;
7133 size_t i;
7135 #ifdef INIT_ENVIRONMENT
7136 /* Set up any other necessary machine specific environment variables. */
7137 xputenv (INIT_ENVIRONMENT);
7138 #endif
7140 /* Make a table of what switches there are (switches, n_switches).
7141 Make a table of specified input files (infiles, n_infiles).
7142 Decode switches that are handled locally. */
7144 process_command (decoded_options_count, decoded_options);
7146 /* Initialize the vector of specs to just the default.
7147 This means one element containing 0s, as a terminator. */
7149 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
7150 memcpy (compilers, default_compilers, sizeof default_compilers);
7151 n_compilers = n_default_compilers;
7153 /* Read specs from a file if there is one. */
7155 machine_suffix = concat (spec_host_machine, dir_separator_str, spec_version,
7156 accel_dir_suffix, dir_separator_str, NULL);
7157 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
7159 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
7160 /* Read the specs file unless it is a default one. */
7161 if (specs_file != 0 && strcmp (specs_file, "specs"))
7162 read_specs (specs_file, true, false);
7163 else
7164 init_spec ();
7166 #ifdef ACCEL_COMPILER
7167 spec_machine_suffix = machine_suffix;
7168 #else
7169 spec_machine_suffix = just_machine_suffix;
7170 #endif
7172 /* We need to check standard_exec_prefix/spec_machine_suffix/specs
7173 for any override of as, ld and libraries. */
7174 specs_file = (char *) alloca (strlen (standard_exec_prefix)
7175 + strlen (spec_machine_suffix) + sizeof ("specs"));
7176 strcpy (specs_file, standard_exec_prefix);
7177 strcat (specs_file, spec_machine_suffix);
7178 strcat (specs_file, "specs");
7179 if (access (specs_file, R_OK) == 0)
7180 read_specs (specs_file, true, false);
7182 /* Process any configure-time defaults specified for the command line
7183 options, via OPTION_DEFAULT_SPECS. */
7184 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
7185 do_option_spec (option_default_specs[i].name,
7186 option_default_specs[i].spec);
7188 /* Process DRIVER_SELF_SPECS, adding any new options to the end
7189 of the command line. */
7191 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
7192 do_self_spec (driver_self_specs[i]);
7194 /* If not cross-compiling, look for executables in the standard
7195 places. */
7196 if (*cross_compile == '0')
7198 if (*md_exec_prefix)
7200 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
7201 PREFIX_PRIORITY_LAST, 0, 0);
7205 /* Process sysroot_suffix_spec. */
7206 if (*sysroot_suffix_spec != 0
7207 && !no_sysroot_suffix
7208 && do_spec_2 (sysroot_suffix_spec) == 0)
7210 if (argbuf.length () > 1)
7211 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
7212 else if (argbuf.length () == 1)
7213 target_sysroot_suffix = xstrdup (argbuf.last ());
7216 #ifdef HAVE_LD_SYSROOT
7217 /* Pass the --sysroot option to the linker, if it supports that. If
7218 there is a sysroot_suffix_spec, it has already been processed by
7219 this point, so target_system_root really is the system root we
7220 should be using. */
7221 if (target_system_root)
7223 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
7224 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
7225 set_spec ("link", XOBFINISH (&obstack, const char *), false);
7227 #endif
7229 /* Process sysroot_hdrs_suffix_spec. */
7230 if (*sysroot_hdrs_suffix_spec != 0
7231 && !no_sysroot_suffix
7232 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
7234 if (argbuf.length () > 1)
7235 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
7236 else if (argbuf.length () == 1)
7237 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
7240 /* Look for startfiles in the standard places. */
7241 if (*startfile_prefix_spec != 0
7242 && do_spec_2 (startfile_prefix_spec) == 0
7243 && do_spec_1 (" ", 0, NULL) == 0)
7245 const char *arg;
7246 int ndx;
7247 FOR_EACH_VEC_ELT (argbuf, ndx, arg)
7248 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
7249 PREFIX_PRIORITY_LAST, 0, 1);
7251 /* We should eventually get rid of all these and stick to
7252 startfile_prefix_spec exclusively. */
7253 else if (*cross_compile == '0' || target_system_root)
7255 if (*md_startfile_prefix)
7256 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
7257 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7259 if (*md_startfile_prefix_1)
7260 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
7261 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7263 /* If standard_startfile_prefix is relative, base it on
7264 standard_exec_prefix. This lets us move the installed tree
7265 as a unit. If GCC_EXEC_PREFIX is defined, base
7266 standard_startfile_prefix on that as well.
7268 If the prefix is relative, only search it for native compilers;
7269 otherwise we will search a directory containing host libraries. */
7270 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
7271 add_sysrooted_prefix (&startfile_prefixes,
7272 standard_startfile_prefix, "BINUTILS",
7273 PREFIX_PRIORITY_LAST, 0, 1);
7274 else if (*cross_compile == '0')
7276 add_prefix (&startfile_prefixes,
7277 concat (gcc_exec_prefix
7278 ? gcc_exec_prefix : standard_exec_prefix,
7279 machine_suffix,
7280 standard_startfile_prefix, NULL),
7281 NULL, PREFIX_PRIORITY_LAST, 0, 1);
7284 /* Sysrooted prefixes are relocated because target_system_root is
7285 also relocated by gcc_exec_prefix. */
7286 if (*standard_startfile_prefix_1)
7287 add_sysrooted_prefix (&startfile_prefixes,
7288 standard_startfile_prefix_1, "BINUTILS",
7289 PREFIX_PRIORITY_LAST, 0, 1);
7290 if (*standard_startfile_prefix_2)
7291 add_sysrooted_prefix (&startfile_prefixes,
7292 standard_startfile_prefix_2, "BINUTILS",
7293 PREFIX_PRIORITY_LAST, 0, 1);
7296 /* Process any user specified specs in the order given on the command
7297 line. */
7298 for (struct user_specs *uptr = user_specs_head; uptr; uptr = uptr->next)
7300 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
7301 R_OK, true);
7302 read_specs (filename ? filename : uptr->filename, false, true);
7305 /* Process any user self specs. */
7307 struct spec_list *sl;
7308 for (sl = specs; sl; sl = sl->next)
7309 if (sl->name_len == sizeof "self_spec" - 1
7310 && !strcmp (sl->name, "self_spec"))
7311 do_self_spec (*sl->ptr_spec);
7314 if (compare_debug)
7316 enum save_temps save;
7318 if (!compare_debug_second)
7320 n_switches_debug_check[1] = n_switches;
7321 n_switches_alloc_debug_check[1] = n_switches_alloc;
7322 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
7323 n_switches_alloc);
7325 do_self_spec ("%:compare-debug-self-opt()");
7326 n_switches_debug_check[0] = n_switches;
7327 n_switches_alloc_debug_check[0] = n_switches_alloc;
7328 switches_debug_check[0] = switches;
7330 n_switches = n_switches_debug_check[1];
7331 n_switches_alloc = n_switches_alloc_debug_check[1];
7332 switches = switches_debug_check[1];
7335 /* Avoid crash when computing %j in this early. */
7336 save = save_temps_flag;
7337 save_temps_flag = SAVE_TEMPS_NONE;
7339 compare_debug = -compare_debug;
7340 do_self_spec ("%:compare-debug-self-opt()");
7342 save_temps_flag = save;
7344 if (!compare_debug_second)
7346 n_switches_debug_check[1] = n_switches;
7347 n_switches_alloc_debug_check[1] = n_switches_alloc;
7348 switches_debug_check[1] = switches;
7349 compare_debug = -compare_debug;
7350 n_switches = n_switches_debug_check[0];
7351 n_switches_alloc = n_switches_debug_check[0];
7352 switches = switches_debug_check[0];
7357 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
7358 if (gcc_exec_prefix)
7359 gcc_exec_prefix = concat (gcc_exec_prefix, spec_host_machine,
7360 dir_separator_str, spec_version,
7361 accel_dir_suffix, dir_separator_str, NULL);
7363 /* Now we have the specs.
7364 Set the `valid' bits for switches that match anything in any spec. */
7366 validate_all_switches ();
7368 /* Now that we have the switches and the specs, set
7369 the subdirectory based on the options. */
7370 set_multilib_dir ();
7373 /* Set up to remember the pathname of gcc and any options
7374 needed for collect. We use argv[0] instead of progname because
7375 we need the complete pathname. */
7377 void
7378 driver::putenv_COLLECT_GCC (const char *argv0) const
7380 obstack_init (&collect_obstack);
7381 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
7382 obstack_grow (&collect_obstack, argv0, strlen (argv0) + 1);
7383 xputenv (XOBFINISH (&collect_obstack, char *));
7386 /* Set up to remember the pathname of the lto wrapper. */
7388 void
7389 driver::maybe_putenv_COLLECT_LTO_WRAPPER () const
7391 char *lto_wrapper_file;
7393 if (have_c)
7394 lto_wrapper_file = NULL;
7395 else
7396 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
7397 X_OK, false);
7398 if (lto_wrapper_file)
7400 lto_wrapper_file = convert_white_space (lto_wrapper_file);
7401 lto_wrapper_spec = lto_wrapper_file;
7402 obstack_init (&collect_obstack);
7403 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
7404 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
7405 obstack_grow (&collect_obstack, lto_wrapper_spec,
7406 strlen (lto_wrapper_spec) + 1);
7407 xputenv (XOBFINISH (&collect_obstack, char *));
7412 /* Set up to remember the names of offload targets. */
7414 void
7415 driver::maybe_putenv_OFFLOAD_TARGETS () const
7417 const char *targets = offload_targets;
7419 /* If no targets specified by -foffload, use all available targets. */
7420 if (!targets)
7421 targets = OFFLOAD_TARGETS;
7423 if (strlen (targets) > 0)
7425 obstack_grow (&collect_obstack, "OFFLOAD_TARGET_NAMES=",
7426 sizeof ("OFFLOAD_TARGET_NAMES=") - 1);
7427 obstack_grow (&collect_obstack, targets,
7428 strlen (targets) + 1);
7429 xputenv (XOBFINISH (&collect_obstack, char *));
7432 free (offload_targets);
7435 /* Reject switches that no pass was interested in. */
7437 void
7438 driver::handle_unrecognized_options () const
7440 for (size_t i = 0; (int) i < n_switches; i++)
7441 if (! switches[i].validated)
7442 error ("unrecognized command line option %<-%s%>", switches[i].part1);
7445 /* Handle the various -print-* options, returning 0 if the driver
7446 should exit, or nonzero if the driver should continue. */
7449 driver::maybe_print_and_exit () const
7451 if (print_search_dirs)
7453 printf (_("install: %s%s\n"),
7454 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
7455 gcc_exec_prefix ? "" : machine_suffix);
7456 printf (_("programs: %s\n"),
7457 build_search_list (&exec_prefixes, "", false, false));
7458 printf (_("libraries: %s\n"),
7459 build_search_list (&startfile_prefixes, "", false, true));
7460 return (0);
7463 if (print_file_name)
7465 printf ("%s\n", find_file (print_file_name));
7466 return (0);
7469 if (print_prog_name)
7471 if (use_ld != NULL && ! strcmp (print_prog_name, "ld"))
7473 /* Append USE_LD to the default linker. */
7474 #ifdef DEFAULT_LINKER
7475 char *ld;
7476 # ifdef HAVE_HOST_EXECUTABLE_SUFFIX
7477 int len = (sizeof (DEFAULT_LINKER)
7478 - sizeof (HOST_EXECUTABLE_SUFFIX));
7479 ld = NULL;
7480 if (len > 0)
7482 char *default_linker = xstrdup (DEFAULT_LINKER);
7483 /* Strip HOST_EXECUTABLE_SUFFIX if DEFAULT_LINKER contains
7484 HOST_EXECUTABLE_SUFFIX. */
7485 if (! strcmp (&default_linker[len], HOST_EXECUTABLE_SUFFIX))
7487 default_linker[len] = '\0';
7488 ld = concat (default_linker, use_ld,
7489 HOST_EXECUTABLE_SUFFIX, NULL);
7492 if (ld == NULL)
7493 # endif
7494 ld = concat (DEFAULT_LINKER, use_ld, NULL);
7495 if (access (ld, X_OK) == 0)
7497 printf ("%s\n", ld);
7498 return (0);
7500 #endif
7501 print_prog_name = concat (print_prog_name, use_ld, NULL);
7503 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
7504 printf ("%s\n", (newname ? newname : print_prog_name));
7505 return (0);
7508 if (print_multi_lib)
7510 print_multilib_info ();
7511 return (0);
7514 if (print_multi_directory)
7516 if (multilib_dir == NULL)
7517 printf (".\n");
7518 else
7519 printf ("%s\n", multilib_dir);
7520 return (0);
7523 if (print_multiarch)
7525 if (multiarch_dir == NULL)
7526 printf ("\n");
7527 else
7528 printf ("%s\n", multiarch_dir);
7529 return (0);
7532 if (print_sysroot)
7534 if (target_system_root)
7536 if (target_sysroot_suffix)
7537 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
7538 else
7539 printf ("%s\n", target_system_root);
7541 return (0);
7544 if (print_multi_os_directory)
7546 if (multilib_os_dir == NULL)
7547 printf (".\n");
7548 else
7549 printf ("%s\n", multilib_os_dir);
7550 return (0);
7553 if (print_sysroot_headers_suffix)
7555 if (*sysroot_hdrs_suffix_spec)
7557 printf("%s\n", (target_sysroot_hdrs_suffix
7558 ? target_sysroot_hdrs_suffix
7559 : ""));
7560 return (0);
7562 else
7563 /* The error status indicates that only one set of fixed
7564 headers should be built. */
7565 fatal_error (input_location,
7566 "not configured with sysroot headers suffix");
7569 if (print_help_list)
7571 display_help ();
7573 if (! verbose_flag)
7575 printf (_("\nFor bug reporting instructions, please see:\n"));
7576 printf ("%s.\n", bug_report_url);
7578 return (0);
7581 /* We do not exit here. Instead we have created a fake input file
7582 called 'help-dummy' which needs to be compiled, and we pass this
7583 on the various sub-processes, along with the --help switch.
7584 Ensure their output appears after ours. */
7585 fputc ('\n', stdout);
7586 fflush (stdout);
7589 if (print_version)
7591 printf (_("%s %s%s\n"), progname, pkgversion_string,
7592 version_string);
7593 printf ("Copyright %s 2015 Free Software Foundation, Inc.\n",
7594 _("(C)"));
7595 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
7596 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
7597 stdout);
7598 if (! verbose_flag)
7599 return 0;
7601 /* We do not exit here. We use the same mechanism of --help to print
7602 the version of the sub-processes. */
7603 fputc ('\n', stdout);
7604 fflush (stdout);
7607 if (verbose_flag)
7609 print_configuration (stderr);
7610 if (n_infiles == 0)
7611 return (0);
7614 return 1;
7617 /* Figure out what to do with each input file.
7618 Return true if we need to exit early from "main", false otherwise. */
7620 bool
7621 driver::prepare_infiles ()
7623 size_t i;
7624 int lang_n_infiles = 0;
7626 if (n_infiles == added_libraries)
7627 fatal_error (input_location, "no input files");
7629 if (seen_error ())
7630 /* Early exit needed from main. */
7631 return true;
7633 /* Make a place to record the compiler output file names
7634 that correspond to the input files. */
7636 i = n_infiles;
7637 i += lang_specific_extra_outfiles;
7638 outfiles = XCNEWVEC (const char *, i);
7640 /* Record which files were specified explicitly as link input. */
7642 explicit_link_files = XCNEWVEC (char, n_infiles);
7644 combine_inputs = have_o || flag_wpa;
7646 for (i = 0; (int) i < n_infiles; i++)
7648 const char *name = infiles[i].name;
7649 struct compiler *compiler = lookup_compiler (name,
7650 strlen (name),
7651 infiles[i].language);
7653 if (compiler && !(compiler->combinable))
7654 combine_inputs = false;
7656 if (lang_n_infiles > 0 && compiler != input_file_compiler
7657 && infiles[i].language && infiles[i].language[0] != '*')
7658 infiles[i].incompiler = compiler;
7659 else if (compiler)
7661 lang_n_infiles++;
7662 input_file_compiler = compiler;
7663 infiles[i].incompiler = compiler;
7665 else
7667 /* Since there is no compiler for this input file, assume it is a
7668 linker file. */
7669 explicit_link_files[i] = 1;
7670 infiles[i].incompiler = NULL;
7672 infiles[i].compiled = false;
7673 infiles[i].preprocessed = false;
7676 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
7677 fatal_error (input_location,
7678 "cannot specify -o with -c, -S or -E with multiple files");
7680 /* No early exit needed from main; we can continue. */
7681 return false;
7684 /* Run the spec machinery on each input file. */
7686 void
7687 driver::do_spec_on_infiles () const
7689 size_t i;
7691 for (i = 0; (int) i < n_infiles; i++)
7693 int this_file_error = 0;
7695 /* Tell do_spec what to substitute for %i. */
7697 input_file_number = i;
7698 set_input (infiles[i].name);
7700 if (infiles[i].compiled)
7701 continue;
7703 /* Use the same thing in %o, unless cp->spec says otherwise. */
7705 outfiles[i] = gcc_input_filename;
7707 /* Figure out which compiler from the file's suffix. */
7709 input_file_compiler
7710 = lookup_compiler (infiles[i].name, input_filename_length,
7711 infiles[i].language);
7713 if (input_file_compiler)
7715 /* Ok, we found an applicable compiler. Run its spec. */
7717 if (input_file_compiler->spec[0] == '#')
7719 error ("%s: %s compiler not installed on this system",
7720 gcc_input_filename, &input_file_compiler->spec[1]);
7721 this_file_error = 1;
7723 else
7725 int value;
7727 if (compare_debug)
7729 free (debug_check_temp_file[0]);
7730 debug_check_temp_file[0] = NULL;
7732 free (debug_check_temp_file[1]);
7733 debug_check_temp_file[1] = NULL;
7736 value = do_spec (input_file_compiler->spec);
7737 infiles[i].compiled = true;
7738 if (value < 0)
7739 this_file_error = 1;
7740 else if (compare_debug && debug_check_temp_file[0])
7742 if (verbose_flag)
7743 inform (0, "recompiling with -fcompare-debug");
7745 compare_debug = -compare_debug;
7746 n_switches = n_switches_debug_check[1];
7747 n_switches_alloc = n_switches_alloc_debug_check[1];
7748 switches = switches_debug_check[1];
7750 value = do_spec (input_file_compiler->spec);
7752 compare_debug = -compare_debug;
7753 n_switches = n_switches_debug_check[0];
7754 n_switches_alloc = n_switches_alloc_debug_check[0];
7755 switches = switches_debug_check[0];
7757 if (value < 0)
7759 error ("during -fcompare-debug recompilation");
7760 this_file_error = 1;
7763 gcc_assert (debug_check_temp_file[1]
7764 && filename_cmp (debug_check_temp_file[0],
7765 debug_check_temp_file[1]));
7767 if (verbose_flag)
7768 inform (0, "comparing final insns dumps");
7770 if (compare_files (debug_check_temp_file))
7771 this_file_error = 1;
7774 if (compare_debug)
7776 free (debug_check_temp_file[0]);
7777 debug_check_temp_file[0] = NULL;
7779 free (debug_check_temp_file[1]);
7780 debug_check_temp_file[1] = NULL;
7785 /* If this file's name does not contain a recognized suffix,
7786 record it as explicit linker input. */
7788 else
7789 explicit_link_files[i] = 1;
7791 /* Clear the delete-on-failure queue, deleting the files in it
7792 if this compilation failed. */
7794 if (this_file_error)
7796 delete_failure_queue ();
7797 errorcount++;
7799 /* If this compilation succeeded, don't delete those files later. */
7800 clear_failure_queue ();
7803 /* Reset the input file name to the first compile/object file name, for use
7804 with %b in LINK_SPEC. We use the first input file that we can find
7805 a compiler to compile it instead of using infiles.language since for
7806 languages other than C we use aliases that we then lookup later. */
7807 if (n_infiles > 0)
7809 int i;
7811 for (i = 0; i < n_infiles ; i++)
7812 if (infiles[i].incompiler
7813 || (infiles[i].language && infiles[i].language[0] != '*'))
7815 set_input (infiles[i].name);
7816 break;
7820 if (!seen_error ())
7822 /* Make sure INPUT_FILE_NUMBER points to first available open
7823 slot. */
7824 input_file_number = n_infiles;
7825 if (lang_specific_pre_link ())
7826 errorcount++;
7830 /* If we have to run the linker, do it now. */
7832 void
7833 driver::maybe_run_linker (const char *argv0) const
7835 size_t i;
7836 int linker_was_run = 0;
7837 int num_linker_inputs;
7839 /* Determine if there are any linker input files. */
7840 num_linker_inputs = 0;
7841 for (i = 0; (int) i < n_infiles; i++)
7842 if (explicit_link_files[i] || outfiles[i] != NULL)
7843 num_linker_inputs++;
7845 /* Run ld to link all the compiler output files. */
7847 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
7849 int tmp = execution_count;
7851 if (! have_c)
7853 #if HAVE_LTO_PLUGIN > 0
7854 #if HAVE_LTO_PLUGIN == 2
7855 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
7856 #else
7857 const char *fuse_linker_plugin = "fuse-linker-plugin";
7858 #endif
7859 #endif
7861 /* We'll use ld if we can't find collect2. */
7862 if (! strcmp (linker_name_spec, "collect2"))
7864 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
7865 if (s == NULL)
7866 linker_name_spec = "ld";
7869 #if HAVE_LTO_PLUGIN > 0
7870 #if HAVE_LTO_PLUGIN == 2
7871 if (!switch_matches (fno_use_linker_plugin,
7872 fno_use_linker_plugin
7873 + strlen (fno_use_linker_plugin), 0))
7874 #else
7875 if (switch_matches (fuse_linker_plugin,
7876 fuse_linker_plugin
7877 + strlen (fuse_linker_plugin), 0))
7878 #endif
7880 char *temp_spec = find_a_file (&exec_prefixes,
7881 LTOPLUGINSONAME, R_OK,
7882 false);
7883 if (!temp_spec)
7884 fatal_error (input_location,
7885 "-fuse-linker-plugin, but %s not found",
7886 LTOPLUGINSONAME);
7887 linker_plugin_file_spec = convert_white_space (temp_spec);
7889 #endif
7890 lto_gcc_spec = argv0;
7893 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
7894 for collect. */
7895 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
7896 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
7898 if (print_subprocess_help == 1)
7900 printf (_("\nLinker options\n==============\n\n"));
7901 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
7902 " to the linker.\n\n"));
7903 fflush (stdout);
7905 int value = do_spec (link_command_spec);
7906 if (value < 0)
7907 errorcount = 1;
7908 linker_was_run = (tmp != execution_count);
7911 /* If options said don't run linker,
7912 complain about input files to be given to the linker. */
7914 if (! linker_was_run && !seen_error ())
7915 for (i = 0; (int) i < n_infiles; i++)
7916 if (explicit_link_files[i]
7917 && !(infiles[i].language && infiles[i].language[0] == '*'))
7918 warning (0, "%s: linker input file unused because linking not done",
7919 outfiles[i]);
7922 /* The end of "main". */
7924 void
7925 driver::final_actions () const
7927 /* Delete some or all of the temporary files we made. */
7929 if (seen_error ())
7930 delete_failure_queue ();
7931 delete_temp_files ();
7933 if (print_help_list)
7935 printf (("\nFor bug reporting instructions, please see:\n"));
7936 printf ("%s\n", bug_report_url);
7940 /* Determine what the exit code of the driver should be. */
7943 driver::get_exit_code () const
7945 return (signal_count != 0 ? 2
7946 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
7947 : 0);
7950 /* Find the proper compilation spec for the file name NAME,
7951 whose length is LENGTH. LANGUAGE is the specified language,
7952 or 0 if this file is to be passed to the linker. */
7954 static struct compiler *
7955 lookup_compiler (const char *name, size_t length, const char *language)
7957 struct compiler *cp;
7959 /* If this was specified by the user to be a linker input, indicate that. */
7960 if (language != 0 && language[0] == '*')
7961 return 0;
7963 /* Otherwise, look for the language, if one is spec'd. */
7964 if (language != 0)
7966 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7967 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
7968 return cp;
7970 error ("language %s not recognized", language);
7971 return 0;
7974 /* Look for a suffix. */
7975 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7977 if (/* The suffix `-' matches only the file name `-'. */
7978 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7979 || (strlen (cp->suffix) < length
7980 /* See if the suffix matches the end of NAME. */
7981 && !strcmp (cp->suffix,
7982 name + length - strlen (cp->suffix))
7984 break;
7987 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
7988 /* Look again, but case-insensitively this time. */
7989 if (cp < compilers)
7990 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7992 if (/* The suffix `-' matches only the file name `-'. */
7993 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7994 || (strlen (cp->suffix) < length
7995 /* See if the suffix matches the end of NAME. */
7996 && ((!strcmp (cp->suffix,
7997 name + length - strlen (cp->suffix))
7998 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
7999 && !strcasecmp (cp->suffix,
8000 name + length - strlen (cp->suffix)))
8002 break;
8004 #endif
8006 if (cp >= compilers)
8008 if (cp->spec[0] != '@')
8009 /* A non-alias entry: return it. */
8010 return cp;
8012 /* An alias entry maps a suffix to a language.
8013 Search for the language; pass 0 for NAME and LENGTH
8014 to avoid infinite recursion if language not found. */
8015 return lookup_compiler (NULL, 0, cp->spec + 1);
8017 return 0;
8020 static char *
8021 save_string (const char *s, int len)
8023 char *result = XNEWVEC (char, len + 1);
8025 memcpy (result, s, len);
8026 result[len] = 0;
8027 return result;
8030 void
8031 pfatal_with_name (const char *name)
8033 perror_with_name (name);
8034 delete_temp_files ();
8035 exit (1);
8038 static void
8039 perror_with_name (const char *name)
8041 error ("%s: %m", name);
8044 static inline void
8045 validate_switches_from_spec (const char *spec, bool user)
8047 const char *p = spec;
8048 char c;
8049 while ((c = *p++))
8050 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
8051 /* We have a switch spec. */
8052 p = validate_switches (p + 1, user);
8055 static void
8056 validate_all_switches (void)
8058 struct compiler *comp;
8059 struct spec_list *spec;
8061 for (comp = compilers; comp->spec; comp++)
8062 validate_switches_from_spec (comp->spec, false);
8064 /* Look through the linked list of specs read from the specs file. */
8065 for (spec = specs; spec; spec = spec->next)
8066 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
8068 validate_switches_from_spec (link_command_spec, false);
8071 /* Look at the switch-name that comes after START
8072 and mark as valid all supplied switches that match it. */
8074 static const char *
8075 validate_switches (const char *start, bool user_spec)
8077 const char *p = start;
8078 const char *atom;
8079 size_t len;
8080 int i;
8081 bool suffix = false;
8082 bool starred = false;
8084 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
8086 next_member:
8087 SKIP_WHITE ();
8089 if (*p == '!')
8090 p++;
8092 SKIP_WHITE ();
8093 if (*p == '.' || *p == ',')
8094 suffix = true, p++;
8096 atom = p;
8097 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
8098 || *p == ',' || *p == '.' || *p == '@')
8099 p++;
8100 len = p - atom;
8102 if (*p == '*')
8103 starred = true, p++;
8105 SKIP_WHITE ();
8107 if (!suffix)
8109 /* Mark all matching switches as valid. */
8110 for (i = 0; i < n_switches; i++)
8111 if (!strncmp (switches[i].part1, atom, len)
8112 && (starred || switches[i].part1[len] == '\0')
8113 && (switches[i].known || user_spec))
8114 switches[i].validated = true;
8117 if (*p) p++;
8118 if (*p && (p[-1] == '|' || p[-1] == '&'))
8119 goto next_member;
8121 if (*p && p[-1] == ':')
8123 while (*p && *p != ';' && *p != '}')
8125 if (*p == '%')
8127 p++;
8128 if (*p == '{' || *p == '<')
8129 p = validate_switches (p+1, user_spec);
8130 else if (p[0] == 'W' && p[1] == '{')
8131 p = validate_switches (p+2, user_spec);
8133 else
8134 p++;
8137 if (*p) p++;
8138 if (*p && p[-1] == ';')
8139 goto next_member;
8142 return p;
8143 #undef SKIP_WHITE
8146 struct mdswitchstr
8148 const char *str;
8149 int len;
8152 static struct mdswitchstr *mdswitches;
8153 static int n_mdswitches;
8155 /* Check whether a particular argument was used. The first time we
8156 canonicalize the switches to keep only the ones we care about. */
8158 static int
8159 used_arg (const char *p, int len)
8161 struct mswitchstr
8163 const char *str;
8164 const char *replace;
8165 int len;
8166 int rep_len;
8169 static struct mswitchstr *mswitches;
8170 static int n_mswitches;
8171 int i, j;
8173 if (!mswitches)
8175 struct mswitchstr *matches;
8176 const char *q;
8177 int cnt = 0;
8179 /* Break multilib_matches into the component strings of string
8180 and replacement string. */
8181 for (q = multilib_matches; *q != '\0'; q++)
8182 if (*q == ';')
8183 cnt++;
8185 matches
8186 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
8187 i = 0;
8188 q = multilib_matches;
8189 while (*q != '\0')
8191 matches[i].str = q;
8192 while (*q != ' ')
8194 if (*q == '\0')
8196 invalid_matches:
8197 fatal_error (input_location, "multilib spec %qs is invalid",
8198 multilib_matches);
8200 q++;
8202 matches[i].len = q - matches[i].str;
8204 matches[i].replace = ++q;
8205 while (*q != ';' && *q != '\0')
8207 if (*q == ' ')
8208 goto invalid_matches;
8209 q++;
8211 matches[i].rep_len = q - matches[i].replace;
8212 i++;
8213 if (*q == ';')
8214 q++;
8217 /* Now build a list of the replacement string for switches that we care
8218 about. Make sure we allocate at least one entry. This prevents
8219 xmalloc from calling fatal, and prevents us from re-executing this
8220 block of code. */
8221 mswitches
8222 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
8223 for (i = 0; i < n_switches; i++)
8224 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
8226 int xlen = strlen (switches[i].part1);
8227 for (j = 0; j < cnt; j++)
8228 if (xlen == matches[j].len
8229 && ! strncmp (switches[i].part1, matches[j].str, xlen))
8231 mswitches[n_mswitches].str = matches[j].replace;
8232 mswitches[n_mswitches].len = matches[j].rep_len;
8233 mswitches[n_mswitches].replace = (char *) 0;
8234 mswitches[n_mswitches].rep_len = 0;
8235 n_mswitches++;
8236 break;
8240 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
8241 on the command line nor any options mutually incompatible with
8242 them. */
8243 for (i = 0; i < n_mdswitches; i++)
8245 const char *r;
8247 for (q = multilib_options; *q != '\0'; *q && q++)
8249 while (*q == ' ')
8250 q++;
8252 r = q;
8253 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
8254 || strchr (" /", q[mdswitches[i].len]) == NULL)
8256 while (*q != ' ' && *q != '/' && *q != '\0')
8257 q++;
8258 if (*q != '/')
8259 break;
8260 q++;
8263 if (*q != ' ' && *q != '\0')
8265 while (*r != ' ' && *r != '\0')
8267 q = r;
8268 while (*q != ' ' && *q != '/' && *q != '\0')
8269 q++;
8271 if (used_arg (r, q - r))
8272 break;
8274 if (*q != '/')
8276 mswitches[n_mswitches].str = mdswitches[i].str;
8277 mswitches[n_mswitches].len = mdswitches[i].len;
8278 mswitches[n_mswitches].replace = (char *) 0;
8279 mswitches[n_mswitches].rep_len = 0;
8280 n_mswitches++;
8281 break;
8284 r = q + 1;
8286 break;
8292 for (i = 0; i < n_mswitches; i++)
8293 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
8294 return 1;
8296 return 0;
8299 static int
8300 default_arg (const char *p, int len)
8302 int i;
8304 for (i = 0; i < n_mdswitches; i++)
8305 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
8306 return 1;
8308 return 0;
8311 /* Work out the subdirectory to use based on the options. The format of
8312 multilib_select is a list of elements. Each element is a subdirectory
8313 name followed by a list of options followed by a semicolon. The format
8314 of multilib_exclusions is the same, but without the preceding
8315 directory. First gcc will check the exclusions, if none of the options
8316 beginning with an exclamation point are present, and all of the other
8317 options are present, then we will ignore this completely. Passing
8318 that, gcc will consider each multilib_select in turn using the same
8319 rules for matching the options. If a match is found, that subdirectory
8320 will be used.
8321 A subdirectory name is optionally followed by a colon and the corresponding
8322 multiarch name. */
8324 static void
8325 set_multilib_dir (void)
8327 const char *p;
8328 unsigned int this_path_len;
8329 const char *this_path, *this_arg;
8330 const char *start, *end;
8331 int not_arg;
8332 int ok, ndfltok, first;
8334 n_mdswitches = 0;
8335 start = multilib_defaults;
8336 while (*start == ' ' || *start == '\t')
8337 start++;
8338 while (*start != '\0')
8340 n_mdswitches++;
8341 while (*start != ' ' && *start != '\t' && *start != '\0')
8342 start++;
8343 while (*start == ' ' || *start == '\t')
8344 start++;
8347 if (n_mdswitches)
8349 int i = 0;
8351 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
8352 for (start = multilib_defaults; *start != '\0'; start = end + 1)
8354 while (*start == ' ' || *start == '\t')
8355 start++;
8357 if (*start == '\0')
8358 break;
8360 for (end = start + 1;
8361 *end != ' ' && *end != '\t' && *end != '\0'; end++)
8364 obstack_grow (&multilib_obstack, start, end - start);
8365 obstack_1grow (&multilib_obstack, 0);
8366 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
8367 mdswitches[i++].len = end - start;
8369 if (*end == '\0')
8370 break;
8374 p = multilib_exclusions;
8375 while (*p != '\0')
8377 /* Ignore newlines. */
8378 if (*p == '\n')
8380 ++p;
8381 continue;
8384 /* Check the arguments. */
8385 ok = 1;
8386 while (*p != ';')
8388 if (*p == '\0')
8390 invalid_exclusions:
8391 fatal_error (input_location, "multilib exclusions %qs is invalid",
8392 multilib_exclusions);
8395 if (! ok)
8397 ++p;
8398 continue;
8401 this_arg = p;
8402 while (*p != ' ' && *p != ';')
8404 if (*p == '\0')
8405 goto invalid_exclusions;
8406 ++p;
8409 if (*this_arg != '!')
8410 not_arg = 0;
8411 else
8413 not_arg = 1;
8414 ++this_arg;
8417 ok = used_arg (this_arg, p - this_arg);
8418 if (not_arg)
8419 ok = ! ok;
8421 if (*p == ' ')
8422 ++p;
8425 if (ok)
8426 return;
8428 ++p;
8431 first = 1;
8432 p = multilib_select;
8434 /* Append multilib reuse rules if any. With those rules, we can reuse
8435 one multilib for certain different options sets. */
8436 if (strlen (multilib_reuse) > 0)
8437 p = concat (p, multilib_reuse, NULL);
8439 while (*p != '\0')
8441 /* Ignore newlines. */
8442 if (*p == '\n')
8444 ++p;
8445 continue;
8448 /* Get the initial path. */
8449 this_path = p;
8450 while (*p != ' ')
8452 if (*p == '\0')
8454 invalid_select:
8455 fatal_error (input_location, "multilib select %qs %qs is invalid",
8456 multilib_select, multilib_reuse);
8458 ++p;
8460 this_path_len = p - this_path;
8462 /* Check the arguments. */
8463 ok = 1;
8464 ndfltok = 1;
8465 ++p;
8466 while (*p != ';')
8468 if (*p == '\0')
8469 goto invalid_select;
8471 if (! ok)
8473 ++p;
8474 continue;
8477 this_arg = p;
8478 while (*p != ' ' && *p != ';')
8480 if (*p == '\0')
8481 goto invalid_select;
8482 ++p;
8485 if (*this_arg != '!')
8486 not_arg = 0;
8487 else
8489 not_arg = 1;
8490 ++this_arg;
8493 /* If this is a default argument, we can just ignore it.
8494 This is true even if this_arg begins with '!'. Beginning
8495 with '!' does not mean that this argument is necessarily
8496 inappropriate for this library: it merely means that
8497 there is a more specific library which uses this
8498 argument. If this argument is a default, we need not
8499 consider that more specific library. */
8500 ok = used_arg (this_arg, p - this_arg);
8501 if (not_arg)
8502 ok = ! ok;
8504 if (! ok)
8505 ndfltok = 0;
8507 if (default_arg (this_arg, p - this_arg))
8508 ok = 1;
8510 if (*p == ' ')
8511 ++p;
8514 if (ok && first)
8516 if (this_path_len != 1
8517 || this_path[0] != '.')
8519 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
8520 char *q;
8522 strncpy (new_multilib_dir, this_path, this_path_len);
8523 new_multilib_dir[this_path_len] = '\0';
8524 q = strchr (new_multilib_dir, ':');
8525 if (q != NULL)
8526 *q = '\0';
8527 multilib_dir = new_multilib_dir;
8529 first = 0;
8532 if (ndfltok)
8534 const char *q = this_path, *end = this_path + this_path_len;
8536 while (q < end && *q != ':')
8537 q++;
8538 if (q < end)
8540 const char *q2 = q + 1, *ml_end = end;
8541 char *new_multilib_os_dir;
8543 while (q2 < end && *q2 != ':')
8544 q2++;
8545 if (*q2 == ':')
8546 ml_end = q2;
8547 if (ml_end - q == 1)
8548 multilib_os_dir = xstrdup (".");
8549 else
8551 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
8552 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
8553 new_multilib_os_dir[ml_end - q - 1] = '\0';
8554 multilib_os_dir = new_multilib_os_dir;
8557 if (q2 < end && *q2 == ':')
8559 char *new_multiarch_dir = XNEWVEC (char, end - q2);
8560 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
8561 new_multiarch_dir[end - q2 - 1] = '\0';
8562 multiarch_dir = new_multiarch_dir;
8564 break;
8568 ++p;
8571 if (multilib_dir == NULL && multilib_os_dir != NULL
8572 && strcmp (multilib_os_dir, ".") == 0)
8574 free (CONST_CAST (char *, multilib_os_dir));
8575 multilib_os_dir = NULL;
8577 else if (multilib_dir != NULL && multilib_os_dir == NULL)
8578 multilib_os_dir = multilib_dir;
8581 /* Print out the multiple library subdirectory selection
8582 information. This prints out a series of lines. Each line looks
8583 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
8584 required. Only the desired options are printed out, the negative
8585 matches. The options are print without a leading dash. There are
8586 no spaces to make it easy to use the information in the shell.
8587 Each subdirectory is printed only once. This assumes the ordering
8588 generated by the genmultilib script. Also, we leave out ones that match
8589 the exclusions. */
8591 static void
8592 print_multilib_info (void)
8594 const char *p = multilib_select;
8595 const char *last_path = 0, *this_path;
8596 int skip;
8597 unsigned int last_path_len = 0;
8599 while (*p != '\0')
8601 skip = 0;
8602 /* Ignore newlines. */
8603 if (*p == '\n')
8605 ++p;
8606 continue;
8609 /* Get the initial path. */
8610 this_path = p;
8611 while (*p != ' ')
8613 if (*p == '\0')
8615 invalid_select:
8616 fatal_error (input_location,
8617 "multilib select %qs is invalid", multilib_select);
8620 ++p;
8623 /* When --disable-multilib was used but target defines
8624 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
8625 with .:: for multiarch configurations) are there just to find
8626 multilib_os_dir, so skip them from output. */
8627 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
8628 skip = 1;
8630 /* Check for matches with the multilib_exclusions. We don't bother
8631 with the '!' in either list. If any of the exclusion rules match
8632 all of its options with the select rule, we skip it. */
8634 const char *e = multilib_exclusions;
8635 const char *this_arg;
8637 while (*e != '\0')
8639 int m = 1;
8640 /* Ignore newlines. */
8641 if (*e == '\n')
8643 ++e;
8644 continue;
8647 /* Check the arguments. */
8648 while (*e != ';')
8650 const char *q;
8651 int mp = 0;
8653 if (*e == '\0')
8655 invalid_exclusion:
8656 fatal_error (input_location,
8657 "multilib exclusion %qs is invalid",
8658 multilib_exclusions);
8661 if (! m)
8663 ++e;
8664 continue;
8667 this_arg = e;
8669 while (*e != ' ' && *e != ';')
8671 if (*e == '\0')
8672 goto invalid_exclusion;
8673 ++e;
8676 q = p + 1;
8677 while (*q != ';')
8679 const char *arg;
8680 int len = e - this_arg;
8682 if (*q == '\0')
8683 goto invalid_select;
8685 arg = q;
8687 while (*q != ' ' && *q != ';')
8689 if (*q == '\0')
8690 goto invalid_select;
8691 ++q;
8694 if (! strncmp (arg, this_arg,
8695 (len < q - arg) ? q - arg : len)
8696 || default_arg (this_arg, e - this_arg))
8698 mp = 1;
8699 break;
8702 if (*q == ' ')
8703 ++q;
8706 if (! mp)
8707 m = 0;
8709 if (*e == ' ')
8710 ++e;
8713 if (m)
8715 skip = 1;
8716 break;
8719 if (*e != '\0')
8720 ++e;
8724 if (! skip)
8726 /* If this is a duplicate, skip it. */
8727 skip = (last_path != 0
8728 && (unsigned int) (p - this_path) == last_path_len
8729 && ! filename_ncmp (last_path, this_path, last_path_len));
8731 last_path = this_path;
8732 last_path_len = p - this_path;
8735 /* If this directory requires any default arguments, we can skip
8736 it. We will already have printed a directory identical to
8737 this one which does not require that default argument. */
8738 if (! skip)
8740 const char *q;
8742 q = p + 1;
8743 while (*q != ';')
8745 const char *arg;
8747 if (*q == '\0')
8748 goto invalid_select;
8750 if (*q == '!')
8751 arg = NULL;
8752 else
8753 arg = q;
8755 while (*q != ' ' && *q != ';')
8757 if (*q == '\0')
8758 goto invalid_select;
8759 ++q;
8762 if (arg != NULL
8763 && default_arg (arg, q - arg))
8765 skip = 1;
8766 break;
8769 if (*q == ' ')
8770 ++q;
8774 if (! skip)
8776 const char *p1;
8778 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
8779 putchar (*p1);
8780 putchar (';');
8783 ++p;
8784 while (*p != ';')
8786 int use_arg;
8788 if (*p == '\0')
8789 goto invalid_select;
8791 if (skip)
8793 ++p;
8794 continue;
8797 use_arg = *p != '!';
8799 if (use_arg)
8800 putchar ('@');
8802 while (*p != ' ' && *p != ';')
8804 if (*p == '\0')
8805 goto invalid_select;
8806 if (use_arg)
8807 putchar (*p);
8808 ++p;
8811 if (*p == ' ')
8812 ++p;
8815 if (! skip)
8817 /* If there are extra options, print them now. */
8818 if (multilib_extra && *multilib_extra)
8820 int print_at = TRUE;
8821 const char *q;
8823 for (q = multilib_extra; *q != '\0'; q++)
8825 if (*q == ' ')
8826 print_at = TRUE;
8827 else
8829 if (print_at)
8830 putchar ('@');
8831 putchar (*q);
8832 print_at = FALSE;
8837 putchar ('\n');
8840 ++p;
8844 /* getenv built-in spec function.
8846 Returns the value of the environment variable given by its first
8847 argument, concatenated with the second argument. If the
8848 environment variable is not defined, a fatal error is issued. */
8850 static const char *
8851 getenv_spec_function (int argc, const char **argv)
8853 char *value;
8854 char *result;
8855 char *ptr;
8856 size_t len;
8858 if (argc != 2)
8859 return NULL;
8861 value = getenv (argv[0]);
8862 if (!value)
8863 fatal_error (input_location,
8864 "environment variable %qs not defined", argv[0]);
8866 /* We have to escape every character of the environment variable so
8867 they are not interpreted as active spec characters. A
8868 particularly painful case is when we are reading a variable
8869 holding a windows path complete with \ separators. */
8870 len = strlen (value) * 2 + strlen (argv[1]) + 1;
8871 result = XNEWVAR (char, len);
8872 for (ptr = result; *value; ptr += 2)
8874 ptr[0] = '\\';
8875 ptr[1] = *value++;
8878 strcpy (ptr, argv[1]);
8880 return result;
8883 /* if-exists built-in spec function.
8885 Checks to see if the file specified by the absolute pathname in
8886 ARGS exists. Returns that pathname if found.
8888 The usual use for this function is to check for a library file
8889 (whose name has been expanded with %s). */
8891 static const char *
8892 if_exists_spec_function (int argc, const char **argv)
8894 /* Must have only one argument. */
8895 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8896 return argv[0];
8898 return NULL;
8901 /* if-exists-else built-in spec function.
8903 This is like if-exists, but takes an additional argument which
8904 is returned if the first argument does not exist. */
8906 static const char *
8907 if_exists_else_spec_function (int argc, const char **argv)
8909 /* Must have exactly two arguments. */
8910 if (argc != 2)
8911 return NULL;
8913 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8914 return argv[0];
8916 return argv[1];
8919 /* sanitize built-in spec function.
8921 This returns non-NULL, if sanitizing address, thread or
8922 any of the undefined behavior sanitizers. */
8924 static const char *
8925 sanitize_spec_function (int argc, const char **argv)
8927 if (argc != 1)
8928 return NULL;
8930 if (strcmp (argv[0], "address") == 0)
8931 return (flag_sanitize & SANITIZE_USER_ADDRESS) ? "" : NULL;
8932 if (strcmp (argv[0], "kernel-address") == 0)
8933 return (flag_sanitize & SANITIZE_KERNEL_ADDRESS) ? "" : NULL;
8934 if (strcmp (argv[0], "thread") == 0)
8935 return (flag_sanitize & SANITIZE_THREAD) ? "" : NULL;
8936 if (strcmp (argv[0], "undefined") == 0)
8937 return ((flag_sanitize & (SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT))
8938 && !flag_sanitize_undefined_trap_on_error) ? "" : NULL;
8939 if (strcmp (argv[0], "leak") == 0)
8940 return ((flag_sanitize
8941 & (SANITIZE_ADDRESS | SANITIZE_LEAK | SANITIZE_THREAD))
8942 == SANITIZE_LEAK) ? "" : NULL;
8943 return NULL;
8946 /* replace-outfile built-in spec function.
8948 This looks for the first argument in the outfiles array's name and
8949 replaces it with the second argument. */
8951 static const char *
8952 replace_outfile_spec_function (int argc, const char **argv)
8954 int i;
8955 /* Must have exactly two arguments. */
8956 if (argc != 2)
8957 abort ();
8959 for (i = 0; i < n_infiles; i++)
8961 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8962 outfiles[i] = xstrdup (argv[1]);
8964 return NULL;
8967 /* remove-outfile built-in spec function.
8969 * This looks for the first argument in the outfiles array's name and
8970 * removes it. */
8972 static const char *
8973 remove_outfile_spec_function (int argc, const char **argv)
8975 int i;
8976 /* Must have exactly one argument. */
8977 if (argc != 1)
8978 abort ();
8980 for (i = 0; i < n_infiles; i++)
8982 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8983 outfiles[i] = NULL;
8985 return NULL;
8988 /* Given two version numbers, compares the two numbers.
8989 A version number must match the regular expression
8990 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
8992 static int
8993 compare_version_strings (const char *v1, const char *v2)
8995 int rresult;
8996 regex_t r;
8998 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
8999 REG_EXTENDED | REG_NOSUB) != 0)
9000 abort ();
9001 rresult = regexec (&r, v1, 0, NULL, 0);
9002 if (rresult == REG_NOMATCH)
9003 fatal_error (input_location, "invalid version number %qs", v1);
9004 else if (rresult != 0)
9005 abort ();
9006 rresult = regexec (&r, v2, 0, NULL, 0);
9007 if (rresult == REG_NOMATCH)
9008 fatal_error (input_location, "invalid version number %qs", v2);
9009 else if (rresult != 0)
9010 abort ();
9012 return strverscmp (v1, v2);
9016 /* version_compare built-in spec function.
9018 This takes an argument of the following form:
9020 <comparison-op> <arg1> [<arg2>] <switch> <result>
9022 and produces "result" if the comparison evaluates to true,
9023 and nothing if it doesn't.
9025 The supported <comparison-op> values are:
9027 >= true if switch is a later (or same) version than arg1
9028 !> opposite of >=
9029 < true if switch is an earlier version than arg1
9030 !< opposite of <
9031 >< true if switch is arg1 or later, and earlier than arg2
9032 <> true if switch is earlier than arg1 or is arg2 or later
9034 If the switch is not present, the condition is false unless
9035 the first character of the <comparison-op> is '!'.
9037 For example,
9038 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
9039 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
9041 static const char *
9042 version_compare_spec_function (int argc, const char **argv)
9044 int comp1, comp2;
9045 size_t switch_len;
9046 const char *switch_value = NULL;
9047 int nargs = 1, i;
9048 bool result;
9050 if (argc < 3)
9051 fatal_error (input_location, "too few arguments to %%:version-compare");
9052 if (argv[0][0] == '\0')
9053 abort ();
9054 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
9055 nargs = 2;
9056 if (argc != nargs + 3)
9057 fatal_error (input_location, "too many arguments to %%:version-compare");
9059 switch_len = strlen (argv[nargs + 1]);
9060 for (i = 0; i < n_switches; i++)
9061 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
9062 && check_live_switch (i, switch_len))
9063 switch_value = switches[i].part1 + switch_len;
9065 if (switch_value == NULL)
9066 comp1 = comp2 = -1;
9067 else
9069 comp1 = compare_version_strings (switch_value, argv[1]);
9070 if (nargs == 2)
9071 comp2 = compare_version_strings (switch_value, argv[2]);
9072 else
9073 comp2 = -1; /* This value unused. */
9076 switch (argv[0][0] << 8 | argv[0][1])
9078 case '>' << 8 | '=':
9079 result = comp1 >= 0;
9080 break;
9081 case '!' << 8 | '<':
9082 result = comp1 >= 0 || switch_value == NULL;
9083 break;
9084 case '<' << 8:
9085 result = comp1 < 0;
9086 break;
9087 case '!' << 8 | '>':
9088 result = comp1 < 0 || switch_value == NULL;
9089 break;
9090 case '>' << 8 | '<':
9091 result = comp1 >= 0 && comp2 < 0;
9092 break;
9093 case '<' << 8 | '>':
9094 result = comp1 < 0 || comp2 >= 0;
9095 break;
9097 default:
9098 fatal_error (input_location,
9099 "unknown operator %qs in %%:version-compare", argv[0]);
9101 if (! result)
9102 return NULL;
9104 return argv[nargs + 2];
9107 /* %:include builtin spec function. This differs from %include in that it
9108 can be nested inside a spec, and thus be conditionalized. It takes
9109 one argument, the filename, and looks for it in the startfile path.
9110 The result is always NULL, i.e. an empty expansion. */
9112 static const char *
9113 include_spec_function (int argc, const char **argv)
9115 char *file;
9117 if (argc != 1)
9118 abort ();
9120 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
9121 read_specs (file ? file : argv[0], false, false);
9123 return NULL;
9126 /* %:find-file spec function. This function replaces its argument by
9127 the file found through find_file, that is the -print-file-name gcc
9128 program option. */
9129 static const char *
9130 find_file_spec_function (int argc, const char **argv)
9132 const char *file;
9134 if (argc != 1)
9135 abort ();
9137 file = find_file (argv[0]);
9138 return file;
9142 /* %:find-plugindir spec function. This function replaces its argument
9143 by the -iplugindir=<dir> option. `dir' is found through find_file, that
9144 is the -print-file-name gcc program option. */
9145 static const char *
9146 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
9148 const char *option;
9150 if (argc != 0)
9151 abort ();
9153 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
9154 return option;
9158 /* %:print-asm-header spec function. Print a banner to say that the
9159 following output is from the assembler. */
9161 static const char *
9162 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
9163 const char **argv ATTRIBUTE_UNUSED)
9165 printf (_("Assembler options\n=================\n\n"));
9166 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
9167 fflush (stdout);
9168 return NULL;
9171 /* Get a random number for -frandom-seed */
9173 static unsigned HOST_WIDE_INT
9174 get_random_number (void)
9176 unsigned HOST_WIDE_INT ret = 0;
9177 int fd;
9179 fd = open ("/dev/urandom", O_RDONLY);
9180 if (fd >= 0)
9182 read (fd, &ret, sizeof (HOST_WIDE_INT));
9183 close (fd);
9184 if (ret)
9185 return ret;
9188 /* Get some more or less random data. */
9189 #ifdef HAVE_GETTIMEOFDAY
9191 struct timeval tv;
9193 gettimeofday (&tv, NULL);
9194 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
9196 #else
9198 time_t now = time (NULL);
9200 if (now != (time_t)-1)
9201 ret = (unsigned) now;
9203 #endif
9205 return ret ^ getpid ();
9208 /* %:compare-debug-dump-opt spec function. Save the last argument,
9209 expected to be the last -fdump-final-insns option, or generate a
9210 temporary. */
9212 static const char *
9213 compare_debug_dump_opt_spec_function (int arg,
9214 const char **argv ATTRIBUTE_UNUSED)
9216 char *ret;
9217 char *name;
9218 int which;
9219 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
9221 if (arg != 0)
9222 fatal_error (input_location,
9223 "too many arguments to %%:compare-debug-dump-opt");
9225 do_spec_2 ("%{fdump-final-insns=*:%*}");
9226 do_spec_1 (" ", 0, NULL);
9228 if (argbuf.length () > 0
9229 && strcmp (argv[argbuf.length () - 1], "."))
9231 if (!compare_debug)
9232 return NULL;
9234 name = xstrdup (argv[argbuf.length () - 1]);
9235 ret = NULL;
9237 else
9239 const char *ext = NULL;
9241 if (argbuf.length () > 0)
9243 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
9244 ext = ".gkd";
9246 else if (!compare_debug)
9247 return NULL;
9248 else
9249 do_spec_2 ("%g.gkd");
9251 do_spec_1 (" ", 0, NULL);
9253 gcc_assert (argbuf.length () > 0);
9255 name = concat (argbuf.last (), ext, NULL);
9257 ret = concat ("-fdump-final-insns=", name, NULL);
9260 which = compare_debug < 0;
9261 debug_check_temp_file[which] = name;
9263 if (!which)
9265 unsigned HOST_WIDE_INT value = get_random_number ();
9267 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
9270 if (*random_seed)
9272 char *tmp = ret;
9273 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
9274 ret, NULL);
9275 free (tmp);
9278 if (which)
9279 *random_seed = 0;
9281 return ret;
9284 static const char *debug_auxbase_opt;
9286 /* %:compare-debug-self-opt spec function. Expands to the options
9287 that are to be passed in the second compilation of
9288 compare-debug. */
9290 static const char *
9291 compare_debug_self_opt_spec_function (int arg,
9292 const char **argv ATTRIBUTE_UNUSED)
9294 if (arg != 0)
9295 fatal_error (input_location,
9296 "too many arguments to %%:compare-debug-self-opt");
9298 if (compare_debug >= 0)
9299 return NULL;
9301 do_spec_2 ("%{c|S:%{o*:%*}}");
9302 do_spec_1 (" ", 0, NULL);
9304 if (argbuf.length () > 0)
9305 debug_auxbase_opt = concat ("-auxbase-strip ",
9306 argbuf.last (),
9307 NULL);
9308 else
9309 debug_auxbase_opt = NULL;
9311 return concat ("\
9312 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
9313 %<fdump-final-insns=* -w -S -o %j \
9314 %{!fcompare-debug-second:-fcompare-debug-second} \
9315 ", compare_debug_opt, NULL);
9318 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
9319 options that are to be passed in the second compilation of
9320 compare-debug. It expects, as an argument, the basename of the
9321 current input file name, with the .gk suffix appended to it. */
9323 static const char *
9324 compare_debug_auxbase_opt_spec_function (int arg,
9325 const char **argv)
9327 char *name;
9328 int len;
9330 if (arg == 0)
9331 fatal_error (input_location,
9332 "too few arguments to %%:compare-debug-auxbase-opt");
9334 if (arg != 1)
9335 fatal_error (input_location,
9336 "too many arguments to %%:compare-debug-auxbase-opt");
9338 if (compare_debug >= 0)
9339 return NULL;
9341 len = strlen (argv[0]);
9342 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
9343 fatal_error (input_location, "argument to %%:compare-debug-auxbase-opt "
9344 "does not end in .gk");
9346 if (debug_auxbase_opt)
9347 return debug_auxbase_opt;
9349 #define OPT "-auxbase "
9351 len -= 3;
9352 name = (char*) xmalloc (sizeof (OPT) + len);
9353 memcpy (name, OPT, sizeof (OPT) - 1);
9354 memcpy (name + sizeof (OPT) - 1, argv[0], len);
9355 name[sizeof (OPT) - 1 + len] = '\0';
9357 #undef OPT
9359 return name;
9362 /* %:pass-through-libs spec function. Finds all -l options and input
9363 file names in the lib spec passed to it, and makes a list of them
9364 prepended with the plugin option to cause them to be passed through
9365 to the final link after all the new object files have been added. */
9367 const char *
9368 pass_through_libs_spec_func (int argc, const char **argv)
9370 char *prepended = xstrdup (" ");
9371 int n;
9372 /* Shlemiel the painter's algorithm. Innately horrible, but at least
9373 we know that there will never be more than a handful of strings to
9374 concat, and it's only once per run, so it's not worth optimising. */
9375 for (n = 0; n < argc; n++)
9377 char *old = prepended;
9378 /* Anything that isn't an option is a full path to an output
9379 file; pass it through if it ends in '.a'. Among options,
9380 pass only -l. */
9381 if (argv[n][0] == '-' && argv[n][1] == 'l')
9383 const char *lopt = argv[n] + 2;
9384 /* Handle both joined and non-joined -l options. If for any
9385 reason there's a trailing -l with no joined or following
9386 arg just discard it. */
9387 if (!*lopt && ++n >= argc)
9388 break;
9389 else if (!*lopt)
9390 lopt = argv[n];
9391 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
9392 lopt, " ", NULL);
9394 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
9396 prepended = concat (prepended, "-plugin-opt=-pass-through=",
9397 argv[n], " ", NULL);
9399 if (prepended != old)
9400 free (old);
9402 return prepended;
9405 /* %:replace-extension spec function. Replaces the extension of the
9406 first argument with the second argument. */
9408 const char *
9409 replace_extension_spec_func (int argc, const char **argv)
9411 char *name;
9412 char *p;
9413 char *result;
9414 int i;
9416 if (argc != 2)
9417 fatal_error (input_location, "too few arguments to %%:replace-extension");
9419 name = xstrdup (argv[0]);
9421 for (i = strlen (name) - 1; i >= 0; i--)
9422 if (IS_DIR_SEPARATOR (name[i]))
9423 break;
9425 p = strrchr (name + i + 1, '.');
9426 if (p != NULL)
9427 *p = '\0';
9429 result = concat (name, argv[1], NULL);
9431 free (name);
9432 return result;
9435 /* Returns "" if the n in ARGV[1] == -opt=<n> is greater than ARGV[2].
9436 Otherwise, return NULL. */
9438 static const char *
9439 greater_than_spec_func (int argc, const char **argv)
9441 char *converted;
9443 if (argc == 1)
9444 return NULL;
9446 gcc_assert (argc == 3);
9447 gcc_assert (argv[0][0] == '-');
9448 gcc_assert (argv[0][1] == '\0');
9450 /* Point p to <n> in in -opt=<n>. */
9451 const char *p = argv[1];
9452 while (true)
9454 char c = *p;
9455 if (c == '\0')
9456 gcc_unreachable ();
9458 ++p;
9460 if (c == '=')
9461 break;
9464 long arg = strtol (p, &converted, 10);
9465 gcc_assert (converted != p);
9467 long lim = strtol (argv[2], &converted, 10);
9468 gcc_assert (converted != argv[2]);
9470 if (arg > lim)
9471 return "";
9473 return NULL;
9476 /* Insert backslash before spaces in ORIG (usually a file path), to
9477 avoid being broken by spec parser.
9479 This function is needed as do_spec_1 treats white space (' ' and '\t')
9480 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
9481 the file name should be treated as a single argument rather than being
9482 broken into multiple. Solution is to insert '\\' before the space in a
9483 file name.
9485 This function converts and only converts all occurrence of ' '
9486 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
9487 "a b" -> "a\\ b"
9488 "a b" -> "a\\ \\ b"
9489 "a\tb" -> "a\\\tb"
9490 "a\\ b" -> "a\\\\ b"
9492 orig: input null-terminating string that was allocated by xalloc. The
9493 memory it points to might be freed in this function. Behavior undefined
9494 if ORIG wasn't xalloced or was freed already at entry.
9496 Return: ORIG if no conversion needed. Otherwise a newly allocated string
9497 that was converted from ORIG. */
9499 static char *
9500 convert_white_space (char *orig)
9502 int len, number_of_space = 0;
9504 for (len = 0; orig[len]; len++)
9505 if (orig[len] == ' ' || orig[len] == '\t') number_of_space++;
9507 if (number_of_space)
9509 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
9510 int j, k;
9511 for (j = 0, k = 0; j <= len; j++, k++)
9513 if (orig[j] == ' ' || orig[j] == '\t')
9514 new_spec[k++] = '\\';
9515 new_spec[k] = orig[j];
9517 free (orig);
9518 return new_spec;
9520 else
9521 return orig;
9524 /* PR jit/64810.
9525 Targets can provide configure-time default options in
9526 OPTION_DEFAULT_SPECS. The jit needs to access these, but
9527 they are expressed in the spec language.
9529 Run just enough of the driver to be able to expand these
9530 specs, and then call the callback CB on each
9531 such option. The options strings are *without* a leading
9532 '-' character e.g. ("march=x86-64"). Finally, clean up. */
9534 void
9535 driver_get_configure_time_options (void (*cb) (const char *option,
9536 void *user_data),
9537 void *user_data)
9539 size_t i;
9541 obstack_init (&obstack);
9542 gcc_obstack_init (&opts_obstack);
9543 n_switches = 0;
9545 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
9546 do_option_spec (option_default_specs[i].name,
9547 option_default_specs[i].spec);
9549 for (i = 0; (int) i < n_switches; i++)
9551 gcc_assert (switches[i].part1);
9552 (*cb) (switches[i].part1, user_data);
9555 obstack_free (&opts_obstack, NULL);
9556 obstack_free (&obstack, NULL);
9557 n_switches = 0;