2014-11-25 Martin Liska <mliska@suse.cz>
[official-gcc.git] / gcc / gcc.c
blobb730ba53d7e33a051565643c397170c60e37a8ce
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987-2014 Free Software Foundation, Inc.
4 This file is part of GCC.
6 GCC is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 3, or (at your option) any later
9 version.
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14 for more details.
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING3. If not see
18 <http://www.gnu.org/licenses/>. */
20 /* This program is the user interface to the C compiler and possibly to
21 other compilers. It is used because compilation is a complicated procedure
22 which involves running several programs and passing temporary files between
23 them, forwarding the users switches to those programs selectively,
24 and deleting the temporary files at the end.
26 CC recognizes how to compile each input file by suffixes in the file names.
27 Once it knows which kind of compilation to perform, the procedure for
28 compilation is specified by a string called a "spec". */
30 #include "config.h"
31 #include "system.h"
32 #include "coretypes.h"
33 #include "multilib.h" /* before tm.h */
34 #include "tm.h"
35 #include "xregex.h"
36 #include "obstack.h"
37 #include "intl.h"
38 #include "prefix.h"
39 #include "gcc.h"
40 #include "diagnostic.h"
41 #include "flags.h"
42 #include "opts.h"
43 #include "params.h"
44 #include "vec.h"
45 #include "filenames.h"
47 /* By default there is no special suffix for target executables. */
48 /* FIXME: when autoconf is fixed, remove the host check - dj */
49 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
50 #define HAVE_TARGET_EXECUTABLE_SUFFIX
51 #endif
53 /* By default there is no special suffix for host executables. */
54 #ifdef HOST_EXECUTABLE_SUFFIX
55 #define HAVE_HOST_EXECUTABLE_SUFFIX
56 #else
57 #define HOST_EXECUTABLE_SUFFIX ""
58 #endif
60 /* By default, the suffix for target object files is ".o". */
61 #ifdef TARGET_OBJECT_SUFFIX
62 #define HAVE_TARGET_OBJECT_SUFFIX
63 #else
64 #define TARGET_OBJECT_SUFFIX ".o"
65 #endif
67 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
69 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
70 #ifndef LIBRARY_PATH_ENV
71 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
72 #endif
74 /* If a stage of compilation returns an exit status >= 1,
75 compilation of that file ceases. */
77 #define MIN_FATAL_STATUS 1
79 /* Flag set by cppspec.c to 1. */
80 int is_cpp_driver;
82 /* Flag set to nonzero if an @file argument has been supplied to gcc. */
83 static bool at_file_supplied;
85 /* Definition of string containing the arguments given to configure. */
86 #include "configargs.h"
88 /* Flag saying to print the command line options understood by gcc and its
89 sub-processes. */
91 static int print_help_list;
93 /* Flag saying to print the version of gcc and its sub-processes. */
95 static int print_version;
97 /* Flag indicating whether we should ONLY print the command and
98 arguments (like verbose_flag) without executing the command.
99 Displayed arguments are quoted so that the generated command
100 line is suitable for execution. This is intended for use in
101 shell scripts to capture the driver-generated command line. */
102 static int verbose_only_flag;
104 /* Flag indicating how to print command line options of sub-processes. */
106 static int print_subprocess_help;
108 /* Linker suffix passed to -fuse-ld=... */
109 static const char *use_ld;
111 /* Whether we should report subprocess execution times to a file. */
113 FILE *report_times_to_file = NULL;
115 /* Nonzero means place this string before uses of /, so that include
116 and library files can be found in an alternate location. */
118 #ifdef TARGET_SYSTEM_ROOT
119 static const char *target_system_root = TARGET_SYSTEM_ROOT;
120 #else
121 static const char *target_system_root = 0;
122 #endif
124 /* Nonzero means pass the updated target_system_root to the compiler. */
126 static int target_system_root_changed;
128 /* Nonzero means append this string to target_system_root. */
130 static const char *target_sysroot_suffix = 0;
132 /* Nonzero means append this string to target_system_root for headers. */
134 static const char *target_sysroot_hdrs_suffix = 0;
136 /* Nonzero means write "temp" files in source directory
137 and use the source file's name in them, and don't delete them. */
139 static enum save_temps {
140 SAVE_TEMPS_NONE, /* no -save-temps */
141 SAVE_TEMPS_CWD, /* -save-temps in current directory */
142 SAVE_TEMPS_OBJ /* -save-temps in object directory */
143 } save_temps_flag;
145 /* Output file to use to get the object directory for -save-temps=obj */
146 static char *save_temps_prefix = 0;
147 static size_t save_temps_length = 0;
149 /* The compiler version. */
151 static const char *compiler_version;
153 /* The target version. */
155 static const char *const spec_version = DEFAULT_TARGET_VERSION;
157 /* The target machine. */
159 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
160 static const char *spec_host_machine = DEFAULT_REAL_TARGET_MACHINE;
162 /* List of offload targets. */
164 static char *offload_targets = NULL;
166 /* Nonzero if cross-compiling.
167 When -b is used, the value comes from the `specs' file. */
169 #ifdef CROSS_DIRECTORY_STRUCTURE
170 static const char *cross_compile = "1";
171 #else
172 static const char *cross_compile = "0";
173 #endif
175 /* Greatest exit code of sub-processes that has been encountered up to
176 now. */
177 static int greatest_status = 1;
179 /* This is the obstack which we use to allocate many strings. */
181 static struct obstack obstack;
183 /* This is the obstack to build an environment variable to pass to
184 collect2 that describes all of the relevant switches of what to
185 pass the compiler in building the list of pointers to constructors
186 and destructors. */
188 static struct obstack collect_obstack;
190 /* Forward declaration for prototypes. */
191 struct path_prefix;
192 struct prefix_list;
194 static void init_spec (void);
195 static void store_arg (const char *, int, int);
196 static void insert_wrapper (const char *);
197 static char *load_specs (const char *);
198 static void read_specs (const char *, bool, bool);
199 static void set_spec (const char *, const char *, bool);
200 static struct compiler *lookup_compiler (const char *, size_t, const char *);
201 static char *build_search_list (const struct path_prefix *, const char *,
202 bool, bool);
203 static void xputenv (const char *);
204 static void putenv_from_prefixes (const struct path_prefix *, const char *,
205 bool);
206 static int access_check (const char *, int);
207 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
208 static void add_prefix (struct path_prefix *, const char *, const char *,
209 int, int, int);
210 static void add_sysrooted_prefix (struct path_prefix *, const char *,
211 const char *, int, int, int);
212 static char *skip_whitespace (char *);
213 static void delete_if_ordinary (const char *);
214 static void delete_temp_files (void);
215 static void delete_failure_queue (void);
216 static void clear_failure_queue (void);
217 static int check_live_switch (int, int);
218 static const char *handle_braces (const char *);
219 static inline bool input_suffix_matches (const char *, const char *);
220 static inline bool switch_matches (const char *, const char *, int);
221 static inline void mark_matching_switches (const char *, const char *, int);
222 static inline void process_marked_switches (void);
223 static const char *process_brace_body (const char *, const char *, const char *, int, int);
224 static const struct spec_function *lookup_spec_function (const char *);
225 static const char *eval_spec_function (const char *, const char *);
226 static const char *handle_spec_function (const char *, bool *);
227 static char *save_string (const char *, int);
228 static void set_collect_gcc_options (void);
229 static int do_spec_1 (const char *, int, const char *);
230 static int do_spec_2 (const char *);
231 static void do_option_spec (const char *, const char *);
232 static void do_self_spec (const char *);
233 static const char *find_file (const char *);
234 static int is_directory (const char *, bool);
235 static const char *validate_switches (const char *, bool);
236 static void validate_all_switches (void);
237 static inline void validate_switches_from_spec (const char *, bool);
238 static void give_switch (int, int);
239 static int used_arg (const char *, int);
240 static int default_arg (const char *, int);
241 static void set_multilib_dir (void);
242 static void print_multilib_info (void);
243 static void perror_with_name (const char *);
244 static void display_help (void);
245 static void add_preprocessor_option (const char *, int);
246 static void add_assembler_option (const char *, int);
247 static void add_linker_option (const char *, int);
248 static void process_command (unsigned int, struct cl_decoded_option *);
249 static int execute (void);
250 static void alloc_args (void);
251 static void clear_args (void);
252 static void fatal_signal (int);
253 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
254 static void init_gcc_specs (struct obstack *, const char *, const char *,
255 const char *);
256 #endif
257 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
258 static const char *convert_filename (const char *, int, int);
259 #endif
261 static void try_generate_repro (const char **argv);
262 static const char *getenv_spec_function (int, const char **);
263 static const char *if_exists_spec_function (int, const char **);
264 static const char *if_exists_else_spec_function (int, const char **);
265 static const char *sanitize_spec_function (int, const char **);
266 static const char *replace_outfile_spec_function (int, const char **);
267 static const char *remove_outfile_spec_function (int, const char **);
268 static const char *version_compare_spec_function (int, const char **);
269 static const char *include_spec_function (int, const char **);
270 static const char *find_file_spec_function (int, const char **);
271 static const char *find_plugindir_spec_function (int, const char **);
272 static const char *print_asm_header_spec_function (int, const char **);
273 static const char *compare_debug_dump_opt_spec_function (int, const char **);
274 static const char *compare_debug_self_opt_spec_function (int, const char **);
275 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
276 static const char *pass_through_libs_spec_func (int, const char **);
277 static const char *replace_extension_spec_func (int, const char **);
278 static char *convert_white_space (char *);
280 /* The Specs Language
282 Specs are strings containing lines, each of which (if not blank)
283 is made up of a program name, and arguments separated by spaces.
284 The program name must be exact and start from root, since no path
285 is searched and it is unreliable to depend on the current working directory.
286 Redirection of input or output is not supported; the subprograms must
287 accept filenames saying what files to read and write.
289 In addition, the specs can contain %-sequences to substitute variable text
290 or for conditional text. Here is a table of all defined %-sequences.
291 Note that spaces are not generated automatically around the results of
292 expanding these sequences; therefore, you can concatenate them together
293 or with constant text in a single argument.
295 %% substitute one % into the program name or argument.
296 %i substitute the name of the input file being processed.
297 %b substitute the basename of the input file being processed.
298 This is the substring up to (and not including) the last period
299 and not including the directory unless -save-temps was specified
300 to put temporaries in a different location.
301 %B same as %b, but include the file suffix (text after the last period).
302 %gSUFFIX
303 substitute a file name that has suffix SUFFIX and is chosen
304 once per compilation, and mark the argument a la %d. To reduce
305 exposure to denial-of-service attacks, the file name is now
306 chosen in a way that is hard to predict even when previously
307 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
308 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
309 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
310 had been pre-processed. Previously, %g was simply substituted
311 with a file name chosen once per compilation, without regard
312 to any appended suffix (which was therefore treated just like
313 ordinary text), making such attacks more likely to succeed.
314 %|SUFFIX
315 like %g, but if -pipe is in effect, expands simply to "-".
316 %mSUFFIX
317 like %g, but if -pipe is in effect, expands to nothing. (We have both
318 %| and %m to accommodate differences between system assemblers; see
319 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
320 %uSUFFIX
321 like %g, but generates a new temporary file name even if %uSUFFIX
322 was already seen.
323 %USUFFIX
324 substitutes the last file name generated with %uSUFFIX, generating a
325 new one if there is no such last file name. In the absence of any
326 %uSUFFIX, this is just like %gSUFFIX, except they don't share
327 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
328 would involve the generation of two distinct file names, one
329 for each `%g.s' and another for each `%U.s'. Previously, %U was
330 simply substituted with a file name chosen for the previous %u,
331 without regard to any appended suffix.
332 %jSUFFIX
333 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
334 writable, and if save-temps is off; otherwise, substitute the name
335 of a temporary file, just like %u. This temporary file is not
336 meant for communication between processes, but rather as a junk
337 disposal mechanism.
338 %.SUFFIX
339 substitutes .SUFFIX for the suffixes of a matched switch's args when
340 it is subsequently output with %*. SUFFIX is terminated by the next
341 space or %.
342 %d marks the argument containing or following the %d as a
343 temporary file name, so that that file will be deleted if GCC exits
344 successfully. Unlike %g, this contributes no text to the argument.
345 %w marks the argument containing or following the %w as the
346 "output file" of this compilation. This puts the argument
347 into the sequence of arguments that %o will substitute later.
348 %V indicates that this compilation produces no "output file".
349 %W{...}
350 like %{...} but mark last argument supplied within
351 as a file to be deleted on failure.
352 %o substitutes the names of all the output files, with spaces
353 automatically placed around them. You should write spaces
354 around the %o as well or the results are undefined.
355 %o is for use in the specs for running the linker.
356 Input files whose names have no recognized suffix are not compiled
357 at all, but they are included among the output files, so they will
358 be linked.
359 %O substitutes the suffix for object files. Note that this is
360 handled specially when it immediately follows %g, %u, or %U
361 (with or without a suffix argument) because of the need for
362 those to form complete file names. The handling is such that
363 %O is treated exactly as if it had already been substituted,
364 except that %g, %u, and %U do not currently support additional
365 SUFFIX characters following %O as they would following, for
366 example, `.o'.
367 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
368 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
369 and -B options) and -imultilib as necessary.
370 %s current argument is the name of a library or startup file of some sort.
371 Search for that file in a standard list of directories
372 and substitute the full name found.
373 %eSTR Print STR as an error message. STR is terminated by a newline.
374 Use this when inconsistent options are detected.
375 %nSTR Print STR as a notice. STR is terminated by a newline.
376 %x{OPTION} Accumulate an option for %X.
377 %X Output the accumulated linker options specified by compilations.
378 %Y Output the accumulated assembler options specified by compilations.
379 %Z Output the accumulated preprocessor options specified by compilations.
380 %a process ASM_SPEC as a spec.
381 This allows config.h to specify part of the spec for running as.
382 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
383 used here. This can be used to run a post-processor after the
384 assembler has done its job.
385 %D Dump out a -L option for each directory in startfile_prefixes.
386 If multilib_dir is set, extra entries are generated with it affixed.
387 %l process LINK_SPEC as a spec.
388 %L process LIB_SPEC as a spec.
389 %M Output multilib_os_dir.
390 %G process LIBGCC_SPEC as a spec.
391 %R Output the concatenation of target_system_root and
392 target_sysroot_suffix.
393 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
394 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
395 %C process CPP_SPEC as a spec.
396 %1 process CC1_SPEC as a spec.
397 %2 process CC1PLUS_SPEC as a spec.
398 %* substitute the variable part of a matched option. (See below.)
399 Note that each comma in the substituted string is replaced by
400 a single space. A space is appended after the last substition
401 unless there is more text in current sequence.
402 %<S remove all occurrences of -S from the command line.
403 Note - this command is position dependent. % commands in the
404 spec string before this one will see -S, % commands in the
405 spec string after this one will not.
406 %>S Similar to "%<S", but keep it in the GCC command line.
407 %<S* remove all occurrences of all switches beginning with -S from the
408 command line.
409 %:function(args)
410 Call the named function FUNCTION, passing it ARGS. ARGS is
411 first processed as a nested spec string, then split into an
412 argument vector in the usual fashion. The function returns
413 a string which is processed as if it had appeared literally
414 as part of the current spec.
415 %{S} substitutes the -S switch, if that switch was given to GCC.
416 If that switch was not specified, this substitutes nothing.
417 Here S is a metasyntactic variable.
418 %{S*} substitutes all the switches specified to GCC whose names start
419 with -S. This is used for -o, -I, etc; switches that take
420 arguments. GCC considers `-o foo' as being one switch whose
421 name starts with `o'. %{o*} would substitute this text,
422 including the space; thus, two arguments would be generated.
423 %{S*&T*} likewise, but preserve order of S and T options (the order
424 of S and T in the spec is not significant). Can be any number
425 of ampersand-separated variables; for each the wild card is
426 optional. Useful for CPP as %{D*&U*&A*}.
428 %{S:X} substitutes X, if the -S switch was given to GCC.
429 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
430 %{S*:X} substitutes X if one or more switches whose names start
431 with -S was given to GCC. Normally X is substituted only
432 once, no matter how many such switches appeared. However,
433 if %* appears somewhere in X, then X will be substituted
434 once for each matching switch, with the %* replaced by the
435 part of that switch that matched the '*'. A space will be
436 appended after the last substition unless there is more
437 text in current sequence.
438 %{.S:X} substitutes X, if processing a file with suffix S.
439 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
440 %{,S:X} substitutes X, if processing a file which will use spec S.
441 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
443 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
444 combined with '!', '.', ',', and '*' as above binding stronger
445 than the OR.
446 If %* appears in X, all of the alternatives must be starred, and
447 only the first matching alternative is substituted.
448 %{%:function(args):X}
449 Call function named FUNCTION with args ARGS. If the function
450 returns non-NULL, then X is substituted, if it returns
451 NULL, it isn't substituted.
452 %{S:X; if S was given to GCC, substitutes X;
453 T:Y; else if T was given to GCC, substitutes Y;
454 :D} else substitutes D. There can be as many clauses as you need.
455 This may be combined with '.', '!', ',', '|', and '*' as above.
457 %(Spec) processes a specification defined in a specs file as *Spec:
459 The conditional text X in a %{S:X} or similar construct may contain
460 other nested % constructs or spaces, or even newlines. They are
461 processed as usual, as described above. Trailing white space in X is
462 ignored. White space may also appear anywhere on the left side of the
463 colon in these constructs, except between . or * and the corresponding
464 word.
466 The -O, -f, -g, -m, and -W switches are handled specifically in these
467 constructs. If another value of -O or the negated form of a -f, -m, or
468 -W switch is found later in the command line, the earlier switch
469 value is ignored, except with {S*} where S is just one letter; this
470 passes all matching options.
472 The character | at the beginning of the predicate text is used to indicate
473 that a command should be piped to the following command, but only if -pipe
474 is specified.
476 Note that it is built into GCC which switches take arguments and which
477 do not. You might think it would be useful to generalize this to
478 allow each compiler's spec to say which switches take arguments. But
479 this cannot be done in a consistent fashion. GCC cannot even decide
480 which input files have been specified without knowing which switches
481 take arguments, and it must know which input files to compile in order
482 to tell which compilers to run.
484 GCC also knows implicitly that arguments starting in `-l' are to be
485 treated as compiler output files, and passed to the linker in their
486 proper position among the other output files. */
488 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
490 /* config.h can define ASM_SPEC to provide extra args to the assembler
491 or extra switch-translations. */
492 #ifndef ASM_SPEC
493 #define ASM_SPEC ""
494 #endif
496 /* config.h can define ASM_FINAL_SPEC to run a post processor after
497 the assembler has run. */
498 #ifndef ASM_FINAL_SPEC
499 #define ASM_FINAL_SPEC \
500 "%{gsplit-dwarf: \n\
501 objcopy --extract-dwo \
502 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
503 %{c:%{o*:%:replace-extension(%{o*:%*} .dwo)}%{!o*:%b.dwo}}%{!c:%b.dwo} \n\
504 objcopy --strip-dwo \
505 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
507 #endif
509 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
510 or extra switch-translations. */
511 #ifndef CPP_SPEC
512 #define CPP_SPEC ""
513 #endif
515 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
516 or extra switch-translations. */
517 #ifndef CC1_SPEC
518 #define CC1_SPEC ""
519 #endif
521 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
522 or extra switch-translations. */
523 #ifndef CC1PLUS_SPEC
524 #define CC1PLUS_SPEC ""
525 #endif
527 /* config.h can define LINK_SPEC to provide extra args to the linker
528 or extra switch-translations. */
529 #ifndef LINK_SPEC
530 #define LINK_SPEC ""
531 #endif
533 /* config.h can define LIB_SPEC to override the default libraries. */
534 #ifndef LIB_SPEC
535 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
536 #endif
538 /* When using -fsplit-stack we need to wrap pthread_create, in order
539 to initialize the stack guard. We always use wrapping, rather than
540 shared library ordering, and we keep the wrapper function in
541 libgcc. This is not yet a real spec, though it could become one;
542 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
543 only works with GNU ld and gold. */
544 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
546 #ifndef LIBASAN_SPEC
547 #define STATIC_LIBASAN_LIBS \
548 " %{static-libasan:%:include(libsanitizer.spec)%(link_libasan)}"
549 #ifdef LIBASAN_EARLY_SPEC
550 #define LIBASAN_SPEC STATIC_LIBASAN_LIBS
551 #elif defined(HAVE_LD_STATIC_DYNAMIC)
552 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
553 "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
554 STATIC_LIBASAN_LIBS
555 #else
556 #define LIBASAN_SPEC "-lasan" STATIC_LIBASAN_LIBS
557 #endif
558 #endif
560 #ifndef LIBASAN_EARLY_SPEC
561 #define LIBASAN_EARLY_SPEC ""
562 #endif
564 #ifndef LIBTSAN_SPEC
565 #define STATIC_LIBTSAN_LIBS \
566 " %{static-libtsan:%:include(libsanitizer.spec)%(link_libtsan)}"
567 #ifdef LIBTSAN_EARLY_SPEC
568 #define LIBTSAN_SPEC STATIC_LIBTSAN_LIBS
569 #elif defined(HAVE_LD_STATIC_DYNAMIC)
570 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
571 "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}" \
572 STATIC_LIBTSAN_LIBS
573 #else
574 #define LIBTSAN_SPEC "-ltsan" STATIC_LIBTSAN_LIBS
575 #endif
576 #endif
578 #ifndef LIBTSAN_EARLY_SPEC
579 #define LIBTSAN_EARLY_SPEC ""
580 #endif
582 #ifndef LIBLSAN_SPEC
583 #define STATIC_LIBLSAN_LIBS \
584 " %{static-liblsan:%:include(libsanitizer.spec)%(link_liblsan)}"
585 #ifdef LIBLSAN_EARLY_SPEC
586 #define LIBLSAN_SPEC STATIC_LIBLSAN_LIBS
587 #elif defined(HAVE_LD_STATIC_DYNAMIC)
588 #define LIBLSAN_SPEC "%{static-liblsan:" LD_STATIC_OPTION \
589 "} -llsan %{static-liblsan:" LD_DYNAMIC_OPTION "}" \
590 STATIC_LIBLSAN_LIBS
591 #else
592 #define LIBLSAN_SPEC "-llsan" STATIC_LIBLSAN_LIBS
593 #endif
594 #endif
596 #ifndef LIBLSAN_EARLY_SPEC
597 #define LIBLSAN_EARLY_SPEC ""
598 #endif
600 #ifndef LIBUBSAN_SPEC
601 #define STATIC_LIBUBSAN_LIBS \
602 " %{static-libubsan:%:include(libsanitizer.spec)%(link_libubsan)}"
603 #ifdef HAVE_LD_STATIC_DYNAMIC
604 #define LIBUBSAN_SPEC "%{static-libubsan:" LD_STATIC_OPTION \
605 "} -lubsan %{static-libubsan:" LD_DYNAMIC_OPTION "}" \
606 STATIC_LIBUBSAN_LIBS
607 #else
608 #define LIBUBSAN_SPEC "-lubsan" STATIC_LIBUBSAN_LIBS
609 #endif
610 #endif
612 /* Linker options for compressed debug sections. */
613 #if HAVE_LD_COMPRESS_DEBUG == 0
614 /* No linker support. */
615 #define LINK_COMPRESS_DEBUG_SPEC \
616 " %{gz*:%e-gz is not supported in this configuration} "
617 #elif HAVE_LD_COMPRESS_DEBUG == 1
618 /* GNU style on input, GNU ld options. Reject, not useful. */
619 #define LINK_COMPRESS_DEBUG_SPEC \
620 " %{gz*:%e-gz is not supported in this configuration} "
621 #elif HAVE_LD_COMPRESS_DEBUG == 2
622 /* GNU style, GNU gold options. */
623 #define LINK_COMPRESS_DEBUG_SPEC \
624 " %{gz|gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
625 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
626 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
627 #elif HAVE_LD_COMPRESS_DEBUG == 3
628 /* ELF gABI style. */
629 #define LINK_COMPRESS_DEBUG_SPEC \
630 " %{gz|gz=zlib:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
631 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
632 " %{gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
633 #else
634 #error Unknown value for HAVE_LD_COMPRESS_DEBUG.
635 #endif
637 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
638 included. */
639 #ifndef LIBGCC_SPEC
640 #if defined(REAL_LIBGCC_SPEC)
641 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
642 #elif defined(LINK_LIBGCC_SPECIAL_1)
643 /* Have gcc do the search for libgcc.a. */
644 #define LIBGCC_SPEC "libgcc.a%s"
645 #else
646 #define LIBGCC_SPEC "-lgcc"
647 #endif
648 #endif
650 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
651 #ifndef STARTFILE_SPEC
652 #define STARTFILE_SPEC \
653 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
654 #endif
656 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
657 #ifndef ENDFILE_SPEC
658 #define ENDFILE_SPEC ""
659 #endif
661 #ifndef LINKER_NAME
662 #define LINKER_NAME "collect2"
663 #endif
665 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
666 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
667 #else
668 #define ASM_MAP ""
669 #endif
671 /* Assembler options for compressed debug sections. */
672 #if HAVE_LD_COMPRESS_DEBUG < 2
673 /* Reject if the linker cannot write compressed debug sections. */
674 #define ASM_COMPRESS_DEBUG_SPEC \
675 " %{gz*:%e-gz is not supported in this configuration} "
676 #else /* HAVE_LD_COMPRESS_DEBUG >= 2 */
677 #if HAVE_AS_COMPRESS_DEBUG == 0
678 /* No assembler support. Ignore silently. */
679 #define ASM_COMPRESS_DEBUG_SPEC \
680 " %{gz*:} "
681 #elif HAVE_AS_COMPRESS_DEBUG == 1
682 /* GNU style, GNU as options. */
683 #define ASM_COMPRESS_DEBUG_SPEC \
684 " %{gz|gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "}" \
685 " %{gz=none:" AS_NO_COMPRESS_DEBUG_OPTION "}" \
686 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
687 #elif HAVE_AS_COMPRESS_DEBUG == 2
688 /* ELF gABI style. */
689 #define ASM_COMPRESS_DEBUG_SPEC \
690 " %{gz|gz=zlib:" AS_COMPRESS_DEBUG_OPTION "=zlib}" \
691 " %{gz=none:" AS_COMPRESS_DEBUG_OPTION "=none}" \
692 " %{gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
693 #else
694 #error Unknown value for HAVE_AS_COMPRESS_DEBUG.
695 #endif
696 #endif /* HAVE_LD_COMPRESS_DEBUG >= 2 */
698 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
699 to the assembler. */
700 #ifndef ASM_DEBUG_SPEC
701 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
702 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
703 # define ASM_DEBUG_SPEC \
704 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
705 ? "%{!g0:%{gdwarf*:--gdwarf2}%{!gdwarf*:%{g*:--gstabs}}}" ASM_MAP \
706 : "%{!g0:%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
707 # else
708 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
709 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gstabs}}" ASM_MAP
710 # endif
711 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
712 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gdwarf2}}" ASM_MAP
713 # endif
714 # endif
715 #endif
716 #ifndef ASM_DEBUG_SPEC
717 # define ASM_DEBUG_SPEC ""
718 #endif
720 /* Here is the spec for running the linker, after compiling all files. */
722 /* This is overridable by the target in case they need to specify the
723 -lgcc and -lc order specially, yet not require them to override all
724 of LINK_COMMAND_SPEC. */
725 #ifndef LINK_GCC_C_SEQUENCE_SPEC
726 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
727 #endif
729 #ifndef LINK_SSP_SPEC
730 #ifdef TARGET_LIBC_PROVIDES_SSP
731 #define LINK_SSP_SPEC "%{fstack-protector:}"
732 #else
733 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-strong|fstack-protector-all:-lssp_nonshared -lssp}"
734 #endif
735 #endif
737 #ifndef LINK_PIE_SPEC
738 #ifdef HAVE_LD_PIE
739 #define LINK_PIE_SPEC "%{pie:-pie} "
740 #else
741 #define LINK_PIE_SPEC "%{pie:} "
742 #endif
743 #endif
745 #ifndef LINK_BUILDID_SPEC
746 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
747 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
748 # endif
749 #endif
751 /* Conditional to test whether the LTO plugin is used or not.
752 FIXME: For slim LTO we will need to enable plugin unconditionally. This
753 still cause problems with PLUGIN_LD != LD and when plugin is built but
754 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
755 plugin only when LTO is enabled. We still honor explicit
756 -fuse-linker-plugin if the linker used understands -plugin. */
758 /* The linker has some plugin support. */
759 #if HAVE_LTO_PLUGIN > 0
760 /* The linker used has full plugin support, use LTO plugin by default. */
761 #if HAVE_LTO_PLUGIN == 2
762 #define PLUGIN_COND "!fno-use-linker-plugin:%{!fno-lto"
763 #define PLUGIN_COND_CLOSE "}"
764 #else
765 /* The linker used has limited plugin support, use LTO plugin with explicit
766 -fuse-linker-plugin. */
767 #define PLUGIN_COND "fuse-linker-plugin"
768 #define PLUGIN_COND_CLOSE ""
769 #endif
770 #define LINK_PLUGIN_SPEC \
771 "%{"PLUGIN_COND": \
772 -plugin %(linker_plugin_file) \
773 -plugin-opt=%(lto_wrapper) \
774 -plugin-opt=-fresolution=%u.res \
775 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
776 }"PLUGIN_COND_CLOSE
777 #else
778 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
779 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
780 %e-fuse-linker-plugin is not supported in this configuration}"
781 #endif
783 /* Linker command line options for -fsanitize= early on the command line. */
784 #ifndef SANITIZER_EARLY_SPEC
785 #define SANITIZER_EARLY_SPEC "\
786 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_EARLY_SPEC "} \
787 %{%:sanitize(thread):" LIBTSAN_EARLY_SPEC "} \
788 %{%:sanitize(leak):" LIBLSAN_EARLY_SPEC "}}}"
789 #endif
791 /* Linker command line options for -fsanitize= late on the command line. */
792 #ifndef SANITIZER_SPEC
793 #define SANITIZER_SPEC "\
794 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_SPEC "\
795 %{static:%ecannot specify -static with -fsanitize=address}}\
796 %{%:sanitize(thread):" LIBTSAN_SPEC "\
797 %{!pie:%{!shared:%e-fsanitize=thread linking must be done with -pie or -shared}}}\
798 %{%:sanitize(undefined):" LIBUBSAN_SPEC "}\
799 %{%:sanitize(leak):" LIBLSAN_SPEC "}}}"
800 #endif
802 /* This is the spec to use, once the code for creating the vtable
803 verification runtime library, libvtv.so, has been created. Currently
804 the vtable verification runtime functions are in libstdc++, so we use
805 the spec just below this one. */
806 #ifndef VTABLE_VERIFICATION_SPEC
807 #define VTABLE_VERIFICATION_SPEC "\
808 %{!nostdlib:%{fvtable-verify=std: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}\
809 %{fvtable-verify=preinit: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}}"
810 #endif
812 /* -u* was put back because both BSD and SysV seem to support it. */
813 /* %{static:} simply prevents an error message if the target machine
814 doesn't handle -static. */
815 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
816 scripts which exist in user specified directories, or in standard
817 directories. */
818 /* We pass any -flto flags on to the linker, which is expected
819 to understand them. In practice, this means it had better be collect2. */
820 /* %{e*} includes -export-dynamic; see comment in common.opt. */
821 #ifndef LINK_COMMAND_SPEC
822 #define LINK_COMMAND_SPEC "\
823 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
824 %(linker) " \
825 LINK_PLUGIN_SPEC \
826 "%{flto|flto=*:%<fcompare-debug*} \
827 %{flto} %{fno-lto} %{flto=*} %l " LINK_PIE_SPEC \
828 "%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
829 "%X %{o*} %{e*} %{N} %{n} %{r}\
830 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}} " VTABLE_VERIFICATION_SPEC " \
831 %{static:} %{L*} %(mfwrap) %(link_libgcc) " SANITIZER_EARLY_SPEC " %o\
832 %{fopenmp|ftree-parallelize-loops=*:%:include(libgomp.spec)%(link_gomp)}\
833 %{fcilkplus:%:include(libcilkrts.spec)%(link_cilkrts)}\
834 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
835 %(mflib) " STACK_SPLIT_SPEC "\
836 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
837 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
838 %{!nostdlib:%{!nostartfiles:%E}} %{T*} }}}}}}"
839 #endif
841 #ifndef LINK_LIBGCC_SPEC
842 /* Generate -L options for startfile prefix list. */
843 # define LINK_LIBGCC_SPEC "%D"
844 #endif
846 #ifndef STARTFILE_PREFIX_SPEC
847 # define STARTFILE_PREFIX_SPEC ""
848 #endif
850 #ifndef SYSROOT_SPEC
851 # define SYSROOT_SPEC "--sysroot=%R"
852 #endif
854 #ifndef SYSROOT_SUFFIX_SPEC
855 # define SYSROOT_SUFFIX_SPEC ""
856 #endif
858 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
859 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
860 #endif
862 static const char *asm_debug = ASM_DEBUG_SPEC;
863 static const char *cpp_spec = CPP_SPEC;
864 static const char *cc1_spec = CC1_SPEC;
865 static const char *cc1plus_spec = CC1PLUS_SPEC;
866 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
867 static const char *link_ssp_spec = LINK_SSP_SPEC;
868 static const char *asm_spec = ASM_SPEC;
869 static const char *asm_final_spec = ASM_FINAL_SPEC;
870 static const char *link_spec = LINK_SPEC;
871 static const char *lib_spec = LIB_SPEC;
872 static const char *link_gomp_spec = "";
873 static const char *libgcc_spec = LIBGCC_SPEC;
874 static const char *endfile_spec = ENDFILE_SPEC;
875 static const char *startfile_spec = STARTFILE_SPEC;
876 static const char *linker_name_spec = LINKER_NAME;
877 static const char *linker_plugin_file_spec = "";
878 static const char *lto_wrapper_spec = "";
879 static const char *lto_gcc_spec = "";
880 static const char *link_command_spec = LINK_COMMAND_SPEC;
881 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
882 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
883 static const char *sysroot_spec = SYSROOT_SPEC;
884 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
885 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
886 static const char *self_spec = "";
888 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
889 There should be no need to override these in target dependent files,
890 but we need to copy them to the specs file so that newer versions
891 of the GCC driver can correctly drive older tool chains with the
892 appropriate -B options. */
894 /* When cpplib handles traditional preprocessing, get rid of this, and
895 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
896 that we default the front end language better. */
897 static const char *trad_capable_cpp =
898 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
900 /* We don't wrap .d files in %W{} since a missing .d file, and
901 therefore no dependency entry, confuses make into thinking a .o
902 file that happens to exist is up-to-date. */
903 static const char *cpp_unique_options =
904 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
905 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
906 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
907 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
908 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
909 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
910 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
911 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
912 %{E|M|MM:%W{o*}}";
914 /* This contains cpp options which are common with cc1_options and are passed
915 only when preprocessing only to avoid duplication. We pass the cc1 spec
916 options to the preprocessor so that it the cc1 spec may manipulate
917 options used to set target flags. Those special target flags settings may
918 in turn cause preprocessor symbols to be defined specially. */
919 static const char *cpp_options =
920 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
921 %{f*} %{g*:%{!g0:%{g*} %{!fno-working-directory:-fworking-directory}}} %{O*}\
922 %{undef} %{save-temps*:-fpch-preprocess}";
924 /* This contains cpp options which are not passed when the preprocessor
925 output will be used by another program. */
926 static const char *cpp_debug_options = "%{d*}";
928 /* NB: This is shared amongst all front-ends, except for Ada. */
929 static const char *cc1_options =
930 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
931 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
932 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
933 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
934 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
935 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
936 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
937 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
938 %{-target-help:--target-help}\
939 %{-version:--version}\
940 %{-help=*:--help=%*}\
941 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
942 %{fsyntax-only:-o %j} %{-param*}\
943 %{coverage:-fprofile-arcs -ftest-coverage}";
945 static const char *asm_options =
946 "%{-target-help:%:print-asm-header()} "
947 #if HAVE_GNU_AS
948 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
949 to the assembler equivalents. */
950 "%{v} %{w:-W} %{I*} "
951 #endif
952 ASM_COMPRESS_DEBUG_SPEC
953 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
955 static const char *invoke_as =
956 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
957 "%{!fwpa*:\
958 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
959 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
961 #else
962 "%{!fwpa*:\
963 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
964 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
966 #endif
968 /* Some compilers have limits on line lengths, and the multilib_select
969 and/or multilib_matches strings can be very long, so we build them at
970 run time. */
971 static struct obstack multilib_obstack;
972 static const char *multilib_select;
973 static const char *multilib_matches;
974 static const char *multilib_defaults;
975 static const char *multilib_exclusions;
976 static const char *multilib_reuse;
978 /* Check whether a particular argument is a default argument. */
980 #ifndef MULTILIB_DEFAULTS
981 #define MULTILIB_DEFAULTS { "" }
982 #endif
984 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
986 #ifndef DRIVER_SELF_SPECS
987 #define DRIVER_SELF_SPECS ""
988 #endif
990 /* Linking to libgomp implies pthreads. This is particularly important
991 for targets that use different start files and suchlike. */
992 #ifndef GOMP_SELF_SPECS
993 #define GOMP_SELF_SPECS "%{fopenmp|ftree-parallelize-loops=*: -pthread}"
994 #endif
996 /* Likewise for -fgnu-tm. */
997 #ifndef GTM_SELF_SPECS
998 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
999 #endif
1001 /* Likewise for -fcilkplus. */
1002 #ifndef CILK_SELF_SPECS
1003 #define CILK_SELF_SPECS "%{fcilkplus: -pthread}"
1004 #endif
1006 static const char *const driver_self_specs[] = {
1007 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
1008 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS,
1009 CILK_SELF_SPECS
1012 #ifndef OPTION_DEFAULT_SPECS
1013 #define OPTION_DEFAULT_SPECS { "", "" }
1014 #endif
1016 struct default_spec
1018 const char *name;
1019 const char *spec;
1022 static const struct default_spec
1023 option_default_specs[] = { OPTION_DEFAULT_SPECS };
1025 struct user_specs
1027 struct user_specs *next;
1028 const char *filename;
1031 static struct user_specs *user_specs_head, *user_specs_tail;
1034 /* Record the mapping from file suffixes for compilation specs. */
1036 struct compiler
1038 const char *suffix; /* Use this compiler for input files
1039 whose names end in this suffix. */
1041 const char *spec; /* To use this compiler, run this spec. */
1043 const char *cpp_spec; /* If non-NULL, substitute this spec
1044 for `%C', rather than the usual
1045 cpp_spec. */
1046 const int combinable; /* If nonzero, compiler can deal with
1047 multiple source files at once (IMA). */
1048 const int needs_preprocessing; /* If nonzero, source files need to
1049 be run through a preprocessor. */
1052 /* Pointer to a vector of `struct compiler' that gives the spec for
1053 compiling a file, based on its suffix.
1054 A file that does not end in any of these suffixes will be passed
1055 unchanged to the loader and nothing else will be done to it.
1057 An entry containing two 0s is used to terminate the vector.
1059 If multiple entries match a file, the last matching one is used. */
1061 static struct compiler *compilers;
1063 /* Number of entries in `compilers', not counting the null terminator. */
1065 static int n_compilers;
1067 /* The default list of file name suffixes and their compilation specs. */
1069 static const struct compiler default_compilers[] =
1071 /* Add lists of suffixes of known languages here. If those languages
1072 were not present when we built the driver, we will hit these copies
1073 and be given a more meaningful error than "file not used since
1074 linking is not done". */
1075 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
1076 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
1077 {".mii", "#Objective-C++", 0, 0, 0},
1078 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
1079 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
1080 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
1081 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
1082 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
1083 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
1084 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
1085 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
1086 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
1087 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
1088 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
1089 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1090 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1091 {".r", "#Ratfor", 0, 0, 0},
1092 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
1093 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
1094 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
1095 {".go", "#Go", 0, 1, 0},
1096 /* Next come the entries for C. */
1097 {".c", "@c", 0, 0, 1},
1098 {"@c",
1099 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1100 external preprocessor if -save-temps is given. */
1101 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1102 %{!E:%{!M:%{!MM:\
1103 %{traditional:\
1104 %eGNU C no longer supports -traditional without -E}\
1105 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1106 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1107 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1108 %(cc1_options)}\
1109 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1110 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1111 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1112 {"-",
1113 "%{!E:%e-E or -x required when input is from standard input}\
1114 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1115 {".h", "@c-header", 0, 0, 0},
1116 {"@c-header",
1117 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1118 external preprocessor if -save-temps is given. */
1119 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1120 %{!E:%{!M:%{!MM:\
1121 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1122 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1123 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1124 %(cc1_options)\
1125 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1126 %W{o*:--output-pch=%*}}%V}\
1127 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1128 cc1 %(cpp_unique_options) %(cc1_options)\
1129 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1130 %W{o*:--output-pch=%*}}%V}}}}}}", 0, 0, 0},
1131 {".i", "@cpp-output", 0, 0, 0},
1132 {"@cpp-output",
1133 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1134 {".s", "@assembler", 0, 0, 0},
1135 {"@assembler",
1136 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1137 {".sx", "@assembler-with-cpp", 0, 0, 0},
1138 {".S", "@assembler-with-cpp", 0, 0, 0},
1139 {"@assembler-with-cpp",
1140 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1141 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1142 %{E|M|MM:%(cpp_debug_options)}\
1143 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1144 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1145 #else
1146 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1147 %{E|M|MM:%(cpp_debug_options)}\
1148 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1149 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1150 #endif
1151 , 0, 0, 0},
1153 #include "specs.h"
1154 /* Mark end of table. */
1155 {0, 0, 0, 0, 0}
1158 /* Number of elements in default_compilers, not counting the terminator. */
1160 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1162 typedef char *char_p; /* For DEF_VEC_P. */
1164 /* A vector of options to give to the linker.
1165 These options are accumulated by %x,
1166 and substituted into the linker command with %X. */
1167 static vec<char_p> linker_options;
1169 /* A vector of options to give to the assembler.
1170 These options are accumulated by -Wa,
1171 and substituted into the assembler command with %Y. */
1172 static vec<char_p> assembler_options;
1174 /* A vector of options to give to the preprocessor.
1175 These options are accumulated by -Wp,
1176 and substituted into the preprocessor command with %Z. */
1177 static vec<char_p> preprocessor_options;
1179 static char *
1180 skip_whitespace (char *p)
1182 while (1)
1184 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1185 be considered whitespace. */
1186 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1187 return p + 1;
1188 else if (*p == '\n' || *p == ' ' || *p == '\t')
1189 p++;
1190 else if (*p == '#')
1192 while (*p != '\n')
1193 p++;
1194 p++;
1196 else
1197 break;
1200 return p;
1202 /* Structures to keep track of prefixes to try when looking for files. */
1204 struct prefix_list
1206 const char *prefix; /* String to prepend to the path. */
1207 struct prefix_list *next; /* Next in linked list. */
1208 int require_machine_suffix; /* Don't use without machine_suffix. */
1209 /* 2 means try both machine_suffix and just_machine_suffix. */
1210 int priority; /* Sort key - priority within list. */
1211 int os_multilib; /* 1 if OS multilib scheme should be used,
1212 0 for GCC multilib scheme. */
1215 struct path_prefix
1217 struct prefix_list *plist; /* List of prefixes to try */
1218 int max_len; /* Max length of a prefix in PLIST */
1219 const char *name; /* Name of this list (used in config stuff) */
1222 /* List of prefixes to try when looking for executables. */
1224 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1226 /* List of prefixes to try when looking for startup (crt0) files. */
1228 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1230 /* List of prefixes to try when looking for include files. */
1232 static struct path_prefix include_prefixes = { 0, 0, "include" };
1234 /* Suffix to attach to directories searched for commands.
1235 This looks like `MACHINE/VERSION/'. */
1237 static const char *machine_suffix = 0;
1239 /* Suffix to attach to directories searched for commands.
1240 This is just `MACHINE/'. */
1242 static const char *just_machine_suffix = 0;
1244 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1246 static const char *gcc_exec_prefix;
1248 /* Adjusted value of standard_libexec_prefix. */
1250 static const char *gcc_libexec_prefix;
1252 /* Default prefixes to attach to command names. */
1254 #ifndef STANDARD_STARTFILE_PREFIX_1
1255 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1256 #endif
1257 #ifndef STANDARD_STARTFILE_PREFIX_2
1258 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1259 #endif
1261 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1262 #undef MD_EXEC_PREFIX
1263 #undef MD_STARTFILE_PREFIX
1264 #undef MD_STARTFILE_PREFIX_1
1265 #endif
1267 /* If no prefixes defined, use the null string, which will disable them. */
1268 #ifndef MD_EXEC_PREFIX
1269 #define MD_EXEC_PREFIX ""
1270 #endif
1271 #ifndef MD_STARTFILE_PREFIX
1272 #define MD_STARTFILE_PREFIX ""
1273 #endif
1274 #ifndef MD_STARTFILE_PREFIX_1
1275 #define MD_STARTFILE_PREFIX_1 ""
1276 #endif
1278 /* These directories are locations set at configure-time based on the
1279 --prefix option provided to configure. Their initializers are
1280 defined in Makefile.in. These paths are not *directly* used when
1281 gcc_exec_prefix is set because, in that case, we know where the
1282 compiler has been installed, and use paths relative to that
1283 location instead. */
1284 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1285 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1286 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1287 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1289 /* For native compilers, these are well-known paths containing
1290 components that may be provided by the system. For cross
1291 compilers, these paths are not used. */
1292 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1293 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1294 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1295 static const char *const standard_startfile_prefix_1
1296 = STANDARD_STARTFILE_PREFIX_1;
1297 static const char *const standard_startfile_prefix_2
1298 = STANDARD_STARTFILE_PREFIX_2;
1300 /* A relative path to be used in finding the location of tools
1301 relative to the driver. */
1302 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1304 /* A prefix to be used when this is an accelerator compiler. */
1305 static const char *const accel_dir_suffix = ACCEL_DIR_SUFFIX;
1307 /* Subdirectory to use for locating libraries. Set by
1308 set_multilib_dir based on the compilation options. */
1310 static const char *multilib_dir;
1312 /* Subdirectory to use for locating libraries in OS conventions. Set by
1313 set_multilib_dir based on the compilation options. */
1315 static const char *multilib_os_dir;
1317 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1318 set_multilib_dir based on the compilation options. */
1320 static const char *multiarch_dir;
1322 /* Structure to keep track of the specs that have been defined so far.
1323 These are accessed using %(specname) in a compiler or link
1324 spec. */
1326 struct spec_list
1328 /* The following 2 fields must be first */
1329 /* to allow EXTRA_SPECS to be initialized */
1330 const char *name; /* name of the spec. */
1331 const char *ptr; /* available ptr if no static pointer */
1333 /* The following fields are not initialized */
1334 /* by EXTRA_SPECS */
1335 const char **ptr_spec; /* pointer to the spec itself. */
1336 struct spec_list *next; /* Next spec in linked list. */
1337 int name_len; /* length of the name */
1338 bool user_p; /* whether string come from file spec. */
1339 bool alloc_p; /* whether string was allocated */
1342 #define INIT_STATIC_SPEC(NAME,PTR) \
1343 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false }
1345 /* List of statically defined specs. */
1346 static struct spec_list static_specs[] =
1348 INIT_STATIC_SPEC ("asm", &asm_spec),
1349 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1350 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1351 INIT_STATIC_SPEC ("asm_options", &asm_options),
1352 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1353 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1354 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1355 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1356 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1357 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1358 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1359 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1360 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1361 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1362 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1363 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1364 INIT_STATIC_SPEC ("link", &link_spec),
1365 INIT_STATIC_SPEC ("lib", &lib_spec),
1366 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1367 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1368 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1369 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1370 INIT_STATIC_SPEC ("version", &compiler_version),
1371 INIT_STATIC_SPEC ("multilib", &multilib_select),
1372 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1373 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1374 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1375 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1376 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1377 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1378 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1379 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1380 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1381 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1382 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1383 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1384 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1385 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1386 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1387 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1388 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1389 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1390 INIT_STATIC_SPEC ("self_spec", &self_spec),
1393 #ifdef EXTRA_SPECS /* additional specs needed */
1394 /* Structure to keep track of just the first two args of a spec_list.
1395 That is all that the EXTRA_SPECS macro gives us. */
1396 struct spec_list_1
1398 const char *const name;
1399 const char *const ptr;
1402 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1403 static struct spec_list *extra_specs = (struct spec_list *) 0;
1404 #endif
1406 /* List of dynamically allocates specs that have been defined so far. */
1408 static struct spec_list *specs = (struct spec_list *) 0;
1410 /* List of static spec functions. */
1412 static const struct spec_function static_spec_functions[] =
1414 { "getenv", getenv_spec_function },
1415 { "if-exists", if_exists_spec_function },
1416 { "if-exists-else", if_exists_else_spec_function },
1417 { "sanitize", sanitize_spec_function },
1418 { "replace-outfile", replace_outfile_spec_function },
1419 { "remove-outfile", remove_outfile_spec_function },
1420 { "version-compare", version_compare_spec_function },
1421 { "include", include_spec_function },
1422 { "find-file", find_file_spec_function },
1423 { "find-plugindir", find_plugindir_spec_function },
1424 { "print-asm-header", print_asm_header_spec_function },
1425 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1426 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1427 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1428 { "pass-through-libs", pass_through_libs_spec_func },
1429 { "replace-extension", replace_extension_spec_func },
1430 #ifdef EXTRA_SPEC_FUNCTIONS
1431 EXTRA_SPEC_FUNCTIONS
1432 #endif
1433 { 0, 0 }
1436 static int processing_spec_function;
1438 /* Add appropriate libgcc specs to OBSTACK, taking into account
1439 various permutations of -shared-libgcc, -shared, and such. */
1441 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1443 #ifndef USE_LD_AS_NEEDED
1444 #define USE_LD_AS_NEEDED 0
1445 #endif
1447 static void
1448 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1449 const char *static_name, const char *eh_name)
1451 char *buf;
1453 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1454 "%{!static:%{!static-libgcc:"
1455 #if USE_LD_AS_NEEDED
1456 "%{!shared-libgcc:",
1457 static_name, " " LD_AS_NEEDED_OPTION " ",
1458 shared_name, " " LD_NO_AS_NEEDED_OPTION
1460 "%{shared-libgcc:",
1461 shared_name, "%{!shared: ", static_name, "}"
1463 #else
1464 "%{!shared:"
1465 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1466 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1468 #ifdef LINK_EH_SPEC
1469 "%{shared:"
1470 "%{shared-libgcc:", shared_name, "}"
1471 "%{!shared-libgcc:", static_name, "}"
1473 #else
1474 "%{shared:", shared_name, "}"
1475 #endif
1476 #endif
1477 "}}", NULL);
1479 obstack_grow (obstack, buf, strlen (buf));
1480 free (buf);
1482 #endif /* ENABLE_SHARED_LIBGCC */
1484 /* Initialize the specs lookup routines. */
1486 static void
1487 init_spec (void)
1489 struct spec_list *next = (struct spec_list *) 0;
1490 struct spec_list *sl = (struct spec_list *) 0;
1491 int i;
1493 if (specs)
1494 return; /* Already initialized. */
1496 if (verbose_flag)
1497 fnotice (stderr, "Using built-in specs.\n");
1499 #ifdef EXTRA_SPECS
1500 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1502 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1504 sl = &extra_specs[i];
1505 sl->name = extra_specs_1[i].name;
1506 sl->ptr = extra_specs_1[i].ptr;
1507 sl->next = next;
1508 sl->name_len = strlen (sl->name);
1509 sl->ptr_spec = &sl->ptr;
1510 next = sl;
1512 #endif
1514 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1516 sl = &static_specs[i];
1517 sl->next = next;
1518 next = sl;
1521 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1522 /* ??? If neither -shared-libgcc nor --static-libgcc was
1523 seen, then we should be making an educated guess. Some proposed
1524 heuristics for ELF include:
1526 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1527 program will be doing dynamic loading, which will likely
1528 need the shared libgcc.
1530 (2) If "-ldl", then it's also a fair bet that we're doing
1531 dynamic loading.
1533 (3) For each ET_DYN we're linking against (either through -lfoo
1534 or /some/path/foo.so), check to see whether it or one of
1535 its dependencies depends on a shared libgcc.
1537 (4) If "-shared"
1539 If the runtime is fixed to look for program headers instead
1540 of calling __register_frame_info at all, for each object,
1541 use the shared libgcc if any EH symbol referenced.
1543 If crtstuff is fixed to not invoke __register_frame_info
1544 automatically, for each object, use the shared libgcc if
1545 any non-empty unwind section found.
1547 Doing any of this probably requires invoking an external program to
1548 do the actual object file scanning. */
1550 const char *p = libgcc_spec;
1551 int in_sep = 1;
1553 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1554 when given the proper command line arguments. */
1555 while (*p)
1557 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1559 init_gcc_specs (&obstack,
1560 "-lgcc_s"
1561 #ifdef USE_LIBUNWIND_EXCEPTIONS
1562 " -lunwind"
1563 #endif
1565 "-lgcc",
1566 "-lgcc_eh"
1567 #ifdef USE_LIBUNWIND_EXCEPTIONS
1568 # ifdef HAVE_LD_STATIC_DYNAMIC
1569 " %{!static:" LD_STATIC_OPTION "} -lunwind"
1570 " %{!static:" LD_DYNAMIC_OPTION "}"
1571 # else
1572 " -lunwind"
1573 # endif
1574 #endif
1577 p += 5;
1578 in_sep = 0;
1580 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1582 /* Ug. We don't know shared library extensions. Hope that
1583 systems that use this form don't do shared libraries. */
1584 init_gcc_specs (&obstack,
1585 "-lgcc_s",
1586 "libgcc.a%s",
1587 "libgcc_eh.a%s"
1588 #ifdef USE_LIBUNWIND_EXCEPTIONS
1589 " -lunwind"
1590 #endif
1592 p += 10;
1593 in_sep = 0;
1595 else
1597 obstack_1grow (&obstack, *p);
1598 in_sep = (*p == ' ');
1599 p += 1;
1603 obstack_1grow (&obstack, '\0');
1604 libgcc_spec = XOBFINISH (&obstack, const char *);
1606 #endif
1607 #ifdef USE_AS_TRADITIONAL_FORMAT
1608 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1610 static const char tf[] = "--traditional-format ";
1611 obstack_grow (&obstack, tf, sizeof (tf) - 1);
1612 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1613 asm_spec = XOBFINISH (&obstack, const char *);
1615 #endif
1617 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1618 defined LINKER_HASH_STYLE
1619 # ifdef LINK_BUILDID_SPEC
1620 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1621 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof (LINK_BUILDID_SPEC) - 1);
1622 # endif
1623 # ifdef LINK_EH_SPEC
1624 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1625 obstack_grow (&obstack, LINK_EH_SPEC, sizeof (LINK_EH_SPEC) - 1);
1626 # endif
1627 # ifdef LINKER_HASH_STYLE
1628 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1629 before. */
1631 static const char hash_style[] = "--hash-style=";
1632 obstack_grow (&obstack, hash_style, sizeof (hash_style) - 1);
1633 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof (LINKER_HASH_STYLE) - 1);
1634 obstack_1grow (&obstack, ' ');
1636 # endif
1637 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1638 link_spec = XOBFINISH (&obstack, const char *);
1639 #endif
1641 specs = sl;
1644 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1645 removed; If the spec starts with a + then SPEC is added to the end of the
1646 current spec. */
1648 static void
1649 set_spec (const char *name, const char *spec, bool user_p)
1651 struct spec_list *sl;
1652 const char *old_spec;
1653 int name_len = strlen (name);
1654 int i;
1656 /* If this is the first call, initialize the statically allocated specs. */
1657 if (!specs)
1659 struct spec_list *next = (struct spec_list *) 0;
1660 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1662 sl = &static_specs[i];
1663 sl->next = next;
1664 next = sl;
1666 specs = sl;
1669 /* See if the spec already exists. */
1670 for (sl = specs; sl; sl = sl->next)
1671 if (name_len == sl->name_len && !strcmp (sl->name, name))
1672 break;
1674 if (!sl)
1676 /* Not found - make it. */
1677 sl = XNEW (struct spec_list);
1678 sl->name = xstrdup (name);
1679 sl->name_len = name_len;
1680 sl->ptr_spec = &sl->ptr;
1681 sl->alloc_p = 0;
1682 *(sl->ptr_spec) = "";
1683 sl->next = specs;
1684 specs = sl;
1687 old_spec = *(sl->ptr_spec);
1688 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1689 ? concat (old_spec, spec + 1, NULL)
1690 : xstrdup (spec));
1692 #ifdef DEBUG_SPECS
1693 if (verbose_flag)
1694 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1695 #endif
1697 /* Free the old spec. */
1698 if (old_spec && sl->alloc_p)
1699 free (CONST_CAST (char *, old_spec));
1701 sl->user_p = user_p;
1702 sl->alloc_p = true;
1705 /* Accumulate a command (program name and args), and run it. */
1707 typedef const char *const_char_p; /* For DEF_VEC_P. */
1709 /* Vector of pointers to arguments in the current line of specifications. */
1711 static vec<const_char_p> argbuf;
1713 /* Were the options -c, -S or -E passed. */
1714 static int have_c = 0;
1716 /* Was the option -o passed. */
1717 static int have_o = 0;
1719 /* Pointer to output file name passed in with -o. */
1720 static const char *output_file = 0;
1722 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1723 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1724 it here. */
1726 static struct temp_name {
1727 const char *suffix; /* suffix associated with the code. */
1728 int length; /* strlen (suffix). */
1729 int unique; /* Indicates whether %g or %u/%U was used. */
1730 const char *filename; /* associated filename. */
1731 int filename_length; /* strlen (filename). */
1732 struct temp_name *next;
1733 } *temp_names;
1735 /* Number of commands executed so far. */
1737 static int execution_count;
1739 /* Number of commands that exited with a signal. */
1741 static int signal_count;
1743 /* Allocate the argument vector. */
1745 static void
1746 alloc_args (void)
1748 argbuf.create (10);
1751 /* Clear out the vector of arguments (after a command is executed). */
1753 static void
1754 clear_args (void)
1756 argbuf.truncate (0);
1759 /* Add one argument to the vector at the end.
1760 This is done when a space is seen or at the end of the line.
1761 If DELETE_ALWAYS is nonzero, the arg is a filename
1762 and the file should be deleted eventually.
1763 If DELETE_FAILURE is nonzero, the arg is a filename
1764 and the file should be deleted if this compilation fails. */
1766 static void
1767 store_arg (const char *arg, int delete_always, int delete_failure)
1769 argbuf.safe_push (arg);
1771 if (delete_always || delete_failure)
1773 const char *p;
1774 /* If the temporary file we should delete is specified as
1775 part of a joined argument extract the filename. */
1776 if (arg[0] == '-'
1777 && (p = strrchr (arg, '=')))
1778 arg = p + 1;
1779 record_temp_file (arg, delete_always, delete_failure);
1783 /* Load specs from a file name named FILENAME, replacing occurrences of
1784 various different types of line-endings, \r\n, \n\r and just \r, with
1785 a single \n. */
1787 static char *
1788 load_specs (const char *filename)
1790 int desc;
1791 int readlen;
1792 struct stat statbuf;
1793 char *buffer;
1794 char *buffer_p;
1795 char *specs;
1796 char *specs_p;
1798 if (verbose_flag)
1799 fnotice (stderr, "Reading specs from %s\n", filename);
1801 /* Open and stat the file. */
1802 desc = open (filename, O_RDONLY, 0);
1803 if (desc < 0)
1804 pfatal_with_name (filename);
1805 if (stat (filename, &statbuf) < 0)
1806 pfatal_with_name (filename);
1808 /* Read contents of file into BUFFER. */
1809 buffer = XNEWVEC (char, statbuf.st_size + 1);
1810 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1811 if (readlen < 0)
1812 pfatal_with_name (filename);
1813 buffer[readlen] = 0;
1814 close (desc);
1816 specs = XNEWVEC (char, readlen + 1);
1817 specs_p = specs;
1818 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1820 int skip = 0;
1821 char c = *buffer_p;
1822 if (c == '\r')
1824 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1825 skip = 1;
1826 else if (*(buffer_p + 1) == '\n') /* \r\n */
1827 skip = 1;
1828 else /* \r */
1829 c = '\n';
1831 if (! skip)
1832 *specs_p++ = c;
1834 *specs_p = '\0';
1836 free (buffer);
1837 return (specs);
1840 /* Read compilation specs from a file named FILENAME,
1841 replacing the default ones.
1843 A suffix which starts with `*' is a definition for
1844 one of the machine-specific sub-specs. The "suffix" should be
1845 *asm, *cc1, *cpp, *link, *startfile, etc.
1846 The corresponding spec is stored in asm_spec, etc.,
1847 rather than in the `compilers' vector.
1849 Anything invalid in the file is a fatal error. */
1851 static void
1852 read_specs (const char *filename, bool main_p, bool user_p)
1854 char *buffer;
1855 char *p;
1857 buffer = load_specs (filename);
1859 /* Scan BUFFER for specs, putting them in the vector. */
1860 p = buffer;
1861 while (1)
1863 char *suffix;
1864 char *spec;
1865 char *in, *out, *p1, *p2, *p3;
1867 /* Advance P in BUFFER to the next nonblank nocomment line. */
1868 p = skip_whitespace (p);
1869 if (*p == 0)
1870 break;
1872 /* Is this a special command that starts with '%'? */
1873 /* Don't allow this for the main specs file, since it would
1874 encourage people to overwrite it. */
1875 if (*p == '%' && !main_p)
1877 p1 = p;
1878 while (*p && *p != '\n')
1879 p++;
1881 /* Skip '\n'. */
1882 p++;
1884 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1885 && (p1[sizeof "%include" - 1] == ' '
1886 || p1[sizeof "%include" - 1] == '\t'))
1888 char *new_filename;
1890 p1 += sizeof ("%include");
1891 while (*p1 == ' ' || *p1 == '\t')
1892 p1++;
1894 if (*p1++ != '<' || p[-2] != '>')
1895 fatal_error ("specs %%include syntax malformed after "
1896 "%ld characters",
1897 (long) (p1 - buffer + 1));
1899 p[-2] = '\0';
1900 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1901 read_specs (new_filename ? new_filename : p1, false, user_p);
1902 continue;
1904 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1905 && (p1[sizeof "%include_noerr" - 1] == ' '
1906 || p1[sizeof "%include_noerr" - 1] == '\t'))
1908 char *new_filename;
1910 p1 += sizeof "%include_noerr";
1911 while (*p1 == ' ' || *p1 == '\t')
1912 p1++;
1914 if (*p1++ != '<' || p[-2] != '>')
1915 fatal_error ("specs %%include syntax malformed after "
1916 "%ld characters",
1917 (long) (p1 - buffer + 1));
1919 p[-2] = '\0';
1920 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1921 if (new_filename)
1922 read_specs (new_filename, false, user_p);
1923 else if (verbose_flag)
1924 fnotice (stderr, "could not find specs file %s\n", p1);
1925 continue;
1927 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1928 && (p1[sizeof "%rename" - 1] == ' '
1929 || p1[sizeof "%rename" - 1] == '\t'))
1931 int name_len;
1932 struct spec_list *sl;
1933 struct spec_list *newsl;
1935 /* Get original name. */
1936 p1 += sizeof "%rename";
1937 while (*p1 == ' ' || *p1 == '\t')
1938 p1++;
1940 if (! ISALPHA ((unsigned char) *p1))
1941 fatal_error ("specs %%rename syntax malformed after "
1942 "%ld characters",
1943 (long) (p1 - buffer));
1945 p2 = p1;
1946 while (*p2 && !ISSPACE ((unsigned char) *p2))
1947 p2++;
1949 if (*p2 != ' ' && *p2 != '\t')
1950 fatal_error ("specs %%rename syntax malformed after "
1951 "%ld characters",
1952 (long) (p2 - buffer));
1954 name_len = p2 - p1;
1955 *p2++ = '\0';
1956 while (*p2 == ' ' || *p2 == '\t')
1957 p2++;
1959 if (! ISALPHA ((unsigned char) *p2))
1960 fatal_error ("specs %%rename syntax malformed after "
1961 "%ld characters",
1962 (long) (p2 - buffer));
1964 /* Get new spec name. */
1965 p3 = p2;
1966 while (*p3 && !ISSPACE ((unsigned char) *p3))
1967 p3++;
1969 if (p3 != p - 1)
1970 fatal_error ("specs %%rename syntax malformed after "
1971 "%ld characters",
1972 (long) (p3 - buffer));
1973 *p3 = '\0';
1975 for (sl = specs; sl; sl = sl->next)
1976 if (name_len == sl->name_len && !strcmp (sl->name, p1))
1977 break;
1979 if (!sl)
1980 fatal_error ("specs %s spec was not found to be renamed", p1);
1982 if (strcmp (p1, p2) == 0)
1983 continue;
1985 for (newsl = specs; newsl; newsl = newsl->next)
1986 if (strcmp (newsl->name, p2) == 0)
1987 fatal_error ("%s: attempt to rename spec %qs to "
1988 "already defined spec %qs",
1989 filename, p1, p2);
1991 if (verbose_flag)
1993 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
1994 #ifdef DEBUG_SPECS
1995 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
1996 #endif
1999 set_spec (p2, *(sl->ptr_spec), user_p);
2000 if (sl->alloc_p)
2001 free (CONST_CAST (char *, *(sl->ptr_spec)));
2003 *(sl->ptr_spec) = "";
2004 sl->alloc_p = 0;
2005 continue;
2007 else
2008 fatal_error ("specs unknown %% command after %ld characters",
2009 (long) (p1 - buffer));
2012 /* Find the colon that should end the suffix. */
2013 p1 = p;
2014 while (*p1 && *p1 != ':' && *p1 != '\n')
2015 p1++;
2017 /* The colon shouldn't be missing. */
2018 if (*p1 != ':')
2019 fatal_error ("specs file malformed after %ld characters",
2020 (long) (p1 - buffer));
2022 /* Skip back over trailing whitespace. */
2023 p2 = p1;
2024 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2025 p2--;
2027 /* Copy the suffix to a string. */
2028 suffix = save_string (p, p2 - p);
2029 /* Find the next line. */
2030 p = skip_whitespace (p1 + 1);
2031 if (p[1] == 0)
2032 fatal_error ("specs file malformed after %ld characters",
2033 (long) (p - buffer));
2035 p1 = p;
2036 /* Find next blank line or end of string. */
2037 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2038 p1++;
2040 /* Specs end at the blank line and do not include the newline. */
2041 spec = save_string (p, p1 - p);
2042 p = p1;
2044 /* Delete backslash-newline sequences from the spec. */
2045 in = spec;
2046 out = spec;
2047 while (*in != 0)
2049 if (in[0] == '\\' && in[1] == '\n')
2050 in += 2;
2051 else if (in[0] == '#')
2052 while (*in && *in != '\n')
2053 in++;
2055 else
2056 *out++ = *in++;
2058 *out = 0;
2060 if (suffix[0] == '*')
2062 if (! strcmp (suffix, "*link_command"))
2063 link_command_spec = spec;
2064 else
2065 set_spec (suffix + 1, spec, user_p);
2067 else
2069 /* Add this pair to the vector. */
2070 compilers
2071 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
2073 compilers[n_compilers].suffix = suffix;
2074 compilers[n_compilers].spec = spec;
2075 n_compilers++;
2076 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2079 if (*suffix == 0)
2080 link_command_spec = spec;
2083 if (link_command_spec == 0)
2084 fatal_error ("spec file has no spec for linking");
2087 /* Record the names of temporary files we tell compilers to write,
2088 and delete them at the end of the run. */
2090 /* This is the common prefix we use to make temp file names.
2091 It is chosen once for each run of this program.
2092 It is substituted into a spec by %g or %j.
2093 Thus, all temp file names contain this prefix.
2094 In practice, all temp file names start with this prefix.
2096 This prefix comes from the envvar TMPDIR if it is defined;
2097 otherwise, from the P_tmpdir macro if that is defined;
2098 otherwise, in /usr/tmp or /tmp;
2099 or finally the current directory if all else fails. */
2101 static const char *temp_filename;
2103 /* Length of the prefix. */
2105 static int temp_filename_length;
2107 /* Define the list of temporary files to delete. */
2109 struct temp_file
2111 const char *name;
2112 struct temp_file *next;
2115 /* Queue of files to delete on success or failure of compilation. */
2116 static struct temp_file *always_delete_queue;
2117 /* Queue of files to delete on failure of compilation. */
2118 static struct temp_file *failure_delete_queue;
2120 /* Record FILENAME as a file to be deleted automatically.
2121 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2122 otherwise delete it in any case.
2123 FAIL_DELETE nonzero means delete it if a compilation step fails;
2124 otherwise delete it in any case. */
2126 void
2127 record_temp_file (const char *filename, int always_delete, int fail_delete)
2129 char *const name = xstrdup (filename);
2131 if (always_delete)
2133 struct temp_file *temp;
2134 for (temp = always_delete_queue; temp; temp = temp->next)
2135 if (! filename_cmp (name, temp->name))
2136 goto already1;
2138 temp = XNEW (struct temp_file);
2139 temp->next = always_delete_queue;
2140 temp->name = name;
2141 always_delete_queue = temp;
2143 already1:;
2146 if (fail_delete)
2148 struct temp_file *temp;
2149 for (temp = failure_delete_queue; temp; temp = temp->next)
2150 if (! filename_cmp (name, temp->name))
2152 free (name);
2153 goto already2;
2156 temp = XNEW (struct temp_file);
2157 temp->next = failure_delete_queue;
2158 temp->name = name;
2159 failure_delete_queue = temp;
2161 already2:;
2165 /* Delete all the temporary files whose names we previously recorded. */
2167 #ifndef DELETE_IF_ORDINARY
2168 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2169 do \
2171 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2172 if (unlink (NAME) < 0) \
2173 if (VERBOSE_FLAG) \
2174 perror_with_name (NAME); \
2175 } while (0)
2176 #endif
2178 static void
2179 delete_if_ordinary (const char *name)
2181 struct stat st;
2182 #ifdef DEBUG
2183 int i, c;
2185 printf ("Delete %s? (y or n) ", name);
2186 fflush (stdout);
2187 i = getchar ();
2188 if (i != '\n')
2189 while ((c = getchar ()) != '\n' && c != EOF)
2192 if (i == 'y' || i == 'Y')
2193 #endif /* DEBUG */
2194 DELETE_IF_ORDINARY (name, st, verbose_flag);
2197 static void
2198 delete_temp_files (void)
2200 struct temp_file *temp;
2202 for (temp = always_delete_queue; temp; temp = temp->next)
2203 delete_if_ordinary (temp->name);
2204 always_delete_queue = 0;
2207 /* Delete all the files to be deleted on error. */
2209 static void
2210 delete_failure_queue (void)
2212 struct temp_file *temp;
2214 for (temp = failure_delete_queue; temp; temp = temp->next)
2215 delete_if_ordinary (temp->name);
2218 static void
2219 clear_failure_queue (void)
2221 failure_delete_queue = 0;
2224 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2225 returns non-NULL.
2226 If DO_MULTI is true iterate over the paths twice, first with multilib
2227 suffix then without, otherwise iterate over the paths once without
2228 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2229 to avoid visiting the same path twice, but we could do better. For
2230 instance, /usr/lib/../lib is considered different from /usr/lib.
2231 At least EXTRA_SPACE chars past the end of the path passed to
2232 CALLBACK are available for use by the callback.
2233 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2235 Returns the value returned by CALLBACK. */
2237 static void *
2238 for_each_path (const struct path_prefix *paths,
2239 bool do_multi,
2240 size_t extra_space,
2241 void *(*callback) (char *, void *),
2242 void *callback_info)
2244 struct prefix_list *pl;
2245 const char *multi_dir = NULL;
2246 const char *multi_os_dir = NULL;
2247 const char *multiarch_suffix = NULL;
2248 const char *multi_suffix;
2249 const char *just_multi_suffix;
2250 char *path = NULL;
2251 void *ret = NULL;
2252 bool skip_multi_dir = false;
2253 bool skip_multi_os_dir = false;
2255 multi_suffix = machine_suffix;
2256 just_multi_suffix = just_machine_suffix;
2257 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2259 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2260 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2261 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2263 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2264 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2265 if (multiarch_dir)
2266 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2268 while (1)
2270 size_t multi_dir_len = 0;
2271 size_t multi_os_dir_len = 0;
2272 size_t multiarch_len = 0;
2273 size_t suffix_len;
2274 size_t just_suffix_len;
2275 size_t len;
2277 if (multi_dir)
2278 multi_dir_len = strlen (multi_dir);
2279 if (multi_os_dir)
2280 multi_os_dir_len = strlen (multi_os_dir);
2281 if (multiarch_suffix)
2282 multiarch_len = strlen (multiarch_suffix);
2283 suffix_len = strlen (multi_suffix);
2284 just_suffix_len = strlen (just_multi_suffix);
2286 if (path == NULL)
2288 len = paths->max_len + extra_space + 1;
2289 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2290 path = XNEWVEC (char, len);
2293 for (pl = paths->plist; pl != 0; pl = pl->next)
2295 len = strlen (pl->prefix);
2296 memcpy (path, pl->prefix, len);
2298 /* Look first in MACHINE/VERSION subdirectory. */
2299 if (!skip_multi_dir)
2301 memcpy (path + len, multi_suffix, suffix_len + 1);
2302 ret = callback (path, callback_info);
2303 if (ret)
2304 break;
2307 /* Some paths are tried with just the machine (ie. target)
2308 subdir. This is used for finding as, ld, etc. */
2309 if (!skip_multi_dir
2310 && pl->require_machine_suffix == 2)
2312 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2313 ret = callback (path, callback_info);
2314 if (ret)
2315 break;
2318 /* Now try the multiarch path. */
2319 if (!skip_multi_dir
2320 && !pl->require_machine_suffix && multiarch_dir)
2322 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2323 ret = callback (path, callback_info);
2324 if (ret)
2325 break;
2328 /* Now try the base path. */
2329 if (!pl->require_machine_suffix
2330 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2332 const char *this_multi;
2333 size_t this_multi_len;
2335 if (pl->os_multilib)
2337 this_multi = multi_os_dir;
2338 this_multi_len = multi_os_dir_len;
2340 else
2342 this_multi = multi_dir;
2343 this_multi_len = multi_dir_len;
2346 if (this_multi_len)
2347 memcpy (path + len, this_multi, this_multi_len + 1);
2348 else
2349 path[len] = '\0';
2351 ret = callback (path, callback_info);
2352 if (ret)
2353 break;
2356 if (pl)
2357 break;
2359 if (multi_dir == NULL && multi_os_dir == NULL)
2360 break;
2362 /* Run through the paths again, this time without multilibs.
2363 Don't repeat any we have already seen. */
2364 if (multi_dir)
2366 free (CONST_CAST (char *, multi_dir));
2367 multi_dir = NULL;
2368 free (CONST_CAST (char *, multi_suffix));
2369 multi_suffix = machine_suffix;
2370 free (CONST_CAST (char *, just_multi_suffix));
2371 just_multi_suffix = just_machine_suffix;
2373 else
2374 skip_multi_dir = true;
2375 if (multi_os_dir)
2377 free (CONST_CAST (char *, multi_os_dir));
2378 multi_os_dir = NULL;
2380 else
2381 skip_multi_os_dir = true;
2384 if (multi_dir)
2386 free (CONST_CAST (char *, multi_dir));
2387 free (CONST_CAST (char *, multi_suffix));
2388 free (CONST_CAST (char *, just_multi_suffix));
2390 if (multi_os_dir)
2391 free (CONST_CAST (char *, multi_os_dir));
2392 if (ret != path)
2393 free (path);
2394 return ret;
2397 /* Callback for build_search_list. Adds path to obstack being built. */
2399 struct add_to_obstack_info {
2400 struct obstack *ob;
2401 bool check_dir;
2402 bool first_time;
2405 static void *
2406 add_to_obstack (char *path, void *data)
2408 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2410 if (info->check_dir && !is_directory (path, false))
2411 return NULL;
2413 if (!info->first_time)
2414 obstack_1grow (info->ob, PATH_SEPARATOR);
2416 obstack_grow (info->ob, path, strlen (path));
2418 info->first_time = false;
2419 return NULL;
2422 /* Add or change the value of an environment variable, outputting the
2423 change to standard error if in verbose mode. */
2424 static void
2425 xputenv (const char *string)
2427 if (verbose_flag)
2428 fnotice (stderr, "%s\n", string);
2429 putenv (CONST_CAST (char *, string));
2432 /* Build a list of search directories from PATHS.
2433 PREFIX is a string to prepend to the list.
2434 If CHECK_DIR_P is true we ensure the directory exists.
2435 If DO_MULTI is true, multilib paths are output first, then
2436 non-multilib paths.
2437 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2438 It is also used by the --print-search-dirs flag. */
2440 static char *
2441 build_search_list (const struct path_prefix *paths, const char *prefix,
2442 bool check_dir, bool do_multi)
2444 struct add_to_obstack_info info;
2446 info.ob = &collect_obstack;
2447 info.check_dir = check_dir;
2448 info.first_time = true;
2450 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2451 obstack_1grow (&collect_obstack, '=');
2453 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2455 obstack_1grow (&collect_obstack, '\0');
2456 return XOBFINISH (&collect_obstack, char *);
2459 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2460 for collect. */
2462 static void
2463 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2464 bool do_multi)
2466 xputenv (build_search_list (paths, env_var, true, do_multi));
2469 /* Check whether NAME can be accessed in MODE. This is like access,
2470 except that it never considers directories to be executable. */
2472 static int
2473 access_check (const char *name, int mode)
2475 if (mode == X_OK)
2477 struct stat st;
2479 if (stat (name, &st) < 0
2480 || S_ISDIR (st.st_mode))
2481 return -1;
2484 return access (name, mode);
2487 /* Callback for find_a_file. Appends the file name to the directory
2488 path. If the resulting file exists in the right mode, return the
2489 full pathname to the file. */
2491 struct file_at_path_info {
2492 const char *name;
2493 const char *suffix;
2494 int name_len;
2495 int suffix_len;
2496 int mode;
2499 static void *
2500 file_at_path (char *path, void *data)
2502 struct file_at_path_info *info = (struct file_at_path_info *) data;
2503 size_t len = strlen (path);
2505 memcpy (path + len, info->name, info->name_len);
2506 len += info->name_len;
2508 /* Some systems have a suffix for executable files.
2509 So try appending that first. */
2510 if (info->suffix_len)
2512 memcpy (path + len, info->suffix, info->suffix_len + 1);
2513 if (access_check (path, info->mode) == 0)
2514 return path;
2517 path[len] = '\0';
2518 if (access_check (path, info->mode) == 0)
2519 return path;
2521 return NULL;
2524 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2525 access to check permissions. If DO_MULTI is true, search multilib
2526 paths then non-multilib paths, otherwise do not search multilib paths.
2527 Return 0 if not found, otherwise return its name, allocated with malloc. */
2529 static char *
2530 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2531 bool do_multi)
2533 struct file_at_path_info info;
2535 #ifdef DEFAULT_ASSEMBLER
2536 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2537 return xstrdup (DEFAULT_ASSEMBLER);
2538 #endif
2540 #ifdef DEFAULT_LINKER
2541 if (! strcmp (name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2542 return xstrdup (DEFAULT_LINKER);
2543 #endif
2545 /* Determine the filename to execute (special case for absolute paths). */
2547 if (IS_ABSOLUTE_PATH (name))
2549 if (access (name, mode) == 0)
2550 return xstrdup (name);
2552 return NULL;
2555 info.name = name;
2556 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2557 info.name_len = strlen (info.name);
2558 info.suffix_len = strlen (info.suffix);
2559 info.mode = mode;
2561 return (char*) for_each_path (pprefix, do_multi,
2562 info.name_len + info.suffix_len,
2563 file_at_path, &info);
2566 /* Ranking of prefixes in the sort list. -B prefixes are put before
2567 all others. */
2569 enum path_prefix_priority
2571 PREFIX_PRIORITY_B_OPT,
2572 PREFIX_PRIORITY_LAST
2575 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2576 order according to PRIORITY. Within each PRIORITY, new entries are
2577 appended.
2579 If WARN is nonzero, we will warn if no file is found
2580 through this prefix. WARN should point to an int
2581 which will be set to 1 if this entry is used.
2583 COMPONENT is the value to be passed to update_path.
2585 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2586 the complete value of machine_suffix.
2587 2 means try both machine_suffix and just_machine_suffix. */
2589 static void
2590 add_prefix (struct path_prefix *pprefix, const char *prefix,
2591 const char *component, /* enum prefix_priority */ int priority,
2592 int require_machine_suffix, int os_multilib)
2594 struct prefix_list *pl, **prev;
2595 int len;
2597 for (prev = &pprefix->plist;
2598 (*prev) != NULL && (*prev)->priority <= priority;
2599 prev = &(*prev)->next)
2602 /* Keep track of the longest prefix. */
2604 prefix = update_path (prefix, component);
2605 len = strlen (prefix);
2606 if (len > pprefix->max_len)
2607 pprefix->max_len = len;
2609 pl = XNEW (struct prefix_list);
2610 pl->prefix = prefix;
2611 pl->require_machine_suffix = require_machine_suffix;
2612 pl->priority = priority;
2613 pl->os_multilib = os_multilib;
2615 /* Insert after PREV. */
2616 pl->next = (*prev);
2617 (*prev) = pl;
2620 /* Same as add_prefix, but prepending target_system_root to prefix. */
2621 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2622 static void
2623 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2624 const char *component,
2625 /* enum prefix_priority */ int priority,
2626 int require_machine_suffix, int os_multilib)
2628 if (!IS_ABSOLUTE_PATH (prefix))
2629 fatal_error ("system path %qs is not absolute", prefix);
2631 if (target_system_root)
2633 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2634 size_t sysroot_len = strlen (target_system_root);
2636 if (sysroot_len > 0
2637 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2638 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2640 if (target_sysroot_suffix)
2641 prefix = concat (sysroot_no_trailing_dir_separator,
2642 target_sysroot_suffix, prefix, NULL);
2643 else
2644 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2646 free (sysroot_no_trailing_dir_separator);
2648 /* We have to override this because GCC's notion of sysroot
2649 moves along with GCC. */
2650 component = "GCC";
2653 add_prefix (pprefix, prefix, component, priority,
2654 require_machine_suffix, os_multilib);
2657 /* Execute the command specified by the arguments on the current line of spec.
2658 When using pipes, this includes several piped-together commands
2659 with `|' between them.
2661 Return 0 if successful, -1 if failed. */
2663 static int
2664 execute (void)
2666 int i;
2667 int n_commands; /* # of command. */
2668 char *string;
2669 struct pex_obj *pex;
2670 struct command
2672 const char *prog; /* program name. */
2673 const char **argv; /* vector of args. */
2675 const char *arg;
2677 struct command *commands; /* each command buffer with above info. */
2679 gcc_assert (!processing_spec_function);
2681 if (wrapper_string)
2683 string = find_a_file (&exec_prefixes,
2684 argbuf[0], X_OK, false);
2685 if (string)
2686 argbuf[0] = string;
2687 insert_wrapper (wrapper_string);
2690 /* Count # of piped commands. */
2691 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2692 if (strcmp (arg, "|") == 0)
2693 n_commands++;
2695 /* Get storage for each command. */
2696 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2698 /* Split argbuf into its separate piped processes,
2699 and record info about each one.
2700 Also search for the programs that are to be run. */
2702 argbuf.safe_push (0);
2704 commands[0].prog = argbuf[0]; /* first command. */
2705 commands[0].argv = argbuf.address ();
2707 if (!wrapper_string)
2709 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2710 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2713 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2714 if (arg && strcmp (arg, "|") == 0)
2715 { /* each command. */
2716 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2717 fatal_error ("-pipe not supported");
2718 #endif
2719 argbuf[i] = 0; /* Termination of
2720 command args. */
2721 commands[n_commands].prog = argbuf[i + 1];
2722 commands[n_commands].argv
2723 = &(argbuf.address ())[i + 1];
2724 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2725 X_OK, false);
2726 if (string)
2727 commands[n_commands].argv[0] = string;
2728 n_commands++;
2731 /* If -v, print what we are about to do, and maybe query. */
2733 if (verbose_flag)
2735 /* For help listings, put a blank line between sub-processes. */
2736 if (print_help_list)
2737 fputc ('\n', stderr);
2739 /* Print each piped command as a separate line. */
2740 for (i = 0; i < n_commands; i++)
2742 const char *const *j;
2744 if (verbose_only_flag)
2746 for (j = commands[i].argv; *j; j++)
2748 const char *p;
2749 for (p = *j; *p; ++p)
2750 if (!ISALNUM ((unsigned char) *p)
2751 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2752 break;
2753 if (*p || !*j)
2755 fprintf (stderr, " \"");
2756 for (p = *j; *p; ++p)
2758 if (*p == '"' || *p == '\\' || *p == '$')
2759 fputc ('\\', stderr);
2760 fputc (*p, stderr);
2762 fputc ('"', stderr);
2764 /* If it's empty, print "". */
2765 else if (!**j)
2766 fprintf (stderr, " \"\"");
2767 else
2768 fprintf (stderr, " %s", *j);
2771 else
2772 for (j = commands[i].argv; *j; j++)
2773 /* If it's empty, print "". */
2774 if (!**j)
2775 fprintf (stderr, " \"\"");
2776 else
2777 fprintf (stderr, " %s", *j);
2779 /* Print a pipe symbol after all but the last command. */
2780 if (i + 1 != n_commands)
2781 fprintf (stderr, " |");
2782 fprintf (stderr, "\n");
2784 fflush (stderr);
2785 if (verbose_only_flag != 0)
2787 /* verbose_only_flag should act as if the spec was
2788 executed, so increment execution_count before
2789 returning. This prevents spurious warnings about
2790 unused linker input files, etc. */
2791 execution_count++;
2792 return 0;
2794 #ifdef DEBUG
2795 fnotice (stderr, "\nGo ahead? (y or n) ");
2796 fflush (stderr);
2797 i = getchar ();
2798 if (i != '\n')
2799 while (getchar () != '\n')
2802 if (i != 'y' && i != 'Y')
2803 return 0;
2804 #endif /* DEBUG */
2807 #ifdef ENABLE_VALGRIND_CHECKING
2808 /* Run the each command through valgrind. To simplify prepending the
2809 path to valgrind and the option "-q" (for quiet operation unless
2810 something triggers), we allocate a separate argv array. */
2812 for (i = 0; i < n_commands; i++)
2814 const char **argv;
2815 int argc;
2816 int j;
2818 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2821 argv = XALLOCAVEC (const char *, argc + 3);
2823 argv[0] = VALGRIND_PATH;
2824 argv[1] = "-q";
2825 for (j = 2; j < argc + 2; j++)
2826 argv[j] = commands[i].argv[j - 2];
2827 argv[j] = NULL;
2829 commands[i].argv = argv;
2830 commands[i].prog = argv[0];
2832 #endif
2834 /* Run each piped subprocess. */
2836 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
2837 ? PEX_RECORD_TIMES : 0),
2838 progname, temp_filename);
2839 if (pex == NULL)
2840 fatal_error ("pex_init failed: %m");
2842 for (i = 0; i < n_commands; i++)
2844 const char *errmsg;
2845 int err;
2846 const char *string = commands[i].argv[0];
2848 errmsg = pex_run (pex,
2849 ((i + 1 == n_commands ? PEX_LAST : 0)
2850 | (string == commands[i].prog ? PEX_SEARCH : 0)),
2851 string, CONST_CAST (char **, commands[i].argv),
2852 NULL, NULL, &err);
2853 if (errmsg != NULL)
2855 if (err == 0)
2856 fatal_error (errmsg);
2857 else
2859 errno = err;
2860 pfatal_with_name (errmsg);
2864 if (i && string != commands[i].prog)
2865 free (CONST_CAST (char *, string));
2868 execution_count++;
2870 /* Wait for all the subprocesses to finish. */
2873 int *statuses;
2874 struct pex_time *times = NULL;
2875 int ret_code = 0;
2877 statuses = (int *) alloca (n_commands * sizeof (int));
2878 if (!pex_get_status (pex, n_commands, statuses))
2879 fatal_error ("failed to get exit status: %m");
2881 if (report_times || report_times_to_file)
2883 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
2884 if (!pex_get_times (pex, n_commands, times))
2885 fatal_error ("failed to get process times: %m");
2888 pex_free (pex);
2890 for (i = 0; i < n_commands; ++i)
2892 int status = statuses[i];
2894 if (WIFSIGNALED (status))
2896 #ifdef SIGPIPE
2897 /* SIGPIPE is a special case. It happens in -pipe mode
2898 when the compiler dies before the preprocessor is done,
2899 or the assembler dies before the compiler is done.
2900 There's generally been an error already, and this is
2901 just fallout. So don't generate another error unless
2902 we would otherwise have succeeded. */
2903 if (WTERMSIG (status) == SIGPIPE
2904 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2906 signal_count++;
2907 ret_code = -1;
2909 else
2910 #endif
2911 internal_error ("%s (program %s)",
2912 strsignal (WTERMSIG (status)), commands[i].prog);
2914 else if (WIFEXITED (status)
2915 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2917 /* For ICEs in cc1, cc1obj, cc1plus see if it is
2918 reproducible or not. */
2919 const char *p;
2920 if (flag_report_bug
2921 && WEXITSTATUS (status) == ICE_EXIT_CODE
2922 && i == 0
2923 && (p = strrchr (commands[0].argv[0], DIR_SEPARATOR))
2924 && ! strncmp (p + 1, "cc1", 3))
2925 try_generate_repro (commands[0].argv);
2926 if (WEXITSTATUS (status) > greatest_status)
2927 greatest_status = WEXITSTATUS (status);
2928 ret_code = -1;
2931 if (report_times || report_times_to_file)
2933 struct pex_time *pt = &times[i];
2934 double ut, st;
2936 ut = ((double) pt->user_seconds
2937 + (double) pt->user_microseconds / 1.0e6);
2938 st = ((double) pt->system_seconds
2939 + (double) pt->system_microseconds / 1.0e6);
2941 if (ut + st != 0)
2943 if (report_times)
2944 fnotice (stderr, "# %s %.2f %.2f\n",
2945 commands[i].prog, ut, st);
2947 if (report_times_to_file)
2949 int c = 0;
2950 const char *const *j;
2952 fprintf (report_times_to_file, "%g %g", ut, st);
2954 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
2956 const char *p;
2957 for (p = *j; *p; ++p)
2958 if (*p == '"' || *p == '\\' || *p == '$'
2959 || ISSPACE (*p))
2960 break;
2962 if (*p)
2964 fprintf (report_times_to_file, " \"");
2965 for (p = *j; *p; ++p)
2967 if (*p == '"' || *p == '\\' || *p == '$')
2968 fputc ('\\', report_times_to_file);
2969 fputc (*p, report_times_to_file);
2971 fputc ('"', report_times_to_file);
2973 else
2974 fprintf (report_times_to_file, " %s", *j);
2977 fputc ('\n', report_times_to_file);
2983 if (commands[0].argv[0] != commands[0].prog)
2984 free (CONST_CAST (char *, commands[0].argv[0]));
2986 return ret_code;
2990 /* Find all the switches given to us
2991 and make a vector describing them.
2992 The elements of the vector are strings, one per switch given.
2993 If a switch uses following arguments, then the `part1' field
2994 is the switch itself and the `args' field
2995 is a null-terminated vector containing the following arguments.
2996 Bits in the `live_cond' field are:
2997 SWITCH_LIVE to indicate this switch is true in a conditional spec.
2998 SWITCH_FALSE to indicate this switch is overridden by a later switch.
2999 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
3000 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored
3001 in all do_spec calls afterwards. Used for %<S from self specs.
3002 The `validated' field is nonzero if any spec has looked at this switch;
3003 if it remains zero at the end of the run, it must be meaningless. */
3005 #define SWITCH_LIVE (1 << 0)
3006 #define SWITCH_FALSE (1 << 1)
3007 #define SWITCH_IGNORE (1 << 2)
3008 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
3009 #define SWITCH_KEEP_FOR_GCC (1 << 4)
3011 struct switchstr
3013 const char *part1;
3014 const char **args;
3015 unsigned int live_cond;
3016 bool known;
3017 bool validated;
3018 bool ordering;
3021 static struct switchstr *switches;
3023 static int n_switches;
3025 static int n_switches_alloc;
3027 /* Set to zero if -fcompare-debug is disabled, positive if it's
3028 enabled and we're running the first compilation, negative if it's
3029 enabled and we're running the second compilation. For most of the
3030 time, it's in the range -1..1, but it can be temporarily set to 2
3031 or 3 to indicate that the -fcompare-debug flags didn't come from
3032 the command-line, but rather from the GCC_COMPARE_DEBUG environment
3033 variable, until a synthesized -fcompare-debug flag is added to the
3034 command line. */
3035 int compare_debug;
3037 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
3038 int compare_debug_second;
3040 /* Set to the flags that should be passed to the second compilation in
3041 a -fcompare-debug compilation. */
3042 const char *compare_debug_opt;
3044 static struct switchstr *switches_debug_check[2];
3046 static int n_switches_debug_check[2];
3048 static int n_switches_alloc_debug_check[2];
3050 static char *debug_check_temp_file[2];
3052 /* Language is one of three things:
3054 1) The name of a real programming language.
3055 2) NULL, indicating that no one has figured out
3056 what it is yet.
3057 3) '*', indicating that the file should be passed
3058 to the linker. */
3059 struct infile
3061 const char *name;
3062 const char *language;
3063 struct compiler *incompiler;
3064 bool compiled;
3065 bool preprocessed;
3068 /* Also a vector of input files specified. */
3070 static struct infile *infiles;
3072 int n_infiles;
3074 static int n_infiles_alloc;
3076 /* True if multiple input files are being compiled to a single
3077 assembly file. */
3079 static bool combine_inputs;
3081 /* This counts the number of libraries added by lang_specific_driver, so that
3082 we can tell if there were any user supplied any files or libraries. */
3084 static int added_libraries;
3086 /* And a vector of corresponding output files is made up later. */
3088 const char **outfiles;
3090 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3092 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3093 is true if we should look for an executable suffix. DO_OBJ
3094 is true if we should look for an object suffix. */
3096 static const char *
3097 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3098 int do_obj ATTRIBUTE_UNUSED)
3100 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3101 int i;
3102 #endif
3103 int len;
3105 if (name == NULL)
3106 return NULL;
3108 len = strlen (name);
3110 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3111 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3112 if (do_obj && len > 2
3113 && name[len - 2] == '.'
3114 && name[len - 1] == 'o')
3116 obstack_grow (&obstack, name, len - 2);
3117 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3118 name = XOBFINISH (&obstack, const char *);
3120 #endif
3122 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3123 /* If there is no filetype, make it the executable suffix (which includes
3124 the "."). But don't get confused if we have just "-o". */
3125 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3126 return name;
3128 for (i = len - 1; i >= 0; i--)
3129 if (IS_DIR_SEPARATOR (name[i]))
3130 break;
3132 for (i++; i < len; i++)
3133 if (name[i] == '.')
3134 return name;
3136 obstack_grow (&obstack, name, len);
3137 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3138 strlen (TARGET_EXECUTABLE_SUFFIX));
3139 name = XOBFINISH (&obstack, const char *);
3140 #endif
3142 return name;
3144 #endif
3146 /* Display the command line switches accepted by gcc. */
3147 static void
3148 display_help (void)
3150 printf (_("Usage: %s [options] file...\n"), progname);
3151 fputs (_("Options:\n"), stdout);
3153 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3154 fputs (_(" --help Display this information\n"), stdout);
3155 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3156 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...]\n"), stdout);
3157 fputs (_(" Display specific types of command line options\n"), stdout);
3158 if (! verbose_flag)
3159 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3160 fputs (_(" --version Display compiler version information\n"), stdout);
3161 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3162 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3163 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3164 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3165 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3166 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3167 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3168 fputs (_("\
3169 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3170 a component in the library path\n"), stdout);
3171 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3172 fputs (_("\
3173 -print-multi-lib Display the mapping between command line options and\n\
3174 multiple library search directories\n"), stdout);
3175 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3176 fputs (_(" -print-sysroot Display the target libraries directory\n"), stdout);
3177 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
3178 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3179 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3180 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3181 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3182 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3183 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3184 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3185 fputs (_(" -save-temps=<arg> Do not delete intermediate files\n"), stdout);
3186 fputs (_("\
3187 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3188 prefixes to other gcc components\n"), stdout);
3189 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3190 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3191 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3192 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3193 fputs (_("\
3194 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3195 and libraries\n"), stdout);
3196 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3197 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3198 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3199 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3200 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3201 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3202 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3203 fputs (_(" -pie Create a position independent executable\n"), stdout);
3204 fputs (_(" -shared Create a shared library\n"), stdout);
3205 fputs (_("\
3206 -x <language> Specify the language of the following input files\n\
3207 Permissible languages include: c c++ assembler none\n\
3208 'none' means revert to the default behavior of\n\
3209 guessing the language based on the file's extension\n\
3210 "), stdout);
3212 printf (_("\
3213 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3214 passed on to the various sub-processes invoked by %s. In order to pass\n\
3215 other options on to these processes the -W<letter> options must be used.\n\
3216 "), progname);
3218 /* The rest of the options are displayed by invocations of the various
3219 sub-processes. */
3222 static void
3223 add_preprocessor_option (const char *option, int len)
3225 preprocessor_options.safe_push (save_string (option, len));
3228 static void
3229 add_assembler_option (const char *option, int len)
3231 assembler_options.safe_push (save_string (option, len));
3234 static void
3235 add_linker_option (const char *option, int len)
3237 linker_options.safe_push (save_string (option, len));
3240 /* Allocate space for an input file in infiles. */
3242 static void
3243 alloc_infile (void)
3245 if (n_infiles_alloc == 0)
3247 n_infiles_alloc = 16;
3248 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3250 else if (n_infiles_alloc == n_infiles)
3252 n_infiles_alloc *= 2;
3253 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3257 /* Store an input file with the given NAME and LANGUAGE in
3258 infiles. */
3260 static void
3261 add_infile (const char *name, const char *language)
3263 alloc_infile ();
3264 infiles[n_infiles].name = name;
3265 infiles[n_infiles++].language = language;
3268 /* Allocate space for a switch in switches. */
3270 static void
3271 alloc_switch (void)
3273 if (n_switches_alloc == 0)
3275 n_switches_alloc = 16;
3276 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3278 else if (n_switches_alloc == n_switches)
3280 n_switches_alloc *= 2;
3281 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3285 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3286 as validated if VALIDATED and KNOWN if it is an internal switch. */
3288 static void
3289 save_switch (const char *opt, size_t n_args, const char *const *args,
3290 bool validated, bool known)
3292 alloc_switch ();
3293 switches[n_switches].part1 = opt + 1;
3294 if (n_args == 0)
3295 switches[n_switches].args = 0;
3296 else
3298 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3299 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3300 switches[n_switches].args[n_args] = NULL;
3303 switches[n_switches].live_cond = 0;
3304 switches[n_switches].validated = validated;
3305 switches[n_switches].known = known;
3306 switches[n_switches].ordering = 0;
3307 n_switches++;
3310 /* Handle an option DECODED that is unknown to the option-processing
3311 machinery. */
3313 static bool
3314 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3316 const char *opt = decoded->arg;
3317 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3318 && !(decoded->errors & CL_ERR_NEGATIVE))
3320 /* Leave unknown -Wno-* options for the compiler proper, to be
3321 diagnosed only if there are warnings. */
3322 save_switch (decoded->canonical_option[0],
3323 decoded->canonical_option_num_elements - 1,
3324 &decoded->canonical_option[1], false, true);
3325 return false;
3327 if (decoded->opt_index == OPT_SPECIAL_unknown)
3329 /* Give it a chance to define it a a spec file. */
3330 save_switch (decoded->canonical_option[0],
3331 decoded->canonical_option_num_elements - 1,
3332 &decoded->canonical_option[1], false, false);
3333 return false;
3335 else
3336 return true;
3339 /* Handle an option DECODED that is not marked as CL_DRIVER.
3340 LANG_MASK will always be CL_DRIVER. */
3342 static void
3343 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3344 unsigned int lang_mask ATTRIBUTE_UNUSED)
3346 /* At this point, non-driver options are accepted (and expected to
3347 be passed down by specs) unless marked to be rejected by the
3348 driver. Options to be rejected by the driver but accepted by the
3349 compilers proper are treated just like completely unknown
3350 options. */
3351 const struct cl_option *option = &cl_options[decoded->opt_index];
3353 if (option->cl_reject_driver)
3354 error ("unrecognized command line option %qs",
3355 decoded->orig_option_with_args_text);
3356 else
3357 save_switch (decoded->canonical_option[0],
3358 decoded->canonical_option_num_elements - 1,
3359 &decoded->canonical_option[1], false, true);
3362 static const char *spec_lang = 0;
3363 static int last_language_n_infiles;
3365 /* Parse -foffload option argument. */
3367 static void
3368 handle_foffload_option (const char *arg)
3370 const char *c, *cur, *n, *next, *end;
3371 char *target;
3373 /* If option argument starts with '-' then no target is specified and we
3374 do not need to parse it. */
3375 if (arg[0] == '-')
3376 return;
3378 end = strchr (arg, '=');
3379 if (end == NULL)
3380 end = strchr (arg, '\0');
3381 cur = arg;
3383 while (cur < end)
3385 next = strchr (cur, ',');
3386 if (next == NULL)
3387 next = end;
3388 next = (next > end) ? end : next;
3390 target = XNEWVEC (char, next - cur + 1);
3391 memcpy (target, cur, next - cur);
3392 target[next - cur] = '\0';
3394 /* If 'disable' is passed to the option, stop parsing the option and clean
3395 the list of offload targets. */
3396 if (strcmp (target, "disable") == 0)
3398 free (offload_targets);
3399 offload_targets = xstrdup ("");
3400 break;
3403 /* Check that GCC is configured to support the offload target. */
3404 c = OFFLOAD_TARGETS;
3405 while (c)
3407 n = strchr (c, ',');
3408 if (n == NULL)
3409 n = strchr (c, '\0');
3411 if (next - cur == n - c && strncmp (target, c, n - c) == 0)
3412 break;
3414 c = *n ? n + 1 : NULL;
3417 if (!c)
3418 fatal_error ("GCC is not configured to support %s as offload target",
3419 target);
3421 if (!offload_targets)
3423 offload_targets = target;
3424 target = NULL;
3426 else
3428 /* Check that the target hasn't already presented in the list. */
3429 c = offload_targets;
3432 n = strchr (c, ':');
3433 if (n == NULL)
3434 n = strchr (c, '\0');
3436 if (next - cur == n - c && strncmp (c, target, n - c) == 0)
3437 break;
3439 c = n + 1;
3441 while (*n);
3443 /* If duplicate is not found, append the target to the list. */
3444 if (c > n)
3446 size_t offload_targets_len = strlen (offload_targets);
3447 offload_targets
3448 = XRESIZEVEC (char, offload_targets,
3449 offload_targets_len + next - cur + 2);
3450 if (offload_targets_len)
3451 offload_targets[offload_targets_len++] = ':';
3452 memcpy (offload_targets + offload_targets_len, target, next - cur);
3456 cur = next + 1;
3457 XDELETEVEC (target);
3461 /* Handle a driver option; arguments and return value as for
3462 handle_option. */
3464 static bool
3465 driver_handle_option (struct gcc_options *opts,
3466 struct gcc_options *opts_set,
3467 const struct cl_decoded_option *decoded,
3468 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3469 location_t loc,
3470 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3471 diagnostic_context *dc)
3473 size_t opt_index = decoded->opt_index;
3474 const char *arg = decoded->arg;
3475 const char *compare_debug_replacement_opt;
3476 int value = decoded->value;
3477 bool validated = false;
3478 bool do_save = true;
3480 gcc_assert (opts == &global_options);
3481 gcc_assert (opts_set == &global_options_set);
3482 gcc_assert (kind == DK_UNSPECIFIED);
3483 gcc_assert (loc == UNKNOWN_LOCATION);
3484 gcc_assert (dc == global_dc);
3486 switch (opt_index)
3488 case OPT_dumpspecs:
3490 struct spec_list *sl;
3491 init_spec ();
3492 for (sl = specs; sl; sl = sl->next)
3493 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3494 if (link_command_spec)
3495 printf ("*link_command:\n%s\n\n", link_command_spec);
3496 exit (0);
3499 case OPT_dumpversion:
3500 printf ("%s\n", spec_version);
3501 exit (0);
3503 case OPT_dumpmachine:
3504 printf ("%s\n", spec_machine);
3505 exit (0);
3507 case OPT__version:
3508 print_version = 1;
3510 /* CPP driver cannot obtain switch from cc1_options. */
3511 if (is_cpp_driver)
3512 add_preprocessor_option ("--version", strlen ("--version"));
3513 add_assembler_option ("--version", strlen ("--version"));
3514 add_linker_option ("--version", strlen ("--version"));
3515 break;
3517 case OPT__help:
3518 print_help_list = 1;
3520 /* CPP driver cannot obtain switch from cc1_options. */
3521 if (is_cpp_driver)
3522 add_preprocessor_option ("--help", 6);
3523 add_assembler_option ("--help", 6);
3524 add_linker_option ("--help", 6);
3525 break;
3527 case OPT__help_:
3528 print_subprocess_help = 2;
3529 break;
3531 case OPT__target_help:
3532 print_subprocess_help = 1;
3534 /* CPP driver cannot obtain switch from cc1_options. */
3535 if (is_cpp_driver)
3536 add_preprocessor_option ("--target-help", 13);
3537 add_assembler_option ("--target-help", 13);
3538 add_linker_option ("--target-help", 13);
3539 break;
3541 case OPT__no_sysroot_suffix:
3542 case OPT_pass_exit_codes:
3543 case OPT_print_search_dirs:
3544 case OPT_print_file_name_:
3545 case OPT_print_prog_name_:
3546 case OPT_print_multi_lib:
3547 case OPT_print_multi_directory:
3548 case OPT_print_sysroot:
3549 case OPT_print_multi_os_directory:
3550 case OPT_print_multiarch:
3551 case OPT_print_sysroot_headers_suffix:
3552 case OPT_time:
3553 case OPT_wrapper:
3554 /* These options set the variables specified in common.opt
3555 automatically, and do not need to be saved for spec
3556 processing. */
3557 do_save = false;
3558 break;
3560 case OPT_print_libgcc_file_name:
3561 print_file_name = "libgcc.a";
3562 do_save = false;
3563 break;
3565 case OPT_fuse_ld_bfd:
3566 use_ld = ".bfd";
3567 break;
3569 case OPT_fuse_ld_gold:
3570 use_ld = ".gold";
3571 break;
3573 case OPT_fcompare_debug_second:
3574 compare_debug_second = 1;
3575 break;
3577 case OPT_fcompare_debug:
3578 switch (value)
3580 case 0:
3581 compare_debug_replacement_opt = "-fcompare-debug=";
3582 arg = "";
3583 goto compare_debug_with_arg;
3585 case 1:
3586 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3587 arg = "-gtoggle";
3588 goto compare_debug_with_arg;
3590 default:
3591 gcc_unreachable ();
3593 break;
3595 case OPT_fcompare_debug_:
3596 compare_debug_replacement_opt = decoded->canonical_option[0];
3597 compare_debug_with_arg:
3598 gcc_assert (decoded->canonical_option_num_elements == 1);
3599 gcc_assert (arg != NULL);
3600 if (*arg)
3601 compare_debug = 1;
3602 else
3603 compare_debug = -1;
3604 if (compare_debug < 0)
3605 compare_debug_opt = NULL;
3606 else
3607 compare_debug_opt = arg;
3608 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3609 return true;
3611 case OPT_Wa_:
3613 int prev, j;
3614 /* Pass the rest of this option to the assembler. */
3616 /* Split the argument at commas. */
3617 prev = 0;
3618 for (j = 0; arg[j]; j++)
3619 if (arg[j] == ',')
3621 add_assembler_option (arg + prev, j - prev);
3622 prev = j + 1;
3625 /* Record the part after the last comma. */
3626 add_assembler_option (arg + prev, j - prev);
3628 do_save = false;
3629 break;
3631 case OPT_Wp_:
3633 int prev, j;
3634 /* Pass the rest of this option to the preprocessor. */
3636 /* Split the argument at commas. */
3637 prev = 0;
3638 for (j = 0; arg[j]; j++)
3639 if (arg[j] == ',')
3641 add_preprocessor_option (arg + prev, j - prev);
3642 prev = j + 1;
3645 /* Record the part after the last comma. */
3646 add_preprocessor_option (arg + prev, j - prev);
3648 do_save = false;
3649 break;
3651 case OPT_Wl_:
3653 int prev, j;
3654 /* Split the argument at commas. */
3655 prev = 0;
3656 for (j = 0; arg[j]; j++)
3657 if (arg[j] == ',')
3659 add_infile (save_string (arg + prev, j - prev), "*");
3660 prev = j + 1;
3662 /* Record the part after the last comma. */
3663 add_infile (arg + prev, "*");
3665 do_save = false;
3666 break;
3668 case OPT_Xlinker:
3669 add_infile (arg, "*");
3670 do_save = false;
3671 break;
3673 case OPT_Xpreprocessor:
3674 add_preprocessor_option (arg, strlen (arg));
3675 do_save = false;
3676 break;
3678 case OPT_Xassembler:
3679 add_assembler_option (arg, strlen (arg));
3680 do_save = false;
3681 break;
3683 case OPT_l:
3684 /* POSIX allows separation of -l and the lib arg; canonicalize
3685 by concatenating -l with its arg */
3686 add_infile (concat ("-l", arg, NULL), "*");
3687 do_save = false;
3688 break;
3690 case OPT_L:
3691 /* Similarly, canonicalize -L for linkers that may not accept
3692 separate arguments. */
3693 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
3694 return true;
3696 case OPT_F:
3697 /* Likewise -F. */
3698 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
3699 return true;
3701 case OPT_save_temps:
3702 save_temps_flag = SAVE_TEMPS_CWD;
3703 validated = true;
3704 break;
3706 case OPT_save_temps_:
3707 if (strcmp (arg, "cwd") == 0)
3708 save_temps_flag = SAVE_TEMPS_CWD;
3709 else if (strcmp (arg, "obj") == 0
3710 || strcmp (arg, "object") == 0)
3711 save_temps_flag = SAVE_TEMPS_OBJ;
3712 else
3713 fatal_error ("%qs is an unknown -save-temps option",
3714 decoded->orig_option_with_args_text);
3715 break;
3717 case OPT_no_canonical_prefixes:
3718 /* Already handled as a special case, so ignored here. */
3719 do_save = false;
3720 break;
3722 case OPT_pipe:
3723 validated = true;
3724 /* These options set the variables specified in common.opt
3725 automatically, but do need to be saved for spec
3726 processing. */
3727 break;
3729 case OPT_specs_:
3731 struct user_specs *user = XNEW (struct user_specs);
3733 user->next = (struct user_specs *) 0;
3734 user->filename = arg;
3735 if (user_specs_tail)
3736 user_specs_tail->next = user;
3737 else
3738 user_specs_head = user;
3739 user_specs_tail = user;
3741 validated = true;
3742 break;
3744 case OPT__sysroot_:
3745 target_system_root = arg;
3746 target_system_root_changed = 1;
3747 do_save = false;
3748 break;
3750 case OPT_time_:
3751 if (report_times_to_file)
3752 fclose (report_times_to_file);
3753 report_times_to_file = fopen (arg, "a");
3754 do_save = false;
3755 break;
3757 case OPT____:
3758 /* "-###"
3759 This is similar to -v except that there is no execution
3760 of the commands and the echoed arguments are quoted. It
3761 is intended for use in shell scripts to capture the
3762 driver-generated command line. */
3763 verbose_only_flag++;
3764 verbose_flag = 1;
3765 do_save = false;
3766 break;
3768 case OPT_B:
3770 size_t len = strlen (arg);
3772 /* Catch the case where the user has forgotten to append a
3773 directory separator to the path. Note, they may be using
3774 -B to add an executable name prefix, eg "i386-elf-", in
3775 order to distinguish between multiple installations of
3776 GCC in the same directory. Hence we must check to see
3777 if appending a directory separator actually makes a
3778 valid directory name. */
3779 if (!IS_DIR_SEPARATOR (arg[len - 1])
3780 && is_directory (arg, false))
3782 char *tmp = XNEWVEC (char, len + 2);
3783 strcpy (tmp, arg);
3784 tmp[len] = DIR_SEPARATOR;
3785 tmp[++len] = 0;
3786 arg = tmp;
3789 add_prefix (&exec_prefixes, arg, NULL,
3790 PREFIX_PRIORITY_B_OPT, 0, 0);
3791 add_prefix (&startfile_prefixes, arg, NULL,
3792 PREFIX_PRIORITY_B_OPT, 0, 0);
3793 add_prefix (&include_prefixes, arg, NULL,
3794 PREFIX_PRIORITY_B_OPT, 0, 0);
3796 validated = true;
3797 break;
3799 case OPT_x:
3800 spec_lang = arg;
3801 if (!strcmp (spec_lang, "none"))
3802 /* Suppress the warning if -xnone comes after the last input
3803 file, because alternate command interfaces like g++ might
3804 find it useful to place -xnone after each input file. */
3805 spec_lang = 0;
3806 else
3807 last_language_n_infiles = n_infiles;
3808 do_save = false;
3809 break;
3811 case OPT_o:
3812 have_o = 1;
3813 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3814 arg = convert_filename (arg, ! have_c, 0);
3815 #endif
3816 output_file = arg;
3817 /* Save the output name in case -save-temps=obj was used. */
3818 save_temps_prefix = xstrdup (arg);
3819 /* On some systems, ld cannot handle "-o" without a space. So
3820 split the option from its argument. */
3821 save_switch ("-o", 1, &arg, validated, true);
3822 return true;
3824 case OPT_static_libgcc:
3825 case OPT_shared_libgcc:
3826 case OPT_static_libgfortran:
3827 case OPT_static_libstdc__:
3828 /* These are always valid, since gcc.c itself understands the
3829 first two, gfortranspec.c understands -static-libgfortran and
3830 g++spec.c understands -static-libstdc++ */
3831 validated = true;
3832 break;
3834 case OPT_fwpa:
3835 flag_wpa = "";
3836 break;
3838 case OPT_foffload_:
3839 handle_foffload_option (arg);
3840 break;
3842 default:
3843 /* Various driver options need no special processing at this
3844 point, having been handled in a prescan above or being
3845 handled by specs. */
3846 break;
3849 if (do_save)
3850 save_switch (decoded->canonical_option[0],
3851 decoded->canonical_option_num_elements - 1,
3852 &decoded->canonical_option[1], validated, true);
3853 return true;
3856 /* Put the driver's standard set of option handlers in *HANDLERS. */
3858 static void
3859 set_option_handlers (struct cl_option_handlers *handlers)
3861 handlers->unknown_option_callback = driver_unknown_option_callback;
3862 handlers->wrong_lang_callback = driver_wrong_lang_callback;
3863 handlers->num_handlers = 3;
3864 handlers->handlers[0].handler = driver_handle_option;
3865 handlers->handlers[0].mask = CL_DRIVER;
3866 handlers->handlers[1].handler = common_handle_option;
3867 handlers->handlers[1].mask = CL_COMMON;
3868 handlers->handlers[2].handler = target_handle_option;
3869 handlers->handlers[2].mask = CL_TARGET;
3872 /* Create the vector `switches' and its contents.
3873 Store its length in `n_switches'. */
3875 static void
3876 process_command (unsigned int decoded_options_count,
3877 struct cl_decoded_option *decoded_options)
3879 const char *temp;
3880 char *temp1;
3881 char *tooldir_prefix, *tooldir_prefix2;
3882 char *(*get_relative_prefix) (const char *, const char *,
3883 const char *) = NULL;
3884 struct cl_option_handlers handlers;
3885 unsigned int j;
3887 gcc_exec_prefix = getenv ("GCC_EXEC_PREFIX");
3889 n_switches = 0;
3890 n_infiles = 0;
3891 added_libraries = 0;
3893 /* Figure compiler version from version string. */
3895 compiler_version = temp1 = xstrdup (version_string);
3897 for (; *temp1; ++temp1)
3899 if (*temp1 == ' ')
3901 *temp1 = '\0';
3902 break;
3906 /* Handle any -no-canonical-prefixes flag early, to assign the function
3907 that builds relative prefixes. This function creates default search
3908 paths that are needed later in normal option handling. */
3910 for (j = 1; j < decoded_options_count; j++)
3912 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
3914 get_relative_prefix = make_relative_prefix_ignore_links;
3915 break;
3918 if (! get_relative_prefix)
3919 get_relative_prefix = make_relative_prefix;
3921 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3922 see if we can create it from the pathname specified in
3923 decoded_options[0].arg. */
3925 gcc_libexec_prefix = standard_libexec_prefix;
3926 #ifndef VMS
3927 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3928 if (!gcc_exec_prefix)
3930 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
3931 standard_bindir_prefix,
3932 standard_exec_prefix);
3933 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
3934 standard_bindir_prefix,
3935 standard_libexec_prefix);
3936 if (gcc_exec_prefix)
3937 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3939 else
3941 /* make_relative_prefix requires a program name, but
3942 GCC_EXEC_PREFIX is typically a directory name with a trailing
3943 / (which is ignored by make_relative_prefix), so append a
3944 program name. */
3945 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
3946 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
3947 standard_exec_prefix,
3948 standard_libexec_prefix);
3950 /* The path is unrelocated, so fallback to the original setting. */
3951 if (!gcc_libexec_prefix)
3952 gcc_libexec_prefix = standard_libexec_prefix;
3954 free (tmp_prefix);
3956 #else
3957 #endif
3958 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
3959 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
3960 or an automatically created GCC_EXEC_PREFIX from
3961 decoded_options[0].arg. */
3963 /* Do language-specific adjustment/addition of flags. */
3964 lang_specific_driver (&decoded_options, &decoded_options_count,
3965 &added_libraries);
3967 if (gcc_exec_prefix)
3969 int len = strlen (gcc_exec_prefix);
3971 if (len > (int) sizeof ("/lib/gcc/") - 1
3972 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3974 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3975 if (IS_DIR_SEPARATOR (*temp)
3976 && filename_ncmp (temp + 1, "lib", 3) == 0
3977 && IS_DIR_SEPARATOR (temp[4])
3978 && filename_ncmp (temp + 5, "gcc", 3) == 0)
3979 len -= sizeof ("/lib/gcc/") - 1;
3982 set_std_prefix (gcc_exec_prefix, len);
3983 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3984 PREFIX_PRIORITY_LAST, 0, 0);
3985 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3986 PREFIX_PRIORITY_LAST, 0, 0);
3989 /* COMPILER_PATH and LIBRARY_PATH have values
3990 that are lists of directory names with colons. */
3992 temp = getenv ("COMPILER_PATH");
3993 if (temp)
3995 const char *startp, *endp;
3996 char *nstore = (char *) alloca (strlen (temp) + 3);
3998 startp = endp = temp;
3999 while (1)
4001 if (*endp == PATH_SEPARATOR || *endp == 0)
4003 strncpy (nstore, startp, endp - startp);
4004 if (endp == startp)
4005 strcpy (nstore, concat (".", dir_separator_str, NULL));
4006 else if (!IS_DIR_SEPARATOR (endp[-1]))
4008 nstore[endp - startp] = DIR_SEPARATOR;
4009 nstore[endp - startp + 1] = 0;
4011 else
4012 nstore[endp - startp] = 0;
4013 add_prefix (&exec_prefixes, nstore, 0,
4014 PREFIX_PRIORITY_LAST, 0, 0);
4015 add_prefix (&include_prefixes, nstore, 0,
4016 PREFIX_PRIORITY_LAST, 0, 0);
4017 if (*endp == 0)
4018 break;
4019 endp = startp = endp + 1;
4021 else
4022 endp++;
4026 temp = getenv (LIBRARY_PATH_ENV);
4027 if (temp && *cross_compile == '0')
4029 const char *startp, *endp;
4030 char *nstore = (char *) alloca (strlen (temp) + 3);
4032 startp = endp = temp;
4033 while (1)
4035 if (*endp == PATH_SEPARATOR || *endp == 0)
4037 strncpy (nstore, startp, endp - startp);
4038 if (endp == startp)
4039 strcpy (nstore, concat (".", dir_separator_str, NULL));
4040 else if (!IS_DIR_SEPARATOR (endp[-1]))
4042 nstore[endp - startp] = DIR_SEPARATOR;
4043 nstore[endp - startp + 1] = 0;
4045 else
4046 nstore[endp - startp] = 0;
4047 add_prefix (&startfile_prefixes, nstore, NULL,
4048 PREFIX_PRIORITY_LAST, 0, 1);
4049 if (*endp == 0)
4050 break;
4051 endp = startp = endp + 1;
4053 else
4054 endp++;
4058 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
4059 temp = getenv ("LPATH");
4060 if (temp && *cross_compile == '0')
4062 const char *startp, *endp;
4063 char *nstore = (char *) alloca (strlen (temp) + 3);
4065 startp = endp = temp;
4066 while (1)
4068 if (*endp == PATH_SEPARATOR || *endp == 0)
4070 strncpy (nstore, startp, endp - startp);
4071 if (endp == startp)
4072 strcpy (nstore, concat (".", dir_separator_str, NULL));
4073 else if (!IS_DIR_SEPARATOR (endp[-1]))
4075 nstore[endp - startp] = DIR_SEPARATOR;
4076 nstore[endp - startp + 1] = 0;
4078 else
4079 nstore[endp - startp] = 0;
4080 add_prefix (&startfile_prefixes, nstore, NULL,
4081 PREFIX_PRIORITY_LAST, 0, 1);
4082 if (*endp == 0)
4083 break;
4084 endp = startp = endp + 1;
4086 else
4087 endp++;
4091 /* Process the options and store input files and switches in their
4092 vectors. */
4094 last_language_n_infiles = -1;
4096 set_option_handlers (&handlers);
4098 for (j = 1; j < decoded_options_count; j++)
4100 switch (decoded_options[j].opt_index)
4102 case OPT_S:
4103 case OPT_c:
4104 case OPT_E:
4105 have_c = 1;
4106 break;
4108 if (have_c)
4109 break;
4112 for (j = 1; j < decoded_options_count; j++)
4114 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
4116 const char *arg = decoded_options[j].arg;
4117 const char *p = strrchr (arg, '@');
4118 char *fname;
4119 long offset;
4120 int consumed;
4121 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4122 arg = convert_filename (arg, 0, access (arg, F_OK));
4123 #endif
4124 /* For LTO static archive support we handle input file
4125 specifications that are composed of a filename and
4126 an offset like FNAME@OFFSET. */
4127 if (p
4128 && p != arg
4129 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
4130 && strlen (p) == (unsigned int)consumed)
4132 fname = (char *)xmalloc (p - arg + 1);
4133 memcpy (fname, arg, p - arg);
4134 fname[p - arg] = '\0';
4135 /* Only accept non-stdin and existing FNAME parts, otherwise
4136 try with the full name. */
4137 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
4139 free (fname);
4140 fname = xstrdup (arg);
4143 else
4144 fname = xstrdup (arg);
4146 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
4147 perror_with_name (fname);
4148 else
4149 add_infile (arg, spec_lang);
4151 free (fname);
4152 continue;
4155 read_cmdline_option (&global_options, &global_options_set,
4156 decoded_options + j, UNKNOWN_LOCATION,
4157 CL_DRIVER, &handlers, global_dc);
4160 if (output_file
4161 && strcmp (output_file, "-") != 0
4162 && strcmp (output_file, HOST_BIT_BUCKET) != 0)
4164 int i;
4165 for (i = 0; i < n_infiles; i++)
4166 if ((!infiles[i].language || infiles[i].language[0] != '*')
4167 && canonical_filename_eq (infiles[i].name, output_file))
4168 fatal_error ("input file %qs is the same as output file",
4169 output_file);
4172 /* If -save-temps=obj and -o name, create the prefix to use for %b.
4173 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
4174 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
4176 save_temps_length = strlen (save_temps_prefix);
4177 temp = strrchr (lbasename (save_temps_prefix), '.');
4178 if (temp)
4180 save_temps_length -= strlen (temp);
4181 save_temps_prefix[save_temps_length] = '\0';
4185 else if (save_temps_prefix != NULL)
4187 free (save_temps_prefix);
4188 save_temps_prefix = NULL;
4191 if (save_temps_flag && use_pipes)
4193 /* -save-temps overrides -pipe, so that temp files are produced */
4194 if (save_temps_flag)
4195 warning (0, "-pipe ignored because -save-temps specified");
4196 use_pipes = 0;
4199 if (!compare_debug)
4201 const char *gcd = getenv ("GCC_COMPARE_DEBUG");
4203 if (gcd && gcd[0] == '-')
4205 compare_debug = 2;
4206 compare_debug_opt = gcd;
4208 else if (gcd && *gcd && strcmp (gcd, "0"))
4210 compare_debug = 3;
4211 compare_debug_opt = "-gtoggle";
4214 else if (compare_debug < 0)
4216 compare_debug = 0;
4217 gcc_assert (!compare_debug_opt);
4220 /* Set up the search paths. We add directories that we expect to
4221 contain GNU Toolchain components before directories specified by
4222 the machine description so that we will find GNU components (like
4223 the GNU assembler) before those of the host system. */
4225 /* If we don't know where the toolchain has been installed, use the
4226 configured-in locations. */
4227 if (!gcc_exec_prefix)
4229 #ifndef OS2
4230 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
4231 PREFIX_PRIORITY_LAST, 1, 0);
4232 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
4233 PREFIX_PRIORITY_LAST, 2, 0);
4234 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
4235 PREFIX_PRIORITY_LAST, 2, 0);
4236 #endif
4237 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
4238 PREFIX_PRIORITY_LAST, 1, 0);
4241 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
4242 tooldir_prefix2 = concat (tooldir_base_prefix, spec_host_machine,
4243 dir_separator_str, NULL);
4245 /* Look for tools relative to the location from which the driver is
4246 running, or, if that is not available, the configured prefix. */
4247 tooldir_prefix
4248 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4249 spec_host_machine, dir_separator_str, spec_version,
4250 accel_dir_suffix, dir_separator_str, tooldir_prefix2, NULL);
4251 free (tooldir_prefix2);
4253 add_prefix (&exec_prefixes,
4254 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4255 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4256 add_prefix (&startfile_prefixes,
4257 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4258 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4259 free (tooldir_prefix);
4261 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4262 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4263 then consider it to relocate with the rest of the GCC installation
4264 if GCC_EXEC_PREFIX is set.
4265 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4266 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
4268 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
4269 standard_bindir_prefix,
4270 target_system_root);
4271 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4273 target_system_root = tmp_prefix;
4274 target_system_root_changed = 1;
4277 #endif
4279 /* More prefixes are enabled in main, after we read the specs file
4280 and determine whether this is cross-compilation or not. */
4282 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4283 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
4285 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
4286 environment variable. */
4287 if (compare_debug == 2 || compare_debug == 3)
4289 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
4290 save_switch (opt, 0, NULL, false, true);
4291 compare_debug = 1;
4294 /* Ensure we only invoke each subprocess once. */
4295 if (print_subprocess_help || print_help_list || print_version)
4297 n_infiles = 0;
4299 /* Create a dummy input file, so that we can pass
4300 the help option on to the various sub-processes. */
4301 add_infile ("help-dummy", "c");
4304 alloc_switch ();
4305 switches[n_switches].part1 = 0;
4306 alloc_infile ();
4307 infiles[n_infiles].name = 0;
4310 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4311 and place that in the environment. */
4313 static void
4314 set_collect_gcc_options (void)
4316 int i;
4317 int first_time;
4319 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4320 the compiler. */
4321 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4322 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4324 first_time = TRUE;
4325 for (i = 0; (int) i < n_switches; i++)
4327 const char *const *args;
4328 const char *p, *q;
4329 if (!first_time)
4330 obstack_grow (&collect_obstack, " ", 1);
4332 first_time = FALSE;
4334 /* Ignore elided switches. */
4335 if ((switches[i].live_cond
4336 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4337 == SWITCH_IGNORE)
4338 continue;
4340 obstack_grow (&collect_obstack, "'-", 2);
4341 q = switches[i].part1;
4342 while ((p = strchr (q, '\'')))
4344 obstack_grow (&collect_obstack, q, p - q);
4345 obstack_grow (&collect_obstack, "'\\''", 4);
4346 q = ++p;
4348 obstack_grow (&collect_obstack, q, strlen (q));
4349 obstack_grow (&collect_obstack, "'", 1);
4351 for (args = switches[i].args; args && *args; args++)
4353 obstack_grow (&collect_obstack, " '", 2);
4354 q = *args;
4355 while ((p = strchr (q, '\'')))
4357 obstack_grow (&collect_obstack, q, p - q);
4358 obstack_grow (&collect_obstack, "'\\''", 4);
4359 q = ++p;
4361 obstack_grow (&collect_obstack, q, strlen (q));
4362 obstack_grow (&collect_obstack, "'", 1);
4365 obstack_grow (&collect_obstack, "\0", 1);
4366 xputenv (XOBFINISH (&collect_obstack, char *));
4369 /* Process a spec string, accumulating and running commands. */
4371 /* These variables describe the input file name.
4372 input_file_number is the index on outfiles of this file,
4373 so that the output file name can be stored for later use by %o.
4374 input_basename is the start of the part of the input file
4375 sans all directory names, and basename_length is the number
4376 of characters starting there excluding the suffix .c or whatever. */
4378 static const char *gcc_input_filename;
4379 static int input_file_number;
4380 size_t input_filename_length;
4381 static int basename_length;
4382 static int suffixed_basename_length;
4383 static const char *input_basename;
4384 static const char *input_suffix;
4385 #ifndef HOST_LACKS_INODE_NUMBERS
4386 static struct stat input_stat;
4387 #endif
4388 static int input_stat_set;
4390 /* The compiler used to process the current input file. */
4391 static struct compiler *input_file_compiler;
4393 /* These are variables used within do_spec and do_spec_1. */
4395 /* Nonzero if an arg has been started and not yet terminated
4396 (with space, tab or newline). */
4397 static int arg_going;
4399 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4400 is a temporary file name. */
4401 static int delete_this_arg;
4403 /* Nonzero means %w has been seen; the next arg to be terminated
4404 is the output file name of this compilation. */
4405 static int this_is_output_file;
4407 /* Nonzero means %s has been seen; the next arg to be terminated
4408 is the name of a library file and we should try the standard
4409 search dirs for it. */
4410 static int this_is_library_file;
4412 /* Nonzero means %T has been seen; the next arg to be terminated
4413 is the name of a linker script and we should try all of the
4414 standard search dirs for it. If it is found insert a --script
4415 command line switch and then substitute the full path in place,
4416 otherwise generate an error message. */
4417 static int this_is_linker_script;
4419 /* Nonzero means that the input of this command is coming from a pipe. */
4420 static int input_from_pipe;
4422 /* Nonnull means substitute this for any suffix when outputting a switches
4423 arguments. */
4424 static const char *suffix_subst;
4426 /* If there is an argument being accumulated, terminate it and store it. */
4428 static void
4429 end_going_arg (void)
4431 if (arg_going)
4433 const char *string;
4435 obstack_1grow (&obstack, 0);
4436 string = XOBFINISH (&obstack, const char *);
4437 if (this_is_library_file)
4438 string = find_file (string);
4439 if (this_is_linker_script)
4441 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4443 if (full_script_path == NULL)
4445 error ("unable to locate default linker script %qs in the library search paths", string);
4446 /* Script was not found on search path. */
4447 return;
4449 store_arg ("--script", false, false);
4450 string = full_script_path;
4452 store_arg (string, delete_this_arg, this_is_output_file);
4453 if (this_is_output_file)
4454 outfiles[input_file_number] = string;
4455 arg_going = 0;
4460 /* Parse the WRAPPER string which is a comma separated list of the command line
4461 and insert them into the beginning of argbuf. */
4463 static void
4464 insert_wrapper (const char *wrapper)
4466 int n = 0;
4467 int i;
4468 char *buf = xstrdup (wrapper);
4469 char *p = buf;
4470 unsigned int old_length = argbuf.length ();
4474 n++;
4475 while (*p == ',')
4476 p++;
4478 while ((p = strchr (p, ',')) != NULL);
4480 argbuf.safe_grow (old_length + n);
4481 memmove (argbuf.address () + n,
4482 argbuf.address (),
4483 old_length * sizeof (const_char_p));
4485 i = 0;
4486 p = buf;
4489 while (*p == ',')
4491 *p = 0;
4492 p++;
4494 argbuf[i] = p;
4495 i++;
4497 while ((p = strchr (p, ',')) != NULL);
4498 gcc_assert (i == n);
4501 /* Process the spec SPEC and run the commands specified therein.
4502 Returns 0 if the spec is successfully processed; -1 if failed. */
4505 do_spec (const char *spec)
4507 int value;
4509 value = do_spec_2 (spec);
4511 /* Force out any unfinished command.
4512 If -pipe, this forces out the last command if it ended in `|'. */
4513 if (value == 0)
4515 if (argbuf.length () > 0
4516 && !strcmp (argbuf.last (), "|"))
4517 argbuf.pop ();
4519 set_collect_gcc_options ();
4521 if (argbuf.length () > 0)
4522 value = execute ();
4525 return value;
4528 static int
4529 do_spec_2 (const char *spec)
4531 int result;
4533 clear_args ();
4534 arg_going = 0;
4535 delete_this_arg = 0;
4536 this_is_output_file = 0;
4537 this_is_library_file = 0;
4538 this_is_linker_script = 0;
4539 input_from_pipe = 0;
4540 suffix_subst = NULL;
4542 result = do_spec_1 (spec, 0, NULL);
4544 end_going_arg ();
4546 return result;
4550 /* Process the given spec string and add any new options to the end
4551 of the switches/n_switches array. */
4553 static void
4554 do_option_spec (const char *name, const char *spec)
4556 unsigned int i, value_count, value_len;
4557 const char *p, *q, *value;
4558 char *tmp_spec, *tmp_spec_p;
4560 if (configure_default_options[0].name == NULL)
4561 return;
4563 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4564 if (strcmp (configure_default_options[i].name, name) == 0)
4565 break;
4566 if (i == ARRAY_SIZE (configure_default_options))
4567 return;
4569 value = configure_default_options[i].value;
4570 value_len = strlen (value);
4572 /* Compute the size of the final spec. */
4573 value_count = 0;
4574 p = spec;
4575 while ((p = strstr (p, "%(VALUE)")) != NULL)
4577 p ++;
4578 value_count ++;
4581 /* Replace each %(VALUE) by the specified value. */
4582 tmp_spec = (char *) alloca (strlen (spec) + 1
4583 + value_count * (value_len - strlen ("%(VALUE)")));
4584 tmp_spec_p = tmp_spec;
4585 q = spec;
4586 while ((p = strstr (q, "%(VALUE)")) != NULL)
4588 memcpy (tmp_spec_p, q, p - q);
4589 tmp_spec_p = tmp_spec_p + (p - q);
4590 memcpy (tmp_spec_p, value, value_len);
4591 tmp_spec_p += value_len;
4592 q = p + strlen ("%(VALUE)");
4594 strcpy (tmp_spec_p, q);
4596 do_self_spec (tmp_spec);
4599 /* Process the given spec string and add any new options to the end
4600 of the switches/n_switches array. */
4602 static void
4603 do_self_spec (const char *spec)
4605 int i;
4607 do_spec_2 (spec);
4608 do_spec_1 (" ", 0, NULL);
4610 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4611 do_self_specs adds the replacements to switches array, so it shouldn't
4612 be processed afterwards. */
4613 for (i = 0; i < n_switches; i++)
4614 if ((switches[i].live_cond & SWITCH_IGNORE))
4615 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4617 if (argbuf.length () > 0)
4619 const char **argbuf_copy;
4620 struct cl_decoded_option *decoded_options;
4621 struct cl_option_handlers handlers;
4622 unsigned int decoded_options_count;
4623 unsigned int j;
4625 /* Create a copy of argbuf with a dummy argv[0] entry for
4626 decode_cmdline_options_to_array. */
4627 argbuf_copy = XNEWVEC (const char *,
4628 argbuf.length () + 1);
4629 argbuf_copy[0] = "";
4630 memcpy (argbuf_copy + 1, argbuf.address (),
4631 argbuf.length () * sizeof (const char *));
4633 decode_cmdline_options_to_array (argbuf.length () + 1,
4634 argbuf_copy,
4635 CL_DRIVER, &decoded_options,
4636 &decoded_options_count);
4637 free (argbuf_copy);
4639 set_option_handlers (&handlers);
4641 for (j = 1; j < decoded_options_count; j++)
4643 switch (decoded_options[j].opt_index)
4645 case OPT_SPECIAL_input_file:
4646 /* Specs should only generate options, not input
4647 files. */
4648 if (strcmp (decoded_options[j].arg, "-") != 0)
4649 fatal_error ("switch %qs does not start with %<-%>",
4650 decoded_options[j].arg);
4651 else
4652 fatal_error ("spec-generated switch is just %<-%>");
4653 break;
4655 case OPT_fcompare_debug_second:
4656 case OPT_fcompare_debug:
4657 case OPT_fcompare_debug_:
4658 case OPT_o:
4659 /* Avoid duplicate processing of some options from
4660 compare-debug specs; just save them here. */
4661 save_switch (decoded_options[j].canonical_option[0],
4662 (decoded_options[j].canonical_option_num_elements
4663 - 1),
4664 &decoded_options[j].canonical_option[1], false, true);
4665 break;
4667 default:
4668 read_cmdline_option (&global_options, &global_options_set,
4669 decoded_options + j, UNKNOWN_LOCATION,
4670 CL_DRIVER, &handlers, global_dc);
4671 break;
4675 alloc_switch ();
4676 switches[n_switches].part1 = 0;
4680 /* Callback for processing %D and %I specs. */
4682 struct spec_path_info {
4683 const char *option;
4684 const char *append;
4685 size_t append_len;
4686 bool omit_relative;
4687 bool separate_options;
4690 static void *
4691 spec_path (char *path, void *data)
4693 struct spec_path_info *info = (struct spec_path_info *) data;
4694 size_t len = 0;
4695 char save = 0;
4697 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4698 return NULL;
4700 if (info->append_len != 0)
4702 len = strlen (path);
4703 memcpy (path + len, info->append, info->append_len + 1);
4706 if (!is_directory (path, true))
4707 return NULL;
4709 do_spec_1 (info->option, 1, NULL);
4710 if (info->separate_options)
4711 do_spec_1 (" ", 0, NULL);
4713 if (info->append_len == 0)
4715 len = strlen (path);
4716 save = path[len - 1];
4717 if (IS_DIR_SEPARATOR (path[len - 1]))
4718 path[len - 1] = '\0';
4721 do_spec_1 (path, 1, NULL);
4722 do_spec_1 (" ", 0, NULL);
4724 /* Must not damage the original path. */
4725 if (info->append_len == 0)
4726 path[len - 1] = save;
4728 return NULL;
4731 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
4732 argument list. */
4734 static void
4735 create_at_file (char **argv)
4737 char *temp_file = make_temp_file ("");
4738 char *at_argument = concat ("@", temp_file, NULL);
4739 FILE *f = fopen (temp_file, "w");
4740 int status;
4742 if (f == NULL)
4743 fatal_error ("could not open temporary response file %s",
4744 temp_file);
4746 status = writeargv (argv, f);
4748 if (status)
4749 fatal_error ("could not write to temporary response file %s",
4750 temp_file);
4752 status = fclose (f);
4754 if (EOF == status)
4755 fatal_error ("could not close temporary response file %s",
4756 temp_file);
4758 store_arg (at_argument, 0, 0);
4760 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
4763 /* True if we should compile INFILE. */
4765 static bool
4766 compile_input_file_p (struct infile *infile)
4768 if ((!infile->language) || (infile->language[0] != '*'))
4769 if (infile->incompiler == input_file_compiler)
4770 return true;
4771 return false;
4774 /* Process each member of VEC as a spec. */
4776 static void
4777 do_specs_vec (vec<char_p> vec)
4779 unsigned ix;
4780 char *opt;
4782 FOR_EACH_VEC_ELT (vec, ix, opt)
4784 do_spec_1 (opt, 1, NULL);
4785 /* Make each accumulated option a separate argument. */
4786 do_spec_1 (" ", 0, NULL);
4790 /* Process the sub-spec SPEC as a portion of a larger spec.
4791 This is like processing a whole spec except that we do
4792 not initialize at the beginning and we do not supply a
4793 newline by default at the end.
4794 INSWITCH nonzero means don't process %-sequences in SPEC;
4795 in this case, % is treated as an ordinary character.
4796 This is used while substituting switches.
4797 INSWITCH nonzero also causes SPC not to terminate an argument.
4799 Value is zero unless a line was finished
4800 and the command on that line reported an error. */
4802 static int
4803 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4805 const char *p = spec;
4806 int c;
4807 int i;
4808 int value;
4810 /* If it's an empty string argument to a switch, keep it as is. */
4811 if (inswitch && !*p)
4812 arg_going = 1;
4814 while ((c = *p++))
4815 /* If substituting a switch, treat all chars like letters.
4816 Otherwise, NL, SPC, TAB and % are special. */
4817 switch (inswitch ? 'a' : c)
4819 case '\n':
4820 end_going_arg ();
4822 if (argbuf.length () > 0
4823 && !strcmp (argbuf.last (), "|"))
4825 /* A `|' before the newline means use a pipe here,
4826 but only if -pipe was specified.
4827 Otherwise, execute now and don't pass the `|' as an arg. */
4828 if (use_pipes)
4830 input_from_pipe = 1;
4831 break;
4833 else
4834 argbuf.pop ();
4837 set_collect_gcc_options ();
4839 if (argbuf.length () > 0)
4841 value = execute ();
4842 if (value)
4843 return value;
4845 /* Reinitialize for a new command, and for a new argument. */
4846 clear_args ();
4847 arg_going = 0;
4848 delete_this_arg = 0;
4849 this_is_output_file = 0;
4850 this_is_library_file = 0;
4851 this_is_linker_script = 0;
4852 input_from_pipe = 0;
4853 break;
4855 case '|':
4856 end_going_arg ();
4858 /* Use pipe */
4859 obstack_1grow (&obstack, c);
4860 arg_going = 1;
4861 break;
4863 case '\t':
4864 case ' ':
4865 end_going_arg ();
4867 /* Reinitialize for a new argument. */
4868 delete_this_arg = 0;
4869 this_is_output_file = 0;
4870 this_is_library_file = 0;
4871 this_is_linker_script = 0;
4872 break;
4874 case '%':
4875 switch (c = *p++)
4877 case 0:
4878 fatal_error ("spec %qs invalid", spec);
4880 case 'b':
4881 if (save_temps_length)
4882 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4883 else
4884 obstack_grow (&obstack, input_basename, basename_length);
4885 if (compare_debug < 0)
4886 obstack_grow (&obstack, ".gk", 3);
4887 arg_going = 1;
4888 break;
4890 case 'B':
4891 if (save_temps_length)
4892 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4893 else
4894 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4895 if (compare_debug < 0)
4896 obstack_grow (&obstack, ".gk", 3);
4897 arg_going = 1;
4898 break;
4900 case 'd':
4901 delete_this_arg = 2;
4902 break;
4904 /* Dump out the directories specified with LIBRARY_PATH,
4905 followed by the absolute directories
4906 that we search for startfiles. */
4907 case 'D':
4909 struct spec_path_info info;
4911 info.option = "-L";
4912 info.append_len = 0;
4913 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4914 /* Used on systems which record the specified -L dirs
4915 and use them to search for dynamic linking.
4916 Relative directories always come from -B,
4917 and it is better not to use them for searching
4918 at run time. In particular, stage1 loses. */
4919 info.omit_relative = true;
4920 #else
4921 info.omit_relative = false;
4922 #endif
4923 info.separate_options = false;
4925 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
4927 break;
4929 case 'e':
4930 /* %efoo means report an error with `foo' as error message
4931 and don't execute any more commands for this file. */
4933 const char *q = p;
4934 char *buf;
4935 while (*p != 0 && *p != '\n')
4936 p++;
4937 buf = (char *) alloca (p - q + 1);
4938 strncpy (buf, q, p - q);
4939 buf[p - q] = 0;
4940 error ("%s", _(buf));
4941 return -1;
4943 break;
4944 case 'n':
4945 /* %nfoo means report a notice with `foo' on stderr. */
4947 const char *q = p;
4948 char *buf;
4949 while (*p != 0 && *p != '\n')
4950 p++;
4951 buf = (char *) alloca (p - q + 1);
4952 strncpy (buf, q, p - q);
4953 buf[p - q] = 0;
4954 inform (0, "%s", _(buf));
4955 if (*p)
4956 p++;
4958 break;
4960 case 'j':
4962 struct stat st;
4964 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4965 defined, and it is not a directory, and it is
4966 writable, use it. Otherwise, treat this like any
4967 other temporary file. */
4969 if ((!save_temps_flag)
4970 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4971 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4973 obstack_grow (&obstack, HOST_BIT_BUCKET,
4974 strlen (HOST_BIT_BUCKET));
4975 delete_this_arg = 0;
4976 arg_going = 1;
4977 break;
4980 goto create_temp_file;
4981 case '|':
4982 if (use_pipes)
4984 obstack_1grow (&obstack, '-');
4985 delete_this_arg = 0;
4986 arg_going = 1;
4988 /* consume suffix */
4989 while (*p == '.' || ISALNUM ((unsigned char) *p))
4990 p++;
4991 if (p[0] == '%' && p[1] == 'O')
4992 p += 2;
4994 break;
4996 goto create_temp_file;
4997 case 'm':
4998 if (use_pipes)
5000 /* consume suffix */
5001 while (*p == '.' || ISALNUM ((unsigned char) *p))
5002 p++;
5003 if (p[0] == '%' && p[1] == 'O')
5004 p += 2;
5006 break;
5008 goto create_temp_file;
5009 case 'g':
5010 case 'u':
5011 case 'U':
5012 create_temp_file:
5014 struct temp_name *t;
5015 int suffix_length;
5016 const char *suffix = p;
5017 char *saved_suffix = NULL;
5019 while (*p == '.' || ISALNUM ((unsigned char) *p))
5020 p++;
5021 suffix_length = p - suffix;
5022 if (p[0] == '%' && p[1] == 'O')
5024 p += 2;
5025 /* We don't support extra suffix characters after %O. */
5026 if (*p == '.' || ISALNUM ((unsigned char) *p))
5027 fatal_error ("spec %qs has invalid %<%%0%c%>", spec, *p);
5028 if (suffix_length == 0)
5029 suffix = TARGET_OBJECT_SUFFIX;
5030 else
5032 saved_suffix
5033 = XNEWVEC (char, suffix_length
5034 + strlen (TARGET_OBJECT_SUFFIX) + 1);
5035 strncpy (saved_suffix, suffix, suffix_length);
5036 strcpy (saved_suffix + suffix_length,
5037 TARGET_OBJECT_SUFFIX);
5039 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
5042 if (compare_debug < 0)
5044 suffix = concat (".gk", suffix, NULL);
5045 suffix_length += 3;
5048 /* If -save-temps=obj and -o were specified, use that for the
5049 temp file. */
5050 if (save_temps_length)
5052 char *tmp;
5053 temp_filename_length
5054 = save_temps_length + suffix_length + 1;
5055 tmp = (char *) alloca (temp_filename_length);
5056 memcpy (tmp, save_temps_prefix, save_temps_length);
5057 memcpy (tmp + save_temps_length, suffix, suffix_length);
5058 tmp[save_temps_length + suffix_length] = '\0';
5059 temp_filename = save_string (tmp, save_temps_length
5060 + suffix_length);
5061 obstack_grow (&obstack, temp_filename,
5062 temp_filename_length);
5063 arg_going = 1;
5064 delete_this_arg = 0;
5065 break;
5068 /* If the gcc_input_filename has the same suffix specified
5069 for the %g, %u, or %U, and -save-temps is specified,
5070 we could end up using that file as an intermediate
5071 thus clobbering the user's source file (.e.g.,
5072 gcc -save-temps foo.s would clobber foo.s with the
5073 output of cpp0). So check for this condition and
5074 generate a temp file as the intermediate. */
5076 if (save_temps_flag)
5078 char *tmp;
5079 temp_filename_length = basename_length + suffix_length + 1;
5080 tmp = (char *) alloca (temp_filename_length);
5081 memcpy (tmp, input_basename, basename_length);
5082 memcpy (tmp + basename_length, suffix, suffix_length);
5083 tmp[basename_length + suffix_length] = '\0';
5084 temp_filename = tmp;
5086 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
5088 #ifndef HOST_LACKS_INODE_NUMBERS
5089 struct stat st_temp;
5091 /* Note, set_input() resets input_stat_set to 0. */
5092 if (input_stat_set == 0)
5094 input_stat_set = stat (gcc_input_filename,
5095 &input_stat);
5096 if (input_stat_set >= 0)
5097 input_stat_set = 1;
5100 /* If we have the stat for the gcc_input_filename
5101 and we can do the stat for the temp_filename
5102 then the they could still refer to the same
5103 file if st_dev/st_ino's are the same. */
5104 if (input_stat_set != 1
5105 || stat (temp_filename, &st_temp) < 0
5106 || input_stat.st_dev != st_temp.st_dev
5107 || input_stat.st_ino != st_temp.st_ino)
5108 #else
5109 /* Just compare canonical pathnames. */
5110 char* input_realname = lrealpath (gcc_input_filename);
5111 char* temp_realname = lrealpath (temp_filename);
5112 bool files_differ = filename_cmp (input_realname, temp_realname);
5113 free (input_realname);
5114 free (temp_realname);
5115 if (files_differ)
5116 #endif
5118 temp_filename = save_string (temp_filename,
5119 temp_filename_length + 1);
5120 obstack_grow (&obstack, temp_filename,
5121 temp_filename_length);
5122 arg_going = 1;
5123 delete_this_arg = 0;
5124 break;
5129 /* See if we already have an association of %g/%u/%U and
5130 suffix. */
5131 for (t = temp_names; t; t = t->next)
5132 if (t->length == suffix_length
5133 && strncmp (t->suffix, suffix, suffix_length) == 0
5134 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
5135 break;
5137 /* Make a new association if needed. %u and %j
5138 require one. */
5139 if (t == 0 || c == 'u' || c == 'j')
5141 if (t == 0)
5143 t = XNEW (struct temp_name);
5144 t->next = temp_names;
5145 temp_names = t;
5147 t->length = suffix_length;
5148 if (saved_suffix)
5150 t->suffix = saved_suffix;
5151 saved_suffix = NULL;
5153 else
5154 t->suffix = save_string (suffix, suffix_length);
5155 t->unique = (c == 'u' || c == 'U' || c == 'j');
5156 temp_filename = make_temp_file (t->suffix);
5157 temp_filename_length = strlen (temp_filename);
5158 t->filename = temp_filename;
5159 t->filename_length = temp_filename_length;
5162 free (saved_suffix);
5164 obstack_grow (&obstack, t->filename, t->filename_length);
5165 delete_this_arg = 1;
5167 arg_going = 1;
5168 break;
5170 case 'i':
5171 if (combine_inputs)
5173 if (at_file_supplied)
5175 /* We are going to expand `%i' to `@FILE', where FILE
5176 is a newly-created temporary filename. The filenames
5177 that would usually be expanded in place of %o will be
5178 written to the temporary file. */
5179 char **argv;
5180 int n_files = 0;
5181 int j;
5183 for (i = 0; i < n_infiles; i++)
5184 if (compile_input_file_p (&infiles[i]))
5185 n_files++;
5187 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5189 /* Copy the strings over. */
5190 for (i = 0, j = 0; i < n_infiles; i++)
5191 if (compile_input_file_p (&infiles[i]))
5193 argv[j] = CONST_CAST (char *, infiles[i].name);
5194 infiles[i].compiled = true;
5195 j++;
5197 argv[j] = NULL;
5199 create_at_file (argv);
5201 else
5202 for (i = 0; (int) i < n_infiles; i++)
5203 if (compile_input_file_p (&infiles[i]))
5205 store_arg (infiles[i].name, 0, 0);
5206 infiles[i].compiled = true;
5209 else
5211 obstack_grow (&obstack, gcc_input_filename,
5212 input_filename_length);
5213 arg_going = 1;
5215 break;
5217 case 'I':
5219 struct spec_path_info info;
5221 if (multilib_dir)
5223 do_spec_1 ("-imultilib", 1, NULL);
5224 /* Make this a separate argument. */
5225 do_spec_1 (" ", 0, NULL);
5226 do_spec_1 (multilib_dir, 1, NULL);
5227 do_spec_1 (" ", 0, NULL);
5230 if (multiarch_dir)
5232 do_spec_1 ("-imultiarch", 1, NULL);
5233 /* Make this a separate argument. */
5234 do_spec_1 (" ", 0, NULL);
5235 do_spec_1 (multiarch_dir, 1, NULL);
5236 do_spec_1 (" ", 0, NULL);
5239 if (gcc_exec_prefix)
5241 do_spec_1 ("-iprefix", 1, NULL);
5242 /* Make this a separate argument. */
5243 do_spec_1 (" ", 0, NULL);
5244 do_spec_1 (gcc_exec_prefix, 1, NULL);
5245 do_spec_1 (" ", 0, NULL);
5248 if (target_system_root_changed ||
5249 (target_system_root && target_sysroot_hdrs_suffix))
5251 do_spec_1 ("-isysroot", 1, NULL);
5252 /* Make this a separate argument. */
5253 do_spec_1 (" ", 0, NULL);
5254 do_spec_1 (target_system_root, 1, NULL);
5255 if (target_sysroot_hdrs_suffix)
5256 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
5257 do_spec_1 (" ", 0, NULL);
5260 info.option = "-isystem";
5261 info.append = "include";
5262 info.append_len = strlen (info.append);
5263 info.omit_relative = false;
5264 info.separate_options = true;
5266 for_each_path (&include_prefixes, false, info.append_len,
5267 spec_path, &info);
5269 info.append = "include-fixed";
5270 if (*sysroot_hdrs_suffix_spec)
5271 info.append = concat (info.append, dir_separator_str,
5272 multilib_dir, NULL);
5273 info.append_len = strlen (info.append);
5274 for_each_path (&include_prefixes, false, info.append_len,
5275 spec_path, &info);
5277 break;
5279 case 'o':
5281 int max = n_infiles;
5282 max += lang_specific_extra_outfiles;
5284 if (HAVE_GNU_LD && at_file_supplied)
5286 /* We are going to expand `%o' to `@FILE', where FILE
5287 is a newly-created temporary filename. The filenames
5288 that would usually be expanded in place of %o will be
5289 written to the temporary file. */
5291 char **argv;
5292 int n_files, j;
5294 /* Convert OUTFILES into a form suitable for writeargv. */
5296 /* Determine how many are non-NULL. */
5297 for (n_files = 0, i = 0; i < max; i++)
5298 n_files += outfiles[i] != NULL;
5300 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5302 /* Copy the strings over. */
5303 for (i = 0, j = 0; i < max; i++)
5304 if (outfiles[i])
5306 argv[j] = CONST_CAST (char *, outfiles[i]);
5307 j++;
5309 argv[j] = NULL;
5311 create_at_file (argv);
5313 else
5314 for (i = 0; i < max; i++)
5315 if (outfiles[i])
5316 store_arg (outfiles[i], 0, 0);
5317 break;
5320 case 'O':
5321 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5322 arg_going = 1;
5323 break;
5325 case 's':
5326 this_is_library_file = 1;
5327 break;
5329 case 'T':
5330 this_is_linker_script = 1;
5331 break;
5333 case 'V':
5334 outfiles[input_file_number] = NULL;
5335 break;
5337 case 'w':
5338 this_is_output_file = 1;
5339 break;
5341 case 'W':
5343 unsigned int cur_index = argbuf.length ();
5344 /* Handle the {...} following the %W. */
5345 if (*p != '{')
5346 fatal_error ("spec %qs has invalid %<%%W%c%>", spec, *p);
5347 p = handle_braces (p + 1);
5348 if (p == 0)
5349 return -1;
5350 end_going_arg ();
5351 /* If any args were output, mark the last one for deletion
5352 on failure. */
5353 if (argbuf.length () != cur_index)
5354 record_temp_file (argbuf.last (), 0, 1);
5355 break;
5358 /* %x{OPTION} records OPTION for %X to output. */
5359 case 'x':
5361 const char *p1 = p;
5362 char *string;
5363 char *opt;
5364 unsigned ix;
5366 /* Skip past the option value and make a copy. */
5367 if (*p != '{')
5368 fatal_error ("spec %qs has invalid %<%%x%c%>", spec, *p);
5369 while (*p++ != '}')
5371 string = save_string (p1 + 1, p - p1 - 2);
5373 /* See if we already recorded this option. */
5374 FOR_EACH_VEC_ELT (linker_options, ix, opt)
5375 if (! strcmp (string, opt))
5377 free (string);
5378 return 0;
5381 /* This option is new; add it. */
5382 add_linker_option (string, strlen (string));
5383 free (string);
5385 break;
5387 /* Dump out the options accumulated previously using %x. */
5388 case 'X':
5389 do_specs_vec (linker_options);
5390 break;
5392 /* Dump out the options accumulated previously using -Wa,. */
5393 case 'Y':
5394 do_specs_vec (assembler_options);
5395 break;
5397 /* Dump out the options accumulated previously using -Wp,. */
5398 case 'Z':
5399 do_specs_vec (preprocessor_options);
5400 break;
5402 /* Here are digits and numbers that just process
5403 a certain constant string as a spec. */
5405 case '1':
5406 value = do_spec_1 (cc1_spec, 0, NULL);
5407 if (value != 0)
5408 return value;
5409 break;
5411 case '2':
5412 value = do_spec_1 (cc1plus_spec, 0, NULL);
5413 if (value != 0)
5414 return value;
5415 break;
5417 case 'a':
5418 value = do_spec_1 (asm_spec, 0, NULL);
5419 if (value != 0)
5420 return value;
5421 break;
5423 case 'A':
5424 value = do_spec_1 (asm_final_spec, 0, NULL);
5425 if (value != 0)
5426 return value;
5427 break;
5429 case 'C':
5431 const char *const spec
5432 = (input_file_compiler->cpp_spec
5433 ? input_file_compiler->cpp_spec
5434 : cpp_spec);
5435 value = do_spec_1 (spec, 0, NULL);
5436 if (value != 0)
5437 return value;
5439 break;
5441 case 'E':
5442 value = do_spec_1 (endfile_spec, 0, NULL);
5443 if (value != 0)
5444 return value;
5445 break;
5447 case 'l':
5448 value = do_spec_1 (link_spec, 0, NULL);
5449 if (value != 0)
5450 return value;
5451 break;
5453 case 'L':
5454 value = do_spec_1 (lib_spec, 0, NULL);
5455 if (value != 0)
5456 return value;
5457 break;
5459 case 'M':
5460 if (multilib_os_dir == NULL)
5461 obstack_1grow (&obstack, '.');
5462 else
5463 obstack_grow (&obstack, multilib_os_dir,
5464 strlen (multilib_os_dir));
5465 break;
5467 case 'G':
5468 value = do_spec_1 (libgcc_spec, 0, NULL);
5469 if (value != 0)
5470 return value;
5471 break;
5473 case 'R':
5474 /* We assume there is a directory
5475 separator at the end of this string. */
5476 if (target_system_root)
5478 obstack_grow (&obstack, target_system_root,
5479 strlen (target_system_root));
5480 if (target_sysroot_suffix)
5481 obstack_grow (&obstack, target_sysroot_suffix,
5482 strlen (target_sysroot_suffix));
5484 break;
5486 case 'S':
5487 value = do_spec_1 (startfile_spec, 0, NULL);
5488 if (value != 0)
5489 return value;
5490 break;
5492 /* Here we define characters other than letters and digits. */
5494 case '{':
5495 p = handle_braces (p);
5496 if (p == 0)
5497 return -1;
5498 break;
5500 case ':':
5501 p = handle_spec_function (p, NULL);
5502 if (p == 0)
5503 return -1;
5504 break;
5506 case '%':
5507 obstack_1grow (&obstack, '%');
5508 break;
5510 case '.':
5512 unsigned len = 0;
5514 while (p[len] && p[len] != ' ' && p[len] != '%')
5515 len++;
5516 suffix_subst = save_string (p - 1, len + 1);
5517 p += len;
5519 break;
5521 /* Henceforth ignore the option(s) matching the pattern
5522 after the %<. */
5523 case '<':
5524 case '>':
5526 unsigned len = 0;
5527 int have_wildcard = 0;
5528 int i;
5529 int switch_option;
5531 if (c == '>')
5532 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5533 else
5534 switch_option = SWITCH_IGNORE;
5536 while (p[len] && p[len] != ' ' && p[len] != '\t')
5537 len++;
5539 if (p[len-1] == '*')
5540 have_wildcard = 1;
5542 for (i = 0; i < n_switches; i++)
5543 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5544 && (have_wildcard || switches[i].part1[len] == '\0'))
5546 switches[i].live_cond |= switch_option;
5547 /* User switch be validated from validate_all_switches.
5548 when the definition is seen from the spec file.
5549 If not defined anywhere, will be rejected. */
5550 if (switches[i].known)
5551 switches[i].validated = true;
5554 p += len;
5556 break;
5558 case '*':
5559 if (soft_matched_part)
5561 if (soft_matched_part[0])
5562 do_spec_1 (soft_matched_part, 1, NULL);
5563 /* Only insert a space after the substitution if it is at the
5564 end of the current sequence. So if:
5566 "%{foo=*:bar%*}%{foo=*:one%*two}"
5568 matches -foo=hello then it will produce:
5570 barhello onehellotwo
5572 if (*p == 0 || *p == '}')
5573 do_spec_1 (" ", 0, NULL);
5575 else
5576 /* Catch the case where a spec string contains something like
5577 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5578 hand side of the :. */
5579 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5580 break;
5582 /* Process a string found as the value of a spec given by name.
5583 This feature allows individual machine descriptions
5584 to add and use their own specs. */
5585 case '(':
5587 const char *name = p;
5588 struct spec_list *sl;
5589 int len;
5591 /* The string after the S/P is the name of a spec that is to be
5592 processed. */
5593 while (*p && *p != ')')
5594 p++;
5596 /* See if it's in the list. */
5597 for (len = p - name, sl = specs; sl; sl = sl->next)
5598 if (sl->name_len == len && !strncmp (sl->name, name, len))
5600 name = *(sl->ptr_spec);
5601 #ifdef DEBUG_SPECS
5602 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5603 sl->name, name);
5604 #endif
5605 break;
5608 if (sl)
5610 value = do_spec_1 (name, 0, NULL);
5611 if (value != 0)
5612 return value;
5615 /* Discard the closing paren. */
5616 if (*p)
5617 p++;
5619 break;
5621 default:
5622 error ("spec failure: unrecognized spec option %qc", c);
5623 break;
5625 break;
5627 case '\\':
5628 /* Backslash: treat next character as ordinary. */
5629 c = *p++;
5631 /* Fall through. */
5632 default:
5633 /* Ordinary character: put it into the current argument. */
5634 obstack_1grow (&obstack, c);
5635 arg_going = 1;
5638 /* End of string. If we are processing a spec function, we need to
5639 end any pending argument. */
5640 if (processing_spec_function)
5641 end_going_arg ();
5643 return 0;
5646 /* Look up a spec function. */
5648 static const struct spec_function *
5649 lookup_spec_function (const char *name)
5651 const struct spec_function *sf;
5653 for (sf = static_spec_functions; sf->name != NULL; sf++)
5654 if (strcmp (sf->name, name) == 0)
5655 return sf;
5657 return NULL;
5660 /* Evaluate a spec function. */
5662 static const char *
5663 eval_spec_function (const char *func, const char *args)
5665 const struct spec_function *sf;
5666 const char *funcval;
5668 /* Saved spec processing context. */
5669 vec<const_char_p> save_argbuf;
5671 int save_arg_going;
5672 int save_delete_this_arg;
5673 int save_this_is_output_file;
5674 int save_this_is_library_file;
5675 int save_input_from_pipe;
5676 int save_this_is_linker_script;
5677 const char *save_suffix_subst;
5679 int save_growing_size;
5680 void *save_growing_value = NULL;
5682 sf = lookup_spec_function (func);
5683 if (sf == NULL)
5684 fatal_error ("unknown spec function %qs", func);
5686 /* Push the spec processing context. */
5687 save_argbuf = argbuf;
5689 save_arg_going = arg_going;
5690 save_delete_this_arg = delete_this_arg;
5691 save_this_is_output_file = this_is_output_file;
5692 save_this_is_library_file = this_is_library_file;
5693 save_this_is_linker_script = this_is_linker_script;
5694 save_input_from_pipe = input_from_pipe;
5695 save_suffix_subst = suffix_subst;
5697 /* If we have some object growing now, finalize it so the args and function
5698 eval proceed from a cleared context. This is needed to prevent the first
5699 constructed arg from mistakenly including the growing value. We'll push
5700 this value back on the obstack once the function evaluation is done, to
5701 restore a consistent processing context for our caller. This is fine as
5702 the address of growing objects isn't guaranteed to remain stable until
5703 they are finalized, and we expect this situation to be rare enough for
5704 the extra copy not to be an issue. */
5705 save_growing_size = obstack_object_size (&obstack);
5706 if (save_growing_size > 0)
5707 save_growing_value = obstack_finish (&obstack);
5709 /* Create a new spec processing context, and build the function
5710 arguments. */
5712 alloc_args ();
5713 if (do_spec_2 (args) < 0)
5714 fatal_error ("error in args to spec function %qs", func);
5716 /* argbuf_index is an index for the next argument to be inserted, and
5717 so contains the count of the args already inserted. */
5719 funcval = (*sf->func) (argbuf.length (),
5720 argbuf.address ());
5722 /* Pop the spec processing context. */
5723 argbuf.release ();
5724 argbuf = save_argbuf;
5726 arg_going = save_arg_going;
5727 delete_this_arg = save_delete_this_arg;
5728 this_is_output_file = save_this_is_output_file;
5729 this_is_library_file = save_this_is_library_file;
5730 this_is_linker_script = save_this_is_linker_script;
5731 input_from_pipe = save_input_from_pipe;
5732 suffix_subst = save_suffix_subst;
5734 if (save_growing_size > 0)
5735 obstack_grow (&obstack, save_growing_value, save_growing_size);
5737 return funcval;
5740 /* Handle a spec function call of the form:
5742 %:function(args)
5744 ARGS is processed as a spec in a separate context and split into an
5745 argument vector in the normal fashion. The function returns a string
5746 containing a spec which we then process in the caller's context, or
5747 NULL if no processing is required.
5749 If RETVAL_NONNULL is not NULL, then store a bool whether function
5750 returned non-NULL. */
5752 static const char *
5753 handle_spec_function (const char *p, bool *retval_nonnull)
5755 char *func, *args;
5756 const char *endp, *funcval;
5757 int count;
5759 processing_spec_function++;
5761 /* Get the function name. */
5762 for (endp = p; *endp != '\0'; endp++)
5764 if (*endp == '(') /* ) */
5765 break;
5766 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5767 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5768 fatal_error ("malformed spec function name");
5770 if (*endp != '(') /* ) */
5771 fatal_error ("no arguments for spec function");
5772 func = save_string (p, endp - p);
5773 p = ++endp;
5775 /* Get the arguments. */
5776 for (count = 0; *endp != '\0'; endp++)
5778 /* ( */
5779 if (*endp == ')')
5781 if (count == 0)
5782 break;
5783 count--;
5785 else if (*endp == '(') /* ) */
5786 count++;
5788 /* ( */
5789 if (*endp != ')')
5790 fatal_error ("malformed spec function arguments");
5791 args = save_string (p, endp - p);
5792 p = ++endp;
5794 /* p now points to just past the end of the spec function expression. */
5796 funcval = eval_spec_function (func, args);
5797 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5798 p = NULL;
5799 if (retval_nonnull)
5800 *retval_nonnull = funcval != NULL;
5802 free (func);
5803 free (args);
5805 processing_spec_function--;
5807 return p;
5810 /* Inline subroutine of handle_braces. Returns true if the current
5811 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5812 static inline bool
5813 input_suffix_matches (const char *atom, const char *end_atom)
5815 return (input_suffix
5816 && !strncmp (input_suffix, atom, end_atom - atom)
5817 && input_suffix[end_atom - atom] == '\0');
5820 /* Subroutine of handle_braces. Returns true if the current
5821 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
5822 static bool
5823 input_spec_matches (const char *atom, const char *end_atom)
5825 return (input_file_compiler
5826 && input_file_compiler->suffix
5827 && input_file_compiler->suffix[0] != '\0'
5828 && !strncmp (input_file_compiler->suffix + 1, atom,
5829 end_atom - atom)
5830 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
5833 /* Subroutine of handle_braces. Returns true if a switch
5834 matching the atom bracketed by ATOM and END_ATOM appeared on the
5835 command line. */
5836 static bool
5837 switch_matches (const char *atom, const char *end_atom, int starred)
5839 int i;
5840 int len = end_atom - atom;
5841 int plen = starred ? len : -1;
5843 for (i = 0; i < n_switches; i++)
5844 if (!strncmp (switches[i].part1, atom, len)
5845 && (starred || switches[i].part1[len] == '\0')
5846 && check_live_switch (i, plen))
5847 return true;
5849 /* Check if a switch with separated form matching the atom.
5850 We check -D and -U switches. */
5851 else if (switches[i].args != 0)
5853 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
5854 && *switches[i].part1 == atom[0])
5856 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
5857 && (starred || (switches[i].part1[1] == '\0'
5858 && switches[i].args[0][len - 1] == '\0'))
5859 && check_live_switch (i, (starred ? 1 : -1)))
5860 return true;
5864 return false;
5867 /* Inline subroutine of handle_braces. Mark all of the switches which
5868 match ATOM (extends to END_ATOM; STARRED indicates whether there
5869 was a star after the atom) for later processing. */
5870 static inline void
5871 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5873 int i;
5874 int len = end_atom - atom;
5875 int plen = starred ? len : -1;
5877 for (i = 0; i < n_switches; i++)
5878 if (!strncmp (switches[i].part1, atom, len)
5879 && (starred || switches[i].part1[len] == '\0')
5880 && check_live_switch (i, plen))
5881 switches[i].ordering = 1;
5884 /* Inline subroutine of handle_braces. Process all the currently
5885 marked switches through give_switch, and clear the marks. */
5886 static inline void
5887 process_marked_switches (void)
5889 int i;
5891 for (i = 0; i < n_switches; i++)
5892 if (switches[i].ordering == 1)
5894 switches[i].ordering = 0;
5895 give_switch (i, 0);
5899 /* Handle a %{ ... } construct. P points just inside the leading {.
5900 Returns a pointer one past the end of the brace block, or 0
5901 if we call do_spec_1 and that returns -1. */
5903 static const char *
5904 handle_braces (const char *p)
5906 const char *atom, *end_atom;
5907 const char *d_atom = NULL, *d_end_atom = NULL;
5908 const char *orig = p;
5910 bool a_is_suffix;
5911 bool a_is_spectype;
5912 bool a_is_starred;
5913 bool a_is_negated;
5914 bool a_matched;
5916 bool a_must_be_last = false;
5917 bool ordered_set = false;
5918 bool disjunct_set = false;
5919 bool disj_matched = false;
5920 bool disj_starred = true;
5921 bool n_way_choice = false;
5922 bool n_way_matched = false;
5924 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5928 if (a_must_be_last)
5929 goto invalid;
5931 /* Scan one "atom" (S in the description above of %{}, possibly
5932 with '!', '.', '@', ',', or '*' modifiers). */
5933 a_matched = false;
5934 a_is_suffix = false;
5935 a_is_starred = false;
5936 a_is_negated = false;
5937 a_is_spectype = false;
5939 SKIP_WHITE ();
5940 if (*p == '!')
5941 p++, a_is_negated = true;
5943 SKIP_WHITE ();
5944 if (*p == '%' && p[1] == ':')
5946 atom = NULL;
5947 end_atom = NULL;
5948 p = handle_spec_function (p + 2, &a_matched);
5950 else
5952 if (*p == '.')
5953 p++, a_is_suffix = true;
5954 else if (*p == ',')
5955 p++, a_is_spectype = true;
5957 atom = p;
5958 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
5959 || *p == ',' || *p == '.' || *p == '@')
5960 p++;
5961 end_atom = p;
5963 if (*p == '*')
5964 p++, a_is_starred = 1;
5967 SKIP_WHITE ();
5968 switch (*p)
5970 case '&': case '}':
5971 /* Substitute the switch(es) indicated by the current atom. */
5972 ordered_set = true;
5973 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5974 || a_is_spectype || atom == end_atom)
5975 goto invalid;
5977 mark_matching_switches (atom, end_atom, a_is_starred);
5979 if (*p == '}')
5980 process_marked_switches ();
5981 break;
5983 case '|': case ':':
5984 /* Substitute some text if the current atom appears as a switch
5985 or suffix. */
5986 disjunct_set = true;
5987 if (ordered_set)
5988 goto invalid;
5990 if (atom && atom == end_atom)
5992 if (!n_way_choice || disj_matched || *p == '|'
5993 || a_is_negated || a_is_suffix || a_is_spectype
5994 || a_is_starred)
5995 goto invalid;
5997 /* An empty term may appear as the last choice of an
5998 N-way choice set; it means "otherwise". */
5999 a_must_be_last = true;
6000 disj_matched = !n_way_matched;
6001 disj_starred = false;
6003 else
6005 if ((a_is_suffix || a_is_spectype) && a_is_starred)
6006 goto invalid;
6008 if (!a_is_starred)
6009 disj_starred = false;
6011 /* Don't bother testing this atom if we already have a
6012 match. */
6013 if (!disj_matched && !n_way_matched)
6015 if (atom == NULL)
6016 /* a_matched is already set by handle_spec_function. */;
6017 else if (a_is_suffix)
6018 a_matched = input_suffix_matches (atom, end_atom);
6019 else if (a_is_spectype)
6020 a_matched = input_spec_matches (atom, end_atom);
6021 else
6022 a_matched = switch_matches (atom, end_atom, a_is_starred);
6024 if (a_matched != a_is_negated)
6026 disj_matched = true;
6027 d_atom = atom;
6028 d_end_atom = end_atom;
6033 if (*p == ':')
6035 /* Found the body, that is, the text to substitute if the
6036 current disjunction matches. */
6037 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
6038 disj_matched && !n_way_matched);
6039 if (p == 0)
6040 return 0;
6042 /* If we have an N-way choice, reset state for the next
6043 disjunction. */
6044 if (*p == ';')
6046 n_way_choice = true;
6047 n_way_matched |= disj_matched;
6048 disj_matched = false;
6049 disj_starred = true;
6050 d_atom = d_end_atom = NULL;
6053 break;
6055 default:
6056 goto invalid;
6059 while (*p++ != '}');
6061 return p;
6063 invalid:
6064 fatal_error ("braced spec %qs is invalid at %qc", orig, *p);
6066 #undef SKIP_WHITE
6069 /* Subroutine of handle_braces. Scan and process a brace substitution body
6070 (X in the description of %{} syntax). P points one past the colon;
6071 ATOM and END_ATOM bracket the first atom which was found to be true
6072 (present) in the current disjunction; STARRED indicates whether all
6073 the atoms in the current disjunction were starred (for syntax validation);
6074 MATCHED indicates whether the disjunction matched or not, and therefore
6075 whether or not the body is to be processed through do_spec_1 or just
6076 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
6077 returns -1. */
6079 static const char *
6080 process_brace_body (const char *p, const char *atom, const char *end_atom,
6081 int starred, int matched)
6083 const char *body, *end_body;
6084 unsigned int nesting_level;
6085 bool have_subst = false;
6087 /* Locate the closing } or ;, honoring nested braces.
6088 Trim trailing whitespace. */
6089 body = p;
6090 nesting_level = 1;
6091 for (;;)
6093 if (*p == '{')
6094 nesting_level++;
6095 else if (*p == '}')
6097 if (!--nesting_level)
6098 break;
6100 else if (*p == ';' && nesting_level == 1)
6101 break;
6102 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
6103 have_subst = true;
6104 else if (*p == '\0')
6105 goto invalid;
6106 p++;
6109 end_body = p;
6110 while (end_body[-1] == ' ' || end_body[-1] == '\t')
6111 end_body--;
6113 if (have_subst && !starred)
6114 goto invalid;
6116 if (matched)
6118 /* Copy the substitution body to permanent storage and execute it.
6119 If have_subst is false, this is a simple matter of running the
6120 body through do_spec_1... */
6121 char *string = save_string (body, end_body - body);
6122 if (!have_subst)
6124 if (do_spec_1 (string, 0, NULL) < 0)
6125 return 0;
6127 else
6129 /* ... but if have_subst is true, we have to process the
6130 body once for each matching switch, with %* set to the
6131 variant part of the switch. */
6132 unsigned int hard_match_len = end_atom - atom;
6133 int i;
6135 for (i = 0; i < n_switches; i++)
6136 if (!strncmp (switches[i].part1, atom, hard_match_len)
6137 && check_live_switch (i, hard_match_len))
6139 if (do_spec_1 (string, 0,
6140 &switches[i].part1[hard_match_len]) < 0)
6141 return 0;
6142 /* Pass any arguments this switch has. */
6143 give_switch (i, 1);
6144 suffix_subst = NULL;
6149 return p;
6151 invalid:
6152 fatal_error ("braced spec body %qs is invalid", body);
6155 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
6156 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
6157 spec, or -1 if either exact match or %* is used.
6159 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
6160 whose value does not begin with "no-" is obsoleted by the same value
6161 with the "no-", similarly for a switch with the "no-" prefix. */
6163 static int
6164 check_live_switch (int switchnum, int prefix_length)
6166 const char *name = switches[switchnum].part1;
6167 int i;
6169 /* If we already processed this switch and determined if it was
6170 live or not, return our past determination. */
6171 if (switches[switchnum].live_cond != 0)
6172 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
6173 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
6174 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
6175 == 0);
6177 /* In the common case of {<at-most-one-letter>*}, a negating
6178 switch would always match, so ignore that case. We will just
6179 send the conflicting switches to the compiler phase. */
6180 if (prefix_length >= 0 && prefix_length <= 1)
6181 return 1;
6183 /* Now search for duplicate in a manner that depends on the name. */
6184 switch (*name)
6186 case 'O':
6187 for (i = switchnum + 1; i < n_switches; i++)
6188 if (switches[i].part1[0] == 'O')
6190 switches[switchnum].validated = true;
6191 switches[switchnum].live_cond = SWITCH_FALSE;
6192 return 0;
6194 break;
6196 case 'W': case 'f': case 'm': case 'g':
6197 if (! strncmp (name + 1, "no-", 3))
6199 /* We have Xno-YYY, search for XYYY. */
6200 for (i = switchnum + 1; i < n_switches; i++)
6201 if (switches[i].part1[0] == name[0]
6202 && ! strcmp (&switches[i].part1[1], &name[4]))
6204 /* --specs are validated with the validate_switches mechanism. */
6205 if (switches[switchnum].known)
6206 switches[switchnum].validated = true;
6207 switches[switchnum].live_cond = SWITCH_FALSE;
6208 return 0;
6211 else
6213 /* We have XYYY, search for Xno-YYY. */
6214 for (i = switchnum + 1; i < n_switches; i++)
6215 if (switches[i].part1[0] == name[0]
6216 && switches[i].part1[1] == 'n'
6217 && switches[i].part1[2] == 'o'
6218 && switches[i].part1[3] == '-'
6219 && !strcmp (&switches[i].part1[4], &name[1]))
6221 /* --specs are validated with the validate_switches mechanism. */
6222 if (switches[switchnum].known)
6223 switches[switchnum].validated = true;
6224 switches[switchnum].live_cond = SWITCH_FALSE;
6225 return 0;
6228 break;
6231 /* Otherwise the switch is live. */
6232 switches[switchnum].live_cond |= SWITCH_LIVE;
6233 return 1;
6236 /* Pass a switch to the current accumulating command
6237 in the same form that we received it.
6238 SWITCHNUM identifies the switch; it is an index into
6239 the vector of switches gcc received, which is `switches'.
6240 This cannot fail since it never finishes a command line.
6242 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
6244 static void
6245 give_switch (int switchnum, int omit_first_word)
6247 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
6248 return;
6250 if (!omit_first_word)
6252 do_spec_1 ("-", 0, NULL);
6253 do_spec_1 (switches[switchnum].part1, 1, NULL);
6256 if (switches[switchnum].args != 0)
6258 const char **p;
6259 for (p = switches[switchnum].args; *p; p++)
6261 const char *arg = *p;
6263 do_spec_1 (" ", 0, NULL);
6264 if (suffix_subst)
6266 unsigned length = strlen (arg);
6267 int dot = 0;
6269 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
6270 if (arg[length] == '.')
6272 (CONST_CAST (char *, arg))[length] = 0;
6273 dot = 1;
6274 break;
6276 do_spec_1 (arg, 1, NULL);
6277 if (dot)
6278 (CONST_CAST (char *, arg))[length] = '.';
6279 do_spec_1 (suffix_subst, 1, NULL);
6281 else
6282 do_spec_1 (arg, 1, NULL);
6286 do_spec_1 (" ", 0, NULL);
6287 switches[switchnum].validated = true;
6290 /* Print GCC configuration (e.g. version, thread model, target,
6291 configuration_arguments) to a given FILE. */
6293 static void
6294 print_configuration (FILE *file)
6296 int n;
6297 const char *thrmod;
6299 fnotice (file, "Target: %s\n", spec_machine);
6300 fnotice (file, "Configured with: %s\n", configuration_arguments);
6302 #ifdef THREAD_MODEL_SPEC
6303 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6304 but there's no point in doing all this processing just to get
6305 thread_model back. */
6306 obstack_init (&obstack);
6307 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6308 obstack_1grow (&obstack, '\0');
6309 thrmod = XOBFINISH (&obstack, const char *);
6310 #else
6311 thrmod = thread_model;
6312 #endif
6314 fnotice (file, "Thread model: %s\n", thrmod);
6316 /* compiler_version is truncated at the first space when initialized
6317 from version string, so truncate version_string at the first space
6318 before comparing. */
6319 for (n = 0; version_string[n]; n++)
6320 if (version_string[n] == ' ')
6321 break;
6323 if (! strncmp (version_string, compiler_version, n)
6324 && compiler_version[n] == 0)
6325 fnotice (file, "gcc version %s %s\n\n", version_string,
6326 pkgversion_string);
6327 else
6328 fnotice (file, "gcc driver version %s %sexecuting gcc version %s\n\n",
6329 version_string, pkgversion_string, compiler_version);
6333 #define RETRY_ICE_ATTEMPTS 3
6335 /* Returns true if FILE1 and FILE2 contain equivalent data, 0 otherwise. */
6337 static bool
6338 files_equal_p (char *file1, char *file2)
6340 struct stat st1, st2;
6341 off_t n, len;
6342 int fd1, fd2;
6343 const int bufsize = 8192;
6344 char *buf = XNEWVEC (char, bufsize);
6346 fd1 = open (file1, O_RDONLY);
6347 fd2 = open (file2, O_RDONLY);
6349 if (fd1 < 0 || fd2 < 0)
6350 goto error;
6352 if (fstat (fd1, &st1) < 0 || fstat (fd2, &st2) < 0)
6353 goto error;
6355 if (st1.st_size != st2.st_size)
6356 goto error;
6358 for (n = st1.st_size; n; n -= len)
6360 len = n;
6361 if ((int) len > bufsize / 2)
6362 len = bufsize / 2;
6364 if (read (fd1, buf, len) != (int) len
6365 || read (fd2, buf + bufsize / 2, len) != (int) len)
6367 goto error;
6370 if (memcmp (buf, buf + bufsize / 2, len) != 0)
6371 goto error;
6374 free (buf);
6375 close (fd1);
6376 close (fd2);
6378 return 1;
6380 error:
6381 free (buf);
6382 close (fd1);
6383 close (fd2);
6384 return 0;
6387 /* Check that compiler's output doesn't differ across runs.
6388 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are arrays of files, containing
6389 stdout and stderr for each compiler run. Return true if all of
6390 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are equivalent. */
6392 static bool
6393 check_repro (char **temp_stdout_files, char **temp_stderr_files)
6395 int i;
6396 for (i = 0; i < RETRY_ICE_ATTEMPTS - 2; ++i)
6398 if (!files_equal_p (temp_stdout_files[i], temp_stdout_files[i + 1])
6399 || !files_equal_p (temp_stderr_files[i], temp_stderr_files[i + 1]))
6401 fnotice (stderr, "The bug is not reproducible, so it is"
6402 " likely a hardware or OS problem.\n");
6403 break;
6406 return i == RETRY_ICE_ATTEMPTS - 2;
6409 enum attempt_status {
6410 ATTEMPT_STATUS_FAIL_TO_RUN,
6411 ATTEMPT_STATUS_SUCCESS,
6412 ATTEMPT_STATUS_ICE
6416 /* Run compiler with arguments NEW_ARGV to reproduce the ICE, storing stdout
6417 to OUT_TEMP and stderr to ERR_TEMP. If APPEND is TRUE, append to OUT_TEMP
6418 and ERR_TEMP instead of truncating. If EMIT_SYSTEM_INFO is TRUE, also write
6419 GCC configuration into to ERR_TEMP. Return ATTEMPT_STATUS_FAIL_TO_RUN if
6420 compiler failed to run, ATTEMPT_STATUS_ICE if compiled ICE-ed and
6421 ATTEMPT_STATUS_SUCCESS otherwise. */
6423 static enum attempt_status
6424 run_attempt (const char **new_argv, const char *out_temp,
6425 const char *err_temp, int emit_system_info, int append)
6428 if (emit_system_info)
6430 FILE *file_out = fopen (err_temp, "a");
6431 print_configuration (file_out);
6432 fclose (file_out);
6435 int exit_status;
6436 const char *errmsg;
6437 struct pex_obj *pex;
6438 int err;
6439 int pex_flags = PEX_USE_PIPES | PEX_LAST;
6440 enum attempt_status status = ATTEMPT_STATUS_FAIL_TO_RUN;
6442 if (append)
6443 pex_flags |= PEX_STDOUT_APPEND | PEX_STDERR_APPEND;
6445 pex = pex_init (PEX_USE_PIPES, new_argv[0], NULL);
6446 if (!pex)
6447 fatal_error ("pex_init failed: %m");
6449 errmsg = pex_run (pex, pex_flags, new_argv[0],
6450 CONST_CAST2 (char *const *, const char **, &new_argv[1]), out_temp,
6451 err_temp, &err);
6452 if (errmsg != NULL)
6454 if (err == 0)
6455 fatal_error (errmsg);
6456 else
6458 errno = err;
6459 pfatal_with_name (errmsg);
6463 if (!pex_get_status (pex, 1, &exit_status))
6464 goto out;
6466 switch (WEXITSTATUS (exit_status))
6468 case ICE_EXIT_CODE:
6469 status = ATTEMPT_STATUS_ICE;
6470 break;
6472 case SUCCESS_EXIT_CODE:
6473 status = ATTEMPT_STATUS_SUCCESS;
6474 break;
6476 default:
6480 out:
6481 pex_free (pex);
6482 return status;
6485 /* This routine adds preprocessed source code into the given ERR_FILE.
6486 To do this, it adds "-E" to NEW_ARGV and execute RUN_ATTEMPT routine to
6487 add information in report file. RUN_ATTEMPT should return
6488 ATTEMPT_STATUS_SUCCESS, in other case we cannot generate the report. */
6490 static void
6491 do_report_bug (const char **new_argv, const int nargs,
6492 char **out_file, char **err_file)
6494 int i, status;
6495 int fd = open (*out_file, O_RDWR | O_APPEND);
6496 if (fd < 0)
6497 return;
6498 write (fd, "\n//", 3);
6499 for (i = 0; i < nargs; i++)
6501 write (fd, " ", 1);
6502 write (fd, new_argv[i], strlen (new_argv[i]));
6504 write (fd, "\n\n", 2);
6505 close (fd);
6506 new_argv[nargs] = "-E";
6507 new_argv[nargs + 1] = NULL;
6509 status = run_attempt (new_argv, *out_file, *err_file, 0, 1);
6511 if (status == ATTEMPT_STATUS_SUCCESS)
6513 fnotice (stderr, "Preprocessed source stored into %s file,"
6514 " please attach this to your bugreport.\n", *out_file);
6515 /* Make sure it is not deleted. */
6516 free (*out_file);
6517 *out_file = NULL;
6521 /* Append string STR to file FILE. */
6523 static void
6524 append_text (char *file, const char *str)
6526 int fd = open (file, O_RDWR | O_APPEND);
6527 if (fd < 0)
6528 return;
6530 write (fd, str, strlen (str));
6531 close (fd);
6534 /* Try to reproduce ICE. If bug is reproducible, generate report .err file
6535 containing GCC configuration, backtrace, compiler's command line options
6536 and preprocessed source code. */
6538 static void
6539 try_generate_repro (const char **argv)
6541 int i, nargs, out_arg = -1, quiet = 0, attempt;
6542 const char **new_argv;
6543 char *temp_files[RETRY_ICE_ATTEMPTS * 2];
6544 char **temp_stdout_files = &temp_files[0];
6545 char **temp_stderr_files = &temp_files[RETRY_ICE_ATTEMPTS];
6547 if (gcc_input_filename == NULL || ! strcmp (gcc_input_filename, "-"))
6548 return;
6550 for (nargs = 0; argv[nargs] != NULL; ++nargs)
6551 /* Only retry compiler ICEs, not preprocessor ones. */
6552 if (! strcmp (argv[nargs], "-E"))
6553 return;
6554 else if (argv[nargs][0] == '-' && argv[nargs][1] == 'o')
6556 if (out_arg == -1)
6557 out_arg = nargs;
6558 else
6559 return;
6561 /* If the compiler is going to output any time information,
6562 it might varry between invocations. */
6563 else if (! strcmp (argv[nargs], "-quiet"))
6564 quiet = 1;
6565 else if (! strcmp (argv[nargs], "-ftime-report"))
6566 return;
6568 if (out_arg == -1 || !quiet)
6569 return;
6571 memset (temp_files, '\0', sizeof (temp_files));
6572 new_argv = XALLOCAVEC (const char *, nargs + 4);
6573 memcpy (new_argv, argv, (nargs + 1) * sizeof (const char *));
6574 new_argv[nargs++] = "-frandom-seed=0";
6575 new_argv[nargs++] = "-fdump-noaddr";
6576 new_argv[nargs] = NULL;
6577 if (new_argv[out_arg][2] == '\0')
6578 new_argv[out_arg + 1] = "-";
6579 else
6580 new_argv[out_arg] = "-o-";
6582 int status;
6583 for (attempt = 0; attempt < RETRY_ICE_ATTEMPTS; ++attempt)
6585 int emit_system_info = 0;
6586 int append = 0;
6587 temp_stdout_files[attempt] = make_temp_file (".out");
6588 temp_stderr_files[attempt] = make_temp_file (".err");
6590 if (attempt == RETRY_ICE_ATTEMPTS - 1)
6592 append = 1;
6593 emit_system_info = 1;
6596 if (emit_system_info)
6597 append_text (temp_stderr_files[attempt], "/*\n");
6599 status = run_attempt (new_argv, temp_stdout_files[attempt],
6600 temp_stderr_files[attempt], emit_system_info,
6601 append);
6603 if (emit_system_info)
6604 append_text (temp_stderr_files[attempt], "*/\n");
6606 if (status != ATTEMPT_STATUS_ICE)
6608 fnotice (stderr, "The bug is not reproducible, so it is"
6609 " likely a hardware or OS problem.\n");
6610 goto out;
6614 if (!check_repro (temp_stdout_files, temp_stderr_files))
6615 goto out;
6617 /* In final attempt we append compiler options and preprocesssed code to last
6618 generated .err file with configuration and backtrace. */
6619 do_report_bug (new_argv, nargs,
6620 &temp_stderr_files[RETRY_ICE_ATTEMPTS - 1],
6621 &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1]);
6623 out:
6624 for (i = 0; i < RETRY_ICE_ATTEMPTS * 2; i++)
6625 if (temp_files[i])
6627 unlink (temp_stdout_files[i]);
6628 free (temp_stdout_files[i]);
6632 /* Search for a file named NAME trying various prefixes including the
6633 user's -B prefix and some standard ones.
6634 Return the absolute file name found. If nothing is found, return NAME. */
6636 static const char *
6637 find_file (const char *name)
6639 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
6640 return newname ? newname : name;
6643 /* Determine whether a directory exists. If LINKER, return 0 for
6644 certain fixed names not needed by the linker. */
6646 static int
6647 is_directory (const char *path1, bool linker)
6649 int len1;
6650 char *path;
6651 char *cp;
6652 struct stat st;
6654 /* Ensure the string ends with "/.". The resulting path will be a
6655 directory even if the given path is a symbolic link. */
6656 len1 = strlen (path1);
6657 path = (char *) alloca (3 + len1);
6658 memcpy (path, path1, len1);
6659 cp = path + len1;
6660 if (!IS_DIR_SEPARATOR (cp[-1]))
6661 *cp++ = DIR_SEPARATOR;
6662 *cp++ = '.';
6663 *cp = '\0';
6665 /* Exclude directories that the linker is known to search. */
6666 if (linker
6667 && IS_DIR_SEPARATOR (path[0])
6668 && ((cp - path == 6
6669 && filename_ncmp (path + 1, "lib", 3) == 0)
6670 || (cp - path == 10
6671 && filename_ncmp (path + 1, "usr", 3) == 0
6672 && IS_DIR_SEPARATOR (path[4])
6673 && filename_ncmp (path + 5, "lib", 3) == 0)))
6674 return 0;
6676 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
6679 /* Set up the various global variables to indicate that we're processing
6680 the input file named FILENAME. */
6682 void
6683 set_input (const char *filename)
6685 const char *p;
6687 gcc_input_filename = filename;
6688 input_filename_length = strlen (gcc_input_filename);
6689 input_basename = lbasename (gcc_input_filename);
6691 /* Find a suffix starting with the last period,
6692 and set basename_length to exclude that suffix. */
6693 basename_length = strlen (input_basename);
6694 suffixed_basename_length = basename_length;
6695 p = input_basename + basename_length;
6696 while (p != input_basename && *p != '.')
6697 --p;
6698 if (*p == '.' && p != input_basename)
6700 basename_length = p - input_basename;
6701 input_suffix = p + 1;
6703 else
6704 input_suffix = "";
6706 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6707 we will need to do a stat on the gcc_input_filename. The
6708 INPUT_STAT_SET signals that the stat is needed. */
6709 input_stat_set = 0;
6712 /* On fatal signals, delete all the temporary files. */
6714 static void
6715 fatal_signal (int signum)
6717 signal (signum, SIG_DFL);
6718 delete_failure_queue ();
6719 delete_temp_files ();
6720 /* Get the same signal again, this time not handled,
6721 so its normal effect occurs. */
6722 kill (getpid (), signum);
6725 /* Compare the contents of the two files named CMPFILE[0] and
6726 CMPFILE[1]. Return zero if they're identical, nonzero
6727 otherwise. */
6729 static int
6730 compare_files (char *cmpfile[])
6732 int ret = 0;
6733 FILE *temp[2] = { NULL, NULL };
6734 int i;
6736 #if HAVE_MMAP_FILE
6738 size_t length[2];
6739 void *map[2] = { NULL, NULL };
6741 for (i = 0; i < 2; i++)
6743 struct stat st;
6745 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
6747 error ("%s: could not determine length of compare-debug file %s",
6748 gcc_input_filename, cmpfile[i]);
6749 ret = 1;
6750 break;
6753 length[i] = st.st_size;
6756 if (!ret && length[0] != length[1])
6758 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
6759 ret = 1;
6762 if (!ret)
6763 for (i = 0; i < 2; i++)
6765 int fd = open (cmpfile[i], O_RDONLY);
6766 if (fd < 0)
6768 error ("%s: could not open compare-debug file %s",
6769 gcc_input_filename, cmpfile[i]);
6770 ret = 1;
6771 break;
6774 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
6775 close (fd);
6777 if (map[i] == (void *) MAP_FAILED)
6779 ret = -1;
6780 break;
6784 if (!ret)
6786 if (memcmp (map[0], map[1], length[0]) != 0)
6788 error ("%s: -fcompare-debug failure", gcc_input_filename);
6789 ret = 1;
6793 for (i = 0; i < 2; i++)
6794 if (map[i])
6795 munmap ((caddr_t) map[i], length[i]);
6797 if (ret >= 0)
6798 return ret;
6800 ret = 0;
6802 #endif
6804 for (i = 0; i < 2; i++)
6806 temp[i] = fopen (cmpfile[i], "r");
6807 if (!temp[i])
6809 error ("%s: could not open compare-debug file %s",
6810 gcc_input_filename, cmpfile[i]);
6811 ret = 1;
6812 break;
6816 if (!ret && temp[0] && temp[1])
6817 for (;;)
6819 int c0, c1;
6820 c0 = fgetc (temp[0]);
6821 c1 = fgetc (temp[1]);
6823 if (c0 != c1)
6825 error ("%s: -fcompare-debug failure",
6826 gcc_input_filename);
6827 ret = 1;
6828 break;
6831 if (c0 == EOF)
6832 break;
6835 for (i = 1; i >= 0; i--)
6837 if (temp[i])
6838 fclose (temp[i]);
6841 return ret;
6844 /* The top-level "main" within the driver would be ~1000 lines long.
6845 This class breaks it up into smaller functions and contains some
6846 state shared by them. */
6848 class driver
6850 public:
6851 int main (int argc, char **argv);
6853 private:
6854 void set_progname (const char *argv0) const;
6855 void expand_at_files (int *argc, char ***argv) const;
6856 void decode_argv (int argc, const char **argv);
6857 void global_initializations ();
6858 void build_multilib_strings () const;
6859 void set_up_specs () const;
6860 void putenv_COLLECT_GCC (const char *argv0) const;
6861 void maybe_putenv_COLLECT_LTO_WRAPPER () const;
6862 void maybe_putenv_OFFLOAD_TARGETS () const;
6863 void handle_unrecognized_options () const;
6864 int maybe_print_and_exit () const;
6865 bool prepare_infiles ();
6866 void do_spec_on_infiles () const;
6867 void maybe_run_linker (const char *argv0) const;
6868 void final_actions () const;
6869 int get_exit_code () const;
6871 private:
6872 char *explicit_link_files;
6873 struct cl_decoded_option *decoded_options;
6874 unsigned int decoded_options_count;
6877 /* Implement the top-level "main" within the driver in terms of
6878 driver::main. */
6880 extern int main (int, char **);
6883 main (int argc, char **argv)
6885 driver d;
6887 return d.main (argc, argv);
6890 /* driver::main is implemented as a series of driver:: method calls. */
6893 driver::main (int argc, char **argv)
6895 bool early_exit;
6897 set_progname (argv[0]);
6898 expand_at_files (&argc, &argv);
6899 decode_argv (argc, const_cast <const char **> (argv));
6900 global_initializations ();
6901 build_multilib_strings ();
6902 set_up_specs ();
6903 putenv_COLLECT_GCC (argv[0]);
6904 maybe_putenv_COLLECT_LTO_WRAPPER ();
6905 maybe_putenv_OFFLOAD_TARGETS ();
6906 handle_unrecognized_options ();
6908 if (!maybe_print_and_exit ())
6909 return 0;
6911 early_exit = prepare_infiles ();
6912 if (early_exit)
6913 return get_exit_code ();
6915 do_spec_on_infiles ();
6916 maybe_run_linker (argv[0]);
6917 final_actions ();
6918 return get_exit_code ();
6921 /* Locate the final component of argv[0] after any leading path, and set
6922 the program name accordingly. */
6924 void
6925 driver::set_progname (const char *argv0) const
6927 const char *p = argv0 + strlen (argv0);
6928 while (p != argv0 && !IS_DIR_SEPARATOR (p[-1]))
6929 --p;
6930 progname = p;
6932 xmalloc_set_program_name (progname);
6935 /* Expand any @ files within the command-line args,
6936 setting at_file_supplied if any were expanded. */
6938 void
6939 driver::expand_at_files (int *argc, char ***argv) const
6941 char **old_argv = *argv;
6943 expandargv (argc, argv);
6945 /* Determine if any expansions were made. */
6946 if (*argv != old_argv)
6947 at_file_supplied = true;
6950 /* Decode the command-line arguments from argc/argv into the
6951 decoded_options array. */
6953 void
6954 driver::decode_argv (int argc, const char **argv)
6956 /* Register the language-independent parameters. */
6957 global_init_params ();
6958 finish_params ();
6960 init_options_struct (&global_options, &global_options_set);
6962 decode_cmdline_options_to_array (argc, argv,
6963 CL_DRIVER,
6964 &decoded_options, &decoded_options_count);
6967 /* Perform various initializations and setup. */
6969 void
6970 driver::global_initializations ()
6972 /* Unlock the stdio streams. */
6973 unlock_std_streams ();
6975 gcc_init_libintl ();
6977 diagnostic_initialize (global_dc, 0);
6979 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6980 /* Perform host dependent initialization when needed. */
6981 GCC_DRIVER_HOST_INITIALIZATION;
6982 #endif
6984 if (atexit (delete_temp_files) != 0)
6985 fatal_error ("atexit failed");
6987 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6988 signal (SIGINT, fatal_signal);
6989 #ifdef SIGHUP
6990 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6991 signal (SIGHUP, fatal_signal);
6992 #endif
6993 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6994 signal (SIGTERM, fatal_signal);
6995 #ifdef SIGPIPE
6996 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6997 signal (SIGPIPE, fatal_signal);
6998 #endif
6999 #ifdef SIGCHLD
7000 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
7001 receive the signal. A different setting is inheritable */
7002 signal (SIGCHLD, SIG_DFL);
7003 #endif
7005 /* Parsing and gimplification sometimes need quite large stack.
7006 Increase stack size limits if possible. */
7007 stack_limit_increase (64 * 1024 * 1024);
7009 /* Allocate the argument vector. */
7010 alloc_args ();
7012 obstack_init (&obstack);
7015 /* Build multilib_select, et. al from the separate lines that make up each
7016 multilib selection. */
7018 void
7019 driver::build_multilib_strings () const
7022 const char *p;
7023 const char *const *q = multilib_raw;
7024 int need_space;
7026 obstack_init (&multilib_obstack);
7027 while ((p = *q++) != (char *) 0)
7028 obstack_grow (&multilib_obstack, p, strlen (p));
7030 obstack_1grow (&multilib_obstack, 0);
7031 multilib_select = XOBFINISH (&multilib_obstack, const char *);
7033 q = multilib_matches_raw;
7034 while ((p = *q++) != (char *) 0)
7035 obstack_grow (&multilib_obstack, p, strlen (p));
7037 obstack_1grow (&multilib_obstack, 0);
7038 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
7040 q = multilib_exclusions_raw;
7041 while ((p = *q++) != (char *) 0)
7042 obstack_grow (&multilib_obstack, p, strlen (p));
7044 obstack_1grow (&multilib_obstack, 0);
7045 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
7047 q = multilib_reuse_raw;
7048 while ((p = *q++) != (char *) 0)
7049 obstack_grow (&multilib_obstack, p, strlen (p));
7051 obstack_1grow (&multilib_obstack, 0);
7052 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
7054 need_space = FALSE;
7055 for (size_t i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
7057 if (need_space)
7058 obstack_1grow (&multilib_obstack, ' ');
7059 obstack_grow (&multilib_obstack,
7060 multilib_defaults_raw[i],
7061 strlen (multilib_defaults_raw[i]));
7062 need_space = TRUE;
7065 obstack_1grow (&multilib_obstack, 0);
7066 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
7070 /* Set up the spec-handling machinery. */
7072 void
7073 driver::set_up_specs () const
7075 const char *spec_machine_suffix;
7076 char *specs_file;
7077 size_t i;
7079 #ifdef INIT_ENVIRONMENT
7080 /* Set up any other necessary machine specific environment variables. */
7081 xputenv (INIT_ENVIRONMENT);
7082 #endif
7084 /* Make a table of what switches there are (switches, n_switches).
7085 Make a table of specified input files (infiles, n_infiles).
7086 Decode switches that are handled locally. */
7088 process_command (decoded_options_count, decoded_options);
7090 /* Initialize the vector of specs to just the default.
7091 This means one element containing 0s, as a terminator. */
7093 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
7094 memcpy (compilers, default_compilers, sizeof default_compilers);
7095 n_compilers = n_default_compilers;
7097 /* Read specs from a file if there is one. */
7099 machine_suffix = concat (spec_host_machine, dir_separator_str, spec_version,
7100 accel_dir_suffix, dir_separator_str, NULL);
7101 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
7103 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
7104 /* Read the specs file unless it is a default one. */
7105 if (specs_file != 0 && strcmp (specs_file, "specs"))
7106 read_specs (specs_file, true, false);
7107 else
7108 init_spec ();
7110 #ifdef ACCEL_COMPILER
7111 spec_machine_suffix = machine_suffix;
7112 #else
7113 spec_machine_suffix = just_machine_suffix;
7114 #endif
7116 /* We need to check standard_exec_prefix/spec_machine_suffix/specs
7117 for any override of as, ld and libraries. */
7118 specs_file = (char *) alloca (strlen (standard_exec_prefix)
7119 + strlen (spec_machine_suffix) + sizeof ("specs"));
7120 strcpy (specs_file, standard_exec_prefix);
7121 strcat (specs_file, spec_machine_suffix);
7122 strcat (specs_file, "specs");
7123 if (access (specs_file, R_OK) == 0)
7124 read_specs (specs_file, true, false);
7126 /* Process any configure-time defaults specified for the command line
7127 options, via OPTION_DEFAULT_SPECS. */
7128 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
7129 do_option_spec (option_default_specs[i].name,
7130 option_default_specs[i].spec);
7132 /* Process DRIVER_SELF_SPECS, adding any new options to the end
7133 of the command line. */
7135 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
7136 do_self_spec (driver_self_specs[i]);
7138 /* If not cross-compiling, look for executables in the standard
7139 places. */
7140 if (*cross_compile == '0')
7142 if (*md_exec_prefix)
7144 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
7145 PREFIX_PRIORITY_LAST, 0, 0);
7149 /* Process sysroot_suffix_spec. */
7150 if (*sysroot_suffix_spec != 0
7151 && !no_sysroot_suffix
7152 && do_spec_2 (sysroot_suffix_spec) == 0)
7154 if (argbuf.length () > 1)
7155 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
7156 else if (argbuf.length () == 1)
7157 target_sysroot_suffix = xstrdup (argbuf.last ());
7160 #ifdef HAVE_LD_SYSROOT
7161 /* Pass the --sysroot option to the linker, if it supports that. If
7162 there is a sysroot_suffix_spec, it has already been processed by
7163 this point, so target_system_root really is the system root we
7164 should be using. */
7165 if (target_system_root)
7167 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
7168 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
7169 set_spec ("link", XOBFINISH (&obstack, const char *), false);
7171 #endif
7173 /* Process sysroot_hdrs_suffix_spec. */
7174 if (*sysroot_hdrs_suffix_spec != 0
7175 && !no_sysroot_suffix
7176 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
7178 if (argbuf.length () > 1)
7179 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
7180 else if (argbuf.length () == 1)
7181 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
7184 /* Look for startfiles in the standard places. */
7185 if (*startfile_prefix_spec != 0
7186 && do_spec_2 (startfile_prefix_spec) == 0
7187 && do_spec_1 (" ", 0, NULL) == 0)
7189 const char *arg;
7190 int ndx;
7191 FOR_EACH_VEC_ELT (argbuf, ndx, arg)
7192 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
7193 PREFIX_PRIORITY_LAST, 0, 1);
7195 /* We should eventually get rid of all these and stick to
7196 startfile_prefix_spec exclusively. */
7197 else if (*cross_compile == '0' || target_system_root)
7199 if (*md_startfile_prefix)
7200 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
7201 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7203 if (*md_startfile_prefix_1)
7204 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
7205 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7207 /* If standard_startfile_prefix is relative, base it on
7208 standard_exec_prefix. This lets us move the installed tree
7209 as a unit. If GCC_EXEC_PREFIX is defined, base
7210 standard_startfile_prefix on that as well.
7212 If the prefix is relative, only search it for native compilers;
7213 otherwise we will search a directory containing host libraries. */
7214 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
7215 add_sysrooted_prefix (&startfile_prefixes,
7216 standard_startfile_prefix, "BINUTILS",
7217 PREFIX_PRIORITY_LAST, 0, 1);
7218 else if (*cross_compile == '0')
7220 add_prefix (&startfile_prefixes,
7221 concat (gcc_exec_prefix
7222 ? gcc_exec_prefix : standard_exec_prefix,
7223 machine_suffix,
7224 standard_startfile_prefix, NULL),
7225 NULL, PREFIX_PRIORITY_LAST, 0, 1);
7228 /* Sysrooted prefixes are relocated because target_system_root is
7229 also relocated by gcc_exec_prefix. */
7230 if (*standard_startfile_prefix_1)
7231 add_sysrooted_prefix (&startfile_prefixes,
7232 standard_startfile_prefix_1, "BINUTILS",
7233 PREFIX_PRIORITY_LAST, 0, 1);
7234 if (*standard_startfile_prefix_2)
7235 add_sysrooted_prefix (&startfile_prefixes,
7236 standard_startfile_prefix_2, "BINUTILS",
7237 PREFIX_PRIORITY_LAST, 0, 1);
7240 /* Process any user specified specs in the order given on the command
7241 line. */
7242 for (struct user_specs *uptr = user_specs_head; uptr; uptr = uptr->next)
7244 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
7245 R_OK, true);
7246 read_specs (filename ? filename : uptr->filename, false, true);
7249 /* Process any user self specs. */
7251 struct spec_list *sl;
7252 for (sl = specs; sl; sl = sl->next)
7253 if (sl->name_len == sizeof "self_spec" - 1
7254 && !strcmp (sl->name, "self_spec"))
7255 do_self_spec (*sl->ptr_spec);
7258 if (compare_debug)
7260 enum save_temps save;
7262 if (!compare_debug_second)
7264 n_switches_debug_check[1] = n_switches;
7265 n_switches_alloc_debug_check[1] = n_switches_alloc;
7266 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
7267 n_switches_alloc);
7269 do_self_spec ("%:compare-debug-self-opt()");
7270 n_switches_debug_check[0] = n_switches;
7271 n_switches_alloc_debug_check[0] = n_switches_alloc;
7272 switches_debug_check[0] = switches;
7274 n_switches = n_switches_debug_check[1];
7275 n_switches_alloc = n_switches_alloc_debug_check[1];
7276 switches = switches_debug_check[1];
7279 /* Avoid crash when computing %j in this early. */
7280 save = save_temps_flag;
7281 save_temps_flag = SAVE_TEMPS_NONE;
7283 compare_debug = -compare_debug;
7284 do_self_spec ("%:compare-debug-self-opt()");
7286 save_temps_flag = save;
7288 if (!compare_debug_second)
7290 n_switches_debug_check[1] = n_switches;
7291 n_switches_alloc_debug_check[1] = n_switches_alloc;
7292 switches_debug_check[1] = switches;
7293 compare_debug = -compare_debug;
7294 n_switches = n_switches_debug_check[0];
7295 n_switches_alloc = n_switches_debug_check[0];
7296 switches = switches_debug_check[0];
7301 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
7302 if (gcc_exec_prefix)
7303 gcc_exec_prefix = concat (gcc_exec_prefix, spec_host_machine,
7304 dir_separator_str, spec_version,
7305 accel_dir_suffix, dir_separator_str, NULL);
7307 /* Now we have the specs.
7308 Set the `valid' bits for switches that match anything in any spec. */
7310 validate_all_switches ();
7312 /* Now that we have the switches and the specs, set
7313 the subdirectory based on the options. */
7314 set_multilib_dir ();
7317 /* Set up to remember the pathname of gcc and any options
7318 needed for collect. We use argv[0] instead of progname because
7319 we need the complete pathname. */
7321 void
7322 driver::putenv_COLLECT_GCC (const char *argv0) const
7324 obstack_init (&collect_obstack);
7325 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
7326 obstack_grow (&collect_obstack, argv0, strlen (argv0) + 1);
7327 xputenv (XOBFINISH (&collect_obstack, char *));
7330 /* Set up to remember the pathname of the lto wrapper. */
7332 void
7333 driver::maybe_putenv_COLLECT_LTO_WRAPPER () const
7335 char *lto_wrapper_file;
7337 if (have_c)
7338 lto_wrapper_file = NULL;
7339 else
7340 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
7341 X_OK, false);
7342 if (lto_wrapper_file)
7344 lto_wrapper_file = convert_white_space (lto_wrapper_file);
7345 lto_wrapper_spec = lto_wrapper_file;
7346 obstack_init (&collect_obstack);
7347 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
7348 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
7349 obstack_grow (&collect_obstack, lto_wrapper_spec,
7350 strlen (lto_wrapper_spec) + 1);
7351 xputenv (XOBFINISH (&collect_obstack, char *));
7356 /* Set up to remember the names of offload targets. */
7358 void
7359 driver::maybe_putenv_OFFLOAD_TARGETS () const
7361 const char *targets = offload_targets;
7363 /* If no targets specified by -foffload, use all available targets. */
7364 if (!targets)
7365 targets = OFFLOAD_TARGETS;
7367 if (strlen (targets) > 0)
7369 obstack_grow (&collect_obstack, "OFFLOAD_TARGET_NAMES=",
7370 sizeof ("OFFLOAD_TARGET_NAMES=") - 1);
7371 obstack_grow (&collect_obstack, targets,
7372 strlen (targets) + 1);
7373 xputenv (XOBFINISH (&collect_obstack, char *));
7376 free (offload_targets);
7379 /* Reject switches that no pass was interested in. */
7381 void
7382 driver::handle_unrecognized_options () const
7384 for (size_t i = 0; (int) i < n_switches; i++)
7385 if (! switches[i].validated)
7386 error ("unrecognized command line option %<-%s%>", switches[i].part1);
7389 /* Handle the various -print-* options, returning 0 if the driver
7390 should exit, or nonzero if the driver should continue. */
7393 driver::maybe_print_and_exit () const
7395 if (print_search_dirs)
7397 printf (_("install: %s%s\n"),
7398 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
7399 gcc_exec_prefix ? "" : machine_suffix);
7400 printf (_("programs: %s\n"),
7401 build_search_list (&exec_prefixes, "", false, false));
7402 printf (_("libraries: %s\n"),
7403 build_search_list (&startfile_prefixes, "", false, true));
7404 return (0);
7407 if (print_file_name)
7409 printf ("%s\n", find_file (print_file_name));
7410 return (0);
7413 if (print_prog_name)
7415 if (use_ld != NULL && ! strcmp (print_prog_name, "ld"))
7417 /* Append USE_LD to to the default linker. */
7418 #ifdef DEFAULT_LINKER
7419 char *ld;
7420 # ifdef HAVE_HOST_EXECUTABLE_SUFFIX
7421 int len = (sizeof (DEFAULT_LINKER)
7422 - sizeof (HOST_EXECUTABLE_SUFFIX));
7423 ld = NULL;
7424 if (len > 0)
7426 char *default_linker = xstrdup (DEFAULT_LINKER);
7427 /* Strip HOST_EXECUTABLE_SUFFIX if DEFAULT_LINKER contains
7428 HOST_EXECUTABLE_SUFFIX. */
7429 if (! strcmp (&default_linker[len], HOST_EXECUTABLE_SUFFIX))
7431 default_linker[len] = '\0';
7432 ld = concat (default_linker, use_ld,
7433 HOST_EXECUTABLE_SUFFIX, NULL);
7436 if (ld == NULL)
7437 # endif
7438 ld = concat (DEFAULT_LINKER, use_ld, NULL);
7439 if (access (ld, X_OK) == 0)
7441 printf ("%s\n", ld);
7442 return (0);
7444 #endif
7445 print_prog_name = concat (print_prog_name, use_ld, NULL);
7447 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
7448 printf ("%s\n", (newname ? newname : print_prog_name));
7449 return (0);
7452 if (print_multi_lib)
7454 print_multilib_info ();
7455 return (0);
7458 if (print_multi_directory)
7460 if (multilib_dir == NULL)
7461 printf (".\n");
7462 else
7463 printf ("%s\n", multilib_dir);
7464 return (0);
7467 if (print_multiarch)
7469 if (multiarch_dir == NULL)
7470 printf ("\n");
7471 else
7472 printf ("%s\n", multiarch_dir);
7473 return (0);
7476 if (print_sysroot)
7478 if (target_system_root)
7480 if (target_sysroot_suffix)
7481 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
7482 else
7483 printf ("%s\n", target_system_root);
7485 return (0);
7488 if (print_multi_os_directory)
7490 if (multilib_os_dir == NULL)
7491 printf (".\n");
7492 else
7493 printf ("%s\n", multilib_os_dir);
7494 return (0);
7497 if (print_sysroot_headers_suffix)
7499 if (*sysroot_hdrs_suffix_spec)
7501 printf("%s\n", (target_sysroot_hdrs_suffix
7502 ? target_sysroot_hdrs_suffix
7503 : ""));
7504 return (0);
7506 else
7507 /* The error status indicates that only one set of fixed
7508 headers should be built. */
7509 fatal_error ("not configured with sysroot headers suffix");
7512 if (print_help_list)
7514 display_help ();
7516 if (! verbose_flag)
7518 printf (_("\nFor bug reporting instructions, please see:\n"));
7519 printf ("%s.\n", bug_report_url);
7521 return (0);
7524 /* We do not exit here. Instead we have created a fake input file
7525 called 'help-dummy' which needs to be compiled, and we pass this
7526 on the various sub-processes, along with the --help switch.
7527 Ensure their output appears after ours. */
7528 fputc ('\n', stdout);
7529 fflush (stdout);
7532 if (print_version)
7534 printf (_("%s %s%s\n"), progname, pkgversion_string,
7535 version_string);
7536 printf ("Copyright %s 2014 Free Software Foundation, Inc.\n",
7537 _("(C)"));
7538 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
7539 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
7540 stdout);
7541 if (! verbose_flag)
7542 return 0;
7544 /* We do not exit here. We use the same mechanism of --help to print
7545 the version of the sub-processes. */
7546 fputc ('\n', stdout);
7547 fflush (stdout);
7550 if (verbose_flag)
7552 print_configuration (stderr);
7553 if (n_infiles == 0)
7554 return (0);
7557 return 1;
7560 /* Figure out what to do with each input file.
7561 Return true if we need to exit early from "main", false otherwise. */
7563 bool
7564 driver::prepare_infiles ()
7566 size_t i;
7567 int lang_n_infiles = 0;
7569 if (n_infiles == added_libraries)
7570 fatal_error ("no input files");
7572 if (seen_error ())
7573 /* Early exit needed from main. */
7574 return true;
7576 /* Make a place to record the compiler output file names
7577 that correspond to the input files. */
7579 i = n_infiles;
7580 i += lang_specific_extra_outfiles;
7581 outfiles = XCNEWVEC (const char *, i);
7583 /* Record which files were specified explicitly as link input. */
7585 explicit_link_files = XCNEWVEC (char, n_infiles);
7587 combine_inputs = have_o || flag_wpa;
7589 for (i = 0; (int) i < n_infiles; i++)
7591 const char *name = infiles[i].name;
7592 struct compiler *compiler = lookup_compiler (name,
7593 strlen (name),
7594 infiles[i].language);
7596 if (compiler && !(compiler->combinable))
7597 combine_inputs = false;
7599 if (lang_n_infiles > 0 && compiler != input_file_compiler
7600 && infiles[i].language && infiles[i].language[0] != '*')
7601 infiles[i].incompiler = compiler;
7602 else if (compiler)
7604 lang_n_infiles++;
7605 input_file_compiler = compiler;
7606 infiles[i].incompiler = compiler;
7608 else
7610 /* Since there is no compiler for this input file, assume it is a
7611 linker file. */
7612 explicit_link_files[i] = 1;
7613 infiles[i].incompiler = NULL;
7615 infiles[i].compiled = false;
7616 infiles[i].preprocessed = false;
7619 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
7620 fatal_error ("cannot specify -o with -c, -S or -E with multiple files");
7622 /* No early exit needed from main; we can continue. */
7623 return false;
7626 /* Run the spec machinery on each input file. */
7628 void
7629 driver::do_spec_on_infiles () const
7631 size_t i;
7633 for (i = 0; (int) i < n_infiles; i++)
7635 int this_file_error = 0;
7637 /* Tell do_spec what to substitute for %i. */
7639 input_file_number = i;
7640 set_input (infiles[i].name);
7642 if (infiles[i].compiled)
7643 continue;
7645 /* Use the same thing in %o, unless cp->spec says otherwise. */
7647 outfiles[i] = gcc_input_filename;
7649 /* Figure out which compiler from the file's suffix. */
7651 input_file_compiler
7652 = lookup_compiler (infiles[i].name, input_filename_length,
7653 infiles[i].language);
7655 if (input_file_compiler)
7657 /* Ok, we found an applicable compiler. Run its spec. */
7659 if (input_file_compiler->spec[0] == '#')
7661 error ("%s: %s compiler not installed on this system",
7662 gcc_input_filename, &input_file_compiler->spec[1]);
7663 this_file_error = 1;
7665 else
7667 int value;
7669 if (compare_debug)
7671 free (debug_check_temp_file[0]);
7672 debug_check_temp_file[0] = NULL;
7674 free (debug_check_temp_file[1]);
7675 debug_check_temp_file[1] = NULL;
7678 value = do_spec (input_file_compiler->spec);
7679 infiles[i].compiled = true;
7680 if (value < 0)
7681 this_file_error = 1;
7682 else if (compare_debug && debug_check_temp_file[0])
7684 if (verbose_flag)
7685 inform (0, "recompiling with -fcompare-debug");
7687 compare_debug = -compare_debug;
7688 n_switches = n_switches_debug_check[1];
7689 n_switches_alloc = n_switches_alloc_debug_check[1];
7690 switches = switches_debug_check[1];
7692 value = do_spec (input_file_compiler->spec);
7694 compare_debug = -compare_debug;
7695 n_switches = n_switches_debug_check[0];
7696 n_switches_alloc = n_switches_alloc_debug_check[0];
7697 switches = switches_debug_check[0];
7699 if (value < 0)
7701 error ("during -fcompare-debug recompilation");
7702 this_file_error = 1;
7705 gcc_assert (debug_check_temp_file[1]
7706 && filename_cmp (debug_check_temp_file[0],
7707 debug_check_temp_file[1]));
7709 if (verbose_flag)
7710 inform (0, "comparing final insns dumps");
7712 if (compare_files (debug_check_temp_file))
7713 this_file_error = 1;
7716 if (compare_debug)
7718 free (debug_check_temp_file[0]);
7719 debug_check_temp_file[0] = NULL;
7721 free (debug_check_temp_file[1]);
7722 debug_check_temp_file[1] = NULL;
7727 /* If this file's name does not contain a recognized suffix,
7728 record it as explicit linker input. */
7730 else
7731 explicit_link_files[i] = 1;
7733 /* Clear the delete-on-failure queue, deleting the files in it
7734 if this compilation failed. */
7736 if (this_file_error)
7738 delete_failure_queue ();
7739 errorcount++;
7741 /* If this compilation succeeded, don't delete those files later. */
7742 clear_failure_queue ();
7745 /* Reset the input file name to the first compile/object file name, for use
7746 with %b in LINK_SPEC. We use the first input file that we can find
7747 a compiler to compile it instead of using infiles.language since for
7748 languages other than C we use aliases that we then lookup later. */
7749 if (n_infiles > 0)
7751 int i;
7753 for (i = 0; i < n_infiles ; i++)
7754 if (infiles[i].incompiler
7755 || (infiles[i].language && infiles[i].language[0] != '*'))
7757 set_input (infiles[i].name);
7758 break;
7762 if (!seen_error ())
7764 /* Make sure INPUT_FILE_NUMBER points to first available open
7765 slot. */
7766 input_file_number = n_infiles;
7767 if (lang_specific_pre_link ())
7768 errorcount++;
7772 /* If we have to run the linker, do it now. */
7774 void
7775 driver::maybe_run_linker (const char *argv0) const
7777 size_t i;
7778 int linker_was_run = 0;
7779 int num_linker_inputs;
7781 /* Determine if there are any linker input files. */
7782 num_linker_inputs = 0;
7783 for (i = 0; (int) i < n_infiles; i++)
7784 if (explicit_link_files[i] || outfiles[i] != NULL)
7785 num_linker_inputs++;
7787 /* Run ld to link all the compiler output files. */
7789 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
7791 int tmp = execution_count;
7793 if (! have_c)
7795 #if HAVE_LTO_PLUGIN > 0
7796 #if HAVE_LTO_PLUGIN == 2
7797 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
7798 #else
7799 const char *fuse_linker_plugin = "fuse-linker-plugin";
7800 #endif
7801 #endif
7803 /* We'll use ld if we can't find collect2. */
7804 if (! strcmp (linker_name_spec, "collect2"))
7806 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
7807 if (s == NULL)
7808 linker_name_spec = "ld";
7811 #if HAVE_LTO_PLUGIN > 0
7812 #if HAVE_LTO_PLUGIN == 2
7813 if (!switch_matches (fno_use_linker_plugin,
7814 fno_use_linker_plugin
7815 + strlen (fno_use_linker_plugin), 0))
7816 #else
7817 if (switch_matches (fuse_linker_plugin,
7818 fuse_linker_plugin
7819 + strlen (fuse_linker_plugin), 0))
7820 #endif
7822 char *temp_spec = find_a_file (&exec_prefixes,
7823 LTOPLUGINSONAME, R_OK,
7824 false);
7825 if (!temp_spec)
7826 fatal_error ("-fuse-linker-plugin, but %s not found",
7827 LTOPLUGINSONAME);
7828 linker_plugin_file_spec = convert_white_space (temp_spec);
7830 #endif
7831 lto_gcc_spec = argv0;
7834 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
7835 for collect. */
7836 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
7837 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
7839 if (print_subprocess_help == 1)
7841 printf (_("\nLinker options\n==============\n\n"));
7842 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
7843 " to the linker.\n\n"));
7844 fflush (stdout);
7846 int value = do_spec (link_command_spec);
7847 if (value < 0)
7848 errorcount = 1;
7849 linker_was_run = (tmp != execution_count);
7852 /* If options said don't run linker,
7853 complain about input files to be given to the linker. */
7855 if (! linker_was_run && !seen_error ())
7856 for (i = 0; (int) i < n_infiles; i++)
7857 if (explicit_link_files[i]
7858 && !(infiles[i].language && infiles[i].language[0] == '*'))
7859 warning (0, "%s: linker input file unused because linking not done",
7860 outfiles[i]);
7863 /* The end of "main". */
7865 void
7866 driver::final_actions () const
7868 /* Delete some or all of the temporary files we made. */
7870 if (seen_error ())
7871 delete_failure_queue ();
7872 delete_temp_files ();
7874 if (print_help_list)
7876 printf (("\nFor bug reporting instructions, please see:\n"));
7877 printf ("%s\n", bug_report_url);
7881 /* Determine what the exit code of the driver should be. */
7884 driver::get_exit_code () const
7886 return (signal_count != 0 ? 2
7887 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
7888 : 0);
7891 /* Find the proper compilation spec for the file name NAME,
7892 whose length is LENGTH. LANGUAGE is the specified language,
7893 or 0 if this file is to be passed to the linker. */
7895 static struct compiler *
7896 lookup_compiler (const char *name, size_t length, const char *language)
7898 struct compiler *cp;
7900 /* If this was specified by the user to be a linker input, indicate that. */
7901 if (language != 0 && language[0] == '*')
7902 return 0;
7904 /* Otherwise, look for the language, if one is spec'd. */
7905 if (language != 0)
7907 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7908 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
7909 return cp;
7911 error ("language %s not recognized", language);
7912 return 0;
7915 /* Look for a suffix. */
7916 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7918 if (/* The suffix `-' matches only the file name `-'. */
7919 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7920 || (strlen (cp->suffix) < length
7921 /* See if the suffix matches the end of NAME. */
7922 && !strcmp (cp->suffix,
7923 name + length - strlen (cp->suffix))
7925 break;
7928 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
7929 /* Look again, but case-insensitively this time. */
7930 if (cp < compilers)
7931 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7933 if (/* The suffix `-' matches only the file name `-'. */
7934 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7935 || (strlen (cp->suffix) < length
7936 /* See if the suffix matches the end of NAME. */
7937 && ((!strcmp (cp->suffix,
7938 name + length - strlen (cp->suffix))
7939 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
7940 && !strcasecmp (cp->suffix,
7941 name + length - strlen (cp->suffix)))
7943 break;
7945 #endif
7947 if (cp >= compilers)
7949 if (cp->spec[0] != '@')
7950 /* A non-alias entry: return it. */
7951 return cp;
7953 /* An alias entry maps a suffix to a language.
7954 Search for the language; pass 0 for NAME and LENGTH
7955 to avoid infinite recursion if language not found. */
7956 return lookup_compiler (NULL, 0, cp->spec + 1);
7958 return 0;
7961 static char *
7962 save_string (const char *s, int len)
7964 char *result = XNEWVEC (char, len + 1);
7966 memcpy (result, s, len);
7967 result[len] = 0;
7968 return result;
7971 void
7972 pfatal_with_name (const char *name)
7974 perror_with_name (name);
7975 delete_temp_files ();
7976 exit (1);
7979 static void
7980 perror_with_name (const char *name)
7982 error ("%s: %m", name);
7985 static inline void
7986 validate_switches_from_spec (const char *spec, bool user)
7988 const char *p = spec;
7989 char c;
7990 while ((c = *p++))
7991 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
7992 /* We have a switch spec. */
7993 p = validate_switches (p + 1, user);
7996 static void
7997 validate_all_switches (void)
7999 struct compiler *comp;
8000 struct spec_list *spec;
8002 for (comp = compilers; comp->spec; comp++)
8003 validate_switches_from_spec (comp->spec, false);
8005 /* Look through the linked list of specs read from the specs file. */
8006 for (spec = specs; spec; spec = spec->next)
8007 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
8009 validate_switches_from_spec (link_command_spec, false);
8012 /* Look at the switch-name that comes after START
8013 and mark as valid all supplied switches that match it. */
8015 static const char *
8016 validate_switches (const char *start, bool user_spec)
8018 const char *p = start;
8019 const char *atom;
8020 size_t len;
8021 int i;
8022 bool suffix = false;
8023 bool starred = false;
8025 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
8027 next_member:
8028 SKIP_WHITE ();
8030 if (*p == '!')
8031 p++;
8033 SKIP_WHITE ();
8034 if (*p == '.' || *p == ',')
8035 suffix = true, p++;
8037 atom = p;
8038 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
8039 || *p == ',' || *p == '.' || *p == '@')
8040 p++;
8041 len = p - atom;
8043 if (*p == '*')
8044 starred = true, p++;
8046 SKIP_WHITE ();
8048 if (!suffix)
8050 /* Mark all matching switches as valid. */
8051 for (i = 0; i < n_switches; i++)
8052 if (!strncmp (switches[i].part1, atom, len)
8053 && (starred || switches[i].part1[len] == '\0')
8054 && (switches[i].known || user_spec))
8055 switches[i].validated = true;
8058 if (*p) p++;
8059 if (*p && (p[-1] == '|' || p[-1] == '&'))
8060 goto next_member;
8062 if (*p && p[-1] == ':')
8064 while (*p && *p != ';' && *p != '}')
8066 if (*p == '%')
8068 p++;
8069 if (*p == '{' || *p == '<')
8070 p = validate_switches (p+1, user_spec);
8071 else if (p[0] == 'W' && p[1] == '{')
8072 p = validate_switches (p+2, user_spec);
8074 else
8075 p++;
8078 if (*p) p++;
8079 if (*p && p[-1] == ';')
8080 goto next_member;
8083 return p;
8084 #undef SKIP_WHITE
8087 struct mdswitchstr
8089 const char *str;
8090 int len;
8093 static struct mdswitchstr *mdswitches;
8094 static int n_mdswitches;
8096 /* Check whether a particular argument was used. The first time we
8097 canonicalize the switches to keep only the ones we care about. */
8099 static int
8100 used_arg (const char *p, int len)
8102 struct mswitchstr
8104 const char *str;
8105 const char *replace;
8106 int len;
8107 int rep_len;
8110 static struct mswitchstr *mswitches;
8111 static int n_mswitches;
8112 int i, j;
8114 if (!mswitches)
8116 struct mswitchstr *matches;
8117 const char *q;
8118 int cnt = 0;
8120 /* Break multilib_matches into the component strings of string
8121 and replacement string. */
8122 for (q = multilib_matches; *q != '\0'; q++)
8123 if (*q == ';')
8124 cnt++;
8126 matches
8127 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
8128 i = 0;
8129 q = multilib_matches;
8130 while (*q != '\0')
8132 matches[i].str = q;
8133 while (*q != ' ')
8135 if (*q == '\0')
8137 invalid_matches:
8138 fatal_error ("multilib spec %qs is invalid",
8139 multilib_matches);
8141 q++;
8143 matches[i].len = q - matches[i].str;
8145 matches[i].replace = ++q;
8146 while (*q != ';' && *q != '\0')
8148 if (*q == ' ')
8149 goto invalid_matches;
8150 q++;
8152 matches[i].rep_len = q - matches[i].replace;
8153 i++;
8154 if (*q == ';')
8155 q++;
8158 /* Now build a list of the replacement string for switches that we care
8159 about. Make sure we allocate at least one entry. This prevents
8160 xmalloc from calling fatal, and prevents us from re-executing this
8161 block of code. */
8162 mswitches
8163 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
8164 for (i = 0; i < n_switches; i++)
8165 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
8167 int xlen = strlen (switches[i].part1);
8168 for (j = 0; j < cnt; j++)
8169 if (xlen == matches[j].len
8170 && ! strncmp (switches[i].part1, matches[j].str, xlen))
8172 mswitches[n_mswitches].str = matches[j].replace;
8173 mswitches[n_mswitches].len = matches[j].rep_len;
8174 mswitches[n_mswitches].replace = (char *) 0;
8175 mswitches[n_mswitches].rep_len = 0;
8176 n_mswitches++;
8177 break;
8181 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
8182 on the command line nor any options mutually incompatible with
8183 them. */
8184 for (i = 0; i < n_mdswitches; i++)
8186 const char *r;
8188 for (q = multilib_options; *q != '\0'; *q && q++)
8190 while (*q == ' ')
8191 q++;
8193 r = q;
8194 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
8195 || strchr (" /", q[mdswitches[i].len]) == NULL)
8197 while (*q != ' ' && *q != '/' && *q != '\0')
8198 q++;
8199 if (*q != '/')
8200 break;
8201 q++;
8204 if (*q != ' ' && *q != '\0')
8206 while (*r != ' ' && *r != '\0')
8208 q = r;
8209 while (*q != ' ' && *q != '/' && *q != '\0')
8210 q++;
8212 if (used_arg (r, q - r))
8213 break;
8215 if (*q != '/')
8217 mswitches[n_mswitches].str = mdswitches[i].str;
8218 mswitches[n_mswitches].len = mdswitches[i].len;
8219 mswitches[n_mswitches].replace = (char *) 0;
8220 mswitches[n_mswitches].rep_len = 0;
8221 n_mswitches++;
8222 break;
8225 r = q + 1;
8227 break;
8233 for (i = 0; i < n_mswitches; i++)
8234 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
8235 return 1;
8237 return 0;
8240 static int
8241 default_arg (const char *p, int len)
8243 int i;
8245 for (i = 0; i < n_mdswitches; i++)
8246 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
8247 return 1;
8249 return 0;
8252 /* Work out the subdirectory to use based on the options. The format of
8253 multilib_select is a list of elements. Each element is a subdirectory
8254 name followed by a list of options followed by a semicolon. The format
8255 of multilib_exclusions is the same, but without the preceding
8256 directory. First gcc will check the exclusions, if none of the options
8257 beginning with an exclamation point are present, and all of the other
8258 options are present, then we will ignore this completely. Passing
8259 that, gcc will consider each multilib_select in turn using the same
8260 rules for matching the options. If a match is found, that subdirectory
8261 will be used.
8262 A subdirectory name is optionally followed by a colon and the corresponding
8263 multiarch name. */
8265 static void
8266 set_multilib_dir (void)
8268 const char *p;
8269 unsigned int this_path_len;
8270 const char *this_path, *this_arg;
8271 const char *start, *end;
8272 int not_arg;
8273 int ok, ndfltok, first;
8275 n_mdswitches = 0;
8276 start = multilib_defaults;
8277 while (*start == ' ' || *start == '\t')
8278 start++;
8279 while (*start != '\0')
8281 n_mdswitches++;
8282 while (*start != ' ' && *start != '\t' && *start != '\0')
8283 start++;
8284 while (*start == ' ' || *start == '\t')
8285 start++;
8288 if (n_mdswitches)
8290 int i = 0;
8292 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
8293 for (start = multilib_defaults; *start != '\0'; start = end + 1)
8295 while (*start == ' ' || *start == '\t')
8296 start++;
8298 if (*start == '\0')
8299 break;
8301 for (end = start + 1;
8302 *end != ' ' && *end != '\t' && *end != '\0'; end++)
8305 obstack_grow (&multilib_obstack, start, end - start);
8306 obstack_1grow (&multilib_obstack, 0);
8307 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
8308 mdswitches[i++].len = end - start;
8310 if (*end == '\0')
8311 break;
8315 p = multilib_exclusions;
8316 while (*p != '\0')
8318 /* Ignore newlines. */
8319 if (*p == '\n')
8321 ++p;
8322 continue;
8325 /* Check the arguments. */
8326 ok = 1;
8327 while (*p != ';')
8329 if (*p == '\0')
8331 invalid_exclusions:
8332 fatal_error ("multilib exclusions %qs is invalid",
8333 multilib_exclusions);
8336 if (! ok)
8338 ++p;
8339 continue;
8342 this_arg = p;
8343 while (*p != ' ' && *p != ';')
8345 if (*p == '\0')
8346 goto invalid_exclusions;
8347 ++p;
8350 if (*this_arg != '!')
8351 not_arg = 0;
8352 else
8354 not_arg = 1;
8355 ++this_arg;
8358 ok = used_arg (this_arg, p - this_arg);
8359 if (not_arg)
8360 ok = ! ok;
8362 if (*p == ' ')
8363 ++p;
8366 if (ok)
8367 return;
8369 ++p;
8372 first = 1;
8373 p = multilib_select;
8375 /* Append multilib reuse rules if any. With those rules, we can reuse
8376 one multilib for certain different options sets. */
8377 if (strlen (multilib_reuse) > 0)
8378 p = concat (p, multilib_reuse, NULL);
8380 while (*p != '\0')
8382 /* Ignore newlines. */
8383 if (*p == '\n')
8385 ++p;
8386 continue;
8389 /* Get the initial path. */
8390 this_path = p;
8391 while (*p != ' ')
8393 if (*p == '\0')
8395 invalid_select:
8396 fatal_error ("multilib select %qs %qs is invalid",
8397 multilib_select, multilib_reuse);
8399 ++p;
8401 this_path_len = p - this_path;
8403 /* Check the arguments. */
8404 ok = 1;
8405 ndfltok = 1;
8406 ++p;
8407 while (*p != ';')
8409 if (*p == '\0')
8410 goto invalid_select;
8412 if (! ok)
8414 ++p;
8415 continue;
8418 this_arg = p;
8419 while (*p != ' ' && *p != ';')
8421 if (*p == '\0')
8422 goto invalid_select;
8423 ++p;
8426 if (*this_arg != '!')
8427 not_arg = 0;
8428 else
8430 not_arg = 1;
8431 ++this_arg;
8434 /* If this is a default argument, we can just ignore it.
8435 This is true even if this_arg begins with '!'. Beginning
8436 with '!' does not mean that this argument is necessarily
8437 inappropriate for this library: it merely means that
8438 there is a more specific library which uses this
8439 argument. If this argument is a default, we need not
8440 consider that more specific library. */
8441 ok = used_arg (this_arg, p - this_arg);
8442 if (not_arg)
8443 ok = ! ok;
8445 if (! ok)
8446 ndfltok = 0;
8448 if (default_arg (this_arg, p - this_arg))
8449 ok = 1;
8451 if (*p == ' ')
8452 ++p;
8455 if (ok && first)
8457 if (this_path_len != 1
8458 || this_path[0] != '.')
8460 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
8461 char *q;
8463 strncpy (new_multilib_dir, this_path, this_path_len);
8464 new_multilib_dir[this_path_len] = '\0';
8465 q = strchr (new_multilib_dir, ':');
8466 if (q != NULL)
8467 *q = '\0';
8468 multilib_dir = new_multilib_dir;
8470 first = 0;
8473 if (ndfltok)
8475 const char *q = this_path, *end = this_path + this_path_len;
8477 while (q < end && *q != ':')
8478 q++;
8479 if (q < end)
8481 const char *q2 = q + 1, *ml_end = end;
8482 char *new_multilib_os_dir;
8484 while (q2 < end && *q2 != ':')
8485 q2++;
8486 if (*q2 == ':')
8487 ml_end = q2;
8488 if (ml_end - q == 1)
8489 multilib_os_dir = xstrdup (".");
8490 else
8492 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
8493 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
8494 new_multilib_os_dir[ml_end - q - 1] = '\0';
8495 multilib_os_dir = new_multilib_os_dir;
8498 if (q2 < end && *q2 == ':')
8500 char *new_multiarch_dir = XNEWVEC (char, end - q2);
8501 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
8502 new_multiarch_dir[end - q2 - 1] = '\0';
8503 multiarch_dir = new_multiarch_dir;
8505 break;
8509 ++p;
8512 if (multilib_dir == NULL && multilib_os_dir != NULL
8513 && strcmp (multilib_os_dir, ".") == 0)
8515 free (CONST_CAST (char *, multilib_os_dir));
8516 multilib_os_dir = NULL;
8518 else if (multilib_dir != NULL && multilib_os_dir == NULL)
8519 multilib_os_dir = multilib_dir;
8522 /* Print out the multiple library subdirectory selection
8523 information. This prints out a series of lines. Each line looks
8524 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
8525 required. Only the desired options are printed out, the negative
8526 matches. The options are print without a leading dash. There are
8527 no spaces to make it easy to use the information in the shell.
8528 Each subdirectory is printed only once. This assumes the ordering
8529 generated by the genmultilib script. Also, we leave out ones that match
8530 the exclusions. */
8532 static void
8533 print_multilib_info (void)
8535 const char *p = multilib_select;
8536 const char *last_path = 0, *this_path;
8537 int skip;
8538 unsigned int last_path_len = 0;
8540 while (*p != '\0')
8542 skip = 0;
8543 /* Ignore newlines. */
8544 if (*p == '\n')
8546 ++p;
8547 continue;
8550 /* Get the initial path. */
8551 this_path = p;
8552 while (*p != ' ')
8554 if (*p == '\0')
8556 invalid_select:
8557 fatal_error ("multilib select %qs is invalid", multilib_select);
8560 ++p;
8563 /* When --disable-multilib was used but target defines
8564 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
8565 with .:: for multiarch configurations) are there just to find
8566 multilib_os_dir, so skip them from output. */
8567 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
8568 skip = 1;
8570 /* Check for matches with the multilib_exclusions. We don't bother
8571 with the '!' in either list. If any of the exclusion rules match
8572 all of its options with the select rule, we skip it. */
8574 const char *e = multilib_exclusions;
8575 const char *this_arg;
8577 while (*e != '\0')
8579 int m = 1;
8580 /* Ignore newlines. */
8581 if (*e == '\n')
8583 ++e;
8584 continue;
8587 /* Check the arguments. */
8588 while (*e != ';')
8590 const char *q;
8591 int mp = 0;
8593 if (*e == '\0')
8595 invalid_exclusion:
8596 fatal_error ("multilib exclusion %qs is invalid",
8597 multilib_exclusions);
8600 if (! m)
8602 ++e;
8603 continue;
8606 this_arg = e;
8608 while (*e != ' ' && *e != ';')
8610 if (*e == '\0')
8611 goto invalid_exclusion;
8612 ++e;
8615 q = p + 1;
8616 while (*q != ';')
8618 const char *arg;
8619 int len = e - this_arg;
8621 if (*q == '\0')
8622 goto invalid_select;
8624 arg = q;
8626 while (*q != ' ' && *q != ';')
8628 if (*q == '\0')
8629 goto invalid_select;
8630 ++q;
8633 if (! strncmp (arg, this_arg,
8634 (len < q - arg) ? q - arg : len)
8635 || default_arg (this_arg, e - this_arg))
8637 mp = 1;
8638 break;
8641 if (*q == ' ')
8642 ++q;
8645 if (! mp)
8646 m = 0;
8648 if (*e == ' ')
8649 ++e;
8652 if (m)
8654 skip = 1;
8655 break;
8658 if (*e != '\0')
8659 ++e;
8663 if (! skip)
8665 /* If this is a duplicate, skip it. */
8666 skip = (last_path != 0
8667 && (unsigned int) (p - this_path) == last_path_len
8668 && ! filename_ncmp (last_path, this_path, last_path_len));
8670 last_path = this_path;
8671 last_path_len = p - this_path;
8674 /* If this directory requires any default arguments, we can skip
8675 it. We will already have printed a directory identical to
8676 this one which does not require that default argument. */
8677 if (! skip)
8679 const char *q;
8681 q = p + 1;
8682 while (*q != ';')
8684 const char *arg;
8686 if (*q == '\0')
8687 goto invalid_select;
8689 if (*q == '!')
8690 arg = NULL;
8691 else
8692 arg = q;
8694 while (*q != ' ' && *q != ';')
8696 if (*q == '\0')
8697 goto invalid_select;
8698 ++q;
8701 if (arg != NULL
8702 && default_arg (arg, q - arg))
8704 skip = 1;
8705 break;
8708 if (*q == ' ')
8709 ++q;
8713 if (! skip)
8715 const char *p1;
8717 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
8718 putchar (*p1);
8719 putchar (';');
8722 ++p;
8723 while (*p != ';')
8725 int use_arg;
8727 if (*p == '\0')
8728 goto invalid_select;
8730 if (skip)
8732 ++p;
8733 continue;
8736 use_arg = *p != '!';
8738 if (use_arg)
8739 putchar ('@');
8741 while (*p != ' ' && *p != ';')
8743 if (*p == '\0')
8744 goto invalid_select;
8745 if (use_arg)
8746 putchar (*p);
8747 ++p;
8750 if (*p == ' ')
8751 ++p;
8754 if (! skip)
8756 /* If there are extra options, print them now. */
8757 if (multilib_extra && *multilib_extra)
8759 int print_at = TRUE;
8760 const char *q;
8762 for (q = multilib_extra; *q != '\0'; q++)
8764 if (*q == ' ')
8765 print_at = TRUE;
8766 else
8768 if (print_at)
8769 putchar ('@');
8770 putchar (*q);
8771 print_at = FALSE;
8776 putchar ('\n');
8779 ++p;
8783 /* getenv built-in spec function.
8785 Returns the value of the environment variable given by its first
8786 argument, concatenated with the second argument. If the
8787 environment variable is not defined, a fatal error is issued. */
8789 static const char *
8790 getenv_spec_function (int argc, const char **argv)
8792 char *value;
8793 char *result;
8794 char *ptr;
8795 size_t len;
8797 if (argc != 2)
8798 return NULL;
8800 value = getenv (argv[0]);
8801 if (!value)
8802 fatal_error ("environment variable %qs not defined", argv[0]);
8804 /* We have to escape every character of the environment variable so
8805 they are not interpreted as active spec characters. A
8806 particularly painful case is when we are reading a variable
8807 holding a windows path complete with \ separators. */
8808 len = strlen (value) * 2 + strlen (argv[1]) + 1;
8809 result = XNEWVAR (char, len);
8810 for (ptr = result; *value; ptr += 2)
8812 ptr[0] = '\\';
8813 ptr[1] = *value++;
8816 strcpy (ptr, argv[1]);
8818 return result;
8821 /* if-exists built-in spec function.
8823 Checks to see if the file specified by the absolute pathname in
8824 ARGS exists. Returns that pathname if found.
8826 The usual use for this function is to check for a library file
8827 (whose name has been expanded with %s). */
8829 static const char *
8830 if_exists_spec_function (int argc, const char **argv)
8832 /* Must have only one argument. */
8833 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8834 return argv[0];
8836 return NULL;
8839 /* if-exists-else built-in spec function.
8841 This is like if-exists, but takes an additional argument which
8842 is returned if the first argument does not exist. */
8844 static const char *
8845 if_exists_else_spec_function (int argc, const char **argv)
8847 /* Must have exactly two arguments. */
8848 if (argc != 2)
8849 return NULL;
8851 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8852 return argv[0];
8854 return argv[1];
8857 /* sanitize built-in spec function.
8859 This returns non-NULL, if sanitizing address, thread or
8860 any of the undefined behavior sanitizers. */
8862 static const char *
8863 sanitize_spec_function (int argc, const char **argv)
8865 if (argc != 1)
8866 return NULL;
8868 if (strcmp (argv[0], "address") == 0)
8869 return (flag_sanitize & SANITIZE_USER_ADDRESS) ? "" : NULL;
8870 if (strcmp (argv[0], "kernel-address") == 0)
8871 return (flag_sanitize & SANITIZE_KERNEL_ADDRESS) ? "" : NULL;
8872 if (strcmp (argv[0], "thread") == 0)
8873 return (flag_sanitize & SANITIZE_THREAD) ? "" : NULL;
8874 if (strcmp (argv[0], "undefined") == 0)
8875 return ((flag_sanitize & (SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT))
8876 && !flag_sanitize_undefined_trap_on_error) ? "" : NULL;
8877 if (strcmp (argv[0], "leak") == 0)
8878 return ((flag_sanitize
8879 & (SANITIZE_ADDRESS | SANITIZE_LEAK | SANITIZE_THREAD))
8880 == SANITIZE_LEAK) ? "" : NULL;
8881 return NULL;
8884 /* replace-outfile built-in spec function.
8886 This looks for the first argument in the outfiles array's name and
8887 replaces it with the second argument. */
8889 static const char *
8890 replace_outfile_spec_function (int argc, const char **argv)
8892 int i;
8893 /* Must have exactly two arguments. */
8894 if (argc != 2)
8895 abort ();
8897 for (i = 0; i < n_infiles; i++)
8899 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8900 outfiles[i] = xstrdup (argv[1]);
8902 return NULL;
8905 /* remove-outfile built-in spec function.
8907 * This looks for the first argument in the outfiles array's name and
8908 * removes it. */
8910 static const char *
8911 remove_outfile_spec_function (int argc, const char **argv)
8913 int i;
8914 /* Must have exactly one argument. */
8915 if (argc != 1)
8916 abort ();
8918 for (i = 0; i < n_infiles; i++)
8920 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8921 outfiles[i] = NULL;
8923 return NULL;
8926 /* Given two version numbers, compares the two numbers.
8927 A version number must match the regular expression
8928 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
8930 static int
8931 compare_version_strings (const char *v1, const char *v2)
8933 int rresult;
8934 regex_t r;
8936 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
8937 REG_EXTENDED | REG_NOSUB) != 0)
8938 abort ();
8939 rresult = regexec (&r, v1, 0, NULL, 0);
8940 if (rresult == REG_NOMATCH)
8941 fatal_error ("invalid version number %qs", v1);
8942 else if (rresult != 0)
8943 abort ();
8944 rresult = regexec (&r, v2, 0, NULL, 0);
8945 if (rresult == REG_NOMATCH)
8946 fatal_error ("invalid version number %qs", v2);
8947 else if (rresult != 0)
8948 abort ();
8950 return strverscmp (v1, v2);
8954 /* version_compare built-in spec function.
8956 This takes an argument of the following form:
8958 <comparison-op> <arg1> [<arg2>] <switch> <result>
8960 and produces "result" if the comparison evaluates to true,
8961 and nothing if it doesn't.
8963 The supported <comparison-op> values are:
8965 >= true if switch is a later (or same) version than arg1
8966 !> opposite of >=
8967 < true if switch is an earlier version than arg1
8968 !< opposite of <
8969 >< true if switch is arg1 or later, and earlier than arg2
8970 <> true if switch is earlier than arg1 or is arg2 or later
8972 If the switch is not present, the condition is false unless
8973 the first character of the <comparison-op> is '!'.
8975 For example,
8976 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
8977 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
8979 static const char *
8980 version_compare_spec_function (int argc, const char **argv)
8982 int comp1, comp2;
8983 size_t switch_len;
8984 const char *switch_value = NULL;
8985 int nargs = 1, i;
8986 bool result;
8988 if (argc < 3)
8989 fatal_error ("too few arguments to %%:version-compare");
8990 if (argv[0][0] == '\0')
8991 abort ();
8992 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
8993 nargs = 2;
8994 if (argc != nargs + 3)
8995 fatal_error ("too many arguments to %%:version-compare");
8997 switch_len = strlen (argv[nargs + 1]);
8998 for (i = 0; i < n_switches; i++)
8999 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
9000 && check_live_switch (i, switch_len))
9001 switch_value = switches[i].part1 + switch_len;
9003 if (switch_value == NULL)
9004 comp1 = comp2 = -1;
9005 else
9007 comp1 = compare_version_strings (switch_value, argv[1]);
9008 if (nargs == 2)
9009 comp2 = compare_version_strings (switch_value, argv[2]);
9010 else
9011 comp2 = -1; /* This value unused. */
9014 switch (argv[0][0] << 8 | argv[0][1])
9016 case '>' << 8 | '=':
9017 result = comp1 >= 0;
9018 break;
9019 case '!' << 8 | '<':
9020 result = comp1 >= 0 || switch_value == NULL;
9021 break;
9022 case '<' << 8:
9023 result = comp1 < 0;
9024 break;
9025 case '!' << 8 | '>':
9026 result = comp1 < 0 || switch_value == NULL;
9027 break;
9028 case '>' << 8 | '<':
9029 result = comp1 >= 0 && comp2 < 0;
9030 break;
9031 case '<' << 8 | '>':
9032 result = comp1 < 0 || comp2 >= 0;
9033 break;
9035 default:
9036 fatal_error ("unknown operator %qs in %%:version-compare", argv[0]);
9038 if (! result)
9039 return NULL;
9041 return argv[nargs + 2];
9044 /* %:include builtin spec function. This differs from %include in that it
9045 can be nested inside a spec, and thus be conditionalized. It takes
9046 one argument, the filename, and looks for it in the startfile path.
9047 The result is always NULL, i.e. an empty expansion. */
9049 static const char *
9050 include_spec_function (int argc, const char **argv)
9052 char *file;
9054 if (argc != 1)
9055 abort ();
9057 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
9058 read_specs (file ? file : argv[0], false, false);
9060 return NULL;
9063 /* %:find-file spec function. This function replaces its argument by
9064 the file found through find_file, that is the -print-file-name gcc
9065 program option. */
9066 static const char *
9067 find_file_spec_function (int argc, const char **argv)
9069 const char *file;
9071 if (argc != 1)
9072 abort ();
9074 file = find_file (argv[0]);
9075 return file;
9079 /* %:find-plugindir spec function. This function replaces its argument
9080 by the -iplugindir=<dir> option. `dir' is found through find_file, that
9081 is the -print-file-name gcc program option. */
9082 static const char *
9083 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
9085 const char *option;
9087 if (argc != 0)
9088 abort ();
9090 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
9091 return option;
9095 /* %:print-asm-header spec function. Print a banner to say that the
9096 following output is from the assembler. */
9098 static const char *
9099 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
9100 const char **argv ATTRIBUTE_UNUSED)
9102 printf (_("Assembler options\n=================\n\n"));
9103 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
9104 fflush (stdout);
9105 return NULL;
9108 /* Get a random number for -frandom-seed */
9110 static unsigned HOST_WIDE_INT
9111 get_random_number (void)
9113 unsigned HOST_WIDE_INT ret = 0;
9114 int fd;
9116 fd = open ("/dev/urandom", O_RDONLY);
9117 if (fd >= 0)
9119 read (fd, &ret, sizeof (HOST_WIDE_INT));
9120 close (fd);
9121 if (ret)
9122 return ret;
9125 /* Get some more or less random data. */
9126 #ifdef HAVE_GETTIMEOFDAY
9128 struct timeval tv;
9130 gettimeofday (&tv, NULL);
9131 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
9133 #else
9135 time_t now = time (NULL);
9137 if (now != (time_t)-1)
9138 ret = (unsigned) now;
9140 #endif
9142 return ret ^ getpid ();
9145 /* %:compare-debug-dump-opt spec function. Save the last argument,
9146 expected to be the last -fdump-final-insns option, or generate a
9147 temporary. */
9149 static const char *
9150 compare_debug_dump_opt_spec_function (int arg,
9151 const char **argv ATTRIBUTE_UNUSED)
9153 char *ret;
9154 char *name;
9155 int which;
9156 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
9158 if (arg != 0)
9159 fatal_error ("too many arguments to %%:compare-debug-dump-opt");
9161 do_spec_2 ("%{fdump-final-insns=*:%*}");
9162 do_spec_1 (" ", 0, NULL);
9164 if (argbuf.length () > 0
9165 && strcmp (argv[argbuf.length () - 1], "."))
9167 if (!compare_debug)
9168 return NULL;
9170 name = xstrdup (argv[argbuf.length () - 1]);
9171 ret = NULL;
9173 else
9175 const char *ext = NULL;
9177 if (argbuf.length () > 0)
9179 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
9180 ext = ".gkd";
9182 else if (!compare_debug)
9183 return NULL;
9184 else
9185 do_spec_2 ("%g.gkd");
9187 do_spec_1 (" ", 0, NULL);
9189 gcc_assert (argbuf.length () > 0);
9191 name = concat (argbuf.last (), ext, NULL);
9193 ret = concat ("-fdump-final-insns=", name, NULL);
9196 which = compare_debug < 0;
9197 debug_check_temp_file[which] = name;
9199 if (!which)
9201 unsigned HOST_WIDE_INT value = get_random_number ();
9203 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
9206 if (*random_seed)
9208 char *tmp = ret;
9209 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
9210 ret, NULL);
9211 free (tmp);
9214 if (which)
9215 *random_seed = 0;
9217 return ret;
9220 static const char *debug_auxbase_opt;
9222 /* %:compare-debug-self-opt spec function. Expands to the options
9223 that are to be passed in the second compilation of
9224 compare-debug. */
9226 static const char *
9227 compare_debug_self_opt_spec_function (int arg,
9228 const char **argv ATTRIBUTE_UNUSED)
9230 if (arg != 0)
9231 fatal_error ("too many arguments to %%:compare-debug-self-opt");
9233 if (compare_debug >= 0)
9234 return NULL;
9236 do_spec_2 ("%{c|S:%{o*:%*}}");
9237 do_spec_1 (" ", 0, NULL);
9239 if (argbuf.length () > 0)
9240 debug_auxbase_opt = concat ("-auxbase-strip ",
9241 argbuf.last (),
9242 NULL);
9243 else
9244 debug_auxbase_opt = NULL;
9246 return concat ("\
9247 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
9248 %<fdump-final-insns=* -w -S -o %j \
9249 %{!fcompare-debug-second:-fcompare-debug-second} \
9250 ", compare_debug_opt, NULL);
9253 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
9254 options that are to be passed in the second compilation of
9255 compare-debug. It expects, as an argument, the basename of the
9256 current input file name, with the .gk suffix appended to it. */
9258 static const char *
9259 compare_debug_auxbase_opt_spec_function (int arg,
9260 const char **argv)
9262 char *name;
9263 int len;
9265 if (arg == 0)
9266 fatal_error ("too few arguments to %%:compare-debug-auxbase-opt");
9268 if (arg != 1)
9269 fatal_error ("too many arguments to %%:compare-debug-auxbase-opt");
9271 if (compare_debug >= 0)
9272 return NULL;
9274 len = strlen (argv[0]);
9275 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
9276 fatal_error ("argument to %%:compare-debug-auxbase-opt "
9277 "does not end in .gk");
9279 if (debug_auxbase_opt)
9280 return debug_auxbase_opt;
9282 #define OPT "-auxbase "
9284 len -= 3;
9285 name = (char*) xmalloc (sizeof (OPT) + len);
9286 memcpy (name, OPT, sizeof (OPT) - 1);
9287 memcpy (name + sizeof (OPT) - 1, argv[0], len);
9288 name[sizeof (OPT) - 1 + len] = '\0';
9290 #undef OPT
9292 return name;
9295 /* %:pass-through-libs spec function. Finds all -l options and input
9296 file names in the lib spec passed to it, and makes a list of them
9297 prepended with the plugin option to cause them to be passed through
9298 to the final link after all the new object files have been added. */
9300 const char *
9301 pass_through_libs_spec_func (int argc, const char **argv)
9303 char *prepended = xstrdup (" ");
9304 int n;
9305 /* Shlemiel the painter's algorithm. Innately horrible, but at least
9306 we know that there will never be more than a handful of strings to
9307 concat, and it's only once per run, so it's not worth optimising. */
9308 for (n = 0; n < argc; n++)
9310 char *old = prepended;
9311 /* Anything that isn't an option is a full path to an output
9312 file; pass it through if it ends in '.a'. Among options,
9313 pass only -l. */
9314 if (argv[n][0] == '-' && argv[n][1] == 'l')
9316 const char *lopt = argv[n] + 2;
9317 /* Handle both joined and non-joined -l options. If for any
9318 reason there's a trailing -l with no joined or following
9319 arg just discard it. */
9320 if (!*lopt && ++n >= argc)
9321 break;
9322 else if (!*lopt)
9323 lopt = argv[n];
9324 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
9325 lopt, " ", NULL);
9327 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
9329 prepended = concat (prepended, "-plugin-opt=-pass-through=",
9330 argv[n], " ", NULL);
9332 if (prepended != old)
9333 free (old);
9335 return prepended;
9338 /* %:replace-extension spec function. Replaces the extension of the
9339 first argument with the second argument. */
9341 const char *
9342 replace_extension_spec_func (int argc, const char **argv)
9344 char *name;
9345 char *p;
9346 char *result;
9347 int i;
9349 if (argc != 2)
9350 fatal_error ("too few arguments to %%:replace-extension");
9352 name = xstrdup (argv[0]);
9354 for (i = strlen (name) - 1; i >= 0; i--)
9355 if (IS_DIR_SEPARATOR (name[i]))
9356 break;
9358 p = strrchr (name + i + 1, '.');
9359 if (p != NULL)
9360 *p = '\0';
9362 result = concat (name, argv[1], NULL);
9364 free (name);
9365 return result;
9368 /* Insert backslash before spaces in ORIG (usually a file path), to
9369 avoid being broken by spec parser.
9371 This function is needed as do_spec_1 treats white space (' ' and '\t')
9372 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
9373 the file name should be treated as a single argument rather than being
9374 broken into multiple. Solution is to insert '\\' before the space in a
9375 file name.
9377 This function converts and only converts all occurrence of ' '
9378 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
9379 "a b" -> "a\\ b"
9380 "a b" -> "a\\ \\ b"
9381 "a\tb" -> "a\\\tb"
9382 "a\\ b" -> "a\\\\ b"
9384 orig: input null-terminating string that was allocated by xalloc. The
9385 memory it points to might be freed in this function. Behavior undefined
9386 if ORIG wasn't xalloced or was freed already at entry.
9388 Return: ORIG if no conversion needed. Otherwise a newly allocated string
9389 that was converted from ORIG. */
9391 static char *
9392 convert_white_space (char *orig)
9394 int len, number_of_space = 0;
9396 for (len = 0; orig[len]; len++)
9397 if (orig[len] == ' ' || orig[len] == '\t') number_of_space++;
9399 if (number_of_space)
9401 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
9402 int j, k;
9403 for (j = 0, k = 0; j <= len; j++, k++)
9405 if (orig[j] == ' ' || orig[j] == '\t')
9406 new_spec[k++] = '\\';
9407 new_spec[k] = orig[j];
9409 free (orig);
9410 return new_spec;
9412 else
9413 return orig;