compiler, runtime: call gcWriteBarrier instead of writebarrierptr
[official-gcc.git] / gcc / gcc.c
blob8be82eaa04fd8b8b6b7a28f6e04b72d58fea8fdb
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987-2018 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 "opt-suggestions.h"
40 #include "gcc.h"
41 #include "diagnostic.h"
42 #include "flags.h"
43 #include "opts.h"
44 #include "params.h"
45 #include "filenames.h"
46 #include "spellcheck.h"
50 /* Manage the manipulation of env vars.
52 We poison "getenv" and "putenv", so that all enviroment-handling is
53 done through this class. Note that poisoning happens in the
54 preprocessor at the identifier level, and doesn't distinguish between
55 env.getenv ();
56 and
57 getenv ();
58 Hence we need to use "get" for the accessor method, not "getenv". */
60 class env_manager
62 public:
63 void init (bool can_restore, bool debug);
64 const char *get (const char *name);
65 void xput (const char *string);
66 void restore ();
68 private:
69 bool m_can_restore;
70 bool m_debug;
71 struct kv
73 char *m_key;
74 char *m_value;
76 vec<kv> m_keys;
80 /* The singleton instance of class env_manager. */
82 static env_manager env;
84 /* Initializer for class env_manager.
86 We can't do this as a constructor since we have a statically
87 allocated instance ("env" above). */
89 void
90 env_manager::init (bool can_restore, bool debug)
92 m_can_restore = can_restore;
93 m_debug = debug;
96 /* Get the value of NAME within the environment. Essentially
97 a wrapper for ::getenv, but adding logging, and the possibility
98 of caching results. */
100 const char *
101 env_manager::get (const char *name)
103 const char *result = ::getenv (name);
104 if (m_debug)
105 fprintf (stderr, "env_manager::getenv (%s) -> %s\n", name, result);
106 return result;
109 /* Put the given KEY=VALUE entry STRING into the environment.
110 If the env_manager was initialized with CAN_RESTORE set, then
111 also record the old value of KEY within the environment, so that it
112 can be later restored. */
114 void
115 env_manager::xput (const char *string)
117 if (m_debug)
118 fprintf (stderr, "env_manager::xput (%s)\n", string);
119 if (verbose_flag)
120 fnotice (stderr, "%s\n", string);
122 if (m_can_restore)
124 char *equals = strchr (const_cast <char *> (string), '=');
125 gcc_assert (equals);
127 struct kv kv;
128 kv.m_key = xstrndup (string, equals - string);
129 const char *cur_value = ::getenv (kv.m_key);
130 if (m_debug)
131 fprintf (stderr, "saving old value: %s\n",cur_value);
132 kv.m_value = cur_value ? xstrdup (cur_value) : NULL;
133 m_keys.safe_push (kv);
136 ::putenv (CONST_CAST (char *, string));
139 /* Undo any xputenv changes made since last restore.
140 Can only be called if the env_manager was initialized with
141 CAN_RESTORE enabled. */
143 void
144 env_manager::restore ()
146 unsigned int i;
147 struct kv *item;
149 gcc_assert (m_can_restore);
151 FOR_EACH_VEC_ELT_REVERSE (m_keys, i, item)
153 if (m_debug)
154 printf ("restoring saved key: %s value: %s\n", item->m_key, item->m_value);
155 if (item->m_value)
156 ::setenv (item->m_key, item->m_value, 1);
157 else
158 ::unsetenv (item->m_key);
159 free (item->m_key);
160 free (item->m_value);
163 m_keys.truncate (0);
166 /* Forbid other uses of getenv and putenv. */
167 #if (GCC_VERSION >= 3000)
168 #pragma GCC poison getenv putenv
169 #endif
173 /* By default there is no special suffix for target executables. */
174 #ifdef TARGET_EXECUTABLE_SUFFIX
175 #define HAVE_TARGET_EXECUTABLE_SUFFIX
176 #else
177 #define TARGET_EXECUTABLE_SUFFIX ""
178 #endif
180 /* By default there is no special suffix for host executables. */
181 #ifdef HOST_EXECUTABLE_SUFFIX
182 #define HAVE_HOST_EXECUTABLE_SUFFIX
183 #else
184 #define HOST_EXECUTABLE_SUFFIX ""
185 #endif
187 /* By default, the suffix for target object files is ".o". */
188 #ifdef TARGET_OBJECT_SUFFIX
189 #define HAVE_TARGET_OBJECT_SUFFIX
190 #else
191 #define TARGET_OBJECT_SUFFIX ".o"
192 #endif
194 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
196 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
197 #ifndef LIBRARY_PATH_ENV
198 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
199 #endif
201 /* If a stage of compilation returns an exit status >= 1,
202 compilation of that file ceases. */
204 #define MIN_FATAL_STATUS 1
206 /* Flag set by cppspec.c to 1. */
207 int is_cpp_driver;
209 /* Flag set to nonzero if an @file argument has been supplied to gcc. */
210 static bool at_file_supplied;
212 /* Definition of string containing the arguments given to configure. */
213 #include "configargs.h"
215 /* Flag saying to print the command line options understood by gcc and its
216 sub-processes. */
218 static int print_help_list;
220 /* Flag saying to print the version of gcc and its sub-processes. */
222 static int print_version;
224 /* Flag that stores string prefix for which we provide bash completion. */
226 static const char *completion = NULL;
228 /* Flag indicating whether we should ONLY print the command and
229 arguments (like verbose_flag) without executing the command.
230 Displayed arguments are quoted so that the generated command
231 line is suitable for execution. This is intended for use in
232 shell scripts to capture the driver-generated command line. */
233 static int verbose_only_flag;
235 /* Flag indicating how to print command line options of sub-processes. */
237 static int print_subprocess_help;
239 /* Linker suffix passed to -fuse-ld=... */
240 static const char *use_ld;
242 /* Whether we should report subprocess execution times to a file. */
244 FILE *report_times_to_file = NULL;
246 /* Nonzero means place this string before uses of /, so that include
247 and library files can be found in an alternate location. */
249 #ifdef TARGET_SYSTEM_ROOT
250 #define DEFAULT_TARGET_SYSTEM_ROOT (TARGET_SYSTEM_ROOT)
251 #else
252 #define DEFAULT_TARGET_SYSTEM_ROOT (0)
253 #endif
254 static const char *target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
256 /* Nonzero means pass the updated target_system_root to the compiler. */
258 static int target_system_root_changed;
260 /* Nonzero means append this string to target_system_root. */
262 static const char *target_sysroot_suffix = 0;
264 /* Nonzero means append this string to target_system_root for headers. */
266 static const char *target_sysroot_hdrs_suffix = 0;
268 /* Nonzero means write "temp" files in source directory
269 and use the source file's name in them, and don't delete them. */
271 static enum save_temps {
272 SAVE_TEMPS_NONE, /* no -save-temps */
273 SAVE_TEMPS_CWD, /* -save-temps in current directory */
274 SAVE_TEMPS_OBJ /* -save-temps in object directory */
275 } save_temps_flag;
277 /* Output file to use to get the object directory for -save-temps=obj */
278 static char *save_temps_prefix = 0;
279 static size_t save_temps_length = 0;
281 /* The compiler version. */
283 static const char *compiler_version;
285 /* The target version. */
287 static const char *const spec_version = DEFAULT_TARGET_VERSION;
289 /* The target machine. */
291 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
292 static const char *spec_host_machine = DEFAULT_REAL_TARGET_MACHINE;
294 /* List of offload targets. Separated by colon. Empty string for
295 -foffload=disable. */
297 static char *offload_targets = NULL;
299 /* Nonzero if cross-compiling.
300 When -b is used, the value comes from the `specs' file. */
302 #ifdef CROSS_DIRECTORY_STRUCTURE
303 static const char *cross_compile = "1";
304 #else
305 static const char *cross_compile = "0";
306 #endif
308 /* Greatest exit code of sub-processes that has been encountered up to
309 now. */
310 static int greatest_status = 1;
312 /* This is the obstack which we use to allocate many strings. */
314 static struct obstack obstack;
316 /* This is the obstack to build an environment variable to pass to
317 collect2 that describes all of the relevant switches of what to
318 pass the compiler in building the list of pointers to constructors
319 and destructors. */
321 static struct obstack collect_obstack;
323 /* Forward declaration for prototypes. */
324 struct path_prefix;
325 struct prefix_list;
327 static void init_spec (void);
328 static void store_arg (const char *, int, int);
329 static void insert_wrapper (const char *);
330 static char *load_specs (const char *);
331 static void read_specs (const char *, bool, bool);
332 static void set_spec (const char *, const char *, bool);
333 static struct compiler *lookup_compiler (const char *, size_t, const char *);
334 static char *build_search_list (const struct path_prefix *, const char *,
335 bool, bool);
336 static void xputenv (const char *);
337 static void putenv_from_prefixes (const struct path_prefix *, const char *,
338 bool);
339 static int access_check (const char *, int);
340 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
341 static void add_prefix (struct path_prefix *, const char *, const char *,
342 int, int, int);
343 static void add_sysrooted_prefix (struct path_prefix *, const char *,
344 const char *, int, int, int);
345 static char *skip_whitespace (char *);
346 static void delete_if_ordinary (const char *);
347 static void delete_temp_files (void);
348 static void delete_failure_queue (void);
349 static void clear_failure_queue (void);
350 static int check_live_switch (int, int);
351 static const char *handle_braces (const char *);
352 static inline bool input_suffix_matches (const char *, const char *);
353 static inline bool switch_matches (const char *, const char *, int);
354 static inline void mark_matching_switches (const char *, const char *, int);
355 static inline void process_marked_switches (void);
356 static const char *process_brace_body (const char *, const char *, const char *, int, int);
357 static const struct spec_function *lookup_spec_function (const char *);
358 static const char *eval_spec_function (const char *, const char *, const char *);
359 static const char *handle_spec_function (const char *, bool *, const char *);
360 static char *save_string (const char *, int);
361 static void set_collect_gcc_options (void);
362 static int do_spec_1 (const char *, int, const char *);
363 static int do_spec_2 (const char *, const char *);
364 static void do_option_spec (const char *, const char *);
365 static void do_self_spec (const char *);
366 static const char *find_file (const char *);
367 static int is_directory (const char *, bool);
368 static const char *validate_switches (const char *, bool);
369 static void validate_all_switches (void);
370 static inline void validate_switches_from_spec (const char *, bool);
371 static void give_switch (int, int);
372 static int default_arg (const char *, int);
373 static void set_multilib_dir (void);
374 static void print_multilib_info (void);
375 static void display_help (void);
376 static void add_preprocessor_option (const char *, int);
377 static void add_assembler_option (const char *, int);
378 static void add_linker_option (const char *, int);
379 static void process_command (unsigned int, struct cl_decoded_option *);
380 static int execute (void);
381 static void alloc_args (void);
382 static void clear_args (void);
383 static void fatal_signal (int);
384 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
385 static void init_gcc_specs (struct obstack *, const char *, const char *,
386 const char *);
387 #endif
388 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
389 static const char *convert_filename (const char *, int, int);
390 #endif
392 static void try_generate_repro (const char **argv);
393 static const char *getenv_spec_function (int, const char **);
394 static const char *if_exists_spec_function (int, const char **);
395 static const char *if_exists_else_spec_function (int, const char **);
396 static const char *sanitize_spec_function (int, const char **);
397 static const char *replace_outfile_spec_function (int, const char **);
398 static const char *remove_outfile_spec_function (int, const char **);
399 static const char *version_compare_spec_function (int, const char **);
400 static const char *include_spec_function (int, const char **);
401 static const char *find_file_spec_function (int, const char **);
402 static const char *find_plugindir_spec_function (int, const char **);
403 static const char *print_asm_header_spec_function (int, const char **);
404 static const char *compare_debug_dump_opt_spec_function (int, const char **);
405 static const char *compare_debug_self_opt_spec_function (int, const char **);
406 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
407 static const char *pass_through_libs_spec_func (int, const char **);
408 static const char *replace_extension_spec_func (int, const char **);
409 static const char *greater_than_spec_func (int, const char **);
410 static const char *debug_level_greater_than_spec_func (int, const char **);
411 static char *convert_white_space (char *);
413 /* The Specs Language
415 Specs are strings containing lines, each of which (if not blank)
416 is made up of a program name, and arguments separated by spaces.
417 The program name must be exact and start from root, since no path
418 is searched and it is unreliable to depend on the current working directory.
419 Redirection of input or output is not supported; the subprograms must
420 accept filenames saying what files to read and write.
422 In addition, the specs can contain %-sequences to substitute variable text
423 or for conditional text. Here is a table of all defined %-sequences.
424 Note that spaces are not generated automatically around the results of
425 expanding these sequences; therefore, you can concatenate them together
426 or with constant text in a single argument.
428 %% substitute one % into the program name or argument.
429 %i substitute the name of the input file being processed.
430 %b substitute the basename of the input file being processed.
431 This is the substring up to (and not including) the last period
432 and not including the directory unless -save-temps was specified
433 to put temporaries in a different location.
434 %B same as %b, but include the file suffix (text after the last period).
435 %gSUFFIX
436 substitute a file name that has suffix SUFFIX and is chosen
437 once per compilation, and mark the argument a la %d. To reduce
438 exposure to denial-of-service attacks, the file name is now
439 chosen in a way that is hard to predict even when previously
440 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
441 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
442 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
443 had been pre-processed. Previously, %g was simply substituted
444 with a file name chosen once per compilation, without regard
445 to any appended suffix (which was therefore treated just like
446 ordinary text), making such attacks more likely to succeed.
447 %|SUFFIX
448 like %g, but if -pipe is in effect, expands simply to "-".
449 %mSUFFIX
450 like %g, but if -pipe is in effect, expands to nothing. (We have both
451 %| and %m to accommodate differences between system assemblers; see
452 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
453 %uSUFFIX
454 like %g, but generates a new temporary file name even if %uSUFFIX
455 was already seen.
456 %USUFFIX
457 substitutes the last file name generated with %uSUFFIX, generating a
458 new one if there is no such last file name. In the absence of any
459 %uSUFFIX, this is just like %gSUFFIX, except they don't share
460 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
461 would involve the generation of two distinct file names, one
462 for each `%g.s' and another for each `%U.s'. Previously, %U was
463 simply substituted with a file name chosen for the previous %u,
464 without regard to any appended suffix.
465 %jSUFFIX
466 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
467 writable, and if save-temps is off; otherwise, substitute the name
468 of a temporary file, just like %u. This temporary file is not
469 meant for communication between processes, but rather as a junk
470 disposal mechanism.
471 %.SUFFIX
472 substitutes .SUFFIX for the suffixes of a matched switch's args when
473 it is subsequently output with %*. SUFFIX is terminated by the next
474 space or %.
475 %d marks the argument containing or following the %d as a
476 temporary file name, so that file will be deleted if GCC exits
477 successfully. Unlike %g, this contributes no text to the argument.
478 %w marks the argument containing or following the %w as the
479 "output file" of this compilation. This puts the argument
480 into the sequence of arguments that %o will substitute later.
481 %V indicates that this compilation produces no "output file".
482 %W{...}
483 like %{...} but marks the last argument supplied within as a file
484 to be deleted on failure.
485 %@{...}
486 like %{...} but puts the result into a FILE and substitutes @FILE
487 if an @file argument has been supplied.
488 %o substitutes the names of all the output files, with spaces
489 automatically placed around them. You should write spaces
490 around the %o as well or the results are undefined.
491 %o is for use in the specs for running the linker.
492 Input files whose names have no recognized suffix are not compiled
493 at all, but they are included among the output files, so they will
494 be linked.
495 %O substitutes the suffix for object files. Note that this is
496 handled specially when it immediately follows %g, %u, or %U
497 (with or without a suffix argument) because of the need for
498 those to form complete file names. The handling is such that
499 %O is treated exactly as if it had already been substituted,
500 except that %g, %u, and %U do not currently support additional
501 SUFFIX characters following %O as they would following, for
502 example, `.o'.
503 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
504 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
505 and -B options) and -imultilib as necessary.
506 %s current argument is the name of a library or startup file of some sort.
507 Search for that file in a standard list of directories
508 and substitute the full name found.
509 %eSTR Print STR as an error message. STR is terminated by a newline.
510 Use this when inconsistent options are detected.
511 %nSTR Print STR as a notice. STR is terminated by a newline.
512 %x{OPTION} Accumulate an option for %X.
513 %X Output the accumulated linker options specified by compilations.
514 %Y Output the accumulated assembler options specified by compilations.
515 %Z Output the accumulated preprocessor options specified by compilations.
516 %a process ASM_SPEC as a spec.
517 This allows config.h to specify part of the spec for running as.
518 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
519 used here. This can be used to run a post-processor after the
520 assembler has done its job.
521 %D Dump out a -L option for each directory in startfile_prefixes.
522 If multilib_dir is set, extra entries are generated with it affixed.
523 %l process LINK_SPEC as a spec.
524 %L process LIB_SPEC as a spec.
525 %M Output multilib_os_dir.
526 %G process LIBGCC_SPEC as a spec.
527 %R Output the concatenation of target_system_root and
528 target_sysroot_suffix.
529 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
530 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
531 %C process CPP_SPEC as a spec.
532 %1 process CC1_SPEC as a spec.
533 %2 process CC1PLUS_SPEC as a spec.
534 %* substitute the variable part of a matched option. (See below.)
535 Note that each comma in the substituted string is replaced by
536 a single space. A space is appended after the last substition
537 unless there is more text in current sequence.
538 %<S remove all occurrences of -S from the command line.
539 Note - this command is position dependent. % commands in the
540 spec string before this one will see -S, % commands in the
541 spec string after this one will not.
542 %>S Similar to "%<S", but keep it in the GCC command line.
543 %<S* remove all occurrences of all switches beginning with -S from the
544 command line.
545 %:function(args)
546 Call the named function FUNCTION, passing it ARGS. ARGS is
547 first processed as a nested spec string, then split into an
548 argument vector in the usual fashion. The function returns
549 a string which is processed as if it had appeared literally
550 as part of the current spec.
551 %{S} substitutes the -S switch, if that switch was given to GCC.
552 If that switch was not specified, this substitutes nothing.
553 Here S is a metasyntactic variable.
554 %{S*} substitutes all the switches specified to GCC whose names start
555 with -S. This is used for -o, -I, etc; switches that take
556 arguments. GCC considers `-o foo' as being one switch whose
557 name starts with `o'. %{o*} would substitute this text,
558 including the space; thus, two arguments would be generated.
559 %{S*&T*} likewise, but preserve order of S and T options (the order
560 of S and T in the spec is not significant). Can be any number
561 of ampersand-separated variables; for each the wild card is
562 optional. Useful for CPP as %{D*&U*&A*}.
564 %{S:X} substitutes X, if the -S switch was given to GCC.
565 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
566 %{S*:X} substitutes X if one or more switches whose names start
567 with -S was given to GCC. Normally X is substituted only
568 once, no matter how many such switches appeared. However,
569 if %* appears somewhere in X, then X will be substituted
570 once for each matching switch, with the %* replaced by the
571 part of that switch that matched the '*'. A space will be
572 appended after the last substition unless there is more
573 text in current sequence.
574 %{.S:X} substitutes X, if processing a file with suffix S.
575 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
576 %{,S:X} substitutes X, if processing a file which will use spec S.
577 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
579 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
580 combined with '!', '.', ',', and '*' as above binding stronger
581 than the OR.
582 If %* appears in X, all of the alternatives must be starred, and
583 only the first matching alternative is substituted.
584 %{%:function(args):X}
585 Call function named FUNCTION with args ARGS. If the function
586 returns non-NULL, then X is substituted, if it returns
587 NULL, it isn't substituted.
588 %{S:X; if S was given to GCC, substitutes X;
589 T:Y; else if T was given to GCC, substitutes Y;
590 :D} else substitutes D. There can be as many clauses as you need.
591 This may be combined with '.', '!', ',', '|', and '*' as above.
593 %(Spec) processes a specification defined in a specs file as *Spec:
595 The switch matching text S in a %{S}, %{S:X}, or similar construct can use
596 a backslash to ignore the special meaning of the character following it,
597 thus allowing literal matching of a character that is otherwise specially
598 treated. For example, %{std=iso9899\:1999:X} substitutes X if the
599 -std=iso9899:1999 option is given.
601 The conditional text X in a %{S:X} or similar construct may contain
602 other nested % constructs or spaces, or even newlines. They are
603 processed as usual, as described above. Trailing white space in X is
604 ignored. White space may also appear anywhere on the left side of the
605 colon in these constructs, except between . or * and the corresponding
606 word.
608 The -O, -f, -g, -m, and -W switches are handled specifically in these
609 constructs. If another value of -O or the negated form of a -f, -m, or
610 -W switch is found later in the command line, the earlier switch
611 value is ignored, except with {S*} where S is just one letter; this
612 passes all matching options.
614 The character | at the beginning of the predicate text is used to indicate
615 that a command should be piped to the following command, but only if -pipe
616 is specified.
618 Note that it is built into GCC which switches take arguments and which
619 do not. You might think it would be useful to generalize this to
620 allow each compiler's spec to say which switches take arguments. But
621 this cannot be done in a consistent fashion. GCC cannot even decide
622 which input files have been specified without knowing which switches
623 take arguments, and it must know which input files to compile in order
624 to tell which compilers to run.
626 GCC also knows implicitly that arguments starting in `-l' are to be
627 treated as compiler output files, and passed to the linker in their
628 proper position among the other output files. */
630 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
632 /* config.h can define ASM_SPEC to provide extra args to the assembler
633 or extra switch-translations. */
634 #ifndef ASM_SPEC
635 #define ASM_SPEC ""
636 #endif
638 /* config.h can define ASM_FINAL_SPEC to run a post processor after
639 the assembler has run. */
640 #ifndef ASM_FINAL_SPEC
641 #define ASM_FINAL_SPEC \
642 "%{gsplit-dwarf: \n\
643 objcopy --extract-dwo \
644 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
645 %{c:%{o*:%:replace-extension(%{o*:%*} .dwo)}%{!o*:%b.dwo}}%{!c:%b.dwo} \n\
646 objcopy --strip-dwo \
647 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
649 #endif
651 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
652 or extra switch-translations. */
653 #ifndef CPP_SPEC
654 #define CPP_SPEC ""
655 #endif
657 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
658 or extra switch-translations. */
659 #ifndef CC1_SPEC
660 #define CC1_SPEC ""
661 #endif
663 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
664 or extra switch-translations. */
665 #ifndef CC1PLUS_SPEC
666 #define CC1PLUS_SPEC ""
667 #endif
669 /* config.h can define LINK_SPEC to provide extra args to the linker
670 or extra switch-translations. */
671 #ifndef LINK_SPEC
672 #define LINK_SPEC ""
673 #endif
675 /* config.h can define LIB_SPEC to override the default libraries. */
676 #ifndef LIB_SPEC
677 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
678 #endif
680 /* When using -fsplit-stack we need to wrap pthread_create, in order
681 to initialize the stack guard. We always use wrapping, rather than
682 shared library ordering, and we keep the wrapper function in
683 libgcc. This is not yet a real spec, though it could become one;
684 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
685 only works with GNU ld and gold. */
686 #ifdef HAVE_GOLD_NON_DEFAULT_SPLIT_STACK
687 #define STACK_SPLIT_SPEC " %{fsplit-stack: -fuse-ld=gold --wrap=pthread_create}"
688 #else
689 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
690 #endif
692 #ifndef LIBASAN_SPEC
693 #define STATIC_LIBASAN_LIBS \
694 " %{static-libasan|static:%:include(libsanitizer.spec)%(link_libasan)}"
695 #ifdef LIBASAN_EARLY_SPEC
696 #define LIBASAN_SPEC STATIC_LIBASAN_LIBS
697 #elif defined(HAVE_LD_STATIC_DYNAMIC)
698 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
699 "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
700 STATIC_LIBASAN_LIBS
701 #else
702 #define LIBASAN_SPEC "-lasan" STATIC_LIBASAN_LIBS
703 #endif
704 #endif
706 #ifndef LIBASAN_EARLY_SPEC
707 #define LIBASAN_EARLY_SPEC ""
708 #endif
710 #ifndef LIBTSAN_SPEC
711 #define STATIC_LIBTSAN_LIBS \
712 " %{static-libtsan|static:%:include(libsanitizer.spec)%(link_libtsan)}"
713 #ifdef LIBTSAN_EARLY_SPEC
714 #define LIBTSAN_SPEC STATIC_LIBTSAN_LIBS
715 #elif defined(HAVE_LD_STATIC_DYNAMIC)
716 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
717 "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}" \
718 STATIC_LIBTSAN_LIBS
719 #else
720 #define LIBTSAN_SPEC "-ltsan" STATIC_LIBTSAN_LIBS
721 #endif
722 #endif
724 #ifndef LIBTSAN_EARLY_SPEC
725 #define LIBTSAN_EARLY_SPEC ""
726 #endif
728 #ifndef LIBLSAN_SPEC
729 #define STATIC_LIBLSAN_LIBS \
730 " %{static-liblsan|static:%:include(libsanitizer.spec)%(link_liblsan)}"
731 #ifdef LIBLSAN_EARLY_SPEC
732 #define LIBLSAN_SPEC STATIC_LIBLSAN_LIBS
733 #elif defined(HAVE_LD_STATIC_DYNAMIC)
734 #define LIBLSAN_SPEC "%{static-liblsan:" LD_STATIC_OPTION \
735 "} -llsan %{static-liblsan:" LD_DYNAMIC_OPTION "}" \
736 STATIC_LIBLSAN_LIBS
737 #else
738 #define LIBLSAN_SPEC "-llsan" STATIC_LIBLSAN_LIBS
739 #endif
740 #endif
742 #ifndef LIBLSAN_EARLY_SPEC
743 #define LIBLSAN_EARLY_SPEC ""
744 #endif
746 #ifndef LIBUBSAN_SPEC
747 #define STATIC_LIBUBSAN_LIBS \
748 " %{static-libubsan|static:%:include(libsanitizer.spec)%(link_libubsan)}"
749 #ifdef HAVE_LD_STATIC_DYNAMIC
750 #define LIBUBSAN_SPEC "%{static-libubsan:" LD_STATIC_OPTION \
751 "} -lubsan %{static-libubsan:" LD_DYNAMIC_OPTION "}" \
752 STATIC_LIBUBSAN_LIBS
753 #else
754 #define LIBUBSAN_SPEC "-lubsan" STATIC_LIBUBSAN_LIBS
755 #endif
756 #endif
758 /* Linker options for compressed debug sections. */
759 #if HAVE_LD_COMPRESS_DEBUG == 0
760 /* No linker support. */
761 #define LINK_COMPRESS_DEBUG_SPEC \
762 " %{gz*:%e-gz is not supported in this configuration} "
763 #elif HAVE_LD_COMPRESS_DEBUG == 1
764 /* GNU style on input, GNU ld options. Reject, not useful. */
765 #define LINK_COMPRESS_DEBUG_SPEC \
766 " %{gz*:%e-gz is not supported in this configuration} "
767 #elif HAVE_LD_COMPRESS_DEBUG == 2
768 /* GNU style, GNU gold options. */
769 #define LINK_COMPRESS_DEBUG_SPEC \
770 " %{gz|gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
771 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
772 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
773 #elif HAVE_LD_COMPRESS_DEBUG == 3
774 /* ELF gABI style. */
775 #define LINK_COMPRESS_DEBUG_SPEC \
776 " %{gz|gz=zlib:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
777 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
778 " %{gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
779 #else
780 #error Unknown value for HAVE_LD_COMPRESS_DEBUG.
781 #endif
783 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
784 included. */
785 #ifndef LIBGCC_SPEC
786 #if defined(REAL_LIBGCC_SPEC)
787 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
788 #elif defined(LINK_LIBGCC_SPECIAL_1)
789 /* Have gcc do the search for libgcc.a. */
790 #define LIBGCC_SPEC "libgcc.a%s"
791 #else
792 #define LIBGCC_SPEC "-lgcc"
793 #endif
794 #endif
796 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
797 #ifndef STARTFILE_SPEC
798 #define STARTFILE_SPEC \
799 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
800 #endif
802 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
803 #ifndef ENDFILE_SPEC
804 #define ENDFILE_SPEC ""
805 #endif
807 #ifndef LINKER_NAME
808 #define LINKER_NAME "collect2"
809 #endif
811 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
812 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
813 #else
814 #define ASM_MAP ""
815 #endif
817 /* Assembler options for compressed debug sections. */
818 #if HAVE_LD_COMPRESS_DEBUG < 2
819 /* Reject if the linker cannot write compressed debug sections. */
820 #define ASM_COMPRESS_DEBUG_SPEC \
821 " %{gz*:%e-gz is not supported in this configuration} "
822 #else /* HAVE_LD_COMPRESS_DEBUG >= 2 */
823 #if HAVE_AS_COMPRESS_DEBUG == 0
824 /* No assembler support. Ignore silently. */
825 #define ASM_COMPRESS_DEBUG_SPEC \
826 " %{gz*:} "
827 #elif HAVE_AS_COMPRESS_DEBUG == 1
828 /* GNU style, GNU as options. */
829 #define ASM_COMPRESS_DEBUG_SPEC \
830 " %{gz|gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "}" \
831 " %{gz=none:" AS_NO_COMPRESS_DEBUG_OPTION "}" \
832 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
833 #elif HAVE_AS_COMPRESS_DEBUG == 2
834 /* ELF gABI style. */
835 #define ASM_COMPRESS_DEBUG_SPEC \
836 " %{gz|gz=zlib:" AS_COMPRESS_DEBUG_OPTION "=zlib}" \
837 " %{gz=none:" AS_COMPRESS_DEBUG_OPTION "=none}" \
838 " %{gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
839 #else
840 #error Unknown value for HAVE_AS_COMPRESS_DEBUG.
841 #endif
842 #endif /* HAVE_LD_COMPRESS_DEBUG >= 2 */
844 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
845 to the assembler. */
846 #ifndef ASM_DEBUG_SPEC
847 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
848 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
849 # define ASM_DEBUG_SPEC \
850 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
851 ? "%{%:debug-level-gt(0):" \
852 "%{gdwarf*:--gdwarf2}%{!gdwarf*:%{g*:--gstabs}}}" ASM_MAP \
853 : "%{%:debug-level-gt(0):" \
854 "%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
855 # else
856 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
857 # define ASM_DEBUG_SPEC "%{g*:%{%:debug-level-gt(0):--gstabs}}" ASM_MAP
858 # endif
859 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
860 # define ASM_DEBUG_SPEC "%{g*:%{%:debug-level-gt(0):--gdwarf2}}" ASM_MAP
861 # endif
862 # endif
863 #endif
864 #ifndef ASM_DEBUG_SPEC
865 # define ASM_DEBUG_SPEC ""
866 #endif
868 /* Here is the spec for running the linker, after compiling all files. */
870 /* This is overridable by the target in case they need to specify the
871 -lgcc and -lc order specially, yet not require them to override all
872 of LINK_COMMAND_SPEC. */
873 #ifndef LINK_GCC_C_SEQUENCE_SPEC
874 #define LINK_GCC_C_SEQUENCE_SPEC "%G %{!nolibc:%L %G}"
875 #endif
877 #ifndef LINK_SSP_SPEC
878 #ifdef TARGET_LIBC_PROVIDES_SSP
879 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
880 "|fstack-protector-strong|fstack-protector-explicit:}"
881 #else
882 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
883 "|fstack-protector-strong|fstack-protector-explicit" \
884 ":-lssp_nonshared -lssp}"
885 #endif
886 #endif
888 #ifdef ENABLE_DEFAULT_PIE
889 #define PIE_SPEC "!no-pie"
890 #define NO_FPIE1_SPEC "fno-pie"
891 #define FPIE1_SPEC NO_FPIE1_SPEC ":;"
892 #define NO_FPIE2_SPEC "fno-PIE"
893 #define FPIE2_SPEC NO_FPIE2_SPEC ":;"
894 #define NO_FPIE_SPEC NO_FPIE1_SPEC "|" NO_FPIE2_SPEC
895 #define FPIE_SPEC NO_FPIE_SPEC ":;"
896 #define NO_FPIC1_SPEC "fno-pic"
897 #define FPIC1_SPEC NO_FPIC1_SPEC ":;"
898 #define NO_FPIC2_SPEC "fno-PIC"
899 #define FPIC2_SPEC NO_FPIC2_SPEC ":;"
900 #define NO_FPIC_SPEC NO_FPIC1_SPEC "|" NO_FPIC2_SPEC
901 #define FPIC_SPEC NO_FPIC_SPEC ":;"
902 #define NO_FPIE1_AND_FPIC1_SPEC NO_FPIE1_SPEC "|" NO_FPIC1_SPEC
903 #define FPIE1_OR_FPIC1_SPEC NO_FPIE1_AND_FPIC1_SPEC ":;"
904 #define NO_FPIE2_AND_FPIC2_SPEC NO_FPIE2_SPEC "|" NO_FPIC2_SPEC
905 #define FPIE2_OR_FPIC2_SPEC NO_FPIE2_AND_FPIC2_SPEC ":;"
906 #define NO_FPIE_AND_FPIC_SPEC NO_FPIE_SPEC "|" NO_FPIC_SPEC
907 #define FPIE_OR_FPIC_SPEC NO_FPIE_AND_FPIC_SPEC ":;"
908 #else
909 #define PIE_SPEC "pie"
910 #define FPIE1_SPEC "fpie"
911 #define NO_FPIE1_SPEC FPIE1_SPEC ":;"
912 #define FPIE2_SPEC "fPIE"
913 #define NO_FPIE2_SPEC FPIE2_SPEC ":;"
914 #define FPIE_SPEC FPIE1_SPEC "|" FPIE2_SPEC
915 #define NO_FPIE_SPEC FPIE_SPEC ":;"
916 #define FPIC1_SPEC "fpic"
917 #define NO_FPIC1_SPEC FPIC1_SPEC ":;"
918 #define FPIC2_SPEC "fPIC"
919 #define NO_FPIC2_SPEC FPIC2_SPEC ":;"
920 #define FPIC_SPEC FPIC1_SPEC "|" FPIC2_SPEC
921 #define NO_FPIC_SPEC FPIC_SPEC ":;"
922 #define FPIE1_OR_FPIC1_SPEC FPIE1_SPEC "|" FPIC1_SPEC
923 #define NO_FPIE1_AND_FPIC1_SPEC FPIE1_OR_FPIC1_SPEC ":;"
924 #define FPIE2_OR_FPIC2_SPEC FPIE2_SPEC "|" FPIC2_SPEC
925 #define NO_FPIE2_AND_FPIC2_SPEC FPIE1_OR_FPIC2_SPEC ":;"
926 #define FPIE_OR_FPIC_SPEC FPIE_SPEC "|" FPIC_SPEC
927 #define NO_FPIE_AND_FPIC_SPEC FPIE_OR_FPIC_SPEC ":;"
928 #endif
930 #ifndef LINK_PIE_SPEC
931 #ifdef HAVE_LD_PIE
932 #ifndef LD_PIE_SPEC
933 #define LD_PIE_SPEC "-pie"
934 #endif
935 #else
936 #define LD_PIE_SPEC ""
937 #endif
938 #define LINK_PIE_SPEC "%{static|shared|r:;" PIE_SPEC ":" LD_PIE_SPEC "} "
939 #endif
941 #ifndef LINK_BUILDID_SPEC
942 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
943 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
944 # endif
945 #endif
947 /* Conditional to test whether the LTO plugin is used or not.
948 FIXME: For slim LTO we will need to enable plugin unconditionally. This
949 still cause problems with PLUGIN_LD != LD and when plugin is built but
950 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
951 plugin only when LTO is enabled. We still honor explicit
952 -fuse-linker-plugin if the linker used understands -plugin. */
954 /* The linker has some plugin support. */
955 #if HAVE_LTO_PLUGIN > 0
956 /* The linker used has full plugin support, use LTO plugin by default. */
957 #if HAVE_LTO_PLUGIN == 2
958 #define PLUGIN_COND "!fno-use-linker-plugin:%{!fno-lto"
959 #define PLUGIN_COND_CLOSE "}"
960 #else
961 /* The linker used has limited plugin support, use LTO plugin with explicit
962 -fuse-linker-plugin. */
963 #define PLUGIN_COND "fuse-linker-plugin"
964 #define PLUGIN_COND_CLOSE ""
965 #endif
966 #define LINK_PLUGIN_SPEC \
967 "%{" PLUGIN_COND": \
968 -plugin %(linker_plugin_file) \
969 -plugin-opt=%(lto_wrapper) \
970 -plugin-opt=-fresolution=%u.res \
971 %{flinker-output=*:-plugin-opt=-linker-output-known} \
972 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
973 }" PLUGIN_COND_CLOSE
974 #else
975 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
976 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
977 %e-fuse-linker-plugin is not supported in this configuration}"
978 #endif
980 /* Linker command line options for -fsanitize= early on the command line. */
981 #ifndef SANITIZER_EARLY_SPEC
982 #define SANITIZER_EARLY_SPEC "\
983 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_EARLY_SPEC "} \
984 %{%:sanitize(thread):" LIBTSAN_EARLY_SPEC "} \
985 %{%:sanitize(leak):" LIBLSAN_EARLY_SPEC "}}}"
986 #endif
988 /* Linker command line options for -fsanitize= late on the command line. */
989 #ifndef SANITIZER_SPEC
990 #define SANITIZER_SPEC "\
991 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_SPEC "\
992 %{static:%ecannot specify -static with -fsanitize=address}}\
993 %{%:sanitize(thread):" LIBTSAN_SPEC "\
994 %{static:%ecannot specify -static with -fsanitize=thread}}\
995 %{%:sanitize(undefined):" LIBUBSAN_SPEC "}\
996 %{%:sanitize(leak):" LIBLSAN_SPEC "}}}"
997 #endif
999 #ifndef POST_LINK_SPEC
1000 #define POST_LINK_SPEC ""
1001 #endif
1003 /* This is the spec to use, once the code for creating the vtable
1004 verification runtime library, libvtv.so, has been created. Currently
1005 the vtable verification runtime functions are in libstdc++, so we use
1006 the spec just below this one. */
1007 #ifndef VTABLE_VERIFICATION_SPEC
1008 #if ENABLE_VTABLE_VERIFY
1009 #define VTABLE_VERIFICATION_SPEC "\
1010 %{!nostdlib:%{fvtable-verify=std: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}\
1011 %{fvtable-verify=preinit: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}}"
1012 #else
1013 #define VTABLE_VERIFICATION_SPEC "\
1014 %{fvtable-verify=none:} \
1015 %{fvtable-verify=std: \
1016 %e-fvtable-verify=std is not supported in this configuration} \
1017 %{fvtable-verify=preinit: \
1018 %e-fvtable-verify=preinit is not supported in this configuration}"
1019 #endif
1020 #endif
1022 /* -u* was put back because both BSD and SysV seem to support it. */
1023 /* %{static|no-pie|static-pie:} simply prevents an error message:
1024 1. If the target machine doesn't handle -static.
1025 2. If PIE isn't enabled by default.
1026 3. If the target machine doesn't handle -static-pie.
1028 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
1029 scripts which exist in user specified directories, or in standard
1030 directories. */
1031 /* We pass any -flto flags on to the linker, which is expected
1032 to understand them. In practice, this means it had better be collect2. */
1033 /* %{e*} includes -export-dynamic; see comment in common.opt. */
1034 #ifndef LINK_COMMAND_SPEC
1035 #define LINK_COMMAND_SPEC "\
1036 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
1037 %(linker) " \
1038 LINK_PLUGIN_SPEC \
1039 "%{flto|flto=*:%<fcompare-debug*} \
1040 %{flto} %{fno-lto} %{flto=*} %l " LINK_PIE_SPEC \
1041 "%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
1042 "%X %{o*} %{e*} %{N} %{n} %{r}\
1043 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}} \
1044 %{static|no-pie|static-pie:} %@{L*} %(mfwrap) %(link_libgcc) " \
1045 VTABLE_VERIFICATION_SPEC " " SANITIZER_EARLY_SPEC " %o "" \
1046 %{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1):\
1047 %:include(libgomp.spec)%(link_gomp)}\
1048 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
1049 %(mflib) " STACK_SPLIT_SPEC "\
1050 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
1051 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
1052 %{!nostdlib:%{!nostartfiles:%E}} %{T*} \n%(post_link) }}}}}}"
1053 #endif
1055 #ifndef LINK_LIBGCC_SPEC
1056 /* Generate -L options for startfile prefix list. */
1057 # define LINK_LIBGCC_SPEC "%D"
1058 #endif
1060 #ifndef STARTFILE_PREFIX_SPEC
1061 # define STARTFILE_PREFIX_SPEC ""
1062 #endif
1064 #ifndef SYSROOT_SPEC
1065 # define SYSROOT_SPEC "--sysroot=%R"
1066 #endif
1068 #ifndef SYSROOT_SUFFIX_SPEC
1069 # define SYSROOT_SUFFIX_SPEC ""
1070 #endif
1072 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
1073 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
1074 #endif
1076 static const char *asm_debug = ASM_DEBUG_SPEC;
1077 static const char *cpp_spec = CPP_SPEC;
1078 static const char *cc1_spec = CC1_SPEC;
1079 static const char *cc1plus_spec = CC1PLUS_SPEC;
1080 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
1081 static const char *link_ssp_spec = LINK_SSP_SPEC;
1082 static const char *asm_spec = ASM_SPEC;
1083 static const char *asm_final_spec = ASM_FINAL_SPEC;
1084 static const char *link_spec = LINK_SPEC;
1085 static const char *lib_spec = LIB_SPEC;
1086 static const char *link_gomp_spec = "";
1087 static const char *libgcc_spec = LIBGCC_SPEC;
1088 static const char *endfile_spec = ENDFILE_SPEC;
1089 static const char *startfile_spec = STARTFILE_SPEC;
1090 static const char *linker_name_spec = LINKER_NAME;
1091 static const char *linker_plugin_file_spec = "";
1092 static const char *lto_wrapper_spec = "";
1093 static const char *lto_gcc_spec = "";
1094 static const char *post_link_spec = POST_LINK_SPEC;
1095 static const char *link_command_spec = LINK_COMMAND_SPEC;
1096 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
1097 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
1098 static const char *sysroot_spec = SYSROOT_SPEC;
1099 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
1100 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
1101 static const char *self_spec = "";
1103 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
1104 There should be no need to override these in target dependent files,
1105 but we need to copy them to the specs file so that newer versions
1106 of the GCC driver can correctly drive older tool chains with the
1107 appropriate -B options. */
1109 /* When cpplib handles traditional preprocessing, get rid of this, and
1110 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
1111 that we default the front end language better. */
1112 static const char *trad_capable_cpp =
1113 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
1115 /* We don't wrap .d files in %W{} since a missing .d file, and
1116 therefore no dependency entry, confuses make into thinking a .o
1117 file that happens to exist is up-to-date. */
1118 static const char *cpp_unique_options =
1119 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %@{I*&F*} %{P} %I\
1120 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
1121 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
1122 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
1123 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
1124 %{remap} %{g3|ggdb3|gstabs3|gxcoff3|gvms3:-dD}\
1125 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1126 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
1127 %{E|M|MM:%W{o*}}";
1129 /* This contains cpp options which are common with cc1_options and are passed
1130 only when preprocessing only to avoid duplication. We pass the cc1 spec
1131 options to the preprocessor so that it the cc1 spec may manipulate
1132 options used to set target flags. Those special target flags settings may
1133 in turn cause preprocessor symbols to be defined specially. */
1134 static const char *cpp_options =
1135 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
1136 %{f*} %{g*:%{%:debug-level-gt(0):%{g*}\
1137 %{!fno-working-directory:-fworking-directory}}} %{O*}\
1138 %{undef} %{save-temps*:-fpch-preprocess}";
1140 /* This contains cpp options which are not passed when the preprocessor
1141 output will be used by another program. */
1142 static const char *cpp_debug_options = "%{d*}";
1144 /* NB: This is shared amongst all front-ends, except for Ada. */
1145 static const char *cc1_options =
1146 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
1147 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1148 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
1149 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
1150 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
1151 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
1152 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
1153 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
1154 %{-target-help:--target-help}\
1155 %{-version:--version}\
1156 %{-help=*:--help=%*}\
1157 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
1158 %{fsyntax-only:-o %j} %{-param*}\
1159 %{coverage:-fprofile-arcs -ftest-coverage}\
1160 %{fprofile-arcs|fprofile-generate*|coverage:\
1161 %{!fprofile-update=single:\
1162 %{pthread:-fprofile-update=prefer-atomic}}}";
1164 static const char *asm_options =
1165 "%{-target-help:%:print-asm-header()} "
1166 #if HAVE_GNU_AS
1167 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
1168 to the assembler equivalents. */
1169 "%{v} %{w:-W} %{I*} "
1170 #endif
1171 ASM_COMPRESS_DEBUG_SPEC
1172 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
1174 static const char *invoke_as =
1175 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1176 "%{!fwpa*:\
1177 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1178 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
1180 #else
1181 "%{!fwpa*:\
1182 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1183 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
1185 #endif
1187 /* Some compilers have limits on line lengths, and the multilib_select
1188 and/or multilib_matches strings can be very long, so we build them at
1189 run time. */
1190 static struct obstack multilib_obstack;
1191 static const char *multilib_select;
1192 static const char *multilib_matches;
1193 static const char *multilib_defaults;
1194 static const char *multilib_exclusions;
1195 static const char *multilib_reuse;
1197 /* Check whether a particular argument is a default argument. */
1199 #ifndef MULTILIB_DEFAULTS
1200 #define MULTILIB_DEFAULTS { "" }
1201 #endif
1203 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
1205 #ifndef DRIVER_SELF_SPECS
1206 #define DRIVER_SELF_SPECS ""
1207 #endif
1209 /* Linking to libgomp implies pthreads. This is particularly important
1210 for targets that use different start files and suchlike. */
1211 #ifndef GOMP_SELF_SPECS
1212 #define GOMP_SELF_SPECS \
1213 "%{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1): " \
1214 "-pthread}"
1215 #endif
1217 /* Likewise for -fgnu-tm. */
1218 #ifndef GTM_SELF_SPECS
1219 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
1220 #endif
1222 static const char *const driver_self_specs[] = {
1223 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
1224 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS
1227 #ifndef OPTION_DEFAULT_SPECS
1228 #define OPTION_DEFAULT_SPECS { "", "" }
1229 #endif
1231 struct default_spec
1233 const char *name;
1234 const char *spec;
1237 static const struct default_spec
1238 option_default_specs[] = { OPTION_DEFAULT_SPECS };
1240 struct user_specs
1242 struct user_specs *next;
1243 const char *filename;
1246 static struct user_specs *user_specs_head, *user_specs_tail;
1249 /* Record the mapping from file suffixes for compilation specs. */
1251 struct compiler
1253 const char *suffix; /* Use this compiler for input files
1254 whose names end in this suffix. */
1256 const char *spec; /* To use this compiler, run this spec. */
1258 const char *cpp_spec; /* If non-NULL, substitute this spec
1259 for `%C', rather than the usual
1260 cpp_spec. */
1261 int combinable; /* If nonzero, compiler can deal with
1262 multiple source files at once (IMA). */
1263 int needs_preprocessing; /* If nonzero, source files need to
1264 be run through a preprocessor. */
1267 /* Pointer to a vector of `struct compiler' that gives the spec for
1268 compiling a file, based on its suffix.
1269 A file that does not end in any of these suffixes will be passed
1270 unchanged to the loader and nothing else will be done to it.
1272 An entry containing two 0s is used to terminate the vector.
1274 If multiple entries match a file, the last matching one is used. */
1276 static struct compiler *compilers;
1278 /* Number of entries in `compilers', not counting the null terminator. */
1280 static int n_compilers;
1282 /* The default list of file name suffixes and their compilation specs. */
1284 static const struct compiler default_compilers[] =
1286 /* Add lists of suffixes of known languages here. If those languages
1287 were not present when we built the driver, we will hit these copies
1288 and be given a more meaningful error than "file not used since
1289 linking is not done". */
1290 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
1291 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
1292 {".mii", "#Objective-C++", 0, 0, 0},
1293 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
1294 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
1295 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
1296 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
1297 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
1298 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
1299 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
1300 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
1301 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
1302 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
1303 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
1304 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1305 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1306 {".r", "#Ratfor", 0, 0, 0},
1307 {".go", "#Go", 0, 1, 0},
1308 /* Next come the entries for C. */
1309 {".c", "@c", 0, 0, 1},
1310 {"@c",
1311 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1312 external preprocessor if -save-temps is given. */
1313 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1314 %{!E:%{!M:%{!MM:\
1315 %{traditional:\
1316 %eGNU C no longer supports -traditional without -E}\
1317 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1318 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1319 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1320 %(cc1_options)}\
1321 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1322 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1323 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1324 {"-",
1325 "%{!E:%e-E or -x required when input is from standard input}\
1326 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1327 {".h", "@c-header", 0, 0, 0},
1328 {"@c-header",
1329 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1330 external preprocessor if -save-temps is given. */
1331 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1332 %{!E:%{!M:%{!MM:\
1333 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1334 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1335 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1336 %(cc1_options)\
1337 %{!fsyntax-only:%{!S:-o %g.s} \
1338 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1339 %W{o*:--output-pch=%*}}%V}}\
1340 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1341 cc1 %(cpp_unique_options) %(cc1_options)\
1342 %{!fsyntax-only:%{!S:-o %g.s} \
1343 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1344 %W{o*:--output-pch=%*}}%V}}}}}}}", 0, 0, 0},
1345 {".i", "@cpp-output", 0, 0, 0},
1346 {"@cpp-output",
1347 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1348 {".s", "@assembler", 0, 0, 0},
1349 {"@assembler",
1350 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1351 {".sx", "@assembler-with-cpp", 0, 0, 0},
1352 {".S", "@assembler-with-cpp", 0, 0, 0},
1353 {"@assembler-with-cpp",
1354 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1355 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1356 %{E|M|MM:%(cpp_debug_options)}\
1357 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1358 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1359 #else
1360 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1361 %{E|M|MM:%(cpp_debug_options)}\
1362 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1363 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1364 #endif
1365 , 0, 0, 0},
1367 #include "specs.h"
1368 /* Mark end of table. */
1369 {0, 0, 0, 0, 0}
1372 /* Number of elements in default_compilers, not counting the terminator. */
1374 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1376 typedef char *char_p; /* For DEF_VEC_P. */
1378 /* A vector of options to give to the linker.
1379 These options are accumulated by %x,
1380 and substituted into the linker command with %X. */
1381 static vec<char_p> linker_options;
1383 /* A vector of options to give to the assembler.
1384 These options are accumulated by -Wa,
1385 and substituted into the assembler command with %Y. */
1386 static vec<char_p> assembler_options;
1388 /* A vector of options to give to the preprocessor.
1389 These options are accumulated by -Wp,
1390 and substituted into the preprocessor command with %Z. */
1391 static vec<char_p> preprocessor_options;
1393 static char *
1394 skip_whitespace (char *p)
1396 while (1)
1398 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1399 be considered whitespace. */
1400 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1401 return p + 1;
1402 else if (*p == '\n' || *p == ' ' || *p == '\t')
1403 p++;
1404 else if (*p == '#')
1406 while (*p != '\n')
1407 p++;
1408 p++;
1410 else
1411 break;
1414 return p;
1416 /* Structures to keep track of prefixes to try when looking for files. */
1418 struct prefix_list
1420 const char *prefix; /* String to prepend to the path. */
1421 struct prefix_list *next; /* Next in linked list. */
1422 int require_machine_suffix; /* Don't use without machine_suffix. */
1423 /* 2 means try both machine_suffix and just_machine_suffix. */
1424 int priority; /* Sort key - priority within list. */
1425 int os_multilib; /* 1 if OS multilib scheme should be used,
1426 0 for GCC multilib scheme. */
1429 struct path_prefix
1431 struct prefix_list *plist; /* List of prefixes to try */
1432 int max_len; /* Max length of a prefix in PLIST */
1433 const char *name; /* Name of this list (used in config stuff) */
1436 /* List of prefixes to try when looking for executables. */
1438 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1440 /* List of prefixes to try when looking for startup (crt0) files. */
1442 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1444 /* List of prefixes to try when looking for include files. */
1446 static struct path_prefix include_prefixes = { 0, 0, "include" };
1448 /* Suffix to attach to directories searched for commands.
1449 This looks like `MACHINE/VERSION/'. */
1451 static const char *machine_suffix = 0;
1453 /* Suffix to attach to directories searched for commands.
1454 This is just `MACHINE/'. */
1456 static const char *just_machine_suffix = 0;
1458 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1460 static const char *gcc_exec_prefix;
1462 /* Adjusted value of standard_libexec_prefix. */
1464 static const char *gcc_libexec_prefix;
1466 /* Default prefixes to attach to command names. */
1468 #ifndef STANDARD_STARTFILE_PREFIX_1
1469 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1470 #endif
1471 #ifndef STANDARD_STARTFILE_PREFIX_2
1472 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1473 #endif
1475 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1476 #undef MD_EXEC_PREFIX
1477 #undef MD_STARTFILE_PREFIX
1478 #undef MD_STARTFILE_PREFIX_1
1479 #endif
1481 /* If no prefixes defined, use the null string, which will disable them. */
1482 #ifndef MD_EXEC_PREFIX
1483 #define MD_EXEC_PREFIX ""
1484 #endif
1485 #ifndef MD_STARTFILE_PREFIX
1486 #define MD_STARTFILE_PREFIX ""
1487 #endif
1488 #ifndef MD_STARTFILE_PREFIX_1
1489 #define MD_STARTFILE_PREFIX_1 ""
1490 #endif
1492 /* These directories are locations set at configure-time based on the
1493 --prefix option provided to configure. Their initializers are
1494 defined in Makefile.in. These paths are not *directly* used when
1495 gcc_exec_prefix is set because, in that case, we know where the
1496 compiler has been installed, and use paths relative to that
1497 location instead. */
1498 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1499 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1500 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1501 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1503 /* For native compilers, these are well-known paths containing
1504 components that may be provided by the system. For cross
1505 compilers, these paths are not used. */
1506 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1507 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1508 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1509 static const char *const standard_startfile_prefix_1
1510 = STANDARD_STARTFILE_PREFIX_1;
1511 static const char *const standard_startfile_prefix_2
1512 = STANDARD_STARTFILE_PREFIX_2;
1514 /* A relative path to be used in finding the location of tools
1515 relative to the driver. */
1516 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1518 /* A prefix to be used when this is an accelerator compiler. */
1519 static const char *const accel_dir_suffix = ACCEL_DIR_SUFFIX;
1521 /* Subdirectory to use for locating libraries. Set by
1522 set_multilib_dir based on the compilation options. */
1524 static const char *multilib_dir;
1526 /* Subdirectory to use for locating libraries in OS conventions. Set by
1527 set_multilib_dir based on the compilation options. */
1529 static const char *multilib_os_dir;
1531 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1532 set_multilib_dir based on the compilation options. */
1534 static const char *multiarch_dir;
1536 /* Structure to keep track of the specs that have been defined so far.
1537 These are accessed using %(specname) in a compiler or link
1538 spec. */
1540 struct spec_list
1542 /* The following 2 fields must be first */
1543 /* to allow EXTRA_SPECS to be initialized */
1544 const char *name; /* name of the spec. */
1545 const char *ptr; /* available ptr if no static pointer */
1547 /* The following fields are not initialized */
1548 /* by EXTRA_SPECS */
1549 const char **ptr_spec; /* pointer to the spec itself. */
1550 struct spec_list *next; /* Next spec in linked list. */
1551 int name_len; /* length of the name */
1552 bool user_p; /* whether string come from file spec. */
1553 bool alloc_p; /* whether string was allocated */
1554 const char *default_ptr; /* The default value of *ptr_spec. */
1557 #define INIT_STATIC_SPEC(NAME,PTR) \
1558 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false, \
1559 *PTR }
1561 /* List of statically defined specs. */
1562 static struct spec_list static_specs[] =
1564 INIT_STATIC_SPEC ("asm", &asm_spec),
1565 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1566 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1567 INIT_STATIC_SPEC ("asm_options", &asm_options),
1568 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1569 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1570 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1571 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1572 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1573 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1574 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1575 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1576 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1577 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1578 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1579 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1580 INIT_STATIC_SPEC ("link", &link_spec),
1581 INIT_STATIC_SPEC ("lib", &lib_spec),
1582 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1583 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1584 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1585 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1586 INIT_STATIC_SPEC ("version", &compiler_version),
1587 INIT_STATIC_SPEC ("multilib", &multilib_select),
1588 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1589 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1590 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1591 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1592 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1593 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1594 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1595 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1596 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1597 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1598 INIT_STATIC_SPEC ("post_link", &post_link_spec),
1599 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1600 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1601 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1602 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1603 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1604 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1605 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1606 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1607 INIT_STATIC_SPEC ("self_spec", &self_spec),
1610 #ifdef EXTRA_SPECS /* additional specs needed */
1611 /* Structure to keep track of just the first two args of a spec_list.
1612 That is all that the EXTRA_SPECS macro gives us. */
1613 struct spec_list_1
1615 const char *const name;
1616 const char *const ptr;
1619 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1620 static struct spec_list *extra_specs = (struct spec_list *) 0;
1621 #endif
1623 /* List of dynamically allocates specs that have been defined so far. */
1625 static struct spec_list *specs = (struct spec_list *) 0;
1627 /* List of static spec functions. */
1629 static const struct spec_function static_spec_functions[] =
1631 { "getenv", getenv_spec_function },
1632 { "if-exists", if_exists_spec_function },
1633 { "if-exists-else", if_exists_else_spec_function },
1634 { "sanitize", sanitize_spec_function },
1635 { "replace-outfile", replace_outfile_spec_function },
1636 { "remove-outfile", remove_outfile_spec_function },
1637 { "version-compare", version_compare_spec_function },
1638 { "include", include_spec_function },
1639 { "find-file", find_file_spec_function },
1640 { "find-plugindir", find_plugindir_spec_function },
1641 { "print-asm-header", print_asm_header_spec_function },
1642 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1643 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1644 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1645 { "pass-through-libs", pass_through_libs_spec_func },
1646 { "replace-extension", replace_extension_spec_func },
1647 { "gt", greater_than_spec_func },
1648 { "debug-level-gt", debug_level_greater_than_spec_func },
1649 #ifdef EXTRA_SPEC_FUNCTIONS
1650 EXTRA_SPEC_FUNCTIONS
1651 #endif
1652 { 0, 0 }
1655 static int processing_spec_function;
1657 /* Add appropriate libgcc specs to OBSTACK, taking into account
1658 various permutations of -shared-libgcc, -shared, and such. */
1660 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1662 #ifndef USE_LD_AS_NEEDED
1663 #define USE_LD_AS_NEEDED 0
1664 #endif
1666 static void
1667 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1668 const char *static_name, const char *eh_name)
1670 char *buf;
1672 #if USE_LD_AS_NEEDED
1673 buf = concat ("%{static|static-libgcc|static-pie:", static_name, " ", eh_name, "}"
1674 "%{!static:%{!static-libgcc:%{!static-pie:"
1675 "%{!shared-libgcc:",
1676 static_name, " " LD_AS_NEEDED_OPTION " ",
1677 shared_name, " " LD_NO_AS_NEEDED_OPTION
1679 "%{shared-libgcc:",
1680 shared_name, "%{!shared: ", static_name, "}"
1681 "}}"
1682 #else
1683 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1684 "%{!static:%{!static-libgcc:"
1685 "%{!shared:"
1686 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1687 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1689 #ifdef LINK_EH_SPEC
1690 "%{shared:"
1691 "%{shared-libgcc:", shared_name, "}"
1692 "%{!shared-libgcc:", static_name, "}"
1694 #else
1695 "%{shared:", shared_name, "}"
1696 #endif
1697 #endif
1698 "}}", NULL);
1700 obstack_grow (obstack, buf, strlen (buf));
1701 free (buf);
1703 #endif /* ENABLE_SHARED_LIBGCC */
1705 /* Initialize the specs lookup routines. */
1707 static void
1708 init_spec (void)
1710 struct spec_list *next = (struct spec_list *) 0;
1711 struct spec_list *sl = (struct spec_list *) 0;
1712 int i;
1714 if (specs)
1715 return; /* Already initialized. */
1717 if (verbose_flag)
1718 fnotice (stderr, "Using built-in specs.\n");
1720 #ifdef EXTRA_SPECS
1721 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1723 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1725 sl = &extra_specs[i];
1726 sl->name = extra_specs_1[i].name;
1727 sl->ptr = extra_specs_1[i].ptr;
1728 sl->next = next;
1729 sl->name_len = strlen (sl->name);
1730 sl->ptr_spec = &sl->ptr;
1731 gcc_assert (sl->ptr_spec != NULL);
1732 sl->default_ptr = sl->ptr;
1733 next = sl;
1735 #endif
1737 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1739 sl = &static_specs[i];
1740 sl->next = next;
1741 next = sl;
1744 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1745 /* ??? If neither -shared-libgcc nor --static-libgcc was
1746 seen, then we should be making an educated guess. Some proposed
1747 heuristics for ELF include:
1749 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1750 program will be doing dynamic loading, which will likely
1751 need the shared libgcc.
1753 (2) If "-ldl", then it's also a fair bet that we're doing
1754 dynamic loading.
1756 (3) For each ET_DYN we're linking against (either through -lfoo
1757 or /some/path/foo.so), check to see whether it or one of
1758 its dependencies depends on a shared libgcc.
1760 (4) If "-shared"
1762 If the runtime is fixed to look for program headers instead
1763 of calling __register_frame_info at all, for each object,
1764 use the shared libgcc if any EH symbol referenced.
1766 If crtstuff is fixed to not invoke __register_frame_info
1767 automatically, for each object, use the shared libgcc if
1768 any non-empty unwind section found.
1770 Doing any of this probably requires invoking an external program to
1771 do the actual object file scanning. */
1773 const char *p = libgcc_spec;
1774 int in_sep = 1;
1776 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1777 when given the proper command line arguments. */
1778 while (*p)
1780 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1782 init_gcc_specs (&obstack,
1783 "-lgcc_s"
1784 #ifdef USE_LIBUNWIND_EXCEPTIONS
1785 " -lunwind"
1786 #endif
1788 "-lgcc",
1789 "-lgcc_eh"
1790 #ifdef USE_LIBUNWIND_EXCEPTIONS
1791 # ifdef HAVE_LD_STATIC_DYNAMIC
1792 " %{!static:%{!static-pie:" LD_STATIC_OPTION "}} -lunwind"
1793 " %{!static:%{!static-pie:" LD_DYNAMIC_OPTION "}}"
1794 # else
1795 " -lunwind"
1796 # endif
1797 #endif
1800 p += 5;
1801 in_sep = 0;
1803 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1805 /* Ug. We don't know shared library extensions. Hope that
1806 systems that use this form don't do shared libraries. */
1807 init_gcc_specs (&obstack,
1808 "-lgcc_s",
1809 "libgcc.a%s",
1810 "libgcc_eh.a%s"
1811 #ifdef USE_LIBUNWIND_EXCEPTIONS
1812 " -lunwind"
1813 #endif
1815 p += 10;
1816 in_sep = 0;
1818 else
1820 obstack_1grow (&obstack, *p);
1821 in_sep = (*p == ' ');
1822 p += 1;
1826 obstack_1grow (&obstack, '\0');
1827 libgcc_spec = XOBFINISH (&obstack, const char *);
1829 #endif
1830 #ifdef USE_AS_TRADITIONAL_FORMAT
1831 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1833 static const char tf[] = "--traditional-format ";
1834 obstack_grow (&obstack, tf, sizeof (tf) - 1);
1835 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1836 asm_spec = XOBFINISH (&obstack, const char *);
1838 #endif
1840 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1841 defined LINKER_HASH_STYLE
1842 # ifdef LINK_BUILDID_SPEC
1843 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1844 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof (LINK_BUILDID_SPEC) - 1);
1845 # endif
1846 # ifdef LINK_EH_SPEC
1847 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1848 obstack_grow (&obstack, LINK_EH_SPEC, sizeof (LINK_EH_SPEC) - 1);
1849 # endif
1850 # ifdef LINKER_HASH_STYLE
1851 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1852 before. */
1854 static const char hash_style[] = "--hash-style=";
1855 obstack_grow (&obstack, hash_style, sizeof (hash_style) - 1);
1856 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof (LINKER_HASH_STYLE) - 1);
1857 obstack_1grow (&obstack, ' ');
1859 # endif
1860 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1861 link_spec = XOBFINISH (&obstack, const char *);
1862 #endif
1864 specs = sl;
1867 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1868 removed; If the spec starts with a + then SPEC is added to the end of the
1869 current spec. */
1871 static void
1872 set_spec (const char *name, const char *spec, bool user_p)
1874 struct spec_list *sl;
1875 const char *old_spec;
1876 int name_len = strlen (name);
1877 int i;
1879 /* If this is the first call, initialize the statically allocated specs. */
1880 if (!specs)
1882 struct spec_list *next = (struct spec_list *) 0;
1883 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1885 sl = &static_specs[i];
1886 sl->next = next;
1887 next = sl;
1889 specs = sl;
1892 /* See if the spec already exists. */
1893 for (sl = specs; sl; sl = sl->next)
1894 if (name_len == sl->name_len && !strcmp (sl->name, name))
1895 break;
1897 if (!sl)
1899 /* Not found - make it. */
1900 sl = XNEW (struct spec_list);
1901 sl->name = xstrdup (name);
1902 sl->name_len = name_len;
1903 sl->ptr_spec = &sl->ptr;
1904 sl->alloc_p = 0;
1905 *(sl->ptr_spec) = "";
1906 sl->next = specs;
1907 sl->default_ptr = NULL;
1908 specs = sl;
1911 old_spec = *(sl->ptr_spec);
1912 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1913 ? concat (old_spec, spec + 1, NULL)
1914 : xstrdup (spec));
1916 #ifdef DEBUG_SPECS
1917 if (verbose_flag)
1918 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1919 #endif
1921 /* Free the old spec. */
1922 if (old_spec && sl->alloc_p)
1923 free (CONST_CAST (char *, old_spec));
1925 sl->user_p = user_p;
1926 sl->alloc_p = true;
1929 /* Accumulate a command (program name and args), and run it. */
1931 typedef const char *const_char_p; /* For DEF_VEC_P. */
1933 /* Vector of pointers to arguments in the current line of specifications. */
1934 static vec<const_char_p> argbuf;
1936 /* Likewise, but for the current @file. */
1937 static vec<const_char_p> at_file_argbuf;
1939 /* Whether an @file is currently open. */
1940 static bool in_at_file = false;
1942 /* Were the options -c, -S or -E passed. */
1943 static int have_c = 0;
1945 /* Was the option -o passed. */
1946 static int have_o = 0;
1948 /* Was the option -E passed. */
1949 static int have_E = 0;
1951 /* Pointer to output file name passed in with -o. */
1952 static const char *output_file = 0;
1954 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1955 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1956 it here. */
1958 static struct temp_name {
1959 const char *suffix; /* suffix associated with the code. */
1960 int length; /* strlen (suffix). */
1961 int unique; /* Indicates whether %g or %u/%U was used. */
1962 const char *filename; /* associated filename. */
1963 int filename_length; /* strlen (filename). */
1964 struct temp_name *next;
1965 } *temp_names;
1967 /* Number of commands executed so far. */
1969 static int execution_count;
1971 /* Number of commands that exited with a signal. */
1973 static int signal_count;
1975 /* Allocate the argument vector. */
1977 static void
1978 alloc_args (void)
1980 argbuf.create (10);
1981 at_file_argbuf.create (10);
1984 /* Clear out the vector of arguments (after a command is executed). */
1986 static void
1987 clear_args (void)
1989 argbuf.truncate (0);
1990 at_file_argbuf.truncate (0);
1993 /* Add one argument to the vector at the end.
1994 This is done when a space is seen or at the end of the line.
1995 If DELETE_ALWAYS is nonzero, the arg is a filename
1996 and the file should be deleted eventually.
1997 If DELETE_FAILURE is nonzero, the arg is a filename
1998 and the file should be deleted if this compilation fails. */
2000 static void
2001 store_arg (const char *arg, int delete_always, int delete_failure)
2003 if (in_at_file)
2004 at_file_argbuf.safe_push (arg);
2005 else
2006 argbuf.safe_push (arg);
2008 if (delete_always || delete_failure)
2010 const char *p;
2011 /* If the temporary file we should delete is specified as
2012 part of a joined argument extract the filename. */
2013 if (arg[0] == '-'
2014 && (p = strrchr (arg, '=')))
2015 arg = p + 1;
2016 record_temp_file (arg, delete_always, delete_failure);
2020 /* Open a temporary @file into which subsequent arguments will be stored. */
2022 static void
2023 open_at_file (void)
2025 if (in_at_file)
2026 fatal_error (input_location, "cannot open nested response file");
2027 else
2028 in_at_file = true;
2031 /* Close the temporary @file and add @file to the argument list. */
2033 static void
2034 close_at_file (void)
2036 if (!in_at_file)
2037 fatal_error (input_location, "cannot close nonexistent response file");
2039 in_at_file = false;
2041 const unsigned int n_args = at_file_argbuf.length ();
2042 if (n_args == 0)
2043 return;
2045 char **argv = (char **) alloca (sizeof (char *) * (n_args + 1));
2046 char *temp_file = make_temp_file ("");
2047 char *at_argument = concat ("@", temp_file, NULL);
2048 FILE *f = fopen (temp_file, "w");
2049 int status;
2050 unsigned int i;
2052 /* Copy the strings over. */
2053 for (i = 0; i < n_args; i++)
2054 argv[i] = CONST_CAST (char *, at_file_argbuf[i]);
2055 argv[i] = NULL;
2057 at_file_argbuf.truncate (0);
2059 if (f == NULL)
2060 fatal_error (input_location, "could not open temporary response file %s",
2061 temp_file);
2063 status = writeargv (argv, f);
2065 if (status)
2066 fatal_error (input_location,
2067 "could not write to temporary response file %s",
2068 temp_file);
2070 status = fclose (f);
2072 if (status == EOF)
2073 fatal_error (input_location, "could not close temporary response file %s",
2074 temp_file);
2076 store_arg (at_argument, 0, 0);
2078 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
2081 /* Load specs from a file name named FILENAME, replacing occurrences of
2082 various different types of line-endings, \r\n, \n\r and just \r, with
2083 a single \n. */
2085 static char *
2086 load_specs (const char *filename)
2088 int desc;
2089 int readlen;
2090 struct stat statbuf;
2091 char *buffer;
2092 char *buffer_p;
2093 char *specs;
2094 char *specs_p;
2096 if (verbose_flag)
2097 fnotice (stderr, "Reading specs from %s\n", filename);
2099 /* Open and stat the file. */
2100 desc = open (filename, O_RDONLY, 0);
2101 if (desc < 0)
2103 failed:
2104 /* This leaves DESC open, but the OS will save us. */
2105 fatal_error (input_location, "cannot read spec file %qs: %m", filename);
2108 if (stat (filename, &statbuf) < 0)
2109 goto failed;
2111 /* Read contents of file into BUFFER. */
2112 buffer = XNEWVEC (char, statbuf.st_size + 1);
2113 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
2114 if (readlen < 0)
2115 goto failed;
2116 buffer[readlen] = 0;
2117 close (desc);
2119 specs = XNEWVEC (char, readlen + 1);
2120 specs_p = specs;
2121 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
2123 int skip = 0;
2124 char c = *buffer_p;
2125 if (c == '\r')
2127 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
2128 skip = 1;
2129 else if (*(buffer_p + 1) == '\n') /* \r\n */
2130 skip = 1;
2131 else /* \r */
2132 c = '\n';
2134 if (! skip)
2135 *specs_p++ = c;
2137 *specs_p = '\0';
2139 free (buffer);
2140 return (specs);
2143 /* Read compilation specs from a file named FILENAME,
2144 replacing the default ones.
2146 A suffix which starts with `*' is a definition for
2147 one of the machine-specific sub-specs. The "suffix" should be
2148 *asm, *cc1, *cpp, *link, *startfile, etc.
2149 The corresponding spec is stored in asm_spec, etc.,
2150 rather than in the `compilers' vector.
2152 Anything invalid in the file is a fatal error. */
2154 static void
2155 read_specs (const char *filename, bool main_p, bool user_p)
2157 char *buffer;
2158 char *p;
2160 buffer = load_specs (filename);
2162 /* Scan BUFFER for specs, putting them in the vector. */
2163 p = buffer;
2164 while (1)
2166 char *suffix;
2167 char *spec;
2168 char *in, *out, *p1, *p2, *p3;
2170 /* Advance P in BUFFER to the next nonblank nocomment line. */
2171 p = skip_whitespace (p);
2172 if (*p == 0)
2173 break;
2175 /* Is this a special command that starts with '%'? */
2176 /* Don't allow this for the main specs file, since it would
2177 encourage people to overwrite it. */
2178 if (*p == '%' && !main_p)
2180 p1 = p;
2181 while (*p && *p != '\n')
2182 p++;
2184 /* Skip '\n'. */
2185 p++;
2187 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
2188 && (p1[sizeof "%include" - 1] == ' '
2189 || p1[sizeof "%include" - 1] == '\t'))
2191 char *new_filename;
2193 p1 += sizeof ("%include");
2194 while (*p1 == ' ' || *p1 == '\t')
2195 p1++;
2197 if (*p1++ != '<' || p[-2] != '>')
2198 fatal_error (input_location,
2199 "specs %%include syntax malformed after "
2200 "%ld characters",
2201 (long) (p1 - buffer + 1));
2203 p[-2] = '\0';
2204 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2205 read_specs (new_filename ? new_filename : p1, false, user_p);
2206 continue;
2208 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
2209 && (p1[sizeof "%include_noerr" - 1] == ' '
2210 || p1[sizeof "%include_noerr" - 1] == '\t'))
2212 char *new_filename;
2214 p1 += sizeof "%include_noerr";
2215 while (*p1 == ' ' || *p1 == '\t')
2216 p1++;
2218 if (*p1++ != '<' || p[-2] != '>')
2219 fatal_error (input_location,
2220 "specs %%include syntax malformed after "
2221 "%ld characters",
2222 (long) (p1 - buffer + 1));
2224 p[-2] = '\0';
2225 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2226 if (new_filename)
2227 read_specs (new_filename, false, user_p);
2228 else if (verbose_flag)
2229 fnotice (stderr, "could not find specs file %s\n", p1);
2230 continue;
2232 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
2233 && (p1[sizeof "%rename" - 1] == ' '
2234 || p1[sizeof "%rename" - 1] == '\t'))
2236 int name_len;
2237 struct spec_list *sl;
2238 struct spec_list *newsl;
2240 /* Get original name. */
2241 p1 += sizeof "%rename";
2242 while (*p1 == ' ' || *p1 == '\t')
2243 p1++;
2245 if (! ISALPHA ((unsigned char) *p1))
2246 fatal_error (input_location,
2247 "specs %%rename syntax malformed after "
2248 "%ld characters",
2249 (long) (p1 - buffer));
2251 p2 = p1;
2252 while (*p2 && !ISSPACE ((unsigned char) *p2))
2253 p2++;
2255 if (*p2 != ' ' && *p2 != '\t')
2256 fatal_error (input_location,
2257 "specs %%rename syntax malformed after "
2258 "%ld characters",
2259 (long) (p2 - buffer));
2261 name_len = p2 - p1;
2262 *p2++ = '\0';
2263 while (*p2 == ' ' || *p2 == '\t')
2264 p2++;
2266 if (! ISALPHA ((unsigned char) *p2))
2267 fatal_error (input_location,
2268 "specs %%rename syntax malformed after "
2269 "%ld characters",
2270 (long) (p2 - buffer));
2272 /* Get new spec name. */
2273 p3 = p2;
2274 while (*p3 && !ISSPACE ((unsigned char) *p3))
2275 p3++;
2277 if (p3 != p - 1)
2278 fatal_error (input_location,
2279 "specs %%rename syntax malformed after "
2280 "%ld characters",
2281 (long) (p3 - buffer));
2282 *p3 = '\0';
2284 for (sl = specs; sl; sl = sl->next)
2285 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2286 break;
2288 if (!sl)
2289 fatal_error (input_location,
2290 "specs %s spec was not found to be renamed", p1);
2292 if (strcmp (p1, p2) == 0)
2293 continue;
2295 for (newsl = specs; newsl; newsl = newsl->next)
2296 if (strcmp (newsl->name, p2) == 0)
2297 fatal_error (input_location,
2298 "%s: attempt to rename spec %qs to "
2299 "already defined spec %qs",
2300 filename, p1, p2);
2302 if (verbose_flag)
2304 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
2305 #ifdef DEBUG_SPECS
2306 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
2307 #endif
2310 set_spec (p2, *(sl->ptr_spec), user_p);
2311 if (sl->alloc_p)
2312 free (CONST_CAST (char *, *(sl->ptr_spec)));
2314 *(sl->ptr_spec) = "";
2315 sl->alloc_p = 0;
2316 continue;
2318 else
2319 fatal_error (input_location,
2320 "specs unknown %% command after %ld characters",
2321 (long) (p1 - buffer));
2324 /* Find the colon that should end the suffix. */
2325 p1 = p;
2326 while (*p1 && *p1 != ':' && *p1 != '\n')
2327 p1++;
2329 /* The colon shouldn't be missing. */
2330 if (*p1 != ':')
2331 fatal_error (input_location,
2332 "specs file malformed after %ld characters",
2333 (long) (p1 - buffer));
2335 /* Skip back over trailing whitespace. */
2336 p2 = p1;
2337 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2338 p2--;
2340 /* Copy the suffix to a string. */
2341 suffix = save_string (p, p2 - p);
2342 /* Find the next line. */
2343 p = skip_whitespace (p1 + 1);
2344 if (p[1] == 0)
2345 fatal_error (input_location,
2346 "specs file malformed after %ld characters",
2347 (long) (p - buffer));
2349 p1 = p;
2350 /* Find next blank line or end of string. */
2351 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2352 p1++;
2354 /* Specs end at the blank line and do not include the newline. */
2355 spec = save_string (p, p1 - p);
2356 p = p1;
2358 /* Delete backslash-newline sequences from the spec. */
2359 in = spec;
2360 out = spec;
2361 while (*in != 0)
2363 if (in[0] == '\\' && in[1] == '\n')
2364 in += 2;
2365 else if (in[0] == '#')
2366 while (*in && *in != '\n')
2367 in++;
2369 else
2370 *out++ = *in++;
2372 *out = 0;
2374 if (suffix[0] == '*')
2376 if (! strcmp (suffix, "*link_command"))
2377 link_command_spec = spec;
2378 else
2380 set_spec (suffix + 1, spec, user_p);
2381 free (spec);
2384 else
2386 /* Add this pair to the vector. */
2387 compilers
2388 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
2390 compilers[n_compilers].suffix = suffix;
2391 compilers[n_compilers].spec = spec;
2392 n_compilers++;
2393 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2396 if (*suffix == 0)
2397 link_command_spec = spec;
2400 if (link_command_spec == 0)
2401 fatal_error (input_location, "spec file has no spec for linking");
2403 XDELETEVEC (buffer);
2406 /* Record the names of temporary files we tell compilers to write,
2407 and delete them at the end of the run. */
2409 /* This is the common prefix we use to make temp file names.
2410 It is chosen once for each run of this program.
2411 It is substituted into a spec by %g or %j.
2412 Thus, all temp file names contain this prefix.
2413 In practice, all temp file names start with this prefix.
2415 This prefix comes from the envvar TMPDIR if it is defined;
2416 otherwise, from the P_tmpdir macro if that is defined;
2417 otherwise, in /usr/tmp or /tmp;
2418 or finally the current directory if all else fails. */
2420 static const char *temp_filename;
2422 /* Length of the prefix. */
2424 static int temp_filename_length;
2426 /* Define the list of temporary files to delete. */
2428 struct temp_file
2430 const char *name;
2431 struct temp_file *next;
2434 /* Queue of files to delete on success or failure of compilation. */
2435 static struct temp_file *always_delete_queue;
2436 /* Queue of files to delete on failure of compilation. */
2437 static struct temp_file *failure_delete_queue;
2439 /* Record FILENAME as a file to be deleted automatically.
2440 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2441 otherwise delete it in any case.
2442 FAIL_DELETE nonzero means delete it if a compilation step fails;
2443 otherwise delete it in any case. */
2445 void
2446 record_temp_file (const char *filename, int always_delete, int fail_delete)
2448 char *const name = xstrdup (filename);
2450 if (always_delete)
2452 struct temp_file *temp;
2453 for (temp = always_delete_queue; temp; temp = temp->next)
2454 if (! filename_cmp (name, temp->name))
2456 free (name);
2457 goto already1;
2460 temp = XNEW (struct temp_file);
2461 temp->next = always_delete_queue;
2462 temp->name = name;
2463 always_delete_queue = temp;
2465 already1:;
2468 if (fail_delete)
2470 struct temp_file *temp;
2471 for (temp = failure_delete_queue; temp; temp = temp->next)
2472 if (! filename_cmp (name, temp->name))
2474 free (name);
2475 goto already2;
2478 temp = XNEW (struct temp_file);
2479 temp->next = failure_delete_queue;
2480 temp->name = name;
2481 failure_delete_queue = temp;
2483 already2:;
2487 /* Delete all the temporary files whose names we previously recorded. */
2489 #ifndef DELETE_IF_ORDINARY
2490 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2491 do \
2493 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2494 if (unlink (NAME) < 0) \
2495 if (VERBOSE_FLAG) \
2496 error ("%s: %m", (NAME)); \
2497 } while (0)
2498 #endif
2500 static void
2501 delete_if_ordinary (const char *name)
2503 struct stat st;
2504 #ifdef DEBUG
2505 int i, c;
2507 printf ("Delete %s? (y or n) ", name);
2508 fflush (stdout);
2509 i = getchar ();
2510 if (i != '\n')
2511 while ((c = getchar ()) != '\n' && c != EOF)
2514 if (i == 'y' || i == 'Y')
2515 #endif /* DEBUG */
2516 DELETE_IF_ORDINARY (name, st, verbose_flag);
2519 static void
2520 delete_temp_files (void)
2522 struct temp_file *temp;
2524 for (temp = always_delete_queue; temp; temp = temp->next)
2525 delete_if_ordinary (temp->name);
2526 always_delete_queue = 0;
2529 /* Delete all the files to be deleted on error. */
2531 static void
2532 delete_failure_queue (void)
2534 struct temp_file *temp;
2536 for (temp = failure_delete_queue; temp; temp = temp->next)
2537 delete_if_ordinary (temp->name);
2540 static void
2541 clear_failure_queue (void)
2543 failure_delete_queue = 0;
2546 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2547 returns non-NULL.
2548 If DO_MULTI is true iterate over the paths twice, first with multilib
2549 suffix then without, otherwise iterate over the paths once without
2550 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2551 to avoid visiting the same path twice, but we could do better. For
2552 instance, /usr/lib/../lib is considered different from /usr/lib.
2553 At least EXTRA_SPACE chars past the end of the path passed to
2554 CALLBACK are available for use by the callback.
2555 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2557 Returns the value returned by CALLBACK. */
2559 static void *
2560 for_each_path (const struct path_prefix *paths,
2561 bool do_multi,
2562 size_t extra_space,
2563 void *(*callback) (char *, void *),
2564 void *callback_info)
2566 struct prefix_list *pl;
2567 const char *multi_dir = NULL;
2568 const char *multi_os_dir = NULL;
2569 const char *multiarch_suffix = NULL;
2570 const char *multi_suffix;
2571 const char *just_multi_suffix;
2572 char *path = NULL;
2573 void *ret = NULL;
2574 bool skip_multi_dir = false;
2575 bool skip_multi_os_dir = false;
2577 multi_suffix = machine_suffix;
2578 just_multi_suffix = just_machine_suffix;
2579 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2581 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2582 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2583 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2585 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2586 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2587 if (multiarch_dir)
2588 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2590 while (1)
2592 size_t multi_dir_len = 0;
2593 size_t multi_os_dir_len = 0;
2594 size_t multiarch_len = 0;
2595 size_t suffix_len;
2596 size_t just_suffix_len;
2597 size_t len;
2599 if (multi_dir)
2600 multi_dir_len = strlen (multi_dir);
2601 if (multi_os_dir)
2602 multi_os_dir_len = strlen (multi_os_dir);
2603 if (multiarch_suffix)
2604 multiarch_len = strlen (multiarch_suffix);
2605 suffix_len = strlen (multi_suffix);
2606 just_suffix_len = strlen (just_multi_suffix);
2608 if (path == NULL)
2610 len = paths->max_len + extra_space + 1;
2611 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2612 path = XNEWVEC (char, len);
2615 for (pl = paths->plist; pl != 0; pl = pl->next)
2617 len = strlen (pl->prefix);
2618 memcpy (path, pl->prefix, len);
2620 /* Look first in MACHINE/VERSION subdirectory. */
2621 if (!skip_multi_dir)
2623 memcpy (path + len, multi_suffix, suffix_len + 1);
2624 ret = callback (path, callback_info);
2625 if (ret)
2626 break;
2629 /* Some paths are tried with just the machine (ie. target)
2630 subdir. This is used for finding as, ld, etc. */
2631 if (!skip_multi_dir
2632 && pl->require_machine_suffix == 2)
2634 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2635 ret = callback (path, callback_info);
2636 if (ret)
2637 break;
2640 /* Now try the multiarch path. */
2641 if (!skip_multi_dir
2642 && !pl->require_machine_suffix && multiarch_dir)
2644 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2645 ret = callback (path, callback_info);
2646 if (ret)
2647 break;
2650 /* Now try the base path. */
2651 if (!pl->require_machine_suffix
2652 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2654 const char *this_multi;
2655 size_t this_multi_len;
2657 if (pl->os_multilib)
2659 this_multi = multi_os_dir;
2660 this_multi_len = multi_os_dir_len;
2662 else
2664 this_multi = multi_dir;
2665 this_multi_len = multi_dir_len;
2668 if (this_multi_len)
2669 memcpy (path + len, this_multi, this_multi_len + 1);
2670 else
2671 path[len] = '\0';
2673 ret = callback (path, callback_info);
2674 if (ret)
2675 break;
2678 if (pl)
2679 break;
2681 if (multi_dir == NULL && multi_os_dir == NULL)
2682 break;
2684 /* Run through the paths again, this time without multilibs.
2685 Don't repeat any we have already seen. */
2686 if (multi_dir)
2688 free (CONST_CAST (char *, multi_dir));
2689 multi_dir = NULL;
2690 free (CONST_CAST (char *, multi_suffix));
2691 multi_suffix = machine_suffix;
2692 free (CONST_CAST (char *, just_multi_suffix));
2693 just_multi_suffix = just_machine_suffix;
2695 else
2696 skip_multi_dir = true;
2697 if (multi_os_dir)
2699 free (CONST_CAST (char *, multi_os_dir));
2700 multi_os_dir = NULL;
2702 else
2703 skip_multi_os_dir = true;
2706 if (multi_dir)
2708 free (CONST_CAST (char *, multi_dir));
2709 free (CONST_CAST (char *, multi_suffix));
2710 free (CONST_CAST (char *, just_multi_suffix));
2712 if (multi_os_dir)
2713 free (CONST_CAST (char *, multi_os_dir));
2714 if (ret != path)
2715 free (path);
2716 return ret;
2719 /* Callback for build_search_list. Adds path to obstack being built. */
2721 struct add_to_obstack_info {
2722 struct obstack *ob;
2723 bool check_dir;
2724 bool first_time;
2727 static void *
2728 add_to_obstack (char *path, void *data)
2730 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2732 if (info->check_dir && !is_directory (path, false))
2733 return NULL;
2735 if (!info->first_time)
2736 obstack_1grow (info->ob, PATH_SEPARATOR);
2738 obstack_grow (info->ob, path, strlen (path));
2740 info->first_time = false;
2741 return NULL;
2744 /* Add or change the value of an environment variable, outputting the
2745 change to standard error if in verbose mode. */
2746 static void
2747 xputenv (const char *string)
2749 env.xput (string);
2752 /* Build a list of search directories from PATHS.
2753 PREFIX is a string to prepend to the list.
2754 If CHECK_DIR_P is true we ensure the directory exists.
2755 If DO_MULTI is true, multilib paths are output first, then
2756 non-multilib paths.
2757 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2758 It is also used by the --print-search-dirs flag. */
2760 static char *
2761 build_search_list (const struct path_prefix *paths, const char *prefix,
2762 bool check_dir, bool do_multi)
2764 struct add_to_obstack_info info;
2766 info.ob = &collect_obstack;
2767 info.check_dir = check_dir;
2768 info.first_time = true;
2770 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2771 obstack_1grow (&collect_obstack, '=');
2773 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2775 obstack_1grow (&collect_obstack, '\0');
2776 return XOBFINISH (&collect_obstack, char *);
2779 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2780 for collect. */
2782 static void
2783 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2784 bool do_multi)
2786 xputenv (build_search_list (paths, env_var, true, do_multi));
2789 /* Check whether NAME can be accessed in MODE. This is like access,
2790 except that it never considers directories to be executable. */
2792 static int
2793 access_check (const char *name, int mode)
2795 if (mode == X_OK)
2797 struct stat st;
2799 if (stat (name, &st) < 0
2800 || S_ISDIR (st.st_mode))
2801 return -1;
2804 return access (name, mode);
2807 /* Callback for find_a_file. Appends the file name to the directory
2808 path. If the resulting file exists in the right mode, return the
2809 full pathname to the file. */
2811 struct file_at_path_info {
2812 const char *name;
2813 const char *suffix;
2814 int name_len;
2815 int suffix_len;
2816 int mode;
2819 static void *
2820 file_at_path (char *path, void *data)
2822 struct file_at_path_info *info = (struct file_at_path_info *) data;
2823 size_t len = strlen (path);
2825 memcpy (path + len, info->name, info->name_len);
2826 len += info->name_len;
2828 /* Some systems have a suffix for executable files.
2829 So try appending that first. */
2830 if (info->suffix_len)
2832 memcpy (path + len, info->suffix, info->suffix_len + 1);
2833 if (access_check (path, info->mode) == 0)
2834 return path;
2837 path[len] = '\0';
2838 if (access_check (path, info->mode) == 0)
2839 return path;
2841 return NULL;
2844 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2845 access to check permissions. If DO_MULTI is true, search multilib
2846 paths then non-multilib paths, otherwise do not search multilib paths.
2847 Return 0 if not found, otherwise return its name, allocated with malloc. */
2849 static char *
2850 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2851 bool do_multi)
2853 struct file_at_path_info info;
2855 #ifdef DEFAULT_ASSEMBLER
2856 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2857 return xstrdup (DEFAULT_ASSEMBLER);
2858 #endif
2860 #ifdef DEFAULT_LINKER
2861 if (! strcmp (name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2862 return xstrdup (DEFAULT_LINKER);
2863 #endif
2865 /* Determine the filename to execute (special case for absolute paths). */
2867 if (IS_ABSOLUTE_PATH (name))
2869 if (access (name, mode) == 0)
2870 return xstrdup (name);
2872 return NULL;
2875 info.name = name;
2876 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2877 info.name_len = strlen (info.name);
2878 info.suffix_len = strlen (info.suffix);
2879 info.mode = mode;
2881 return (char*) for_each_path (pprefix, do_multi,
2882 info.name_len + info.suffix_len,
2883 file_at_path, &info);
2886 /* Ranking of prefixes in the sort list. -B prefixes are put before
2887 all others. */
2889 enum path_prefix_priority
2891 PREFIX_PRIORITY_B_OPT,
2892 PREFIX_PRIORITY_LAST
2895 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2896 order according to PRIORITY. Within each PRIORITY, new entries are
2897 appended.
2899 If WARN is nonzero, we will warn if no file is found
2900 through this prefix. WARN should point to an int
2901 which will be set to 1 if this entry is used.
2903 COMPONENT is the value to be passed to update_path.
2905 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2906 the complete value of machine_suffix.
2907 2 means try both machine_suffix and just_machine_suffix. */
2909 static void
2910 add_prefix (struct path_prefix *pprefix, const char *prefix,
2911 const char *component, /* enum prefix_priority */ int priority,
2912 int require_machine_suffix, int os_multilib)
2914 struct prefix_list *pl, **prev;
2915 int len;
2917 for (prev = &pprefix->plist;
2918 (*prev) != NULL && (*prev)->priority <= priority;
2919 prev = &(*prev)->next)
2922 /* Keep track of the longest prefix. */
2924 prefix = update_path (prefix, component);
2925 len = strlen (prefix);
2926 if (len > pprefix->max_len)
2927 pprefix->max_len = len;
2929 pl = XNEW (struct prefix_list);
2930 pl->prefix = prefix;
2931 pl->require_machine_suffix = require_machine_suffix;
2932 pl->priority = priority;
2933 pl->os_multilib = os_multilib;
2935 /* Insert after PREV. */
2936 pl->next = (*prev);
2937 (*prev) = pl;
2940 /* Same as add_prefix, but prepending target_system_root to prefix. */
2941 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2942 static void
2943 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2944 const char *component,
2945 /* enum prefix_priority */ int priority,
2946 int require_machine_suffix, int os_multilib)
2948 if (!IS_ABSOLUTE_PATH (prefix))
2949 fatal_error (input_location, "system path %qs is not absolute", prefix);
2951 if (target_system_root)
2953 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2954 size_t sysroot_len = strlen (target_system_root);
2956 if (sysroot_len > 0
2957 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2958 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2960 if (target_sysroot_suffix)
2961 prefix = concat (sysroot_no_trailing_dir_separator,
2962 target_sysroot_suffix, prefix, NULL);
2963 else
2964 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2966 free (sysroot_no_trailing_dir_separator);
2968 /* We have to override this because GCC's notion of sysroot
2969 moves along with GCC. */
2970 component = "GCC";
2973 add_prefix (pprefix, prefix, component, priority,
2974 require_machine_suffix, os_multilib);
2977 /* Execute the command specified by the arguments on the current line of spec.
2978 When using pipes, this includes several piped-together commands
2979 with `|' between them.
2981 Return 0 if successful, -1 if failed. */
2983 static int
2984 execute (void)
2986 int i;
2987 int n_commands; /* # of command. */
2988 char *string;
2989 struct pex_obj *pex;
2990 struct command
2992 const char *prog; /* program name. */
2993 const char **argv; /* vector of args. */
2995 const char *arg;
2997 struct command *commands; /* each command buffer with above info. */
2999 gcc_assert (!processing_spec_function);
3001 if (wrapper_string)
3003 string = find_a_file (&exec_prefixes,
3004 argbuf[0], X_OK, false);
3005 if (string)
3006 argbuf[0] = string;
3007 insert_wrapper (wrapper_string);
3010 /* Count # of piped commands. */
3011 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
3012 if (strcmp (arg, "|") == 0)
3013 n_commands++;
3015 /* Get storage for each command. */
3016 commands = (struct command *) alloca (n_commands * sizeof (struct command));
3018 /* Split argbuf into its separate piped processes,
3019 and record info about each one.
3020 Also search for the programs that are to be run. */
3022 argbuf.safe_push (0);
3024 commands[0].prog = argbuf[0]; /* first command. */
3025 commands[0].argv = argbuf.address ();
3027 if (!wrapper_string)
3029 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
3030 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
3033 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
3034 if (arg && strcmp (arg, "|") == 0)
3035 { /* each command. */
3036 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
3037 fatal_error (input_location, "-pipe not supported");
3038 #endif
3039 argbuf[i] = 0; /* Termination of
3040 command args. */
3041 commands[n_commands].prog = argbuf[i + 1];
3042 commands[n_commands].argv
3043 = &(argbuf.address ())[i + 1];
3044 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
3045 X_OK, false);
3046 if (string)
3047 commands[n_commands].argv[0] = string;
3048 n_commands++;
3051 /* If -v, print what we are about to do, and maybe query. */
3053 if (verbose_flag)
3055 /* For help listings, put a blank line between sub-processes. */
3056 if (print_help_list)
3057 fputc ('\n', stderr);
3059 /* Print each piped command as a separate line. */
3060 for (i = 0; i < n_commands; i++)
3062 const char *const *j;
3064 if (verbose_only_flag)
3066 for (j = commands[i].argv; *j; j++)
3068 const char *p;
3069 for (p = *j; *p; ++p)
3070 if (!ISALNUM ((unsigned char) *p)
3071 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
3072 break;
3073 if (*p || !*j)
3075 fprintf (stderr, " \"");
3076 for (p = *j; *p; ++p)
3078 if (*p == '"' || *p == '\\' || *p == '$')
3079 fputc ('\\', stderr);
3080 fputc (*p, stderr);
3082 fputc ('"', stderr);
3084 /* If it's empty, print "". */
3085 else if (!**j)
3086 fprintf (stderr, " \"\"");
3087 else
3088 fprintf (stderr, " %s", *j);
3091 else
3092 for (j = commands[i].argv; *j; j++)
3093 /* If it's empty, print "". */
3094 if (!**j)
3095 fprintf (stderr, " \"\"");
3096 else
3097 fprintf (stderr, " %s", *j);
3099 /* Print a pipe symbol after all but the last command. */
3100 if (i + 1 != n_commands)
3101 fprintf (stderr, " |");
3102 fprintf (stderr, "\n");
3104 fflush (stderr);
3105 if (verbose_only_flag != 0)
3107 /* verbose_only_flag should act as if the spec was
3108 executed, so increment execution_count before
3109 returning. This prevents spurious warnings about
3110 unused linker input files, etc. */
3111 execution_count++;
3112 return 0;
3114 #ifdef DEBUG
3115 fnotice (stderr, "\nGo ahead? (y or n) ");
3116 fflush (stderr);
3117 i = getchar ();
3118 if (i != '\n')
3119 while (getchar () != '\n')
3122 if (i != 'y' && i != 'Y')
3123 return 0;
3124 #endif /* DEBUG */
3127 #ifdef ENABLE_VALGRIND_CHECKING
3128 /* Run the each command through valgrind. To simplify prepending the
3129 path to valgrind and the option "-q" (for quiet operation unless
3130 something triggers), we allocate a separate argv array. */
3132 for (i = 0; i < n_commands; i++)
3134 const char **argv;
3135 int argc;
3136 int j;
3138 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
3141 argv = XALLOCAVEC (const char *, argc + 3);
3143 argv[0] = VALGRIND_PATH;
3144 argv[1] = "-q";
3145 for (j = 2; j < argc + 2; j++)
3146 argv[j] = commands[i].argv[j - 2];
3147 argv[j] = NULL;
3149 commands[i].argv = argv;
3150 commands[i].prog = argv[0];
3152 #endif
3154 /* Run each piped subprocess. */
3156 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
3157 ? PEX_RECORD_TIMES : 0),
3158 progname, temp_filename);
3159 if (pex == NULL)
3160 fatal_error (input_location, "pex_init failed: %m");
3162 for (i = 0; i < n_commands; i++)
3164 const char *errmsg;
3165 int err;
3166 const char *string = commands[i].argv[0];
3168 errmsg = pex_run (pex,
3169 ((i + 1 == n_commands ? PEX_LAST : 0)
3170 | (string == commands[i].prog ? PEX_SEARCH : 0)),
3171 string, CONST_CAST (char **, commands[i].argv),
3172 NULL, NULL, &err);
3173 if (errmsg != NULL)
3175 errno = err;
3176 fatal_error (input_location,
3177 err ? G_("cannot execute %qs: %s: %m")
3178 : G_("cannot execute %qs: %s"),
3179 string, errmsg);
3182 if (i && string != commands[i].prog)
3183 free (CONST_CAST (char *, string));
3186 execution_count++;
3188 /* Wait for all the subprocesses to finish. */
3191 int *statuses;
3192 struct pex_time *times = NULL;
3193 int ret_code = 0;
3195 statuses = (int *) alloca (n_commands * sizeof (int));
3196 if (!pex_get_status (pex, n_commands, statuses))
3197 fatal_error (input_location, "failed to get exit status: %m");
3199 if (report_times || report_times_to_file)
3201 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
3202 if (!pex_get_times (pex, n_commands, times))
3203 fatal_error (input_location, "failed to get process times: %m");
3206 pex_free (pex);
3208 for (i = 0; i < n_commands; ++i)
3210 int status = statuses[i];
3212 if (WIFSIGNALED (status))
3213 switch (WTERMSIG (status))
3215 case SIGINT:
3216 case SIGTERM:
3217 /* SIGQUIT and SIGKILL are not available on MinGW. */
3218 #ifdef SIGQUIT
3219 case SIGQUIT:
3220 #endif
3221 #ifdef SIGKILL
3222 case SIGKILL:
3223 #endif
3224 /* The user (or environment) did something to the
3225 inferior. Making this an ICE confuses the user into
3226 thinking there's a compiler bug. Much more likely is
3227 the user or OOM killer nuked it. */
3228 fatal_error (input_location,
3229 "%s signal terminated program %s",
3230 strsignal (WTERMSIG (status)),
3231 commands[i].prog);
3232 break;
3234 #ifdef SIGPIPE
3235 case SIGPIPE:
3236 /* SIGPIPE is a special case. It happens in -pipe mode
3237 when the compiler dies before the preprocessor is
3238 done, or the assembler dies before the compiler is
3239 done. There's generally been an error already, and
3240 this is just fallout. So don't generate another
3241 error unless we would otherwise have succeeded. */
3242 if (signal_count || greatest_status >= MIN_FATAL_STATUS)
3244 signal_count++;
3245 ret_code = -1;
3246 break;
3248 #endif
3249 /* FALLTHROUGH */
3251 default:
3252 /* The inferior failed to catch the signal. */
3253 internal_error_no_backtrace ("%s signal terminated program %s",
3254 strsignal (WTERMSIG (status)),
3255 commands[i].prog);
3257 else if (WIFEXITED (status)
3258 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
3260 /* For ICEs in cc1, cc1obj, cc1plus see if it is
3261 reproducible or not. */
3262 const char *p;
3263 if (flag_report_bug
3264 && WEXITSTATUS (status) == ICE_EXIT_CODE
3265 && i == 0
3266 && (p = strrchr (commands[0].argv[0], DIR_SEPARATOR))
3267 && ! strncmp (p + 1, "cc1", 3))
3268 try_generate_repro (commands[0].argv);
3269 if (WEXITSTATUS (status) > greatest_status)
3270 greatest_status = WEXITSTATUS (status);
3271 ret_code = -1;
3274 if (report_times || report_times_to_file)
3276 struct pex_time *pt = &times[i];
3277 double ut, st;
3279 ut = ((double) pt->user_seconds
3280 + (double) pt->user_microseconds / 1.0e6);
3281 st = ((double) pt->system_seconds
3282 + (double) pt->system_microseconds / 1.0e6);
3284 if (ut + st != 0)
3286 if (report_times)
3287 fnotice (stderr, "# %s %.2f %.2f\n",
3288 commands[i].prog, ut, st);
3290 if (report_times_to_file)
3292 int c = 0;
3293 const char *const *j;
3295 fprintf (report_times_to_file, "%g %g", ut, st);
3297 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
3299 const char *p;
3300 for (p = *j; *p; ++p)
3301 if (*p == '"' || *p == '\\' || *p == '$'
3302 || ISSPACE (*p))
3303 break;
3305 if (*p)
3307 fprintf (report_times_to_file, " \"");
3308 for (p = *j; *p; ++p)
3310 if (*p == '"' || *p == '\\' || *p == '$')
3311 fputc ('\\', report_times_to_file);
3312 fputc (*p, report_times_to_file);
3314 fputc ('"', report_times_to_file);
3316 else
3317 fprintf (report_times_to_file, " %s", *j);
3320 fputc ('\n', report_times_to_file);
3326 if (commands[0].argv[0] != commands[0].prog)
3327 free (CONST_CAST (char *, commands[0].argv[0]));
3329 return ret_code;
3333 /* Find all the switches given to us
3334 and make a vector describing them.
3335 The elements of the vector are strings, one per switch given.
3336 If a switch uses following arguments, then the `part1' field
3337 is the switch itself and the `args' field
3338 is a null-terminated vector containing the following arguments.
3339 Bits in the `live_cond' field are:
3340 SWITCH_LIVE to indicate this switch is true in a conditional spec.
3341 SWITCH_FALSE to indicate this switch is overridden by a later switch.
3342 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
3343 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored.
3344 SWITCH_KEEP_FOR_GCC to indicate that this switch, otherwise ignored,
3345 should be included in COLLECT_GCC_OPTIONS.
3346 in all do_spec calls afterwards. Used for %<S from self specs.
3347 The `known' field describes whether this is an internal switch.
3348 The `validated' field describes whether any spec has looked at this switch;
3349 if it remains false at the end of the run, the switch must be meaningless.
3350 The `ordering' field is used to temporarily mark switches that have to be
3351 kept in a specific order. */
3353 #define SWITCH_LIVE (1 << 0)
3354 #define SWITCH_FALSE (1 << 1)
3355 #define SWITCH_IGNORE (1 << 2)
3356 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
3357 #define SWITCH_KEEP_FOR_GCC (1 << 4)
3359 struct switchstr
3361 const char *part1;
3362 const char **args;
3363 unsigned int live_cond;
3364 bool known;
3365 bool validated;
3366 bool ordering;
3369 static struct switchstr *switches;
3371 static int n_switches;
3373 static int n_switches_alloc;
3375 /* Set to zero if -fcompare-debug is disabled, positive if it's
3376 enabled and we're running the first compilation, negative if it's
3377 enabled and we're running the second compilation. For most of the
3378 time, it's in the range -1..1, but it can be temporarily set to 2
3379 or 3 to indicate that the -fcompare-debug flags didn't come from
3380 the command-line, but rather from the GCC_COMPARE_DEBUG environment
3381 variable, until a synthesized -fcompare-debug flag is added to the
3382 command line. */
3383 int compare_debug;
3385 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
3386 int compare_debug_second;
3388 /* Set to the flags that should be passed to the second compilation in
3389 a -fcompare-debug compilation. */
3390 const char *compare_debug_opt;
3392 static struct switchstr *switches_debug_check[2];
3394 static int n_switches_debug_check[2];
3396 static int n_switches_alloc_debug_check[2];
3398 static char *debug_check_temp_file[2];
3400 /* Language is one of three things:
3402 1) The name of a real programming language.
3403 2) NULL, indicating that no one has figured out
3404 what it is yet.
3405 3) '*', indicating that the file should be passed
3406 to the linker. */
3407 struct infile
3409 const char *name;
3410 const char *language;
3411 struct compiler *incompiler;
3412 bool compiled;
3413 bool preprocessed;
3416 /* Also a vector of input files specified. */
3418 static struct infile *infiles;
3420 int n_infiles;
3422 static int n_infiles_alloc;
3424 /* True if undefined environment variables encountered during spec processing
3425 are ok to ignore, typically when we're running for --help or --version. */
3427 static bool spec_undefvar_allowed;
3429 /* True if multiple input files are being compiled to a single
3430 assembly file. */
3432 static bool combine_inputs;
3434 /* This counts the number of libraries added by lang_specific_driver, so that
3435 we can tell if there were any user supplied any files or libraries. */
3437 static int added_libraries;
3439 /* And a vector of corresponding output files is made up later. */
3441 const char **outfiles;
3443 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3445 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3446 is true if we should look for an executable suffix. DO_OBJ
3447 is true if we should look for an object suffix. */
3449 static const char *
3450 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3451 int do_obj ATTRIBUTE_UNUSED)
3453 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3454 int i;
3455 #endif
3456 int len;
3458 if (name == NULL)
3459 return NULL;
3461 len = strlen (name);
3463 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3464 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3465 if (do_obj && len > 2
3466 && name[len - 2] == '.'
3467 && name[len - 1] == 'o')
3469 obstack_grow (&obstack, name, len - 2);
3470 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3471 name = XOBFINISH (&obstack, const char *);
3473 #endif
3475 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3476 /* If there is no filetype, make it the executable suffix (which includes
3477 the "."). But don't get confused if we have just "-o". */
3478 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3479 return name;
3481 for (i = len - 1; i >= 0; i--)
3482 if (IS_DIR_SEPARATOR (name[i]))
3483 break;
3485 for (i++; i < len; i++)
3486 if (name[i] == '.')
3487 return name;
3489 obstack_grow (&obstack, name, len);
3490 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3491 strlen (TARGET_EXECUTABLE_SUFFIX));
3492 name = XOBFINISH (&obstack, const char *);
3493 #endif
3495 return name;
3497 #endif
3499 /* Display the command line switches accepted by gcc. */
3500 static void
3501 display_help (void)
3503 printf (_("Usage: %s [options] file...\n"), progname);
3504 fputs (_("Options:\n"), stdout);
3506 fputs (_(" -pass-exit-codes Exit with highest error code from a phase.\n"), stdout);
3507 fputs (_(" --help Display this information.\n"), stdout);
3508 fputs (_(" --target-help Display target specific command line options.\n"), stdout);
3509 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...].\n"), stdout);
3510 fputs (_(" Display specific types of command line options.\n"), stdout);
3511 if (! verbose_flag)
3512 fputs (_(" (Use '-v --help' to display command line options of sub-processes).\n"), stdout);
3513 fputs (_(" --version Display compiler version information.\n"), stdout);
3514 fputs (_(" -dumpspecs Display all of the built in spec strings.\n"), stdout);
3515 fputs (_(" -dumpversion Display the version of the compiler.\n"), stdout);
3516 fputs (_(" -dumpmachine Display the compiler's target processor.\n"), stdout);
3517 fputs (_(" -print-search-dirs Display the directories in the compiler's search path.\n"), stdout);
3518 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library.\n"), stdout);
3519 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>.\n"), stdout);
3520 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>.\n"), stdout);
3521 fputs (_("\
3522 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3523 a component in the library path.\n"), stdout);
3524 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc.\n"), stdout);
3525 fputs (_("\
3526 -print-multi-lib Display the mapping between command line options and\n\
3527 multiple library search directories.\n"), stdout);
3528 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries.\n"), stdout);
3529 fputs (_(" -print-sysroot Display the target libraries directory.\n"), stdout);
3530 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers.\n"), stdout);
3531 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler.\n"), stdout);
3532 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor.\n"), stdout);
3533 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker.\n"), stdout);
3534 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler.\n"), stdout);
3535 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor.\n"), stdout);
3536 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker.\n"), stdout);
3537 fputs (_(" -save-temps Do not delete intermediate files.\n"), stdout);
3538 fputs (_(" -save-temps=<arg> Do not delete intermediate files.\n"), stdout);
3539 fputs (_("\
3540 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3541 prefixes to other gcc components.\n"), stdout);
3542 fputs (_(" -pipe Use pipes rather than intermediate files.\n"), stdout);
3543 fputs (_(" -time Time the execution of each subprocess.\n"), stdout);
3544 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>.\n"), stdout);
3545 fputs (_(" -std=<standard> Assume that the input sources are for <standard>.\n"), stdout);
3546 fputs (_("\
3547 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3548 and libraries.\n"), stdout);
3549 fputs (_(" -B <directory> Add <directory> to the compiler's search paths.\n"), stdout);
3550 fputs (_(" -v Display the programs invoked by the compiler.\n"), stdout);
3551 fputs (_(" -### Like -v but options quoted and commands not executed.\n"), stdout);
3552 fputs (_(" -E Preprocess only; do not compile, assemble or link.\n"), stdout);
3553 fputs (_(" -S Compile only; do not assemble or link.\n"), stdout);
3554 fputs (_(" -c Compile and assemble, but do not link.\n"), stdout);
3555 fputs (_(" -o <file> Place the output into <file>.\n"), stdout);
3556 fputs (_(" -pie Create a dynamically linked position independent\n\
3557 executable.\n"), stdout);
3558 fputs (_(" -shared Create a shared library.\n"), stdout);
3559 fputs (_("\
3560 -x <language> Specify the language of the following input files.\n\
3561 Permissible languages include: c c++ assembler none\n\
3562 'none' means revert to the default behavior of\n\
3563 guessing the language based on the file's extension.\n\
3564 "), stdout);
3566 printf (_("\
3567 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3568 passed on to the various sub-processes invoked by %s. In order to pass\n\
3569 other options on to these processes the -W<letter> options must be used.\n\
3570 "), progname);
3572 /* The rest of the options are displayed by invocations of the various
3573 sub-processes. */
3576 static void
3577 add_preprocessor_option (const char *option, int len)
3579 preprocessor_options.safe_push (save_string (option, len));
3582 static void
3583 add_assembler_option (const char *option, int len)
3585 assembler_options.safe_push (save_string (option, len));
3588 static void
3589 add_linker_option (const char *option, int len)
3591 linker_options.safe_push (save_string (option, len));
3594 /* Allocate space for an input file in infiles. */
3596 static void
3597 alloc_infile (void)
3599 if (n_infiles_alloc == 0)
3601 n_infiles_alloc = 16;
3602 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3604 else if (n_infiles_alloc == n_infiles)
3606 n_infiles_alloc *= 2;
3607 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3611 /* Store an input file with the given NAME and LANGUAGE in
3612 infiles. */
3614 static void
3615 add_infile (const char *name, const char *language)
3617 alloc_infile ();
3618 infiles[n_infiles].name = name;
3619 infiles[n_infiles++].language = language;
3622 /* Allocate space for a switch in switches. */
3624 static void
3625 alloc_switch (void)
3627 if (n_switches_alloc == 0)
3629 n_switches_alloc = 16;
3630 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3632 else if (n_switches_alloc == n_switches)
3634 n_switches_alloc *= 2;
3635 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3639 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3640 as validated if VALIDATED and KNOWN if it is an internal switch. */
3642 static void
3643 save_switch (const char *opt, size_t n_args, const char *const *args,
3644 bool validated, bool known)
3646 alloc_switch ();
3647 switches[n_switches].part1 = opt + 1;
3648 if (n_args == 0)
3649 switches[n_switches].args = 0;
3650 else
3652 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3653 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3654 switches[n_switches].args[n_args] = NULL;
3657 switches[n_switches].live_cond = 0;
3658 switches[n_switches].validated = validated;
3659 switches[n_switches].known = known;
3660 switches[n_switches].ordering = 0;
3661 n_switches++;
3664 /* Set the SOURCE_DATE_EPOCH environment variable to the current time if it is
3665 not set already. */
3667 static void
3668 set_source_date_epoch_envvar ()
3670 /* Array size is 21 = ceil(log_10(2^64)) + 1 to hold string representations
3671 of 64 bit integers. */
3672 char source_date_epoch[21];
3673 time_t tt;
3675 errno = 0;
3676 tt = time (NULL);
3677 if (tt < (time_t) 0 || errno != 0)
3678 tt = (time_t) 0;
3680 snprintf (source_date_epoch, 21, "%llu", (unsigned long long) tt);
3681 /* Using setenv instead of xputenv because we want the variable to remain
3682 after finalizing so that it's still set in the second run when using
3683 -fcompare-debug. */
3684 setenv ("SOURCE_DATE_EPOCH", source_date_epoch, 0);
3687 /* Handle an option DECODED that is unknown to the option-processing
3688 machinery. */
3690 static bool
3691 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3693 const char *opt = decoded->arg;
3694 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3695 && !(decoded->errors & CL_ERR_NEGATIVE))
3697 /* Leave unknown -Wno-* options for the compiler proper, to be
3698 diagnosed only if there are warnings. */
3699 save_switch (decoded->canonical_option[0],
3700 decoded->canonical_option_num_elements - 1,
3701 &decoded->canonical_option[1], false, true);
3702 return false;
3704 if (decoded->opt_index == OPT_SPECIAL_unknown)
3706 /* Give it a chance to define it a spec file. */
3707 save_switch (decoded->canonical_option[0],
3708 decoded->canonical_option_num_elements - 1,
3709 &decoded->canonical_option[1], false, false);
3710 return false;
3712 else
3713 return true;
3716 /* Handle an option DECODED that is not marked as CL_DRIVER.
3717 LANG_MASK will always be CL_DRIVER. */
3719 static void
3720 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3721 unsigned int lang_mask ATTRIBUTE_UNUSED)
3723 /* At this point, non-driver options are accepted (and expected to
3724 be passed down by specs) unless marked to be rejected by the
3725 driver. Options to be rejected by the driver but accepted by the
3726 compilers proper are treated just like completely unknown
3727 options. */
3728 const struct cl_option *option = &cl_options[decoded->opt_index];
3730 if (option->cl_reject_driver)
3731 error ("unrecognized command line option %qs",
3732 decoded->orig_option_with_args_text);
3733 else
3734 save_switch (decoded->canonical_option[0],
3735 decoded->canonical_option_num_elements - 1,
3736 &decoded->canonical_option[1], false, true);
3739 static const char *spec_lang = 0;
3740 static int last_language_n_infiles;
3742 /* Parse -foffload option argument. */
3744 static void
3745 handle_foffload_option (const char *arg)
3747 const char *c, *cur, *n, *next, *end;
3748 char *target;
3750 /* If option argument starts with '-' then no target is specified and we
3751 do not need to parse it. */
3752 if (arg[0] == '-')
3753 return;
3755 end = strchr (arg, '=');
3756 if (end == NULL)
3757 end = strchr (arg, '\0');
3758 cur = arg;
3760 while (cur < end)
3762 next = strchr (cur, ',');
3763 if (next == NULL)
3764 next = end;
3765 next = (next > end) ? end : next;
3767 target = XNEWVEC (char, next - cur + 1);
3768 memcpy (target, cur, next - cur);
3769 target[next - cur] = '\0';
3771 /* If 'disable' is passed to the option, stop parsing the option and clean
3772 the list of offload targets. */
3773 if (strcmp (target, "disable") == 0)
3775 free (offload_targets);
3776 offload_targets = xstrdup ("");
3777 break;
3780 /* Check that GCC is configured to support the offload target. */
3781 c = OFFLOAD_TARGETS;
3782 while (c)
3784 n = strchr (c, ',');
3785 if (n == NULL)
3786 n = strchr (c, '\0');
3788 if (next - cur == n - c && strncmp (target, c, n - c) == 0)
3789 break;
3791 c = *n ? n + 1 : NULL;
3794 if (!c)
3795 fatal_error (input_location,
3796 "GCC is not configured to support %s as offload target",
3797 target);
3799 if (!offload_targets)
3801 offload_targets = target;
3802 target = NULL;
3804 else
3806 /* Check that the target hasn't already presented in the list. */
3807 c = offload_targets;
3810 n = strchr (c, ':');
3811 if (n == NULL)
3812 n = strchr (c, '\0');
3814 if (next - cur == n - c && strncmp (c, target, n - c) == 0)
3815 break;
3817 c = n + 1;
3819 while (*n);
3821 /* If duplicate is not found, append the target to the list. */
3822 if (c > n)
3824 size_t offload_targets_len = strlen (offload_targets);
3825 offload_targets
3826 = XRESIZEVEC (char, offload_targets,
3827 offload_targets_len + 1 + next - cur + 1);
3828 offload_targets[offload_targets_len++] = ':';
3829 memcpy (offload_targets + offload_targets_len, target, next - cur + 1);
3833 cur = next + 1;
3834 XDELETEVEC (target);
3838 /* Handle a driver option; arguments and return value as for
3839 handle_option. */
3841 static bool
3842 driver_handle_option (struct gcc_options *opts,
3843 struct gcc_options *opts_set,
3844 const struct cl_decoded_option *decoded,
3845 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3846 location_t loc,
3847 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3848 diagnostic_context *dc,
3849 void (*) (void))
3851 size_t opt_index = decoded->opt_index;
3852 const char *arg = decoded->arg;
3853 const char *compare_debug_replacement_opt;
3854 int value = decoded->value;
3855 bool validated = false;
3856 bool do_save = true;
3858 gcc_assert (opts == &global_options);
3859 gcc_assert (opts_set == &global_options_set);
3860 gcc_assert (kind == DK_UNSPECIFIED);
3861 gcc_assert (loc == UNKNOWN_LOCATION);
3862 gcc_assert (dc == global_dc);
3864 switch (opt_index)
3866 case OPT_dumpspecs:
3868 struct spec_list *sl;
3869 init_spec ();
3870 for (sl = specs; sl; sl = sl->next)
3871 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3872 if (link_command_spec)
3873 printf ("*link_command:\n%s\n\n", link_command_spec);
3874 exit (0);
3877 case OPT_dumpversion:
3878 printf ("%s\n", spec_version);
3879 exit (0);
3881 case OPT_dumpmachine:
3882 printf ("%s\n", spec_machine);
3883 exit (0);
3885 case OPT_dumpfullversion:
3886 printf ("%s\n", BASEVER);
3887 exit (0);
3889 case OPT__version:
3890 print_version = 1;
3892 /* CPP driver cannot obtain switch from cc1_options. */
3893 if (is_cpp_driver)
3894 add_preprocessor_option ("--version", strlen ("--version"));
3895 add_assembler_option ("--version", strlen ("--version"));
3896 add_linker_option ("--version", strlen ("--version"));
3897 break;
3899 case OPT__completion_:
3900 validated = true;
3901 completion = decoded->arg;
3902 break;
3904 case OPT__help:
3905 print_help_list = 1;
3907 /* CPP driver cannot obtain switch from cc1_options. */
3908 if (is_cpp_driver)
3909 add_preprocessor_option ("--help", 6);
3910 add_assembler_option ("--help", 6);
3911 add_linker_option ("--help", 6);
3912 break;
3914 case OPT__help_:
3915 print_subprocess_help = 2;
3916 break;
3918 case OPT__target_help:
3919 print_subprocess_help = 1;
3921 /* CPP driver cannot obtain switch from cc1_options. */
3922 if (is_cpp_driver)
3923 add_preprocessor_option ("--target-help", 13);
3924 add_assembler_option ("--target-help", 13);
3925 add_linker_option ("--target-help", 13);
3926 break;
3928 case OPT__no_sysroot_suffix:
3929 case OPT_pass_exit_codes:
3930 case OPT_print_search_dirs:
3931 case OPT_print_file_name_:
3932 case OPT_print_prog_name_:
3933 case OPT_print_multi_lib:
3934 case OPT_print_multi_directory:
3935 case OPT_print_sysroot:
3936 case OPT_print_multi_os_directory:
3937 case OPT_print_multiarch:
3938 case OPT_print_sysroot_headers_suffix:
3939 case OPT_time:
3940 case OPT_wrapper:
3941 /* These options set the variables specified in common.opt
3942 automatically, and do not need to be saved for spec
3943 processing. */
3944 do_save = false;
3945 break;
3947 case OPT_print_libgcc_file_name:
3948 print_file_name = "libgcc.a";
3949 do_save = false;
3950 break;
3952 case OPT_fuse_ld_bfd:
3953 use_ld = ".bfd";
3954 break;
3956 case OPT_fuse_ld_gold:
3957 use_ld = ".gold";
3958 break;
3960 case OPT_fcompare_debug_second:
3961 compare_debug_second = 1;
3962 break;
3964 case OPT_fcompare_debug:
3965 switch (value)
3967 case 0:
3968 compare_debug_replacement_opt = "-fcompare-debug=";
3969 arg = "";
3970 goto compare_debug_with_arg;
3972 case 1:
3973 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3974 arg = "-gtoggle";
3975 goto compare_debug_with_arg;
3977 default:
3978 gcc_unreachable ();
3980 break;
3982 case OPT_fcompare_debug_:
3983 compare_debug_replacement_opt = decoded->canonical_option[0];
3984 compare_debug_with_arg:
3985 gcc_assert (decoded->canonical_option_num_elements == 1);
3986 gcc_assert (arg != NULL);
3987 if (*arg)
3988 compare_debug = 1;
3989 else
3990 compare_debug = -1;
3991 if (compare_debug < 0)
3992 compare_debug_opt = NULL;
3993 else
3994 compare_debug_opt = arg;
3995 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3996 set_source_date_epoch_envvar ();
3997 return true;
3999 case OPT_fdiagnostics_color_:
4000 diagnostic_color_init (dc, value);
4001 break;
4003 case OPT_Wa_:
4005 int prev, j;
4006 /* Pass the rest of this option to the assembler. */
4008 /* Split the argument at commas. */
4009 prev = 0;
4010 for (j = 0; arg[j]; j++)
4011 if (arg[j] == ',')
4013 add_assembler_option (arg + prev, j - prev);
4014 prev = j + 1;
4017 /* Record the part after the last comma. */
4018 add_assembler_option (arg + prev, j - prev);
4020 do_save = false;
4021 break;
4023 case OPT_Wp_:
4025 int prev, j;
4026 /* Pass the rest of this option to the preprocessor. */
4028 /* Split the argument at commas. */
4029 prev = 0;
4030 for (j = 0; arg[j]; j++)
4031 if (arg[j] == ',')
4033 add_preprocessor_option (arg + prev, j - prev);
4034 prev = j + 1;
4037 /* Record the part after the last comma. */
4038 add_preprocessor_option (arg + prev, j - prev);
4040 do_save = false;
4041 break;
4043 case OPT_Wl_:
4045 int prev, j;
4046 /* Split the argument at commas. */
4047 prev = 0;
4048 for (j = 0; arg[j]; j++)
4049 if (arg[j] == ',')
4051 add_infile (save_string (arg + prev, j - prev), "*");
4052 prev = j + 1;
4054 /* Record the part after the last comma. */
4055 add_infile (arg + prev, "*");
4057 do_save = false;
4058 break;
4060 case OPT_Xlinker:
4061 add_infile (arg, "*");
4062 do_save = false;
4063 break;
4065 case OPT_Xpreprocessor:
4066 add_preprocessor_option (arg, strlen (arg));
4067 do_save = false;
4068 break;
4070 case OPT_Xassembler:
4071 add_assembler_option (arg, strlen (arg));
4072 do_save = false;
4073 break;
4075 case OPT_l:
4076 /* POSIX allows separation of -l and the lib arg; canonicalize
4077 by concatenating -l with its arg */
4078 add_infile (concat ("-l", arg, NULL), "*");
4079 do_save = false;
4080 break;
4082 case OPT_L:
4083 /* Similarly, canonicalize -L for linkers that may not accept
4084 separate arguments. */
4085 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
4086 return true;
4088 case OPT_F:
4089 /* Likewise -F. */
4090 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
4091 return true;
4093 case OPT_save_temps:
4094 save_temps_flag = SAVE_TEMPS_CWD;
4095 validated = true;
4096 break;
4098 case OPT_save_temps_:
4099 if (strcmp (arg, "cwd") == 0)
4100 save_temps_flag = SAVE_TEMPS_CWD;
4101 else if (strcmp (arg, "obj") == 0
4102 || strcmp (arg, "object") == 0)
4103 save_temps_flag = SAVE_TEMPS_OBJ;
4104 else
4105 fatal_error (input_location, "%qs is an unknown -save-temps option",
4106 decoded->orig_option_with_args_text);
4107 break;
4109 case OPT_no_canonical_prefixes:
4110 /* Already handled as a special case, so ignored here. */
4111 do_save = false;
4112 break;
4114 case OPT_pipe:
4115 validated = true;
4116 /* These options set the variables specified in common.opt
4117 automatically, but do need to be saved for spec
4118 processing. */
4119 break;
4121 case OPT_specs_:
4123 struct user_specs *user = XNEW (struct user_specs);
4125 user->next = (struct user_specs *) 0;
4126 user->filename = arg;
4127 if (user_specs_tail)
4128 user_specs_tail->next = user;
4129 else
4130 user_specs_head = user;
4131 user_specs_tail = user;
4133 validated = true;
4134 break;
4136 case OPT__sysroot_:
4137 target_system_root = arg;
4138 target_system_root_changed = 1;
4139 do_save = false;
4140 break;
4142 case OPT_time_:
4143 if (report_times_to_file)
4144 fclose (report_times_to_file);
4145 report_times_to_file = fopen (arg, "a");
4146 do_save = false;
4147 break;
4149 case OPT____:
4150 /* "-###"
4151 This is similar to -v except that there is no execution
4152 of the commands and the echoed arguments are quoted. It
4153 is intended for use in shell scripts to capture the
4154 driver-generated command line. */
4155 verbose_only_flag++;
4156 verbose_flag = 1;
4157 do_save = false;
4158 break;
4160 case OPT_B:
4162 size_t len = strlen (arg);
4164 /* Catch the case where the user has forgotten to append a
4165 directory separator to the path. Note, they may be using
4166 -B to add an executable name prefix, eg "i386-elf-", in
4167 order to distinguish between multiple installations of
4168 GCC in the same directory. Hence we must check to see
4169 if appending a directory separator actually makes a
4170 valid directory name. */
4171 if (!IS_DIR_SEPARATOR (arg[len - 1])
4172 && is_directory (arg, false))
4174 char *tmp = XNEWVEC (char, len + 2);
4175 strcpy (tmp, arg);
4176 tmp[len] = DIR_SEPARATOR;
4177 tmp[++len] = 0;
4178 arg = tmp;
4181 add_prefix (&exec_prefixes, arg, NULL,
4182 PREFIX_PRIORITY_B_OPT, 0, 0);
4183 add_prefix (&startfile_prefixes, arg, NULL,
4184 PREFIX_PRIORITY_B_OPT, 0, 0);
4185 add_prefix (&include_prefixes, arg, NULL,
4186 PREFIX_PRIORITY_B_OPT, 0, 0);
4188 validated = true;
4189 break;
4191 case OPT_E:
4192 have_E = true;
4193 break;
4195 case OPT_x:
4196 spec_lang = arg;
4197 if (!strcmp (spec_lang, "none"))
4198 /* Suppress the warning if -xnone comes after the last input
4199 file, because alternate command interfaces like g++ might
4200 find it useful to place -xnone after each input file. */
4201 spec_lang = 0;
4202 else
4203 last_language_n_infiles = n_infiles;
4204 do_save = false;
4205 break;
4207 case OPT_o:
4208 have_o = 1;
4209 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
4210 arg = convert_filename (arg, ! have_c, 0);
4211 #endif
4212 output_file = arg;
4213 /* Save the output name in case -save-temps=obj was used. */
4214 save_temps_prefix = xstrdup (arg);
4215 /* On some systems, ld cannot handle "-o" without a space. So
4216 split the option from its argument. */
4217 save_switch ("-o", 1, &arg, validated, true);
4218 return true;
4220 #ifdef ENABLE_DEFAULT_PIE
4221 case OPT_pie:
4222 /* -pie is turned on by default. */
4223 #endif
4225 case OPT_static_libgcc:
4226 case OPT_shared_libgcc:
4227 case OPT_static_libgfortran:
4228 case OPT_static_libstdc__:
4229 /* These are always valid, since gcc.c itself understands the
4230 first two, gfortranspec.c understands -static-libgfortran and
4231 g++spec.c understands -static-libstdc++ */
4232 validated = true;
4233 break;
4235 case OPT_fwpa:
4236 flag_wpa = "";
4237 break;
4239 case OPT_foffload_:
4240 handle_foffload_option (arg);
4241 break;
4243 default:
4244 /* Various driver options need no special processing at this
4245 point, having been handled in a prescan above or being
4246 handled by specs. */
4247 break;
4250 if (do_save)
4251 save_switch (decoded->canonical_option[0],
4252 decoded->canonical_option_num_elements - 1,
4253 &decoded->canonical_option[1], validated, true);
4254 return true;
4257 /* Put the driver's standard set of option handlers in *HANDLERS. */
4259 static void
4260 set_option_handlers (struct cl_option_handlers *handlers)
4262 handlers->unknown_option_callback = driver_unknown_option_callback;
4263 handlers->wrong_lang_callback = driver_wrong_lang_callback;
4264 handlers->num_handlers = 3;
4265 handlers->handlers[0].handler = driver_handle_option;
4266 handlers->handlers[0].mask = CL_DRIVER;
4267 handlers->handlers[1].handler = common_handle_option;
4268 handlers->handlers[1].mask = CL_COMMON;
4269 handlers->handlers[2].handler = target_handle_option;
4270 handlers->handlers[2].mask = CL_TARGET;
4273 /* Create the vector `switches' and its contents.
4274 Store its length in `n_switches'. */
4276 static void
4277 process_command (unsigned int decoded_options_count,
4278 struct cl_decoded_option *decoded_options)
4280 const char *temp;
4281 char *temp1;
4282 char *tooldir_prefix, *tooldir_prefix2;
4283 char *(*get_relative_prefix) (const char *, const char *,
4284 const char *) = NULL;
4285 struct cl_option_handlers handlers;
4286 unsigned int j;
4288 gcc_exec_prefix = env.get ("GCC_EXEC_PREFIX");
4290 n_switches = 0;
4291 n_infiles = 0;
4292 added_libraries = 0;
4294 /* Figure compiler version from version string. */
4296 compiler_version = temp1 = xstrdup (version_string);
4298 for (; *temp1; ++temp1)
4300 if (*temp1 == ' ')
4302 *temp1 = '\0';
4303 break;
4307 /* Handle any -no-canonical-prefixes flag early, to assign the function
4308 that builds relative prefixes. This function creates default search
4309 paths that are needed later in normal option handling. */
4311 for (j = 1; j < decoded_options_count; j++)
4313 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
4315 get_relative_prefix = make_relative_prefix_ignore_links;
4316 break;
4319 if (! get_relative_prefix)
4320 get_relative_prefix = make_relative_prefix;
4322 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
4323 see if we can create it from the pathname specified in
4324 decoded_options[0].arg. */
4326 gcc_libexec_prefix = standard_libexec_prefix;
4327 #ifndef VMS
4328 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
4329 if (!gcc_exec_prefix)
4331 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
4332 standard_bindir_prefix,
4333 standard_exec_prefix);
4334 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
4335 standard_bindir_prefix,
4336 standard_libexec_prefix);
4337 if (gcc_exec_prefix)
4338 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
4340 else
4342 /* make_relative_prefix requires a program name, but
4343 GCC_EXEC_PREFIX is typically a directory name with a trailing
4344 / (which is ignored by make_relative_prefix), so append a
4345 program name. */
4346 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
4347 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
4348 standard_exec_prefix,
4349 standard_libexec_prefix);
4351 /* The path is unrelocated, so fallback to the original setting. */
4352 if (!gcc_libexec_prefix)
4353 gcc_libexec_prefix = standard_libexec_prefix;
4355 free (tmp_prefix);
4357 #else
4358 #endif
4359 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
4360 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
4361 or an automatically created GCC_EXEC_PREFIX from
4362 decoded_options[0].arg. */
4364 /* Do language-specific adjustment/addition of flags. */
4365 lang_specific_driver (&decoded_options, &decoded_options_count,
4366 &added_libraries);
4368 if (gcc_exec_prefix)
4370 int len = strlen (gcc_exec_prefix);
4372 if (len > (int) sizeof ("/lib/gcc/") - 1
4373 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
4375 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
4376 if (IS_DIR_SEPARATOR (*temp)
4377 && filename_ncmp (temp + 1, "lib", 3) == 0
4378 && IS_DIR_SEPARATOR (temp[4])
4379 && filename_ncmp (temp + 5, "gcc", 3) == 0)
4380 len -= sizeof ("/lib/gcc/") - 1;
4383 set_std_prefix (gcc_exec_prefix, len);
4384 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
4385 PREFIX_PRIORITY_LAST, 0, 0);
4386 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
4387 PREFIX_PRIORITY_LAST, 0, 0);
4390 /* COMPILER_PATH and LIBRARY_PATH have values
4391 that are lists of directory names with colons. */
4393 temp = env.get ("COMPILER_PATH");
4394 if (temp)
4396 const char *startp, *endp;
4397 char *nstore = (char *) alloca (strlen (temp) + 3);
4399 startp = endp = temp;
4400 while (1)
4402 if (*endp == PATH_SEPARATOR || *endp == 0)
4404 strncpy (nstore, startp, endp - startp);
4405 if (endp == startp)
4406 strcpy (nstore, concat (".", dir_separator_str, NULL));
4407 else if (!IS_DIR_SEPARATOR (endp[-1]))
4409 nstore[endp - startp] = DIR_SEPARATOR;
4410 nstore[endp - startp + 1] = 0;
4412 else
4413 nstore[endp - startp] = 0;
4414 add_prefix (&exec_prefixes, nstore, 0,
4415 PREFIX_PRIORITY_LAST, 0, 0);
4416 add_prefix (&include_prefixes, nstore, 0,
4417 PREFIX_PRIORITY_LAST, 0, 0);
4418 if (*endp == 0)
4419 break;
4420 endp = startp = endp + 1;
4422 else
4423 endp++;
4427 temp = env.get (LIBRARY_PATH_ENV);
4428 if (temp && *cross_compile == '0')
4430 const char *startp, *endp;
4431 char *nstore = (char *) alloca (strlen (temp) + 3);
4433 startp = endp = temp;
4434 while (1)
4436 if (*endp == PATH_SEPARATOR || *endp == 0)
4438 strncpy (nstore, startp, endp - startp);
4439 if (endp == startp)
4440 strcpy (nstore, concat (".", dir_separator_str, NULL));
4441 else if (!IS_DIR_SEPARATOR (endp[-1]))
4443 nstore[endp - startp] = DIR_SEPARATOR;
4444 nstore[endp - startp + 1] = 0;
4446 else
4447 nstore[endp - startp] = 0;
4448 add_prefix (&startfile_prefixes, nstore, NULL,
4449 PREFIX_PRIORITY_LAST, 0, 1);
4450 if (*endp == 0)
4451 break;
4452 endp = startp = endp + 1;
4454 else
4455 endp++;
4459 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
4460 temp = env.get ("LPATH");
4461 if (temp && *cross_compile == '0')
4463 const char *startp, *endp;
4464 char *nstore = (char *) alloca (strlen (temp) + 3);
4466 startp = endp = temp;
4467 while (1)
4469 if (*endp == PATH_SEPARATOR || *endp == 0)
4471 strncpy (nstore, startp, endp - startp);
4472 if (endp == startp)
4473 strcpy (nstore, concat (".", dir_separator_str, NULL));
4474 else if (!IS_DIR_SEPARATOR (endp[-1]))
4476 nstore[endp - startp] = DIR_SEPARATOR;
4477 nstore[endp - startp + 1] = 0;
4479 else
4480 nstore[endp - startp] = 0;
4481 add_prefix (&startfile_prefixes, nstore, NULL,
4482 PREFIX_PRIORITY_LAST, 0, 1);
4483 if (*endp == 0)
4484 break;
4485 endp = startp = endp + 1;
4487 else
4488 endp++;
4492 /* Process the options and store input files and switches in their
4493 vectors. */
4495 last_language_n_infiles = -1;
4497 set_option_handlers (&handlers);
4499 for (j = 1; j < decoded_options_count; j++)
4501 switch (decoded_options[j].opt_index)
4503 case OPT_S:
4504 case OPT_c:
4505 case OPT_E:
4506 have_c = 1;
4507 break;
4509 if (have_c)
4510 break;
4513 for (j = 1; j < decoded_options_count; j++)
4515 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
4517 const char *arg = decoded_options[j].arg;
4518 const char *p = strrchr (arg, '@');
4519 char *fname;
4520 long offset;
4521 int consumed;
4522 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4523 arg = convert_filename (arg, 0, access (arg, F_OK));
4524 #endif
4525 /* For LTO static archive support we handle input file
4526 specifications that are composed of a filename and
4527 an offset like FNAME@OFFSET. */
4528 if (p
4529 && p != arg
4530 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
4531 && strlen (p) == (unsigned int)consumed)
4533 fname = (char *)xmalloc (p - arg + 1);
4534 memcpy (fname, arg, p - arg);
4535 fname[p - arg] = '\0';
4536 /* Only accept non-stdin and existing FNAME parts, otherwise
4537 try with the full name. */
4538 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
4540 free (fname);
4541 fname = xstrdup (arg);
4544 else
4545 fname = xstrdup (arg);
4547 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
4549 bool resp = fname[0] == '@' && access (fname + 1, F_OK) < 0;
4550 error ("%s: %m", fname + resp);
4552 else
4553 add_infile (arg, spec_lang);
4555 free (fname);
4556 continue;
4559 read_cmdline_option (&global_options, &global_options_set,
4560 decoded_options + j, UNKNOWN_LOCATION,
4561 CL_DRIVER, &handlers, global_dc);
4564 /* If the user didn't specify any, default to all configured offload
4565 targets. */
4566 if (ENABLE_OFFLOADING && offload_targets == NULL)
4567 handle_foffload_option (OFFLOAD_TARGETS);
4569 if (output_file
4570 && strcmp (output_file, "-") != 0
4571 && strcmp (output_file, HOST_BIT_BUCKET) != 0)
4573 int i;
4574 for (i = 0; i < n_infiles; i++)
4575 if ((!infiles[i].language || infiles[i].language[0] != '*')
4576 && canonical_filename_eq (infiles[i].name, output_file))
4577 fatal_error (input_location,
4578 "input file %qs is the same as output file",
4579 output_file);
4582 if (output_file != NULL && output_file[0] == '\0')
4583 fatal_error (input_location, "output filename may not be empty");
4585 /* If -save-temps=obj and -o name, create the prefix to use for %b.
4586 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
4587 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
4589 save_temps_length = strlen (save_temps_prefix);
4590 temp = strrchr (lbasename (save_temps_prefix), '.');
4591 if (temp)
4593 save_temps_length -= strlen (temp);
4594 save_temps_prefix[save_temps_length] = '\0';
4598 else if (save_temps_prefix != NULL)
4600 free (save_temps_prefix);
4601 save_temps_prefix = NULL;
4604 if (save_temps_flag && use_pipes)
4606 /* -save-temps overrides -pipe, so that temp files are produced */
4607 if (save_temps_flag)
4608 warning (0, "-pipe ignored because -save-temps specified");
4609 use_pipes = 0;
4612 if (!compare_debug)
4614 const char *gcd = env.get ("GCC_COMPARE_DEBUG");
4616 if (gcd && gcd[0] == '-')
4618 compare_debug = 2;
4619 compare_debug_opt = gcd;
4621 else if (gcd && *gcd && strcmp (gcd, "0"))
4623 compare_debug = 3;
4624 compare_debug_opt = "-gtoggle";
4627 else if (compare_debug < 0)
4629 compare_debug = 0;
4630 gcc_assert (!compare_debug_opt);
4633 /* Set up the search paths. We add directories that we expect to
4634 contain GNU Toolchain components before directories specified by
4635 the machine description so that we will find GNU components (like
4636 the GNU assembler) before those of the host system. */
4638 /* If we don't know where the toolchain has been installed, use the
4639 configured-in locations. */
4640 if (!gcc_exec_prefix)
4642 #ifndef OS2
4643 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
4644 PREFIX_PRIORITY_LAST, 1, 0);
4645 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
4646 PREFIX_PRIORITY_LAST, 2, 0);
4647 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
4648 PREFIX_PRIORITY_LAST, 2, 0);
4649 #endif
4650 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
4651 PREFIX_PRIORITY_LAST, 1, 0);
4654 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
4655 tooldir_prefix2 = concat (tooldir_base_prefix, spec_machine,
4656 dir_separator_str, NULL);
4658 /* Look for tools relative to the location from which the driver is
4659 running, or, if that is not available, the configured prefix. */
4660 tooldir_prefix
4661 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4662 spec_host_machine, dir_separator_str, spec_version,
4663 accel_dir_suffix, dir_separator_str, tooldir_prefix2, NULL);
4664 free (tooldir_prefix2);
4666 add_prefix (&exec_prefixes,
4667 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4668 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4669 add_prefix (&startfile_prefixes,
4670 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4671 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4672 free (tooldir_prefix);
4674 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4675 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4676 then consider it to relocate with the rest of the GCC installation
4677 if GCC_EXEC_PREFIX is set.
4678 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4679 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
4681 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
4682 standard_bindir_prefix,
4683 target_system_root);
4684 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4686 target_system_root = tmp_prefix;
4687 target_system_root_changed = 1;
4690 #endif
4692 /* More prefixes are enabled in main, after we read the specs file
4693 and determine whether this is cross-compilation or not. */
4695 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4696 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
4698 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
4699 environment variable. */
4700 if (compare_debug == 2 || compare_debug == 3)
4702 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
4703 save_switch (opt, 0, NULL, false, true);
4704 compare_debug = 1;
4707 /* Ensure we only invoke each subprocess once. */
4708 if (print_subprocess_help || print_help_list || print_version)
4710 n_infiles = 0;
4712 /* Create a dummy input file, so that we can pass
4713 the help option on to the various sub-processes. */
4714 add_infile ("help-dummy", "c");
4717 /* Decide if undefined variable references are allowed in specs. */
4719 /* -v alone is safe. --version and --help alone or together are safe. Note
4720 that -v would make them unsafe, as they'd then be run for subprocesses as
4721 well, the location of which might depend on variables possibly coming
4722 from self-specs. Note also that the command name is counted in
4723 decoded_options_count. */
4725 unsigned help_version_count = 0;
4727 if (print_version)
4728 help_version_count++;
4730 if (print_help_list)
4731 help_version_count++;
4733 spec_undefvar_allowed =
4734 ((verbose_flag && decoded_options_count == 2)
4735 || help_version_count == decoded_options_count - 1);
4737 alloc_switch ();
4738 switches[n_switches].part1 = 0;
4739 alloc_infile ();
4740 infiles[n_infiles].name = 0;
4743 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4744 and place that in the environment. */
4746 static void
4747 set_collect_gcc_options (void)
4749 int i;
4750 int first_time;
4752 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4753 the compiler. */
4754 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4755 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4757 first_time = TRUE;
4758 for (i = 0; (int) i < n_switches; i++)
4760 const char *const *args;
4761 const char *p, *q;
4762 if (!first_time)
4763 obstack_grow (&collect_obstack, " ", 1);
4765 first_time = FALSE;
4767 /* Ignore elided switches. */
4768 if ((switches[i].live_cond
4769 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4770 == SWITCH_IGNORE)
4771 continue;
4773 obstack_grow (&collect_obstack, "'-", 2);
4774 q = switches[i].part1;
4775 while ((p = strchr (q, '\'')))
4777 obstack_grow (&collect_obstack, q, p - q);
4778 obstack_grow (&collect_obstack, "'\\''", 4);
4779 q = ++p;
4781 obstack_grow (&collect_obstack, q, strlen (q));
4782 obstack_grow (&collect_obstack, "'", 1);
4784 for (args = switches[i].args; args && *args; args++)
4786 obstack_grow (&collect_obstack, " '", 2);
4787 q = *args;
4788 while ((p = strchr (q, '\'')))
4790 obstack_grow (&collect_obstack, q, p - q);
4791 obstack_grow (&collect_obstack, "'\\''", 4);
4792 q = ++p;
4794 obstack_grow (&collect_obstack, q, strlen (q));
4795 obstack_grow (&collect_obstack, "'", 1);
4798 obstack_grow (&collect_obstack, "\0", 1);
4799 xputenv (XOBFINISH (&collect_obstack, char *));
4802 /* Process a spec string, accumulating and running commands. */
4804 /* These variables describe the input file name.
4805 input_file_number is the index on outfiles of this file,
4806 so that the output file name can be stored for later use by %o.
4807 input_basename is the start of the part of the input file
4808 sans all directory names, and basename_length is the number
4809 of characters starting there excluding the suffix .c or whatever. */
4811 static const char *gcc_input_filename;
4812 static int input_file_number;
4813 size_t input_filename_length;
4814 static int basename_length;
4815 static int suffixed_basename_length;
4816 static const char *input_basename;
4817 static const char *input_suffix;
4818 #ifndef HOST_LACKS_INODE_NUMBERS
4819 static struct stat input_stat;
4820 #endif
4821 static int input_stat_set;
4823 /* The compiler used to process the current input file. */
4824 static struct compiler *input_file_compiler;
4826 /* These are variables used within do_spec and do_spec_1. */
4828 /* Nonzero if an arg has been started and not yet terminated
4829 (with space, tab or newline). */
4830 static int arg_going;
4832 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4833 is a temporary file name. */
4834 static int delete_this_arg;
4836 /* Nonzero means %w has been seen; the next arg to be terminated
4837 is the output file name of this compilation. */
4838 static int this_is_output_file;
4840 /* Nonzero means %s has been seen; the next arg to be terminated
4841 is the name of a library file and we should try the standard
4842 search dirs for it. */
4843 static int this_is_library_file;
4845 /* Nonzero means %T has been seen; the next arg to be terminated
4846 is the name of a linker script and we should try all of the
4847 standard search dirs for it. If it is found insert a --script
4848 command line switch and then substitute the full path in place,
4849 otherwise generate an error message. */
4850 static int this_is_linker_script;
4852 /* Nonzero means that the input of this command is coming from a pipe. */
4853 static int input_from_pipe;
4855 /* Nonnull means substitute this for any suffix when outputting a switches
4856 arguments. */
4857 static const char *suffix_subst;
4859 /* If there is an argument being accumulated, terminate it and store it. */
4861 static void
4862 end_going_arg (void)
4864 if (arg_going)
4866 const char *string;
4868 obstack_1grow (&obstack, 0);
4869 string = XOBFINISH (&obstack, const char *);
4870 if (this_is_library_file)
4871 string = find_file (string);
4872 if (this_is_linker_script)
4874 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4876 if (full_script_path == NULL)
4878 error ("unable to locate default linker script %qs in the library search paths", string);
4879 /* Script was not found on search path. */
4880 return;
4882 store_arg ("--script", false, false);
4883 string = full_script_path;
4885 store_arg (string, delete_this_arg, this_is_output_file);
4886 if (this_is_output_file)
4887 outfiles[input_file_number] = string;
4888 arg_going = 0;
4893 /* Parse the WRAPPER string which is a comma separated list of the command line
4894 and insert them into the beginning of argbuf. */
4896 static void
4897 insert_wrapper (const char *wrapper)
4899 int n = 0;
4900 int i;
4901 char *buf = xstrdup (wrapper);
4902 char *p = buf;
4903 unsigned int old_length = argbuf.length ();
4907 n++;
4908 while (*p == ',')
4909 p++;
4911 while ((p = strchr (p, ',')) != NULL);
4913 argbuf.safe_grow (old_length + n);
4914 memmove (argbuf.address () + n,
4915 argbuf.address (),
4916 old_length * sizeof (const_char_p));
4918 i = 0;
4919 p = buf;
4922 while (*p == ',')
4924 *p = 0;
4925 p++;
4927 argbuf[i] = p;
4928 i++;
4930 while ((p = strchr (p, ',')) != NULL);
4931 gcc_assert (i == n);
4934 /* Process the spec SPEC and run the commands specified therein.
4935 Returns 0 if the spec is successfully processed; -1 if failed. */
4938 do_spec (const char *spec)
4940 int value;
4942 value = do_spec_2 (spec, NULL);
4944 /* Force out any unfinished command.
4945 If -pipe, this forces out the last command if it ended in `|'. */
4946 if (value == 0)
4948 if (argbuf.length () > 0
4949 && !strcmp (argbuf.last (), "|"))
4950 argbuf.pop ();
4952 set_collect_gcc_options ();
4954 if (argbuf.length () > 0)
4955 value = execute ();
4958 return value;
4961 /* Process the spec SPEC, with SOFT_MATCHED_PART designating the current value
4962 of a matched * pattern which may be re-injected by way of %*. */
4964 static int
4965 do_spec_2 (const char *spec, const char *soft_matched_part)
4967 int result;
4969 clear_args ();
4970 arg_going = 0;
4971 delete_this_arg = 0;
4972 this_is_output_file = 0;
4973 this_is_library_file = 0;
4974 this_is_linker_script = 0;
4975 input_from_pipe = 0;
4976 suffix_subst = NULL;
4978 result = do_spec_1 (spec, 0, soft_matched_part);
4980 end_going_arg ();
4982 return result;
4985 /* Process the given spec string and add any new options to the end
4986 of the switches/n_switches array. */
4988 static void
4989 do_option_spec (const char *name, const char *spec)
4991 unsigned int i, value_count, value_len;
4992 const char *p, *q, *value;
4993 char *tmp_spec, *tmp_spec_p;
4995 if (configure_default_options[0].name == NULL)
4996 return;
4998 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4999 if (strcmp (configure_default_options[i].name, name) == 0)
5000 break;
5001 if (i == ARRAY_SIZE (configure_default_options))
5002 return;
5004 value = configure_default_options[i].value;
5005 value_len = strlen (value);
5007 /* Compute the size of the final spec. */
5008 value_count = 0;
5009 p = spec;
5010 while ((p = strstr (p, "%(VALUE)")) != NULL)
5012 p ++;
5013 value_count ++;
5016 /* Replace each %(VALUE) by the specified value. */
5017 tmp_spec = (char *) alloca (strlen (spec) + 1
5018 + value_count * (value_len - strlen ("%(VALUE)")));
5019 tmp_spec_p = tmp_spec;
5020 q = spec;
5021 while ((p = strstr (q, "%(VALUE)")) != NULL)
5023 memcpy (tmp_spec_p, q, p - q);
5024 tmp_spec_p = tmp_spec_p + (p - q);
5025 memcpy (tmp_spec_p, value, value_len);
5026 tmp_spec_p += value_len;
5027 q = p + strlen ("%(VALUE)");
5029 strcpy (tmp_spec_p, q);
5031 do_self_spec (tmp_spec);
5034 /* Process the given spec string and add any new options to the end
5035 of the switches/n_switches array. */
5037 static void
5038 do_self_spec (const char *spec)
5040 int i;
5042 do_spec_2 (spec, NULL);
5043 do_spec_1 (" ", 0, NULL);
5045 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
5046 do_self_specs adds the replacements to switches array, so it shouldn't
5047 be processed afterwards. */
5048 for (i = 0; i < n_switches; i++)
5049 if ((switches[i].live_cond & SWITCH_IGNORE))
5050 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
5052 if (argbuf.length () > 0)
5054 const char **argbuf_copy;
5055 struct cl_decoded_option *decoded_options;
5056 struct cl_option_handlers handlers;
5057 unsigned int decoded_options_count;
5058 unsigned int j;
5060 /* Create a copy of argbuf with a dummy argv[0] entry for
5061 decode_cmdline_options_to_array. */
5062 argbuf_copy = XNEWVEC (const char *,
5063 argbuf.length () + 1);
5064 argbuf_copy[0] = "";
5065 memcpy (argbuf_copy + 1, argbuf.address (),
5066 argbuf.length () * sizeof (const char *));
5068 decode_cmdline_options_to_array (argbuf.length () + 1,
5069 argbuf_copy,
5070 CL_DRIVER, &decoded_options,
5071 &decoded_options_count);
5072 free (argbuf_copy);
5074 set_option_handlers (&handlers);
5076 for (j = 1; j < decoded_options_count; j++)
5078 switch (decoded_options[j].opt_index)
5080 case OPT_SPECIAL_input_file:
5081 /* Specs should only generate options, not input
5082 files. */
5083 if (strcmp (decoded_options[j].arg, "-") != 0)
5084 fatal_error (input_location,
5085 "switch %qs does not start with %<-%>",
5086 decoded_options[j].arg);
5087 else
5088 fatal_error (input_location,
5089 "spec-generated switch is just %<-%>");
5090 break;
5092 case OPT_fcompare_debug_second:
5093 case OPT_fcompare_debug:
5094 case OPT_fcompare_debug_:
5095 case OPT_o:
5096 /* Avoid duplicate processing of some options from
5097 compare-debug specs; just save them here. */
5098 save_switch (decoded_options[j].canonical_option[0],
5099 (decoded_options[j].canonical_option_num_elements
5100 - 1),
5101 &decoded_options[j].canonical_option[1], false, true);
5102 break;
5104 default:
5105 read_cmdline_option (&global_options, &global_options_set,
5106 decoded_options + j, UNKNOWN_LOCATION,
5107 CL_DRIVER, &handlers, global_dc);
5108 break;
5112 free (decoded_options);
5114 alloc_switch ();
5115 switches[n_switches].part1 = 0;
5119 /* Callback for processing %D and %I specs. */
5121 struct spec_path_info {
5122 const char *option;
5123 const char *append;
5124 size_t append_len;
5125 bool omit_relative;
5126 bool separate_options;
5129 static void *
5130 spec_path (char *path, void *data)
5132 struct spec_path_info *info = (struct spec_path_info *) data;
5133 size_t len = 0;
5134 char save = 0;
5136 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
5137 return NULL;
5139 if (info->append_len != 0)
5141 len = strlen (path);
5142 memcpy (path + len, info->append, info->append_len + 1);
5145 if (!is_directory (path, true))
5146 return NULL;
5148 do_spec_1 (info->option, 1, NULL);
5149 if (info->separate_options)
5150 do_spec_1 (" ", 0, NULL);
5152 if (info->append_len == 0)
5154 len = strlen (path);
5155 save = path[len - 1];
5156 if (IS_DIR_SEPARATOR (path[len - 1]))
5157 path[len - 1] = '\0';
5160 do_spec_1 (path, 1, NULL);
5161 do_spec_1 (" ", 0, NULL);
5163 /* Must not damage the original path. */
5164 if (info->append_len == 0)
5165 path[len - 1] = save;
5167 return NULL;
5170 /* True if we should compile INFILE. */
5172 static bool
5173 compile_input_file_p (struct infile *infile)
5175 if ((!infile->language) || (infile->language[0] != '*'))
5176 if (infile->incompiler == input_file_compiler)
5177 return true;
5178 return false;
5181 /* Process each member of VEC as a spec. */
5183 static void
5184 do_specs_vec (vec<char_p> vec)
5186 unsigned ix;
5187 char *opt;
5189 FOR_EACH_VEC_ELT (vec, ix, opt)
5191 do_spec_1 (opt, 1, NULL);
5192 /* Make each accumulated option a separate argument. */
5193 do_spec_1 (" ", 0, NULL);
5197 /* Process the sub-spec SPEC as a portion of a larger spec.
5198 This is like processing a whole spec except that we do
5199 not initialize at the beginning and we do not supply a
5200 newline by default at the end.
5201 INSWITCH nonzero means don't process %-sequences in SPEC;
5202 in this case, % is treated as an ordinary character.
5203 This is used while substituting switches.
5204 INSWITCH nonzero also causes SPC not to terminate an argument.
5206 Value is zero unless a line was finished
5207 and the command on that line reported an error. */
5209 static int
5210 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
5212 const char *p = spec;
5213 int c;
5214 int i;
5215 int value;
5217 /* If it's an empty string argument to a switch, keep it as is. */
5218 if (inswitch && !*p)
5219 arg_going = 1;
5221 while ((c = *p++))
5222 /* If substituting a switch, treat all chars like letters.
5223 Otherwise, NL, SPC, TAB and % are special. */
5224 switch (inswitch ? 'a' : c)
5226 case '\n':
5227 end_going_arg ();
5229 if (argbuf.length () > 0
5230 && !strcmp (argbuf.last (), "|"))
5232 /* A `|' before the newline means use a pipe here,
5233 but only if -pipe was specified.
5234 Otherwise, execute now and don't pass the `|' as an arg. */
5235 if (use_pipes)
5237 input_from_pipe = 1;
5238 break;
5240 else
5241 argbuf.pop ();
5244 set_collect_gcc_options ();
5246 if (argbuf.length () > 0)
5248 value = execute ();
5249 if (value)
5250 return value;
5252 /* Reinitialize for a new command, and for a new argument. */
5253 clear_args ();
5254 arg_going = 0;
5255 delete_this_arg = 0;
5256 this_is_output_file = 0;
5257 this_is_library_file = 0;
5258 this_is_linker_script = 0;
5259 input_from_pipe = 0;
5260 break;
5262 case '|':
5263 end_going_arg ();
5265 /* Use pipe */
5266 obstack_1grow (&obstack, c);
5267 arg_going = 1;
5268 break;
5270 case '\t':
5271 case ' ':
5272 end_going_arg ();
5274 /* Reinitialize for a new argument. */
5275 delete_this_arg = 0;
5276 this_is_output_file = 0;
5277 this_is_library_file = 0;
5278 this_is_linker_script = 0;
5279 break;
5281 case '%':
5282 switch (c = *p++)
5284 case 0:
5285 fatal_error (input_location, "spec %qs invalid", spec);
5287 case 'b':
5288 if (save_temps_length)
5289 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
5290 else
5291 obstack_grow (&obstack, input_basename, basename_length);
5292 if (compare_debug < 0)
5293 obstack_grow (&obstack, ".gk", 3);
5294 arg_going = 1;
5295 break;
5297 case 'B':
5298 if (save_temps_length)
5299 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
5300 else
5301 obstack_grow (&obstack, input_basename, suffixed_basename_length);
5302 if (compare_debug < 0)
5303 obstack_grow (&obstack, ".gk", 3);
5304 arg_going = 1;
5305 break;
5307 case 'd':
5308 delete_this_arg = 2;
5309 break;
5311 /* Dump out the directories specified with LIBRARY_PATH,
5312 followed by the absolute directories
5313 that we search for startfiles. */
5314 case 'D':
5316 struct spec_path_info info;
5318 info.option = "-L";
5319 info.append_len = 0;
5320 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
5321 /* Used on systems which record the specified -L dirs
5322 and use them to search for dynamic linking.
5323 Relative directories always come from -B,
5324 and it is better not to use them for searching
5325 at run time. In particular, stage1 loses. */
5326 info.omit_relative = true;
5327 #else
5328 info.omit_relative = false;
5329 #endif
5330 info.separate_options = false;
5332 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
5334 break;
5336 case 'e':
5337 /* %efoo means report an error with `foo' as error message
5338 and don't execute any more commands for this file. */
5340 const char *q = p;
5341 char *buf;
5342 while (*p != 0 && *p != '\n')
5343 p++;
5344 buf = (char *) alloca (p - q + 1);
5345 strncpy (buf, q, p - q);
5346 buf[p - q] = 0;
5347 error ("%s", _(buf));
5348 return -1;
5350 break;
5351 case 'n':
5352 /* %nfoo means report a notice with `foo' on stderr. */
5354 const char *q = p;
5355 char *buf;
5356 while (*p != 0 && *p != '\n')
5357 p++;
5358 buf = (char *) alloca (p - q + 1);
5359 strncpy (buf, q, p - q);
5360 buf[p - q] = 0;
5361 inform (UNKNOWN_LOCATION, "%s", _(buf));
5362 if (*p)
5363 p++;
5365 break;
5367 case 'j':
5369 struct stat st;
5371 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
5372 defined, and it is not a directory, and it is
5373 writable, use it. Otherwise, treat this like any
5374 other temporary file. */
5376 if ((!save_temps_flag)
5377 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
5378 && (access (HOST_BIT_BUCKET, W_OK) == 0))
5380 obstack_grow (&obstack, HOST_BIT_BUCKET,
5381 strlen (HOST_BIT_BUCKET));
5382 delete_this_arg = 0;
5383 arg_going = 1;
5384 break;
5387 goto create_temp_file;
5388 case '|':
5389 if (use_pipes)
5391 obstack_1grow (&obstack, '-');
5392 delete_this_arg = 0;
5393 arg_going = 1;
5395 /* consume suffix */
5396 while (*p == '.' || ISALNUM ((unsigned char) *p))
5397 p++;
5398 if (p[0] == '%' && p[1] == 'O')
5399 p += 2;
5401 break;
5403 goto create_temp_file;
5404 case 'm':
5405 if (use_pipes)
5407 /* consume suffix */
5408 while (*p == '.' || ISALNUM ((unsigned char) *p))
5409 p++;
5410 if (p[0] == '%' && p[1] == 'O')
5411 p += 2;
5413 break;
5415 goto create_temp_file;
5416 case 'g':
5417 case 'u':
5418 case 'U':
5419 create_temp_file:
5421 struct temp_name *t;
5422 int suffix_length;
5423 const char *suffix = p;
5424 char *saved_suffix = NULL;
5426 while (*p == '.' || ISALNUM ((unsigned char) *p))
5427 p++;
5428 suffix_length = p - suffix;
5429 if (p[0] == '%' && p[1] == 'O')
5431 p += 2;
5432 /* We don't support extra suffix characters after %O. */
5433 if (*p == '.' || ISALNUM ((unsigned char) *p))
5434 fatal_error (input_location,
5435 "spec %qs has invalid %<%%0%c%>", spec, *p);
5436 if (suffix_length == 0)
5437 suffix = TARGET_OBJECT_SUFFIX;
5438 else
5440 saved_suffix
5441 = XNEWVEC (char, suffix_length
5442 + strlen (TARGET_OBJECT_SUFFIX) + 1);
5443 strncpy (saved_suffix, suffix, suffix_length);
5444 strcpy (saved_suffix + suffix_length,
5445 TARGET_OBJECT_SUFFIX);
5447 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
5450 if (compare_debug < 0)
5452 suffix = concat (".gk", suffix, NULL);
5453 suffix_length += 3;
5456 /* If -save-temps=obj and -o were specified, use that for the
5457 temp file. */
5458 if (save_temps_length)
5460 char *tmp;
5461 temp_filename_length
5462 = save_temps_length + suffix_length + 1;
5463 tmp = (char *) alloca (temp_filename_length);
5464 memcpy (tmp, save_temps_prefix, save_temps_length);
5465 memcpy (tmp + save_temps_length, suffix, suffix_length);
5466 tmp[save_temps_length + suffix_length] = '\0';
5467 temp_filename = save_string (tmp, save_temps_length
5468 + suffix_length);
5469 obstack_grow (&obstack, temp_filename,
5470 temp_filename_length);
5471 arg_going = 1;
5472 delete_this_arg = 0;
5473 break;
5476 /* If the gcc_input_filename has the same suffix specified
5477 for the %g, %u, or %U, and -save-temps is specified,
5478 we could end up using that file as an intermediate
5479 thus clobbering the user's source file (.e.g.,
5480 gcc -save-temps foo.s would clobber foo.s with the
5481 output of cpp0). So check for this condition and
5482 generate a temp file as the intermediate. */
5484 if (save_temps_flag)
5486 char *tmp;
5487 temp_filename_length = basename_length + suffix_length + 1;
5488 tmp = (char *) alloca (temp_filename_length);
5489 memcpy (tmp, input_basename, basename_length);
5490 memcpy (tmp + basename_length, suffix, suffix_length);
5491 tmp[basename_length + suffix_length] = '\0';
5492 temp_filename = tmp;
5494 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
5496 #ifndef HOST_LACKS_INODE_NUMBERS
5497 struct stat st_temp;
5499 /* Note, set_input() resets input_stat_set to 0. */
5500 if (input_stat_set == 0)
5502 input_stat_set = stat (gcc_input_filename,
5503 &input_stat);
5504 if (input_stat_set >= 0)
5505 input_stat_set = 1;
5508 /* If we have the stat for the gcc_input_filename
5509 and we can do the stat for the temp_filename
5510 then the they could still refer to the same
5511 file if st_dev/st_ino's are the same. */
5512 if (input_stat_set != 1
5513 || stat (temp_filename, &st_temp) < 0
5514 || input_stat.st_dev != st_temp.st_dev
5515 || input_stat.st_ino != st_temp.st_ino)
5516 #else
5517 /* Just compare canonical pathnames. */
5518 char* input_realname = lrealpath (gcc_input_filename);
5519 char* temp_realname = lrealpath (temp_filename);
5520 bool files_differ = filename_cmp (input_realname, temp_realname);
5521 free (input_realname);
5522 free (temp_realname);
5523 if (files_differ)
5524 #endif
5526 temp_filename
5527 = save_string (temp_filename,
5528 temp_filename_length - 1);
5529 obstack_grow (&obstack, temp_filename,
5530 temp_filename_length);
5531 arg_going = 1;
5532 delete_this_arg = 0;
5533 break;
5538 /* See if we already have an association of %g/%u/%U and
5539 suffix. */
5540 for (t = temp_names; t; t = t->next)
5541 if (t->length == suffix_length
5542 && strncmp (t->suffix, suffix, suffix_length) == 0
5543 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
5544 break;
5546 /* Make a new association if needed. %u and %j
5547 require one. */
5548 if (t == 0 || c == 'u' || c == 'j')
5550 if (t == 0)
5552 t = XNEW (struct temp_name);
5553 t->next = temp_names;
5554 temp_names = t;
5556 t->length = suffix_length;
5557 if (saved_suffix)
5559 t->suffix = saved_suffix;
5560 saved_suffix = NULL;
5562 else
5563 t->suffix = save_string (suffix, suffix_length);
5564 t->unique = (c == 'u' || c == 'U' || c == 'j');
5565 temp_filename = make_temp_file (t->suffix);
5566 temp_filename_length = strlen (temp_filename);
5567 t->filename = temp_filename;
5568 t->filename_length = temp_filename_length;
5571 free (saved_suffix);
5573 obstack_grow (&obstack, t->filename, t->filename_length);
5574 delete_this_arg = 1;
5576 arg_going = 1;
5577 break;
5579 case 'i':
5580 if (combine_inputs)
5582 /* We are going to expand `%i' into `@FILE', where FILE
5583 is a newly-created temporary filename. The filenames
5584 that would usually be expanded in place of %o will be
5585 written to the temporary file. */
5586 if (at_file_supplied)
5587 open_at_file ();
5589 for (i = 0; (int) i < n_infiles; i++)
5590 if (compile_input_file_p (&infiles[i]))
5592 store_arg (infiles[i].name, 0, 0);
5593 infiles[i].compiled = true;
5596 if (at_file_supplied)
5597 close_at_file ();
5599 else
5601 obstack_grow (&obstack, gcc_input_filename,
5602 input_filename_length);
5603 arg_going = 1;
5605 break;
5607 case 'I':
5609 struct spec_path_info info;
5611 if (multilib_dir)
5613 do_spec_1 ("-imultilib", 1, NULL);
5614 /* Make this a separate argument. */
5615 do_spec_1 (" ", 0, NULL);
5616 do_spec_1 (multilib_dir, 1, NULL);
5617 do_spec_1 (" ", 0, NULL);
5620 if (multiarch_dir)
5622 do_spec_1 ("-imultiarch", 1, NULL);
5623 /* Make this a separate argument. */
5624 do_spec_1 (" ", 0, NULL);
5625 do_spec_1 (multiarch_dir, 1, NULL);
5626 do_spec_1 (" ", 0, NULL);
5629 if (gcc_exec_prefix)
5631 do_spec_1 ("-iprefix", 1, NULL);
5632 /* Make this a separate argument. */
5633 do_spec_1 (" ", 0, NULL);
5634 do_spec_1 (gcc_exec_prefix, 1, NULL);
5635 do_spec_1 (" ", 0, NULL);
5638 if (target_system_root_changed ||
5639 (target_system_root && target_sysroot_hdrs_suffix))
5641 do_spec_1 ("-isysroot", 1, NULL);
5642 /* Make this a separate argument. */
5643 do_spec_1 (" ", 0, NULL);
5644 do_spec_1 (target_system_root, 1, NULL);
5645 if (target_sysroot_hdrs_suffix)
5646 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
5647 do_spec_1 (" ", 0, NULL);
5650 info.option = "-isystem";
5651 info.append = "include";
5652 info.append_len = strlen (info.append);
5653 info.omit_relative = false;
5654 info.separate_options = true;
5656 for_each_path (&include_prefixes, false, info.append_len,
5657 spec_path, &info);
5659 info.append = "include-fixed";
5660 if (*sysroot_hdrs_suffix_spec)
5661 info.append = concat (info.append, dir_separator_str,
5662 multilib_dir, NULL);
5663 info.append_len = strlen (info.append);
5664 for_each_path (&include_prefixes, false, info.append_len,
5665 spec_path, &info);
5667 break;
5669 case 'o':
5670 /* We are going to expand `%o' into `@FILE', where FILE
5671 is a newly-created temporary filename. The filenames
5672 that would usually be expanded in place of %o will be
5673 written to the temporary file. */
5674 if (at_file_supplied)
5675 open_at_file ();
5677 for (i = 0; i < n_infiles + lang_specific_extra_outfiles; i++)
5678 if (outfiles[i])
5679 store_arg (outfiles[i], 0, 0);
5681 if (at_file_supplied)
5682 close_at_file ();
5683 break;
5685 case 'O':
5686 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5687 arg_going = 1;
5688 break;
5690 case 's':
5691 this_is_library_file = 1;
5692 break;
5694 case 'T':
5695 this_is_linker_script = 1;
5696 break;
5698 case 'V':
5699 outfiles[input_file_number] = NULL;
5700 break;
5702 case 'w':
5703 this_is_output_file = 1;
5704 break;
5706 case 'W':
5708 unsigned int cur_index = argbuf.length ();
5709 /* Handle the {...} following the %W. */
5710 if (*p != '{')
5711 fatal_error (input_location,
5712 "spec %qs has invalid %<%%W%c%>", spec, *p);
5713 p = handle_braces (p + 1);
5714 if (p == 0)
5715 return -1;
5716 end_going_arg ();
5717 /* If any args were output, mark the last one for deletion
5718 on failure. */
5719 if (argbuf.length () != cur_index)
5720 record_temp_file (argbuf.last (), 0, 1);
5721 break;
5724 case '@':
5725 /* Handle the {...} following the %@. */
5726 if (*p != '{')
5727 fatal_error (input_location,
5728 "spec %qs has invalid %<%%@%c%>", spec, *p);
5729 if (at_file_supplied)
5730 open_at_file ();
5731 p = handle_braces (p + 1);
5732 if (at_file_supplied)
5733 close_at_file ();
5734 if (p == 0)
5735 return -1;
5736 break;
5738 /* %x{OPTION} records OPTION for %X to output. */
5739 case 'x':
5741 const char *p1 = p;
5742 char *string;
5743 char *opt;
5744 unsigned ix;
5746 /* Skip past the option value and make a copy. */
5747 if (*p != '{')
5748 fatal_error (input_location,
5749 "spec %qs has invalid %<%%x%c%>", spec, *p);
5750 while (*p++ != '}')
5752 string = save_string (p1 + 1, p - p1 - 2);
5754 /* See if we already recorded this option. */
5755 FOR_EACH_VEC_ELT (linker_options, ix, opt)
5756 if (! strcmp (string, opt))
5758 free (string);
5759 return 0;
5762 /* This option is new; add it. */
5763 add_linker_option (string, strlen (string));
5764 free (string);
5766 break;
5768 /* Dump out the options accumulated previously using %x. */
5769 case 'X':
5770 do_specs_vec (linker_options);
5771 break;
5773 /* Dump out the options accumulated previously using -Wa,. */
5774 case 'Y':
5775 do_specs_vec (assembler_options);
5776 break;
5778 /* Dump out the options accumulated previously using -Wp,. */
5779 case 'Z':
5780 do_specs_vec (preprocessor_options);
5781 break;
5783 /* Here are digits and numbers that just process
5784 a certain constant string as a spec. */
5786 case '1':
5787 value = do_spec_1 (cc1_spec, 0, NULL);
5788 if (value != 0)
5789 return value;
5790 break;
5792 case '2':
5793 value = do_spec_1 (cc1plus_spec, 0, NULL);
5794 if (value != 0)
5795 return value;
5796 break;
5798 case 'a':
5799 value = do_spec_1 (asm_spec, 0, NULL);
5800 if (value != 0)
5801 return value;
5802 break;
5804 case 'A':
5805 value = do_spec_1 (asm_final_spec, 0, NULL);
5806 if (value != 0)
5807 return value;
5808 break;
5810 case 'C':
5812 const char *const spec
5813 = (input_file_compiler->cpp_spec
5814 ? input_file_compiler->cpp_spec
5815 : cpp_spec);
5816 value = do_spec_1 (spec, 0, NULL);
5817 if (value != 0)
5818 return value;
5820 break;
5822 case 'E':
5823 value = do_spec_1 (endfile_spec, 0, NULL);
5824 if (value != 0)
5825 return value;
5826 break;
5828 case 'l':
5829 value = do_spec_1 (link_spec, 0, NULL);
5830 if (value != 0)
5831 return value;
5832 break;
5834 case 'L':
5835 value = do_spec_1 (lib_spec, 0, NULL);
5836 if (value != 0)
5837 return value;
5838 break;
5840 case 'M':
5841 if (multilib_os_dir == NULL)
5842 obstack_1grow (&obstack, '.');
5843 else
5844 obstack_grow (&obstack, multilib_os_dir,
5845 strlen (multilib_os_dir));
5846 break;
5848 case 'G':
5849 value = do_spec_1 (libgcc_spec, 0, NULL);
5850 if (value != 0)
5851 return value;
5852 break;
5854 case 'R':
5855 /* We assume there is a directory
5856 separator at the end of this string. */
5857 if (target_system_root)
5859 obstack_grow (&obstack, target_system_root,
5860 strlen (target_system_root));
5861 if (target_sysroot_suffix)
5862 obstack_grow (&obstack, target_sysroot_suffix,
5863 strlen (target_sysroot_suffix));
5865 break;
5867 case 'S':
5868 value = do_spec_1 (startfile_spec, 0, NULL);
5869 if (value != 0)
5870 return value;
5871 break;
5873 /* Here we define characters other than letters and digits. */
5875 case '{':
5876 p = handle_braces (p);
5877 if (p == 0)
5878 return -1;
5879 break;
5881 case ':':
5882 p = handle_spec_function (p, NULL, soft_matched_part);
5883 if (p == 0)
5884 return -1;
5885 break;
5887 case '%':
5888 obstack_1grow (&obstack, '%');
5889 break;
5891 case '.':
5893 unsigned len = 0;
5895 while (p[len] && p[len] != ' ' && p[len] != '%')
5896 len++;
5897 suffix_subst = save_string (p - 1, len + 1);
5898 p += len;
5900 break;
5902 /* Henceforth ignore the option(s) matching the pattern
5903 after the %<. */
5904 case '<':
5905 case '>':
5907 unsigned len = 0;
5908 int have_wildcard = 0;
5909 int i;
5910 int switch_option;
5912 if (c == '>')
5913 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5914 else
5915 switch_option = SWITCH_IGNORE;
5917 while (p[len] && p[len] != ' ' && p[len] != '\t')
5918 len++;
5920 if (p[len-1] == '*')
5921 have_wildcard = 1;
5923 for (i = 0; i < n_switches; i++)
5924 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5925 && (have_wildcard || switches[i].part1[len] == '\0'))
5927 switches[i].live_cond |= switch_option;
5928 /* User switch be validated from validate_all_switches.
5929 when the definition is seen from the spec file.
5930 If not defined anywhere, will be rejected. */
5931 if (switches[i].known)
5932 switches[i].validated = true;
5935 p += len;
5937 break;
5939 case '*':
5940 if (soft_matched_part)
5942 if (soft_matched_part[0])
5943 do_spec_1 (soft_matched_part, 1, NULL);
5944 /* Only insert a space after the substitution if it is at the
5945 end of the current sequence. So if:
5947 "%{foo=*:bar%*}%{foo=*:one%*two}"
5949 matches -foo=hello then it will produce:
5951 barhello onehellotwo
5953 if (*p == 0 || *p == '}')
5954 do_spec_1 (" ", 0, NULL);
5956 else
5957 /* Catch the case where a spec string contains something like
5958 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5959 hand side of the :. */
5960 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5961 break;
5963 /* Process a string found as the value of a spec given by name.
5964 This feature allows individual machine descriptions
5965 to add and use their own specs. */
5966 case '(':
5968 const char *name = p;
5969 struct spec_list *sl;
5970 int len;
5972 /* The string after the S/P is the name of a spec that is to be
5973 processed. */
5974 while (*p && *p != ')')
5975 p++;
5977 /* See if it's in the list. */
5978 for (len = p - name, sl = specs; sl; sl = sl->next)
5979 if (sl->name_len == len && !strncmp (sl->name, name, len))
5981 name = *(sl->ptr_spec);
5982 #ifdef DEBUG_SPECS
5983 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5984 sl->name, name);
5985 #endif
5986 break;
5989 if (sl)
5991 value = do_spec_1 (name, 0, NULL);
5992 if (value != 0)
5993 return value;
5996 /* Discard the closing paren. */
5997 if (*p)
5998 p++;
6000 break;
6002 default:
6003 error ("spec failure: unrecognized spec option %qc", c);
6004 break;
6006 break;
6008 case '\\':
6009 /* Backslash: treat next character as ordinary. */
6010 c = *p++;
6012 /* Fall through. */
6013 default:
6014 /* Ordinary character: put it into the current argument. */
6015 obstack_1grow (&obstack, c);
6016 arg_going = 1;
6019 /* End of string. If we are processing a spec function, we need to
6020 end any pending argument. */
6021 if (processing_spec_function)
6022 end_going_arg ();
6024 return 0;
6027 /* Look up a spec function. */
6029 static const struct spec_function *
6030 lookup_spec_function (const char *name)
6032 const struct spec_function *sf;
6034 for (sf = static_spec_functions; sf->name != NULL; sf++)
6035 if (strcmp (sf->name, name) == 0)
6036 return sf;
6038 return NULL;
6041 /* Evaluate a spec function. */
6043 static const char *
6044 eval_spec_function (const char *func, const char *args,
6045 const char *soft_matched_part)
6047 const struct spec_function *sf;
6048 const char *funcval;
6050 /* Saved spec processing context. */
6051 vec<const_char_p> save_argbuf;
6053 int save_arg_going;
6054 int save_delete_this_arg;
6055 int save_this_is_output_file;
6056 int save_this_is_library_file;
6057 int save_input_from_pipe;
6058 int save_this_is_linker_script;
6059 const char *save_suffix_subst;
6061 int save_growing_size;
6062 void *save_growing_value = NULL;
6064 sf = lookup_spec_function (func);
6065 if (sf == NULL)
6066 fatal_error (input_location, "unknown spec function %qs", func);
6068 /* Push the spec processing context. */
6069 save_argbuf = argbuf;
6071 save_arg_going = arg_going;
6072 save_delete_this_arg = delete_this_arg;
6073 save_this_is_output_file = this_is_output_file;
6074 save_this_is_library_file = this_is_library_file;
6075 save_this_is_linker_script = this_is_linker_script;
6076 save_input_from_pipe = input_from_pipe;
6077 save_suffix_subst = suffix_subst;
6079 /* If we have some object growing now, finalize it so the args and function
6080 eval proceed from a cleared context. This is needed to prevent the first
6081 constructed arg from mistakenly including the growing value. We'll push
6082 this value back on the obstack once the function evaluation is done, to
6083 restore a consistent processing context for our caller. This is fine as
6084 the address of growing objects isn't guaranteed to remain stable until
6085 they are finalized, and we expect this situation to be rare enough for
6086 the extra copy not to be an issue. */
6087 save_growing_size = obstack_object_size (&obstack);
6088 if (save_growing_size > 0)
6089 save_growing_value = obstack_finish (&obstack);
6091 /* Create a new spec processing context, and build the function
6092 arguments. */
6094 alloc_args ();
6095 if (do_spec_2 (args, soft_matched_part) < 0)
6096 fatal_error (input_location, "error in args to spec function %qs", func);
6098 /* argbuf_index is an index for the next argument to be inserted, and
6099 so contains the count of the args already inserted. */
6101 funcval = (*sf->func) (argbuf.length (),
6102 argbuf.address ());
6104 /* Pop the spec processing context. */
6105 argbuf.release ();
6106 argbuf = save_argbuf;
6108 arg_going = save_arg_going;
6109 delete_this_arg = save_delete_this_arg;
6110 this_is_output_file = save_this_is_output_file;
6111 this_is_library_file = save_this_is_library_file;
6112 this_is_linker_script = save_this_is_linker_script;
6113 input_from_pipe = save_input_from_pipe;
6114 suffix_subst = save_suffix_subst;
6116 if (save_growing_size > 0)
6117 obstack_grow (&obstack, save_growing_value, save_growing_size);
6119 return funcval;
6122 /* Handle a spec function call of the form:
6124 %:function(args)
6126 ARGS is processed as a spec in a separate context and split into an
6127 argument vector in the normal fashion. The function returns a string
6128 containing a spec which we then process in the caller's context, or
6129 NULL if no processing is required.
6131 If RETVAL_NONNULL is not NULL, then store a bool whether function
6132 returned non-NULL.
6134 SOFT_MATCHED_PART holds the current value of a matched * pattern, which
6135 may be re-expanded with a %* as part of the function arguments. */
6137 static const char *
6138 handle_spec_function (const char *p, bool *retval_nonnull,
6139 const char *soft_matched_part)
6141 char *func, *args;
6142 const char *endp, *funcval;
6143 int count;
6145 processing_spec_function++;
6147 /* Get the function name. */
6148 for (endp = p; *endp != '\0'; endp++)
6150 if (*endp == '(') /* ) */
6151 break;
6152 /* Only allow [A-Za-z0-9], -, and _ in function names. */
6153 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
6154 fatal_error (input_location, "malformed spec function name");
6156 if (*endp != '(') /* ) */
6157 fatal_error (input_location, "no arguments for spec function");
6158 func = save_string (p, endp - p);
6159 p = ++endp;
6161 /* Get the arguments. */
6162 for (count = 0; *endp != '\0'; endp++)
6164 /* ( */
6165 if (*endp == ')')
6167 if (count == 0)
6168 break;
6169 count--;
6171 else if (*endp == '(') /* ) */
6172 count++;
6174 /* ( */
6175 if (*endp != ')')
6176 fatal_error (input_location, "malformed spec function arguments");
6177 args = save_string (p, endp - p);
6178 p = ++endp;
6180 /* p now points to just past the end of the spec function expression. */
6182 funcval = eval_spec_function (func, args, soft_matched_part);
6183 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
6184 p = NULL;
6185 if (retval_nonnull)
6186 *retval_nonnull = funcval != NULL;
6188 free (func);
6189 free (args);
6191 processing_spec_function--;
6193 return p;
6196 /* Inline subroutine of handle_braces. Returns true if the current
6197 input suffix matches the atom bracketed by ATOM and END_ATOM. */
6198 static inline bool
6199 input_suffix_matches (const char *atom, const char *end_atom)
6201 return (input_suffix
6202 && !strncmp (input_suffix, atom, end_atom - atom)
6203 && input_suffix[end_atom - atom] == '\0');
6206 /* Subroutine of handle_braces. Returns true if the current
6207 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
6208 static bool
6209 input_spec_matches (const char *atom, const char *end_atom)
6211 return (input_file_compiler
6212 && input_file_compiler->suffix
6213 && input_file_compiler->suffix[0] != '\0'
6214 && !strncmp (input_file_compiler->suffix + 1, atom,
6215 end_atom - atom)
6216 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
6219 /* Subroutine of handle_braces. Returns true if a switch
6220 matching the atom bracketed by ATOM and END_ATOM appeared on the
6221 command line. */
6222 static bool
6223 switch_matches (const char *atom, const char *end_atom, int starred)
6225 int i;
6226 int len = end_atom - atom;
6227 int plen = starred ? len : -1;
6229 for (i = 0; i < n_switches; i++)
6230 if (!strncmp (switches[i].part1, atom, len)
6231 && (starred || switches[i].part1[len] == '\0')
6232 && check_live_switch (i, plen))
6233 return true;
6235 /* Check if a switch with separated form matching the atom.
6236 We check -D and -U switches. */
6237 else if (switches[i].args != 0)
6239 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
6240 && *switches[i].part1 == atom[0])
6242 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
6243 && (starred || (switches[i].part1[1] == '\0'
6244 && switches[i].args[0][len - 1] == '\0'))
6245 && check_live_switch (i, (starred ? 1 : -1)))
6246 return true;
6250 return false;
6253 /* Inline subroutine of handle_braces. Mark all of the switches which
6254 match ATOM (extends to END_ATOM; STARRED indicates whether there
6255 was a star after the atom) for later processing. */
6256 static inline void
6257 mark_matching_switches (const char *atom, const char *end_atom, int starred)
6259 int i;
6260 int len = end_atom - atom;
6261 int plen = starred ? len : -1;
6263 for (i = 0; i < n_switches; i++)
6264 if (!strncmp (switches[i].part1, atom, len)
6265 && (starred || switches[i].part1[len] == '\0')
6266 && check_live_switch (i, plen))
6267 switches[i].ordering = 1;
6270 /* Inline subroutine of handle_braces. Process all the currently
6271 marked switches through give_switch, and clear the marks. */
6272 static inline void
6273 process_marked_switches (void)
6275 int i;
6277 for (i = 0; i < n_switches; i++)
6278 if (switches[i].ordering == 1)
6280 switches[i].ordering = 0;
6281 give_switch (i, 0);
6285 /* Handle a %{ ... } construct. P points just inside the leading {.
6286 Returns a pointer one past the end of the brace block, or 0
6287 if we call do_spec_1 and that returns -1. */
6289 static const char *
6290 handle_braces (const char *p)
6292 const char *atom, *end_atom;
6293 const char *d_atom = NULL, *d_end_atom = NULL;
6294 char *esc_buf = NULL, *d_esc_buf = NULL;
6295 int esc;
6296 const char *orig = p;
6298 bool a_is_suffix;
6299 bool a_is_spectype;
6300 bool a_is_starred;
6301 bool a_is_negated;
6302 bool a_matched;
6304 bool a_must_be_last = false;
6305 bool ordered_set = false;
6306 bool disjunct_set = false;
6307 bool disj_matched = false;
6308 bool disj_starred = true;
6309 bool n_way_choice = false;
6310 bool n_way_matched = false;
6312 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
6316 if (a_must_be_last)
6317 goto invalid;
6319 /* Scan one "atom" (S in the description above of %{}, possibly
6320 with '!', '.', '@', ',', or '*' modifiers). */
6321 a_matched = false;
6322 a_is_suffix = false;
6323 a_is_starred = false;
6324 a_is_negated = false;
6325 a_is_spectype = false;
6327 SKIP_WHITE ();
6328 if (*p == '!')
6329 p++, a_is_negated = true;
6331 SKIP_WHITE ();
6332 if (*p == '%' && p[1] == ':')
6334 atom = NULL;
6335 end_atom = NULL;
6336 p = handle_spec_function (p + 2, &a_matched, NULL);
6338 else
6340 if (*p == '.')
6341 p++, a_is_suffix = true;
6342 else if (*p == ',')
6343 p++, a_is_spectype = true;
6345 atom = p;
6346 esc = 0;
6347 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
6348 || *p == ',' || *p == '.' || *p == '@' || *p == '\\')
6350 if (*p == '\\')
6352 p++;
6353 if (!*p)
6354 fatal_error (input_location,
6355 "braced spec %qs ends in escape", orig);
6356 esc++;
6358 p++;
6360 end_atom = p;
6362 if (esc)
6364 const char *ap;
6365 char *ep;
6367 if (esc_buf && esc_buf != d_esc_buf)
6368 free (esc_buf);
6369 esc_buf = NULL;
6370 ep = esc_buf = (char *) xmalloc (end_atom - atom - esc + 1);
6371 for (ap = atom; ap != end_atom; ap++, ep++)
6373 if (*ap == '\\')
6374 ap++;
6375 *ep = *ap;
6377 *ep = '\0';
6378 atom = esc_buf;
6379 end_atom = ep;
6382 if (*p == '*')
6383 p++, a_is_starred = 1;
6386 SKIP_WHITE ();
6387 switch (*p)
6389 case '&': case '}':
6390 /* Substitute the switch(es) indicated by the current atom. */
6391 ordered_set = true;
6392 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
6393 || a_is_spectype || atom == end_atom)
6394 goto invalid;
6396 mark_matching_switches (atom, end_atom, a_is_starred);
6398 if (*p == '}')
6399 process_marked_switches ();
6400 break;
6402 case '|': case ':':
6403 /* Substitute some text if the current atom appears as a switch
6404 or suffix. */
6405 disjunct_set = true;
6406 if (ordered_set)
6407 goto invalid;
6409 if (atom && atom == end_atom)
6411 if (!n_way_choice || disj_matched || *p == '|'
6412 || a_is_negated || a_is_suffix || a_is_spectype
6413 || a_is_starred)
6414 goto invalid;
6416 /* An empty term may appear as the last choice of an
6417 N-way choice set; it means "otherwise". */
6418 a_must_be_last = true;
6419 disj_matched = !n_way_matched;
6420 disj_starred = false;
6422 else
6424 if ((a_is_suffix || a_is_spectype) && a_is_starred)
6425 goto invalid;
6427 if (!a_is_starred)
6428 disj_starred = false;
6430 /* Don't bother testing this atom if we already have a
6431 match. */
6432 if (!disj_matched && !n_way_matched)
6434 if (atom == NULL)
6435 /* a_matched is already set by handle_spec_function. */;
6436 else if (a_is_suffix)
6437 a_matched = input_suffix_matches (atom, end_atom);
6438 else if (a_is_spectype)
6439 a_matched = input_spec_matches (atom, end_atom);
6440 else
6441 a_matched = switch_matches (atom, end_atom, a_is_starred);
6443 if (a_matched != a_is_negated)
6445 disj_matched = true;
6446 d_atom = atom;
6447 d_end_atom = end_atom;
6448 d_esc_buf = esc_buf;
6453 if (*p == ':')
6455 /* Found the body, that is, the text to substitute if the
6456 current disjunction matches. */
6457 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
6458 disj_matched && !n_way_matched);
6459 if (p == 0)
6460 goto done;
6462 /* If we have an N-way choice, reset state for the next
6463 disjunction. */
6464 if (*p == ';')
6466 n_way_choice = true;
6467 n_way_matched |= disj_matched;
6468 disj_matched = false;
6469 disj_starred = true;
6470 d_atom = d_end_atom = NULL;
6473 break;
6475 default:
6476 goto invalid;
6479 while (*p++ != '}');
6481 done:
6482 if (d_esc_buf && d_esc_buf != esc_buf)
6483 free (d_esc_buf);
6484 if (esc_buf)
6485 free (esc_buf);
6487 return p;
6489 invalid:
6490 fatal_error (input_location, "braced spec %qs is invalid at %qc", orig, *p);
6492 #undef SKIP_WHITE
6495 /* Subroutine of handle_braces. Scan and process a brace substitution body
6496 (X in the description of %{} syntax). P points one past the colon;
6497 ATOM and END_ATOM bracket the first atom which was found to be true
6498 (present) in the current disjunction; STARRED indicates whether all
6499 the atoms in the current disjunction were starred (for syntax validation);
6500 MATCHED indicates whether the disjunction matched or not, and therefore
6501 whether or not the body is to be processed through do_spec_1 or just
6502 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
6503 returns -1. */
6505 static const char *
6506 process_brace_body (const char *p, const char *atom, const char *end_atom,
6507 int starred, int matched)
6509 const char *body, *end_body;
6510 unsigned int nesting_level;
6511 bool have_subst = false;
6513 /* Locate the closing } or ;, honoring nested braces.
6514 Trim trailing whitespace. */
6515 body = p;
6516 nesting_level = 1;
6517 for (;;)
6519 if (*p == '{')
6520 nesting_level++;
6521 else if (*p == '}')
6523 if (!--nesting_level)
6524 break;
6526 else if (*p == ';' && nesting_level == 1)
6527 break;
6528 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
6529 have_subst = true;
6530 else if (*p == '\0')
6531 goto invalid;
6532 p++;
6535 end_body = p;
6536 while (end_body[-1] == ' ' || end_body[-1] == '\t')
6537 end_body--;
6539 if (have_subst && !starred)
6540 goto invalid;
6542 if (matched)
6544 /* Copy the substitution body to permanent storage and execute it.
6545 If have_subst is false, this is a simple matter of running the
6546 body through do_spec_1... */
6547 char *string = save_string (body, end_body - body);
6548 if (!have_subst)
6550 if (do_spec_1 (string, 0, NULL) < 0)
6552 free (string);
6553 return 0;
6556 else
6558 /* ... but if have_subst is true, we have to process the
6559 body once for each matching switch, with %* set to the
6560 variant part of the switch. */
6561 unsigned int hard_match_len = end_atom - atom;
6562 int i;
6564 for (i = 0; i < n_switches; i++)
6565 if (!strncmp (switches[i].part1, atom, hard_match_len)
6566 && check_live_switch (i, hard_match_len))
6568 if (do_spec_1 (string, 0,
6569 &switches[i].part1[hard_match_len]) < 0)
6571 free (string);
6572 return 0;
6574 /* Pass any arguments this switch has. */
6575 give_switch (i, 1);
6576 suffix_subst = NULL;
6579 free (string);
6582 return p;
6584 invalid:
6585 fatal_error (input_location, "braced spec body %qs is invalid", body);
6588 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
6589 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
6590 spec, or -1 if either exact match or %* is used.
6592 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
6593 whose value does not begin with "no-" is obsoleted by the same value
6594 with the "no-", similarly for a switch with the "no-" prefix. */
6596 static int
6597 check_live_switch (int switchnum, int prefix_length)
6599 const char *name = switches[switchnum].part1;
6600 int i;
6602 /* If we already processed this switch and determined if it was
6603 live or not, return our past determination. */
6604 if (switches[switchnum].live_cond != 0)
6605 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
6606 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
6607 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
6608 == 0);
6610 /* In the common case of {<at-most-one-letter>*}, a negating
6611 switch would always match, so ignore that case. We will just
6612 send the conflicting switches to the compiler phase. */
6613 if (prefix_length >= 0 && prefix_length <= 1)
6614 return 1;
6616 /* Now search for duplicate in a manner that depends on the name. */
6617 switch (*name)
6619 case 'O':
6620 for (i = switchnum + 1; i < n_switches; i++)
6621 if (switches[i].part1[0] == 'O')
6623 switches[switchnum].validated = true;
6624 switches[switchnum].live_cond = SWITCH_FALSE;
6625 return 0;
6627 break;
6629 case 'W': case 'f': case 'm': case 'g':
6630 if (! strncmp (name + 1, "no-", 3))
6632 /* We have Xno-YYY, search for XYYY. */
6633 for (i = switchnum + 1; i < n_switches; i++)
6634 if (switches[i].part1[0] == name[0]
6635 && ! strcmp (&switches[i].part1[1], &name[4]))
6637 /* --specs are validated with the validate_switches mechanism. */
6638 if (switches[switchnum].known)
6639 switches[switchnum].validated = true;
6640 switches[switchnum].live_cond = SWITCH_FALSE;
6641 return 0;
6644 else
6646 /* We have XYYY, search for Xno-YYY. */
6647 for (i = switchnum + 1; i < n_switches; i++)
6648 if (switches[i].part1[0] == name[0]
6649 && switches[i].part1[1] == 'n'
6650 && switches[i].part1[2] == 'o'
6651 && switches[i].part1[3] == '-'
6652 && !strcmp (&switches[i].part1[4], &name[1]))
6654 /* --specs are validated with the validate_switches mechanism. */
6655 if (switches[switchnum].known)
6656 switches[switchnum].validated = true;
6657 switches[switchnum].live_cond = SWITCH_FALSE;
6658 return 0;
6661 break;
6664 /* Otherwise the switch is live. */
6665 switches[switchnum].live_cond |= SWITCH_LIVE;
6666 return 1;
6669 /* Pass a switch to the current accumulating command
6670 in the same form that we received it.
6671 SWITCHNUM identifies the switch; it is an index into
6672 the vector of switches gcc received, which is `switches'.
6673 This cannot fail since it never finishes a command line.
6675 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
6677 static void
6678 give_switch (int switchnum, int omit_first_word)
6680 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
6681 return;
6683 if (!omit_first_word)
6685 do_spec_1 ("-", 0, NULL);
6686 do_spec_1 (switches[switchnum].part1, 1, NULL);
6689 if (switches[switchnum].args != 0)
6691 const char **p;
6692 for (p = switches[switchnum].args; *p; p++)
6694 const char *arg = *p;
6696 do_spec_1 (" ", 0, NULL);
6697 if (suffix_subst)
6699 unsigned length = strlen (arg);
6700 int dot = 0;
6702 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
6703 if (arg[length] == '.')
6705 (CONST_CAST (char *, arg))[length] = 0;
6706 dot = 1;
6707 break;
6709 do_spec_1 (arg, 1, NULL);
6710 if (dot)
6711 (CONST_CAST (char *, arg))[length] = '.';
6712 do_spec_1 (suffix_subst, 1, NULL);
6714 else
6715 do_spec_1 (arg, 1, NULL);
6719 do_spec_1 (" ", 0, NULL);
6720 switches[switchnum].validated = true;
6723 /* Print GCC configuration (e.g. version, thread model, target,
6724 configuration_arguments) to a given FILE. */
6726 static void
6727 print_configuration (FILE *file)
6729 int n;
6730 const char *thrmod;
6732 fnotice (file, "Target: %s\n", spec_machine);
6733 fnotice (file, "Configured with: %s\n", configuration_arguments);
6735 #ifdef THREAD_MODEL_SPEC
6736 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6737 but there's no point in doing all this processing just to get
6738 thread_model back. */
6739 obstack_init (&obstack);
6740 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6741 obstack_1grow (&obstack, '\0');
6742 thrmod = XOBFINISH (&obstack, const char *);
6743 #else
6744 thrmod = thread_model;
6745 #endif
6747 fnotice (file, "Thread model: %s\n", thrmod);
6749 /* compiler_version is truncated at the first space when initialized
6750 from version string, so truncate version_string at the first space
6751 before comparing. */
6752 for (n = 0; version_string[n]; n++)
6753 if (version_string[n] == ' ')
6754 break;
6756 if (! strncmp (version_string, compiler_version, n)
6757 && compiler_version[n] == 0)
6758 fnotice (file, "gcc version %s %s\n", version_string,
6759 pkgversion_string);
6760 else
6761 fnotice (file, "gcc driver version %s %sexecuting gcc version %s\n",
6762 version_string, pkgversion_string, compiler_version);
6766 #define RETRY_ICE_ATTEMPTS 3
6768 /* Returns true if FILE1 and FILE2 contain equivalent data, 0 otherwise. */
6770 static bool
6771 files_equal_p (char *file1, char *file2)
6773 struct stat st1, st2;
6774 off_t n, len;
6775 int fd1, fd2;
6776 const int bufsize = 8192;
6777 char *buf = XNEWVEC (char, bufsize);
6779 fd1 = open (file1, O_RDONLY);
6780 fd2 = open (file2, O_RDONLY);
6782 if (fd1 < 0 || fd2 < 0)
6783 goto error;
6785 if (fstat (fd1, &st1) < 0 || fstat (fd2, &st2) < 0)
6786 goto error;
6788 if (st1.st_size != st2.st_size)
6789 goto error;
6791 for (n = st1.st_size; n; n -= len)
6793 len = n;
6794 if ((int) len > bufsize / 2)
6795 len = bufsize / 2;
6797 if (read (fd1, buf, len) != (int) len
6798 || read (fd2, buf + bufsize / 2, len) != (int) len)
6800 goto error;
6803 if (memcmp (buf, buf + bufsize / 2, len) != 0)
6804 goto error;
6807 free (buf);
6808 close (fd1);
6809 close (fd2);
6811 return 1;
6813 error:
6814 free (buf);
6815 close (fd1);
6816 close (fd2);
6817 return 0;
6820 /* Check that compiler's output doesn't differ across runs.
6821 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are arrays of files, containing
6822 stdout and stderr for each compiler run. Return true if all of
6823 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are equivalent. */
6825 static bool
6826 check_repro (char **temp_stdout_files, char **temp_stderr_files)
6828 int i;
6829 for (i = 0; i < RETRY_ICE_ATTEMPTS - 2; ++i)
6831 if (!files_equal_p (temp_stdout_files[i], temp_stdout_files[i + 1])
6832 || !files_equal_p (temp_stderr_files[i], temp_stderr_files[i + 1]))
6834 fnotice (stderr, "The bug is not reproducible, so it is"
6835 " likely a hardware or OS problem.\n");
6836 break;
6839 return i == RETRY_ICE_ATTEMPTS - 2;
6842 enum attempt_status {
6843 ATTEMPT_STATUS_FAIL_TO_RUN,
6844 ATTEMPT_STATUS_SUCCESS,
6845 ATTEMPT_STATUS_ICE
6849 /* Run compiler with arguments NEW_ARGV to reproduce the ICE, storing stdout
6850 to OUT_TEMP and stderr to ERR_TEMP. If APPEND is TRUE, append to OUT_TEMP
6851 and ERR_TEMP instead of truncating. If EMIT_SYSTEM_INFO is TRUE, also write
6852 GCC configuration into to ERR_TEMP. Return ATTEMPT_STATUS_FAIL_TO_RUN if
6853 compiler failed to run, ATTEMPT_STATUS_ICE if compiled ICE-ed and
6854 ATTEMPT_STATUS_SUCCESS otherwise. */
6856 static enum attempt_status
6857 run_attempt (const char **new_argv, const char *out_temp,
6858 const char *err_temp, int emit_system_info, int append)
6861 if (emit_system_info)
6863 FILE *file_out = fopen (err_temp, "a");
6864 print_configuration (file_out);
6865 fputs ("\n", file_out);
6866 fclose (file_out);
6869 int exit_status;
6870 const char *errmsg;
6871 struct pex_obj *pex;
6872 int err;
6873 int pex_flags = PEX_USE_PIPES | PEX_LAST;
6874 enum attempt_status status = ATTEMPT_STATUS_FAIL_TO_RUN;
6876 if (append)
6877 pex_flags |= PEX_STDOUT_APPEND | PEX_STDERR_APPEND;
6879 pex = pex_init (PEX_USE_PIPES, new_argv[0], NULL);
6880 if (!pex)
6881 fatal_error (input_location, "pex_init failed: %m");
6883 errmsg = pex_run (pex, pex_flags, new_argv[0],
6884 CONST_CAST2 (char *const *, const char **, &new_argv[1]), out_temp,
6885 err_temp, &err);
6886 if (errmsg != NULL)
6888 errno = err;
6889 fatal_error (input_location,
6890 err ? G_ ("cannot execute %qs: %s: %m")
6891 : G_ ("cannot execute %qs: %s"),
6892 new_argv[0], errmsg);
6895 if (!pex_get_status (pex, 1, &exit_status))
6896 goto out;
6898 switch (WEXITSTATUS (exit_status))
6900 case ICE_EXIT_CODE:
6901 status = ATTEMPT_STATUS_ICE;
6902 break;
6904 case SUCCESS_EXIT_CODE:
6905 status = ATTEMPT_STATUS_SUCCESS;
6906 break;
6908 default:
6912 out:
6913 pex_free (pex);
6914 return status;
6917 /* This routine reads lines from IN file, adds C++ style comments
6918 at the begining of each line and writes result into OUT. */
6920 static void
6921 insert_comments (const char *file_in, const char *file_out)
6923 FILE *in = fopen (file_in, "rb");
6924 FILE *out = fopen (file_out, "wb");
6925 char line[256];
6927 bool add_comment = true;
6928 while (fgets (line, sizeof (line), in))
6930 if (add_comment)
6931 fputs ("// ", out);
6932 fputs (line, out);
6933 add_comment = strchr (line, '\n') != NULL;
6936 fclose (in);
6937 fclose (out);
6940 /* This routine adds preprocessed source code into the given ERR_FILE.
6941 To do this, it adds "-E" to NEW_ARGV and execute RUN_ATTEMPT routine to
6942 add information in report file. RUN_ATTEMPT should return
6943 ATTEMPT_STATUS_SUCCESS, in other case we cannot generate the report. */
6945 static void
6946 do_report_bug (const char **new_argv, const int nargs,
6947 char **out_file, char **err_file)
6949 int i, status;
6950 int fd = open (*out_file, O_RDWR | O_APPEND);
6951 if (fd < 0)
6952 return;
6953 write (fd, "\n//", 3);
6954 for (i = 0; i < nargs; i++)
6956 write (fd, " ", 1);
6957 write (fd, new_argv[i], strlen (new_argv[i]));
6959 write (fd, "\n\n", 2);
6960 close (fd);
6961 new_argv[nargs] = "-E";
6962 new_argv[nargs + 1] = NULL;
6964 status = run_attempt (new_argv, *out_file, *err_file, 0, 1);
6966 if (status == ATTEMPT_STATUS_SUCCESS)
6968 fnotice (stderr, "Preprocessed source stored into %s file,"
6969 " please attach this to your bugreport.\n", *out_file);
6970 /* Make sure it is not deleted. */
6971 free (*out_file);
6972 *out_file = NULL;
6976 /* Try to reproduce ICE. If bug is reproducible, generate report .err file
6977 containing GCC configuration, backtrace, compiler's command line options
6978 and preprocessed source code. */
6980 static void
6981 try_generate_repro (const char **argv)
6983 int i, nargs, out_arg = -1, quiet = 0, attempt;
6984 const char **new_argv;
6985 char *temp_files[RETRY_ICE_ATTEMPTS * 2];
6986 char **temp_stdout_files = &temp_files[0];
6987 char **temp_stderr_files = &temp_files[RETRY_ICE_ATTEMPTS];
6989 if (gcc_input_filename == NULL || ! strcmp (gcc_input_filename, "-"))
6990 return;
6992 for (nargs = 0; argv[nargs] != NULL; ++nargs)
6993 /* Only retry compiler ICEs, not preprocessor ones. */
6994 if (! strcmp (argv[nargs], "-E"))
6995 return;
6996 else if (argv[nargs][0] == '-' && argv[nargs][1] == 'o')
6998 if (out_arg == -1)
6999 out_arg = nargs;
7000 else
7001 return;
7003 /* If the compiler is going to output any time information,
7004 it might varry between invocations. */
7005 else if (! strcmp (argv[nargs], "-quiet"))
7006 quiet = 1;
7007 else if (! strcmp (argv[nargs], "-ftime-report"))
7008 return;
7010 if (out_arg == -1 || !quiet)
7011 return;
7013 memset (temp_files, '\0', sizeof (temp_files));
7014 new_argv = XALLOCAVEC (const char *, nargs + 4);
7015 memcpy (new_argv, argv, (nargs + 1) * sizeof (const char *));
7016 new_argv[nargs++] = "-frandom-seed=0";
7017 new_argv[nargs++] = "-fdump-noaddr";
7018 new_argv[nargs] = NULL;
7019 if (new_argv[out_arg][2] == '\0')
7020 new_argv[out_arg + 1] = "-";
7021 else
7022 new_argv[out_arg] = "-o-";
7024 int status;
7025 for (attempt = 0; attempt < RETRY_ICE_ATTEMPTS; ++attempt)
7027 int emit_system_info = 0;
7028 int append = 0;
7029 temp_stdout_files[attempt] = make_temp_file (".out");
7030 temp_stderr_files[attempt] = make_temp_file (".err");
7032 if (attempt == RETRY_ICE_ATTEMPTS - 1)
7034 append = 1;
7035 emit_system_info = 1;
7038 status = run_attempt (new_argv, temp_stdout_files[attempt],
7039 temp_stderr_files[attempt], emit_system_info,
7040 append);
7042 if (status != ATTEMPT_STATUS_ICE)
7044 fnotice (stderr, "The bug is not reproducible, so it is"
7045 " likely a hardware or OS problem.\n");
7046 goto out;
7050 if (!check_repro (temp_stdout_files, temp_stderr_files))
7051 goto out;
7054 /* Insert commented out backtrace into report file. */
7055 char **stderr_commented = &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1];
7056 insert_comments (temp_stderr_files[RETRY_ICE_ATTEMPTS - 1],
7057 *stderr_commented);
7059 /* In final attempt we append compiler options and preprocesssed code to last
7060 generated .out file with configuration and backtrace. */
7061 char **err = &temp_stderr_files[RETRY_ICE_ATTEMPTS - 1];
7062 do_report_bug (new_argv, nargs, stderr_commented, err);
7065 out:
7066 for (i = 0; i < RETRY_ICE_ATTEMPTS * 2; i++)
7067 if (temp_files[i])
7069 unlink (temp_stdout_files[i]);
7070 free (temp_stdout_files[i]);
7074 /* Search for a file named NAME trying various prefixes including the
7075 user's -B prefix and some standard ones.
7076 Return the absolute file name found. If nothing is found, return NAME. */
7078 static const char *
7079 find_file (const char *name)
7081 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
7082 return newname ? newname : name;
7085 /* Determine whether a directory exists. If LINKER, return 0 for
7086 certain fixed names not needed by the linker. */
7088 static int
7089 is_directory (const char *path1, bool linker)
7091 int len1;
7092 char *path;
7093 char *cp;
7094 struct stat st;
7096 /* Ensure the string ends with "/.". The resulting path will be a
7097 directory even if the given path is a symbolic link. */
7098 len1 = strlen (path1);
7099 path = (char *) alloca (3 + len1);
7100 memcpy (path, path1, len1);
7101 cp = path + len1;
7102 if (!IS_DIR_SEPARATOR (cp[-1]))
7103 *cp++ = DIR_SEPARATOR;
7104 *cp++ = '.';
7105 *cp = '\0';
7107 /* Exclude directories that the linker is known to search. */
7108 if (linker
7109 && IS_DIR_SEPARATOR (path[0])
7110 && ((cp - path == 6
7111 && filename_ncmp (path + 1, "lib", 3) == 0)
7112 || (cp - path == 10
7113 && filename_ncmp (path + 1, "usr", 3) == 0
7114 && IS_DIR_SEPARATOR (path[4])
7115 && filename_ncmp (path + 5, "lib", 3) == 0)))
7116 return 0;
7118 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
7121 /* Set up the various global variables to indicate that we're processing
7122 the input file named FILENAME. */
7124 void
7125 set_input (const char *filename)
7127 const char *p;
7129 gcc_input_filename = filename;
7130 input_filename_length = strlen (gcc_input_filename);
7131 input_basename = lbasename (gcc_input_filename);
7133 /* Find a suffix starting with the last period,
7134 and set basename_length to exclude that suffix. */
7135 basename_length = strlen (input_basename);
7136 suffixed_basename_length = basename_length;
7137 p = input_basename + basename_length;
7138 while (p != input_basename && *p != '.')
7139 --p;
7140 if (*p == '.' && p != input_basename)
7142 basename_length = p - input_basename;
7143 input_suffix = p + 1;
7145 else
7146 input_suffix = "";
7148 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
7149 we will need to do a stat on the gcc_input_filename. The
7150 INPUT_STAT_SET signals that the stat is needed. */
7151 input_stat_set = 0;
7154 /* On fatal signals, delete all the temporary files. */
7156 static void
7157 fatal_signal (int signum)
7159 signal (signum, SIG_DFL);
7160 delete_failure_queue ();
7161 delete_temp_files ();
7162 /* Get the same signal again, this time not handled,
7163 so its normal effect occurs. */
7164 kill (getpid (), signum);
7167 /* Compare the contents of the two files named CMPFILE[0] and
7168 CMPFILE[1]. Return zero if they're identical, nonzero
7169 otherwise. */
7171 static int
7172 compare_files (char *cmpfile[])
7174 int ret = 0;
7175 FILE *temp[2] = { NULL, NULL };
7176 int i;
7178 #if HAVE_MMAP_FILE
7180 size_t length[2];
7181 void *map[2] = { NULL, NULL };
7183 for (i = 0; i < 2; i++)
7185 struct stat st;
7187 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
7189 error ("%s: could not determine length of compare-debug file %s",
7190 gcc_input_filename, cmpfile[i]);
7191 ret = 1;
7192 break;
7195 length[i] = st.st_size;
7198 if (!ret && length[0] != length[1])
7200 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
7201 ret = 1;
7204 if (!ret)
7205 for (i = 0; i < 2; i++)
7207 int fd = open (cmpfile[i], O_RDONLY);
7208 if (fd < 0)
7210 error ("%s: could not open compare-debug file %s",
7211 gcc_input_filename, cmpfile[i]);
7212 ret = 1;
7213 break;
7216 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
7217 close (fd);
7219 if (map[i] == (void *) MAP_FAILED)
7221 ret = -1;
7222 break;
7226 if (!ret)
7228 if (memcmp (map[0], map[1], length[0]) != 0)
7230 error ("%s: -fcompare-debug failure", gcc_input_filename);
7231 ret = 1;
7235 for (i = 0; i < 2; i++)
7236 if (map[i])
7237 munmap ((caddr_t) map[i], length[i]);
7239 if (ret >= 0)
7240 return ret;
7242 ret = 0;
7244 #endif
7246 for (i = 0; i < 2; i++)
7248 temp[i] = fopen (cmpfile[i], "r");
7249 if (!temp[i])
7251 error ("%s: could not open compare-debug file %s",
7252 gcc_input_filename, cmpfile[i]);
7253 ret = 1;
7254 break;
7258 if (!ret && temp[0] && temp[1])
7259 for (;;)
7261 int c0, c1;
7262 c0 = fgetc (temp[0]);
7263 c1 = fgetc (temp[1]);
7265 if (c0 != c1)
7267 error ("%s: -fcompare-debug failure",
7268 gcc_input_filename);
7269 ret = 1;
7270 break;
7273 if (c0 == EOF)
7274 break;
7277 for (i = 1; i >= 0; i--)
7279 if (temp[i])
7280 fclose (temp[i]);
7283 return ret;
7286 driver::driver (bool can_finalize, bool debug) :
7287 explicit_link_files (NULL),
7288 decoded_options (NULL)
7290 env.init (can_finalize, debug);
7293 driver::~driver ()
7295 XDELETEVEC (explicit_link_files);
7296 XDELETEVEC (decoded_options);
7299 /* driver::main is implemented as a series of driver:: method calls. */
7302 driver::main (int argc, char **argv)
7304 bool early_exit;
7306 set_progname (argv[0]);
7307 expand_at_files (&argc, &argv);
7308 decode_argv (argc, const_cast <const char **> (argv));
7309 global_initializations ();
7310 build_multilib_strings ();
7311 set_up_specs ();
7312 putenv_COLLECT_GCC (argv[0]);
7313 maybe_putenv_COLLECT_LTO_WRAPPER ();
7314 maybe_putenv_OFFLOAD_TARGETS ();
7315 handle_unrecognized_options ();
7317 if (completion)
7319 m_option_proposer.suggest_completion (completion);
7320 return 0;
7323 if (!maybe_print_and_exit ())
7324 return 0;
7326 early_exit = prepare_infiles ();
7327 if (early_exit)
7328 return get_exit_code ();
7330 do_spec_on_infiles ();
7331 maybe_run_linker (argv[0]);
7332 final_actions ();
7333 return get_exit_code ();
7336 /* Locate the final component of argv[0] after any leading path, and set
7337 the program name accordingly. */
7339 void
7340 driver::set_progname (const char *argv0) const
7342 const char *p = argv0 + strlen (argv0);
7343 while (p != argv0 && !IS_DIR_SEPARATOR (p[-1]))
7344 --p;
7345 progname = p;
7347 xmalloc_set_program_name (progname);
7350 /* Expand any @ files within the command-line args,
7351 setting at_file_supplied if any were expanded. */
7353 void
7354 driver::expand_at_files (int *argc, char ***argv) const
7356 char **old_argv = *argv;
7358 expandargv (argc, argv);
7360 /* Determine if any expansions were made. */
7361 if (*argv != old_argv)
7362 at_file_supplied = true;
7365 /* Decode the command-line arguments from argc/argv into the
7366 decoded_options array. */
7368 void
7369 driver::decode_argv (int argc, const char **argv)
7371 /* Register the language-independent parameters. */
7372 global_init_params ();
7373 finish_params ();
7375 init_opts_obstack ();
7376 init_options_struct (&global_options, &global_options_set);
7378 decode_cmdline_options_to_array (argc, argv,
7379 CL_DRIVER,
7380 &decoded_options, &decoded_options_count);
7383 /* Perform various initializations and setup. */
7385 void
7386 driver::global_initializations ()
7388 /* Unlock the stdio streams. */
7389 unlock_std_streams ();
7391 gcc_init_libintl ();
7393 diagnostic_initialize (global_dc, 0);
7394 diagnostic_color_init (global_dc);
7396 #ifdef GCC_DRIVER_HOST_INITIALIZATION
7397 /* Perform host dependent initialization when needed. */
7398 GCC_DRIVER_HOST_INITIALIZATION;
7399 #endif
7401 if (atexit (delete_temp_files) != 0)
7402 fatal_error (input_location, "atexit failed");
7404 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
7405 signal (SIGINT, fatal_signal);
7406 #ifdef SIGHUP
7407 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
7408 signal (SIGHUP, fatal_signal);
7409 #endif
7410 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
7411 signal (SIGTERM, fatal_signal);
7412 #ifdef SIGPIPE
7413 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
7414 signal (SIGPIPE, fatal_signal);
7415 #endif
7416 #ifdef SIGCHLD
7417 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
7418 receive the signal. A different setting is inheritable */
7419 signal (SIGCHLD, SIG_DFL);
7420 #endif
7422 /* Parsing and gimplification sometimes need quite large stack.
7423 Increase stack size limits if possible. */
7424 stack_limit_increase (64 * 1024 * 1024);
7426 /* Allocate the argument vector. */
7427 alloc_args ();
7429 obstack_init (&obstack);
7432 /* Build multilib_select, et. al from the separate lines that make up each
7433 multilib selection. */
7435 void
7436 driver::build_multilib_strings () const
7439 const char *p;
7440 const char *const *q = multilib_raw;
7441 int need_space;
7443 obstack_init (&multilib_obstack);
7444 while ((p = *q++) != (char *) 0)
7445 obstack_grow (&multilib_obstack, p, strlen (p));
7447 obstack_1grow (&multilib_obstack, 0);
7448 multilib_select = XOBFINISH (&multilib_obstack, const char *);
7450 q = multilib_matches_raw;
7451 while ((p = *q++) != (char *) 0)
7452 obstack_grow (&multilib_obstack, p, strlen (p));
7454 obstack_1grow (&multilib_obstack, 0);
7455 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
7457 q = multilib_exclusions_raw;
7458 while ((p = *q++) != (char *) 0)
7459 obstack_grow (&multilib_obstack, p, strlen (p));
7461 obstack_1grow (&multilib_obstack, 0);
7462 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
7464 q = multilib_reuse_raw;
7465 while ((p = *q++) != (char *) 0)
7466 obstack_grow (&multilib_obstack, p, strlen (p));
7468 obstack_1grow (&multilib_obstack, 0);
7469 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
7471 need_space = FALSE;
7472 for (size_t i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
7474 if (need_space)
7475 obstack_1grow (&multilib_obstack, ' ');
7476 obstack_grow (&multilib_obstack,
7477 multilib_defaults_raw[i],
7478 strlen (multilib_defaults_raw[i]));
7479 need_space = TRUE;
7482 obstack_1grow (&multilib_obstack, 0);
7483 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
7487 /* Set up the spec-handling machinery. */
7489 void
7490 driver::set_up_specs () const
7492 const char *spec_machine_suffix;
7493 char *specs_file;
7494 size_t i;
7496 #ifdef INIT_ENVIRONMENT
7497 /* Set up any other necessary machine specific environment variables. */
7498 xputenv (INIT_ENVIRONMENT);
7499 #endif
7501 /* Make a table of what switches there are (switches, n_switches).
7502 Make a table of specified input files (infiles, n_infiles).
7503 Decode switches that are handled locally. */
7505 process_command (decoded_options_count, decoded_options);
7507 /* Initialize the vector of specs to just the default.
7508 This means one element containing 0s, as a terminator. */
7510 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
7511 memcpy (compilers, default_compilers, sizeof default_compilers);
7512 n_compilers = n_default_compilers;
7514 /* Read specs from a file if there is one. */
7516 machine_suffix = concat (spec_host_machine, dir_separator_str, spec_version,
7517 accel_dir_suffix, dir_separator_str, NULL);
7518 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
7520 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
7521 /* Read the specs file unless it is a default one. */
7522 if (specs_file != 0 && strcmp (specs_file, "specs"))
7523 read_specs (specs_file, true, false);
7524 else
7525 init_spec ();
7527 #ifdef ACCEL_COMPILER
7528 spec_machine_suffix = machine_suffix;
7529 #else
7530 spec_machine_suffix = just_machine_suffix;
7531 #endif
7533 /* We need to check standard_exec_prefix/spec_machine_suffix/specs
7534 for any override of as, ld and libraries. */
7535 specs_file = (char *) alloca (strlen (standard_exec_prefix)
7536 + strlen (spec_machine_suffix) + sizeof ("specs"));
7537 strcpy (specs_file, standard_exec_prefix);
7538 strcat (specs_file, spec_machine_suffix);
7539 strcat (specs_file, "specs");
7540 if (access (specs_file, R_OK) == 0)
7541 read_specs (specs_file, true, false);
7543 /* Process any configure-time defaults specified for the command line
7544 options, via OPTION_DEFAULT_SPECS. */
7545 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
7546 do_option_spec (option_default_specs[i].name,
7547 option_default_specs[i].spec);
7549 /* Process DRIVER_SELF_SPECS, adding any new options to the end
7550 of the command line. */
7552 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
7553 do_self_spec (driver_self_specs[i]);
7555 /* If not cross-compiling, look for executables in the standard
7556 places. */
7557 if (*cross_compile == '0')
7559 if (*md_exec_prefix)
7561 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
7562 PREFIX_PRIORITY_LAST, 0, 0);
7566 /* Process sysroot_suffix_spec. */
7567 if (*sysroot_suffix_spec != 0
7568 && !no_sysroot_suffix
7569 && do_spec_2 (sysroot_suffix_spec, NULL) == 0)
7571 if (argbuf.length () > 1)
7572 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
7573 else if (argbuf.length () == 1)
7574 target_sysroot_suffix = xstrdup (argbuf.last ());
7577 #ifdef HAVE_LD_SYSROOT
7578 /* Pass the --sysroot option to the linker, if it supports that. If
7579 there is a sysroot_suffix_spec, it has already been processed by
7580 this point, so target_system_root really is the system root we
7581 should be using. */
7582 if (target_system_root)
7584 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
7585 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
7586 set_spec ("link", XOBFINISH (&obstack, const char *), false);
7588 #endif
7590 /* Process sysroot_hdrs_suffix_spec. */
7591 if (*sysroot_hdrs_suffix_spec != 0
7592 && !no_sysroot_suffix
7593 && do_spec_2 (sysroot_hdrs_suffix_spec, NULL) == 0)
7595 if (argbuf.length () > 1)
7596 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
7597 else if (argbuf.length () == 1)
7598 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
7601 /* Look for startfiles in the standard places. */
7602 if (*startfile_prefix_spec != 0
7603 && do_spec_2 (startfile_prefix_spec, NULL) == 0
7604 && do_spec_1 (" ", 0, NULL) == 0)
7606 const char *arg;
7607 int ndx;
7608 FOR_EACH_VEC_ELT (argbuf, ndx, arg)
7609 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
7610 PREFIX_PRIORITY_LAST, 0, 1);
7612 /* We should eventually get rid of all these and stick to
7613 startfile_prefix_spec exclusively. */
7614 else if (*cross_compile == '0' || target_system_root)
7616 if (*md_startfile_prefix)
7617 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
7618 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7620 if (*md_startfile_prefix_1)
7621 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
7622 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7624 /* If standard_startfile_prefix is relative, base it on
7625 standard_exec_prefix. This lets us move the installed tree
7626 as a unit. If GCC_EXEC_PREFIX is defined, base
7627 standard_startfile_prefix on that as well.
7629 If the prefix is relative, only search it for native compilers;
7630 otherwise we will search a directory containing host libraries. */
7631 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
7632 add_sysrooted_prefix (&startfile_prefixes,
7633 standard_startfile_prefix, "BINUTILS",
7634 PREFIX_PRIORITY_LAST, 0, 1);
7635 else if (*cross_compile == '0')
7637 add_prefix (&startfile_prefixes,
7638 concat (gcc_exec_prefix
7639 ? gcc_exec_prefix : standard_exec_prefix,
7640 machine_suffix,
7641 standard_startfile_prefix, NULL),
7642 NULL, PREFIX_PRIORITY_LAST, 0, 1);
7645 /* Sysrooted prefixes are relocated because target_system_root is
7646 also relocated by gcc_exec_prefix. */
7647 if (*standard_startfile_prefix_1)
7648 add_sysrooted_prefix (&startfile_prefixes,
7649 standard_startfile_prefix_1, "BINUTILS",
7650 PREFIX_PRIORITY_LAST, 0, 1);
7651 if (*standard_startfile_prefix_2)
7652 add_sysrooted_prefix (&startfile_prefixes,
7653 standard_startfile_prefix_2, "BINUTILS",
7654 PREFIX_PRIORITY_LAST, 0, 1);
7657 /* Process any user specified specs in the order given on the command
7658 line. */
7659 for (struct user_specs *uptr = user_specs_head; uptr; uptr = uptr->next)
7661 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
7662 R_OK, true);
7663 read_specs (filename ? filename : uptr->filename, false, true);
7666 /* Process any user self specs. */
7668 struct spec_list *sl;
7669 for (sl = specs; sl; sl = sl->next)
7670 if (sl->name_len == sizeof "self_spec" - 1
7671 && !strcmp (sl->name, "self_spec"))
7672 do_self_spec (*sl->ptr_spec);
7675 if (compare_debug)
7677 enum save_temps save;
7679 if (!compare_debug_second)
7681 n_switches_debug_check[1] = n_switches;
7682 n_switches_alloc_debug_check[1] = n_switches_alloc;
7683 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
7684 n_switches_alloc);
7686 do_self_spec ("%:compare-debug-self-opt()");
7687 n_switches_debug_check[0] = n_switches;
7688 n_switches_alloc_debug_check[0] = n_switches_alloc;
7689 switches_debug_check[0] = switches;
7691 n_switches = n_switches_debug_check[1];
7692 n_switches_alloc = n_switches_alloc_debug_check[1];
7693 switches = switches_debug_check[1];
7696 /* Avoid crash when computing %j in this early. */
7697 save = save_temps_flag;
7698 save_temps_flag = SAVE_TEMPS_NONE;
7700 compare_debug = -compare_debug;
7701 do_self_spec ("%:compare-debug-self-opt()");
7703 save_temps_flag = save;
7705 if (!compare_debug_second)
7707 n_switches_debug_check[1] = n_switches;
7708 n_switches_alloc_debug_check[1] = n_switches_alloc;
7709 switches_debug_check[1] = switches;
7710 compare_debug = -compare_debug;
7711 n_switches = n_switches_debug_check[0];
7712 n_switches_alloc = n_switches_debug_check[0];
7713 switches = switches_debug_check[0];
7718 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
7719 if (gcc_exec_prefix)
7720 gcc_exec_prefix = concat (gcc_exec_prefix, spec_host_machine,
7721 dir_separator_str, spec_version,
7722 accel_dir_suffix, dir_separator_str, NULL);
7724 /* Now we have the specs.
7725 Set the `valid' bits for switches that match anything in any spec. */
7727 validate_all_switches ();
7729 /* Now that we have the switches and the specs, set
7730 the subdirectory based on the options. */
7731 set_multilib_dir ();
7734 /* Set up to remember the pathname of gcc and any options
7735 needed for collect. We use argv[0] instead of progname because
7736 we need the complete pathname. */
7738 void
7739 driver::putenv_COLLECT_GCC (const char *argv0) const
7741 obstack_init (&collect_obstack);
7742 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
7743 obstack_grow (&collect_obstack, argv0, strlen (argv0) + 1);
7744 xputenv (XOBFINISH (&collect_obstack, char *));
7747 /* Set up to remember the pathname of the lto wrapper. */
7749 void
7750 driver::maybe_putenv_COLLECT_LTO_WRAPPER () const
7752 char *lto_wrapper_file;
7754 if (have_c)
7755 lto_wrapper_file = NULL;
7756 else
7757 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
7758 X_OK, false);
7759 if (lto_wrapper_file)
7761 lto_wrapper_file = convert_white_space (lto_wrapper_file);
7762 lto_wrapper_spec = lto_wrapper_file;
7763 obstack_init (&collect_obstack);
7764 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
7765 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
7766 obstack_grow (&collect_obstack, lto_wrapper_spec,
7767 strlen (lto_wrapper_spec) + 1);
7768 xputenv (XOBFINISH (&collect_obstack, char *));
7773 /* Set up to remember the names of offload targets. */
7775 void
7776 driver::maybe_putenv_OFFLOAD_TARGETS () const
7778 if (offload_targets && offload_targets[0] != '\0')
7780 obstack_grow (&collect_obstack, "OFFLOAD_TARGET_NAMES=",
7781 sizeof ("OFFLOAD_TARGET_NAMES=") - 1);
7782 obstack_grow (&collect_obstack, offload_targets,
7783 strlen (offload_targets) + 1);
7784 xputenv (XOBFINISH (&collect_obstack, char *));
7787 free (offload_targets);
7788 offload_targets = NULL;
7791 /* Reject switches that no pass was interested in. */
7793 void
7794 driver::handle_unrecognized_options ()
7796 for (size_t i = 0; (int) i < n_switches; i++)
7797 if (! switches[i].validated)
7799 const char *hint = m_option_proposer.suggest_option (switches[i].part1);
7800 if (hint)
7801 error ("unrecognized command line option %<-%s%>;"
7802 " did you mean %<-%s%>?",
7803 switches[i].part1, hint);
7804 else
7805 error ("unrecognized command line option %<-%s%>",
7806 switches[i].part1);
7810 /* Handle the various -print-* options, returning 0 if the driver
7811 should exit, or nonzero if the driver should continue. */
7814 driver::maybe_print_and_exit () const
7816 if (print_search_dirs)
7818 printf (_("install: %s%s\n"),
7819 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
7820 gcc_exec_prefix ? "" : machine_suffix);
7821 printf (_("programs: %s\n"),
7822 build_search_list (&exec_prefixes, "", false, false));
7823 printf (_("libraries: %s\n"),
7824 build_search_list (&startfile_prefixes, "", false, true));
7825 return (0);
7828 if (print_file_name)
7830 printf ("%s\n", find_file (print_file_name));
7831 return (0);
7834 if (print_prog_name)
7836 if (use_ld != NULL && ! strcmp (print_prog_name, "ld"))
7838 /* Append USE_LD to the default linker. */
7839 #ifdef DEFAULT_LINKER
7840 char *ld;
7841 # ifdef HAVE_HOST_EXECUTABLE_SUFFIX
7842 int len = (sizeof (DEFAULT_LINKER)
7843 - sizeof (HOST_EXECUTABLE_SUFFIX));
7844 ld = NULL;
7845 if (len > 0)
7847 char *default_linker = xstrdup (DEFAULT_LINKER);
7848 /* Strip HOST_EXECUTABLE_SUFFIX if DEFAULT_LINKER contains
7849 HOST_EXECUTABLE_SUFFIX. */
7850 if (! strcmp (&default_linker[len], HOST_EXECUTABLE_SUFFIX))
7852 default_linker[len] = '\0';
7853 ld = concat (default_linker, use_ld,
7854 HOST_EXECUTABLE_SUFFIX, NULL);
7857 if (ld == NULL)
7858 # endif
7859 ld = concat (DEFAULT_LINKER, use_ld, NULL);
7860 if (access (ld, X_OK) == 0)
7862 printf ("%s\n", ld);
7863 return (0);
7865 #endif
7866 print_prog_name = concat (print_prog_name, use_ld, NULL);
7868 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
7869 printf ("%s\n", (newname ? newname : print_prog_name));
7870 return (0);
7873 if (print_multi_lib)
7875 print_multilib_info ();
7876 return (0);
7879 if (print_multi_directory)
7881 if (multilib_dir == NULL)
7882 printf (".\n");
7883 else
7884 printf ("%s\n", multilib_dir);
7885 return (0);
7888 if (print_multiarch)
7890 if (multiarch_dir == NULL)
7891 printf ("\n");
7892 else
7893 printf ("%s\n", multiarch_dir);
7894 return (0);
7897 if (print_sysroot)
7899 if (target_system_root)
7901 if (target_sysroot_suffix)
7902 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
7903 else
7904 printf ("%s\n", target_system_root);
7906 return (0);
7909 if (print_multi_os_directory)
7911 if (multilib_os_dir == NULL)
7912 printf (".\n");
7913 else
7914 printf ("%s\n", multilib_os_dir);
7915 return (0);
7918 if (print_sysroot_headers_suffix)
7920 if (*sysroot_hdrs_suffix_spec)
7922 printf("%s\n", (target_sysroot_hdrs_suffix
7923 ? target_sysroot_hdrs_suffix
7924 : ""));
7925 return (0);
7927 else
7928 /* The error status indicates that only one set of fixed
7929 headers should be built. */
7930 fatal_error (input_location,
7931 "not configured with sysroot headers suffix");
7934 if (print_help_list)
7936 display_help ();
7938 if (! verbose_flag)
7940 printf (_("\nFor bug reporting instructions, please see:\n"));
7941 printf ("%s.\n", bug_report_url);
7943 return (0);
7946 /* We do not exit here. Instead we have created a fake input file
7947 called 'help-dummy' which needs to be compiled, and we pass this
7948 on the various sub-processes, along with the --help switch.
7949 Ensure their output appears after ours. */
7950 fputc ('\n', stdout);
7951 fflush (stdout);
7954 if (print_version)
7956 printf (_("%s %s%s\n"), progname, pkgversion_string,
7957 version_string);
7958 printf ("Copyright %s 2018 Free Software Foundation, Inc.\n",
7959 _("(C)"));
7960 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
7961 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
7962 stdout);
7963 if (! verbose_flag)
7964 return 0;
7966 /* We do not exit here. We use the same mechanism of --help to print
7967 the version of the sub-processes. */
7968 fputc ('\n', stdout);
7969 fflush (stdout);
7972 if (verbose_flag)
7974 print_configuration (stderr);
7975 if (n_infiles == 0)
7976 return (0);
7979 return 1;
7982 /* Figure out what to do with each input file.
7983 Return true if we need to exit early from "main", false otherwise. */
7985 bool
7986 driver::prepare_infiles ()
7988 size_t i;
7989 int lang_n_infiles = 0;
7991 if (n_infiles == added_libraries)
7992 fatal_error (input_location, "no input files");
7994 if (seen_error ())
7995 /* Early exit needed from main. */
7996 return true;
7998 /* Make a place to record the compiler output file names
7999 that correspond to the input files. */
8001 i = n_infiles;
8002 i += lang_specific_extra_outfiles;
8003 outfiles = XCNEWVEC (const char *, i);
8005 /* Record which files were specified explicitly as link input. */
8007 explicit_link_files = XCNEWVEC (char, n_infiles);
8009 combine_inputs = have_o || flag_wpa;
8011 for (i = 0; (int) i < n_infiles; i++)
8013 const char *name = infiles[i].name;
8014 struct compiler *compiler = lookup_compiler (name,
8015 strlen (name),
8016 infiles[i].language);
8018 if (compiler && !(compiler->combinable))
8019 combine_inputs = false;
8021 if (lang_n_infiles > 0 && compiler != input_file_compiler
8022 && infiles[i].language && infiles[i].language[0] != '*')
8023 infiles[i].incompiler = compiler;
8024 else if (compiler)
8026 lang_n_infiles++;
8027 input_file_compiler = compiler;
8028 infiles[i].incompiler = compiler;
8030 else
8032 /* Since there is no compiler for this input file, assume it is a
8033 linker file. */
8034 explicit_link_files[i] = 1;
8035 infiles[i].incompiler = NULL;
8037 infiles[i].compiled = false;
8038 infiles[i].preprocessed = false;
8041 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
8042 fatal_error (input_location,
8043 "cannot specify -o with -c, -S or -E with multiple files");
8045 /* No early exit needed from main; we can continue. */
8046 return false;
8049 /* Run the spec machinery on each input file. */
8051 void
8052 driver::do_spec_on_infiles () const
8054 size_t i;
8056 for (i = 0; (int) i < n_infiles; i++)
8058 int this_file_error = 0;
8060 /* Tell do_spec what to substitute for %i. */
8062 input_file_number = i;
8063 set_input (infiles[i].name);
8065 if (infiles[i].compiled)
8066 continue;
8068 /* Use the same thing in %o, unless cp->spec says otherwise. */
8070 outfiles[i] = gcc_input_filename;
8072 /* Figure out which compiler from the file's suffix. */
8074 input_file_compiler
8075 = lookup_compiler (infiles[i].name, input_filename_length,
8076 infiles[i].language);
8078 if (input_file_compiler)
8080 /* Ok, we found an applicable compiler. Run its spec. */
8082 if (input_file_compiler->spec[0] == '#')
8084 error ("%s: %s compiler not installed on this system",
8085 gcc_input_filename, &input_file_compiler->spec[1]);
8086 this_file_error = 1;
8088 else
8090 int value;
8092 if (compare_debug)
8094 free (debug_check_temp_file[0]);
8095 debug_check_temp_file[0] = NULL;
8097 free (debug_check_temp_file[1]);
8098 debug_check_temp_file[1] = NULL;
8101 value = do_spec (input_file_compiler->spec);
8102 infiles[i].compiled = true;
8103 if (value < 0)
8104 this_file_error = 1;
8105 else if (compare_debug && debug_check_temp_file[0])
8107 if (verbose_flag)
8108 inform (UNKNOWN_LOCATION,
8109 "recompiling with -fcompare-debug");
8111 compare_debug = -compare_debug;
8112 n_switches = n_switches_debug_check[1];
8113 n_switches_alloc = n_switches_alloc_debug_check[1];
8114 switches = switches_debug_check[1];
8116 value = do_spec (input_file_compiler->spec);
8118 compare_debug = -compare_debug;
8119 n_switches = n_switches_debug_check[0];
8120 n_switches_alloc = n_switches_alloc_debug_check[0];
8121 switches = switches_debug_check[0];
8123 if (value < 0)
8125 error ("during -fcompare-debug recompilation");
8126 this_file_error = 1;
8129 gcc_assert (debug_check_temp_file[1]
8130 && filename_cmp (debug_check_temp_file[0],
8131 debug_check_temp_file[1]));
8133 if (verbose_flag)
8134 inform (UNKNOWN_LOCATION, "comparing final insns dumps");
8136 if (compare_files (debug_check_temp_file))
8137 this_file_error = 1;
8140 if (compare_debug)
8142 free (debug_check_temp_file[0]);
8143 debug_check_temp_file[0] = NULL;
8145 free (debug_check_temp_file[1]);
8146 debug_check_temp_file[1] = NULL;
8151 /* If this file's name does not contain a recognized suffix,
8152 record it as explicit linker input. */
8154 else
8155 explicit_link_files[i] = 1;
8157 /* Clear the delete-on-failure queue, deleting the files in it
8158 if this compilation failed. */
8160 if (this_file_error)
8162 delete_failure_queue ();
8163 errorcount++;
8165 /* If this compilation succeeded, don't delete those files later. */
8166 clear_failure_queue ();
8169 /* Reset the input file name to the first compile/object file name, for use
8170 with %b in LINK_SPEC. We use the first input file that we can find
8171 a compiler to compile it instead of using infiles.language since for
8172 languages other than C we use aliases that we then lookup later. */
8173 if (n_infiles > 0)
8175 int i;
8177 for (i = 0; i < n_infiles ; i++)
8178 if (infiles[i].incompiler
8179 || (infiles[i].language && infiles[i].language[0] != '*'))
8181 set_input (infiles[i].name);
8182 break;
8186 if (!seen_error ())
8188 /* Make sure INPUT_FILE_NUMBER points to first available open
8189 slot. */
8190 input_file_number = n_infiles;
8191 if (lang_specific_pre_link ())
8192 errorcount++;
8196 /* If we have to run the linker, do it now. */
8198 void
8199 driver::maybe_run_linker (const char *argv0) const
8201 size_t i;
8202 int linker_was_run = 0;
8203 int num_linker_inputs;
8205 /* Determine if there are any linker input files. */
8206 num_linker_inputs = 0;
8207 for (i = 0; (int) i < n_infiles; i++)
8208 if (explicit_link_files[i] || outfiles[i] != NULL)
8209 num_linker_inputs++;
8211 /* Run ld to link all the compiler output files. */
8213 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
8215 int tmp = execution_count;
8217 if (! have_c)
8219 #if HAVE_LTO_PLUGIN > 0
8220 #if HAVE_LTO_PLUGIN == 2
8221 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
8222 #else
8223 const char *fuse_linker_plugin = "fuse-linker-plugin";
8224 #endif
8225 #endif
8227 /* We'll use ld if we can't find collect2. */
8228 if (! strcmp (linker_name_spec, "collect2"))
8230 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
8231 if (s == NULL)
8232 linker_name_spec = "ld";
8235 #if HAVE_LTO_PLUGIN > 0
8236 #if HAVE_LTO_PLUGIN == 2
8237 if (!switch_matches (fno_use_linker_plugin,
8238 fno_use_linker_plugin
8239 + strlen (fno_use_linker_plugin), 0))
8240 #else
8241 if (switch_matches (fuse_linker_plugin,
8242 fuse_linker_plugin
8243 + strlen (fuse_linker_plugin), 0))
8244 #endif
8246 char *temp_spec = find_a_file (&exec_prefixes,
8247 LTOPLUGINSONAME, R_OK,
8248 false);
8249 if (!temp_spec)
8250 fatal_error (input_location,
8251 "-fuse-linker-plugin, but %s not found",
8252 LTOPLUGINSONAME);
8253 linker_plugin_file_spec = convert_white_space (temp_spec);
8255 #endif
8256 lto_gcc_spec = argv0;
8259 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
8260 for collect. */
8261 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
8262 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
8264 if (print_subprocess_help == 1)
8266 printf (_("\nLinker options\n==============\n\n"));
8267 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
8268 " to the linker.\n\n"));
8269 fflush (stdout);
8271 int value = do_spec (link_command_spec);
8272 if (value < 0)
8273 errorcount = 1;
8274 linker_was_run = (tmp != execution_count);
8277 /* If options said don't run linker,
8278 complain about input files to be given to the linker. */
8280 if (! linker_was_run && !seen_error ())
8281 for (i = 0; (int) i < n_infiles; i++)
8282 if (explicit_link_files[i]
8283 && !(infiles[i].language && infiles[i].language[0] == '*'))
8284 warning (0, "%s: linker input file unused because linking not done",
8285 outfiles[i]);
8288 /* The end of "main". */
8290 void
8291 driver::final_actions () const
8293 /* Delete some or all of the temporary files we made. */
8295 if (seen_error ())
8296 delete_failure_queue ();
8297 delete_temp_files ();
8299 if (print_help_list)
8301 printf (("\nFor bug reporting instructions, please see:\n"));
8302 printf ("%s\n", bug_report_url);
8306 /* Determine what the exit code of the driver should be. */
8309 driver::get_exit_code () const
8311 return (signal_count != 0 ? 2
8312 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
8313 : 0);
8316 /* Find the proper compilation spec for the file name NAME,
8317 whose length is LENGTH. LANGUAGE is the specified language,
8318 or 0 if this file is to be passed to the linker. */
8320 static struct compiler *
8321 lookup_compiler (const char *name, size_t length, const char *language)
8323 struct compiler *cp;
8325 /* If this was specified by the user to be a linker input, indicate that. */
8326 if (language != 0 && language[0] == '*')
8327 return 0;
8329 /* Otherwise, look for the language, if one is spec'd. */
8330 if (language != 0)
8332 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8333 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
8335 if (name != NULL && strcmp (name, "-") == 0
8336 && (strcmp (cp->suffix, "@c-header") == 0
8337 || strcmp (cp->suffix, "@c++-header") == 0)
8338 && !have_E)
8339 fatal_error (input_location,
8340 "cannot use %<-%> as input filename for a "
8341 "precompiled header");
8343 return cp;
8346 error ("language %s not recognized", language);
8347 return 0;
8350 /* Look for a suffix. */
8351 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8353 if (/* The suffix `-' matches only the file name `-'. */
8354 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
8355 || (strlen (cp->suffix) < length
8356 /* See if the suffix matches the end of NAME. */
8357 && !strcmp (cp->suffix,
8358 name + length - strlen (cp->suffix))
8360 break;
8363 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
8364 /* Look again, but case-insensitively this time. */
8365 if (cp < compilers)
8366 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8368 if (/* The suffix `-' matches only the file name `-'. */
8369 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
8370 || (strlen (cp->suffix) < length
8371 /* See if the suffix matches the end of NAME. */
8372 && ((!strcmp (cp->suffix,
8373 name + length - strlen (cp->suffix))
8374 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
8375 && !strcasecmp (cp->suffix,
8376 name + length - strlen (cp->suffix)))
8378 break;
8380 #endif
8382 if (cp >= compilers)
8384 if (cp->spec[0] != '@')
8385 /* A non-alias entry: return it. */
8386 return cp;
8388 /* An alias entry maps a suffix to a language.
8389 Search for the language; pass 0 for NAME and LENGTH
8390 to avoid infinite recursion if language not found. */
8391 return lookup_compiler (NULL, 0, cp->spec + 1);
8393 return 0;
8396 static char *
8397 save_string (const char *s, int len)
8399 char *result = XNEWVEC (char, len + 1);
8401 gcc_checking_assert (strlen (s) >= (unsigned int) len);
8402 memcpy (result, s, len);
8403 result[len] = 0;
8404 return result;
8408 static inline void
8409 validate_switches_from_spec (const char *spec, bool user)
8411 const char *p = spec;
8412 char c;
8413 while ((c = *p++))
8414 if (c == '%'
8415 && (*p == '{'
8416 || *p == '<'
8417 || (*p == 'W' && *++p == '{')
8418 || (*p == '@' && *++p == '{')))
8419 /* We have a switch spec. */
8420 p = validate_switches (p + 1, user);
8423 static void
8424 validate_all_switches (void)
8426 struct compiler *comp;
8427 struct spec_list *spec;
8429 for (comp = compilers; comp->spec; comp++)
8430 validate_switches_from_spec (comp->spec, false);
8432 /* Look through the linked list of specs read from the specs file. */
8433 for (spec = specs; spec; spec = spec->next)
8434 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
8436 validate_switches_from_spec (link_command_spec, false);
8439 /* Look at the switch-name that comes after START
8440 and mark as valid all supplied switches that match it. */
8442 static const char *
8443 validate_switches (const char *start, bool user_spec)
8445 const char *p = start;
8446 const char *atom;
8447 size_t len;
8448 int i;
8449 bool suffix = false;
8450 bool starred = false;
8452 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
8454 next_member:
8455 SKIP_WHITE ();
8457 if (*p == '!')
8458 p++;
8460 SKIP_WHITE ();
8461 if (*p == '.' || *p == ',')
8462 suffix = true, p++;
8464 atom = p;
8465 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
8466 || *p == ',' || *p == '.' || *p == '@')
8467 p++;
8468 len = p - atom;
8470 if (*p == '*')
8471 starred = true, p++;
8473 SKIP_WHITE ();
8475 if (!suffix)
8477 /* Mark all matching switches as valid. */
8478 for (i = 0; i < n_switches; i++)
8479 if (!strncmp (switches[i].part1, atom, len)
8480 && (starred || switches[i].part1[len] == '\0')
8481 && (switches[i].known || user_spec))
8482 switches[i].validated = true;
8485 if (*p) p++;
8486 if (*p && (p[-1] == '|' || p[-1] == '&'))
8487 goto next_member;
8489 if (*p && p[-1] == ':')
8491 while (*p && *p != ';' && *p != '}')
8493 if (*p == '%')
8495 p++;
8496 if (*p == '{' || *p == '<')
8497 p = validate_switches (p+1, user_spec);
8498 else if (p[0] == 'W' && p[1] == '{')
8499 p = validate_switches (p+2, user_spec);
8500 else if (p[0] == '@' && p[1] == '{')
8501 p = validate_switches (p+2, user_spec);
8503 else
8504 p++;
8507 if (*p) p++;
8508 if (*p && p[-1] == ';')
8509 goto next_member;
8512 return p;
8513 #undef SKIP_WHITE
8516 struct mdswitchstr
8518 const char *str;
8519 int len;
8522 static struct mdswitchstr *mdswitches;
8523 static int n_mdswitches;
8525 /* Check whether a particular argument was used. The first time we
8526 canonicalize the switches to keep only the ones we care about. */
8528 class used_arg_t
8530 public:
8531 int operator () (const char *p, int len);
8532 void finalize ();
8534 private:
8535 struct mswitchstr
8537 const char *str;
8538 const char *replace;
8539 int len;
8540 int rep_len;
8543 mswitchstr *mswitches;
8544 int n_mswitches;
8548 used_arg_t used_arg;
8551 used_arg_t::operator () (const char *p, int len)
8553 int i, j;
8555 if (!mswitches)
8557 struct mswitchstr *matches;
8558 const char *q;
8559 int cnt = 0;
8561 /* Break multilib_matches into the component strings of string
8562 and replacement string. */
8563 for (q = multilib_matches; *q != '\0'; q++)
8564 if (*q == ';')
8565 cnt++;
8567 matches
8568 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
8569 i = 0;
8570 q = multilib_matches;
8571 while (*q != '\0')
8573 matches[i].str = q;
8574 while (*q != ' ')
8576 if (*q == '\0')
8578 invalid_matches:
8579 fatal_error (input_location, "multilib spec %qs is invalid",
8580 multilib_matches);
8582 q++;
8584 matches[i].len = q - matches[i].str;
8586 matches[i].replace = ++q;
8587 while (*q != ';' && *q != '\0')
8589 if (*q == ' ')
8590 goto invalid_matches;
8591 q++;
8593 matches[i].rep_len = q - matches[i].replace;
8594 i++;
8595 if (*q == ';')
8596 q++;
8599 /* Now build a list of the replacement string for switches that we care
8600 about. Make sure we allocate at least one entry. This prevents
8601 xmalloc from calling fatal, and prevents us from re-executing this
8602 block of code. */
8603 mswitches
8604 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
8605 for (i = 0; i < n_switches; i++)
8606 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
8608 int xlen = strlen (switches[i].part1);
8609 for (j = 0; j < cnt; j++)
8610 if (xlen == matches[j].len
8611 && ! strncmp (switches[i].part1, matches[j].str, xlen))
8613 mswitches[n_mswitches].str = matches[j].replace;
8614 mswitches[n_mswitches].len = matches[j].rep_len;
8615 mswitches[n_mswitches].replace = (char *) 0;
8616 mswitches[n_mswitches].rep_len = 0;
8617 n_mswitches++;
8618 break;
8622 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
8623 on the command line nor any options mutually incompatible with
8624 them. */
8625 for (i = 0; i < n_mdswitches; i++)
8627 const char *r;
8629 for (q = multilib_options; *q != '\0'; *q && q++)
8631 while (*q == ' ')
8632 q++;
8634 r = q;
8635 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
8636 || strchr (" /", q[mdswitches[i].len]) == NULL)
8638 while (*q != ' ' && *q != '/' && *q != '\0')
8639 q++;
8640 if (*q != '/')
8641 break;
8642 q++;
8645 if (*q != ' ' && *q != '\0')
8647 while (*r != ' ' && *r != '\0')
8649 q = r;
8650 while (*q != ' ' && *q != '/' && *q != '\0')
8651 q++;
8653 if (used_arg (r, q - r))
8654 break;
8656 if (*q != '/')
8658 mswitches[n_mswitches].str = mdswitches[i].str;
8659 mswitches[n_mswitches].len = mdswitches[i].len;
8660 mswitches[n_mswitches].replace = (char *) 0;
8661 mswitches[n_mswitches].rep_len = 0;
8662 n_mswitches++;
8663 break;
8666 r = q + 1;
8668 break;
8674 for (i = 0; i < n_mswitches; i++)
8675 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
8676 return 1;
8678 return 0;
8681 void used_arg_t::finalize ()
8683 XDELETEVEC (mswitches);
8684 mswitches = NULL;
8685 n_mswitches = 0;
8689 static int
8690 default_arg (const char *p, int len)
8692 int i;
8694 for (i = 0; i < n_mdswitches; i++)
8695 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
8696 return 1;
8698 return 0;
8701 /* Work out the subdirectory to use based on the options. The format of
8702 multilib_select is a list of elements. Each element is a subdirectory
8703 name followed by a list of options followed by a semicolon. The format
8704 of multilib_exclusions is the same, but without the preceding
8705 directory. First gcc will check the exclusions, if none of the options
8706 beginning with an exclamation point are present, and all of the other
8707 options are present, then we will ignore this completely. Passing
8708 that, gcc will consider each multilib_select in turn using the same
8709 rules for matching the options. If a match is found, that subdirectory
8710 will be used.
8711 A subdirectory name is optionally followed by a colon and the corresponding
8712 multiarch name. */
8714 static void
8715 set_multilib_dir (void)
8717 const char *p;
8718 unsigned int this_path_len;
8719 const char *this_path, *this_arg;
8720 const char *start, *end;
8721 int not_arg;
8722 int ok, ndfltok, first;
8724 n_mdswitches = 0;
8725 start = multilib_defaults;
8726 while (*start == ' ' || *start == '\t')
8727 start++;
8728 while (*start != '\0')
8730 n_mdswitches++;
8731 while (*start != ' ' && *start != '\t' && *start != '\0')
8732 start++;
8733 while (*start == ' ' || *start == '\t')
8734 start++;
8737 if (n_mdswitches)
8739 int i = 0;
8741 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
8742 for (start = multilib_defaults; *start != '\0'; start = end + 1)
8744 while (*start == ' ' || *start == '\t')
8745 start++;
8747 if (*start == '\0')
8748 break;
8750 for (end = start + 1;
8751 *end != ' ' && *end != '\t' && *end != '\0'; end++)
8754 obstack_grow (&multilib_obstack, start, end - start);
8755 obstack_1grow (&multilib_obstack, 0);
8756 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
8757 mdswitches[i++].len = end - start;
8759 if (*end == '\0')
8760 break;
8764 p = multilib_exclusions;
8765 while (*p != '\0')
8767 /* Ignore newlines. */
8768 if (*p == '\n')
8770 ++p;
8771 continue;
8774 /* Check the arguments. */
8775 ok = 1;
8776 while (*p != ';')
8778 if (*p == '\0')
8780 invalid_exclusions:
8781 fatal_error (input_location, "multilib exclusions %qs is invalid",
8782 multilib_exclusions);
8785 if (! ok)
8787 ++p;
8788 continue;
8791 this_arg = p;
8792 while (*p != ' ' && *p != ';')
8794 if (*p == '\0')
8795 goto invalid_exclusions;
8796 ++p;
8799 if (*this_arg != '!')
8800 not_arg = 0;
8801 else
8803 not_arg = 1;
8804 ++this_arg;
8807 ok = used_arg (this_arg, p - this_arg);
8808 if (not_arg)
8809 ok = ! ok;
8811 if (*p == ' ')
8812 ++p;
8815 if (ok)
8816 return;
8818 ++p;
8821 first = 1;
8822 p = multilib_select;
8824 /* Append multilib reuse rules if any. With those rules, we can reuse
8825 one multilib for certain different options sets. */
8826 if (strlen (multilib_reuse) > 0)
8827 p = concat (p, multilib_reuse, NULL);
8829 while (*p != '\0')
8831 /* Ignore newlines. */
8832 if (*p == '\n')
8834 ++p;
8835 continue;
8838 /* Get the initial path. */
8839 this_path = p;
8840 while (*p != ' ')
8842 if (*p == '\0')
8844 invalid_select:
8845 fatal_error (input_location, "multilib select %qs %qs is invalid",
8846 multilib_select, multilib_reuse);
8848 ++p;
8850 this_path_len = p - this_path;
8852 /* Check the arguments. */
8853 ok = 1;
8854 ndfltok = 1;
8855 ++p;
8856 while (*p != ';')
8858 if (*p == '\0')
8859 goto invalid_select;
8861 if (! ok)
8863 ++p;
8864 continue;
8867 this_arg = p;
8868 while (*p != ' ' && *p != ';')
8870 if (*p == '\0')
8871 goto invalid_select;
8872 ++p;
8875 if (*this_arg != '!')
8876 not_arg = 0;
8877 else
8879 not_arg = 1;
8880 ++this_arg;
8883 /* If this is a default argument, we can just ignore it.
8884 This is true even if this_arg begins with '!'. Beginning
8885 with '!' does not mean that this argument is necessarily
8886 inappropriate for this library: it merely means that
8887 there is a more specific library which uses this
8888 argument. If this argument is a default, we need not
8889 consider that more specific library. */
8890 ok = used_arg (this_arg, p - this_arg);
8891 if (not_arg)
8892 ok = ! ok;
8894 if (! ok)
8895 ndfltok = 0;
8897 if (default_arg (this_arg, p - this_arg))
8898 ok = 1;
8900 if (*p == ' ')
8901 ++p;
8904 if (ok && first)
8906 if (this_path_len != 1
8907 || this_path[0] != '.')
8909 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
8910 char *q;
8912 strncpy (new_multilib_dir, this_path, this_path_len);
8913 new_multilib_dir[this_path_len] = '\0';
8914 q = strchr (new_multilib_dir, ':');
8915 if (q != NULL)
8916 *q = '\0';
8917 multilib_dir = new_multilib_dir;
8919 first = 0;
8922 if (ndfltok)
8924 const char *q = this_path, *end = this_path + this_path_len;
8926 while (q < end && *q != ':')
8927 q++;
8928 if (q < end)
8930 const char *q2 = q + 1, *ml_end = end;
8931 char *new_multilib_os_dir;
8933 while (q2 < end && *q2 != ':')
8934 q2++;
8935 if (*q2 == ':')
8936 ml_end = q2;
8937 if (ml_end - q == 1)
8938 multilib_os_dir = xstrdup (".");
8939 else
8941 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
8942 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
8943 new_multilib_os_dir[ml_end - q - 1] = '\0';
8944 multilib_os_dir = new_multilib_os_dir;
8947 if (q2 < end && *q2 == ':')
8949 char *new_multiarch_dir = XNEWVEC (char, end - q2);
8950 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
8951 new_multiarch_dir[end - q2 - 1] = '\0';
8952 multiarch_dir = new_multiarch_dir;
8954 break;
8958 ++p;
8961 if (multilib_dir == NULL && multilib_os_dir != NULL
8962 && strcmp (multilib_os_dir, ".") == 0)
8964 free (CONST_CAST (char *, multilib_os_dir));
8965 multilib_os_dir = NULL;
8967 else if (multilib_dir != NULL && multilib_os_dir == NULL)
8968 multilib_os_dir = multilib_dir;
8971 /* Print out the multiple library subdirectory selection
8972 information. This prints out a series of lines. Each line looks
8973 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
8974 required. Only the desired options are printed out, the negative
8975 matches. The options are print without a leading dash. There are
8976 no spaces to make it easy to use the information in the shell.
8977 Each subdirectory is printed only once. This assumes the ordering
8978 generated by the genmultilib script. Also, we leave out ones that match
8979 the exclusions. */
8981 static void
8982 print_multilib_info (void)
8984 const char *p = multilib_select;
8985 const char *last_path = 0, *this_path;
8986 int skip;
8987 unsigned int last_path_len = 0;
8989 while (*p != '\0')
8991 skip = 0;
8992 /* Ignore newlines. */
8993 if (*p == '\n')
8995 ++p;
8996 continue;
8999 /* Get the initial path. */
9000 this_path = p;
9001 while (*p != ' ')
9003 if (*p == '\0')
9005 invalid_select:
9006 fatal_error (input_location,
9007 "multilib select %qs is invalid", multilib_select);
9010 ++p;
9013 /* When --disable-multilib was used but target defines
9014 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
9015 with .:: for multiarch configurations) are there just to find
9016 multilib_os_dir, so skip them from output. */
9017 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
9018 skip = 1;
9020 /* Check for matches with the multilib_exclusions. We don't bother
9021 with the '!' in either list. If any of the exclusion rules match
9022 all of its options with the select rule, we skip it. */
9024 const char *e = multilib_exclusions;
9025 const char *this_arg;
9027 while (*e != '\0')
9029 int m = 1;
9030 /* Ignore newlines. */
9031 if (*e == '\n')
9033 ++e;
9034 continue;
9037 /* Check the arguments. */
9038 while (*e != ';')
9040 const char *q;
9041 int mp = 0;
9043 if (*e == '\0')
9045 invalid_exclusion:
9046 fatal_error (input_location,
9047 "multilib exclusion %qs is invalid",
9048 multilib_exclusions);
9051 if (! m)
9053 ++e;
9054 continue;
9057 this_arg = e;
9059 while (*e != ' ' && *e != ';')
9061 if (*e == '\0')
9062 goto invalid_exclusion;
9063 ++e;
9066 q = p + 1;
9067 while (*q != ';')
9069 const char *arg;
9070 int len = e - this_arg;
9072 if (*q == '\0')
9073 goto invalid_select;
9075 arg = q;
9077 while (*q != ' ' && *q != ';')
9079 if (*q == '\0')
9080 goto invalid_select;
9081 ++q;
9084 if (! strncmp (arg, this_arg,
9085 (len < q - arg) ? q - arg : len)
9086 || default_arg (this_arg, e - this_arg))
9088 mp = 1;
9089 break;
9092 if (*q == ' ')
9093 ++q;
9096 if (! mp)
9097 m = 0;
9099 if (*e == ' ')
9100 ++e;
9103 if (m)
9105 skip = 1;
9106 break;
9109 if (*e != '\0')
9110 ++e;
9114 if (! skip)
9116 /* If this is a duplicate, skip it. */
9117 skip = (last_path != 0
9118 && (unsigned int) (p - this_path) == last_path_len
9119 && ! filename_ncmp (last_path, this_path, last_path_len));
9121 last_path = this_path;
9122 last_path_len = p - this_path;
9125 /* If this directory requires any default arguments, we can skip
9126 it. We will already have printed a directory identical to
9127 this one which does not require that default argument. */
9128 if (! skip)
9130 const char *q;
9132 q = p + 1;
9133 while (*q != ';')
9135 const char *arg;
9137 if (*q == '\0')
9138 goto invalid_select;
9140 if (*q == '!')
9141 arg = NULL;
9142 else
9143 arg = q;
9145 while (*q != ' ' && *q != ';')
9147 if (*q == '\0')
9148 goto invalid_select;
9149 ++q;
9152 if (arg != NULL
9153 && default_arg (arg, q - arg))
9155 skip = 1;
9156 break;
9159 if (*q == ' ')
9160 ++q;
9164 if (! skip)
9166 const char *p1;
9168 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
9169 putchar (*p1);
9170 putchar (';');
9173 ++p;
9174 while (*p != ';')
9176 int use_arg;
9178 if (*p == '\0')
9179 goto invalid_select;
9181 if (skip)
9183 ++p;
9184 continue;
9187 use_arg = *p != '!';
9189 if (use_arg)
9190 putchar ('@');
9192 while (*p != ' ' && *p != ';')
9194 if (*p == '\0')
9195 goto invalid_select;
9196 if (use_arg)
9197 putchar (*p);
9198 ++p;
9201 if (*p == ' ')
9202 ++p;
9205 if (! skip)
9207 /* If there are extra options, print them now. */
9208 if (multilib_extra && *multilib_extra)
9210 int print_at = TRUE;
9211 const char *q;
9213 for (q = multilib_extra; *q != '\0'; q++)
9215 if (*q == ' ')
9216 print_at = TRUE;
9217 else
9219 if (print_at)
9220 putchar ('@');
9221 putchar (*q);
9222 print_at = FALSE;
9227 putchar ('\n');
9230 ++p;
9234 /* getenv built-in spec function.
9236 Returns the value of the environment variable given by its first argument,
9237 concatenated with the second argument. If the variable is not defined, a
9238 fatal error is issued unless such undefs are internally allowed, in which
9239 case the variable name prefixed by a '/' is used as the variable value.
9241 The leading '/' allows using the result at a spot where a full path would
9242 normally be expected and when the actual value doesn't really matter since
9243 undef vars are allowed. */
9245 static const char *
9246 getenv_spec_function (int argc, const char **argv)
9248 const char *value;
9249 const char *varname;
9251 char *result;
9252 char *ptr;
9253 size_t len;
9255 if (argc != 2)
9256 return NULL;
9258 varname = argv[0];
9259 value = env.get (varname);
9261 /* If the variable isn't defined and this is allowed, craft our expected
9262 return value. Assume variable names used in specs strings don't contain
9263 any active spec character so don't need escaping. */
9264 if (!value && spec_undefvar_allowed)
9266 result = XNEWVAR (char, strlen(varname) + 2);
9267 sprintf (result, "/%s", varname);
9268 return result;
9271 if (!value)
9272 fatal_error (input_location,
9273 "environment variable %qs not defined", varname);
9275 /* We have to escape every character of the environment variable so
9276 they are not interpreted as active spec characters. A
9277 particularly painful case is when we are reading a variable
9278 holding a windows path complete with \ separators. */
9279 len = strlen (value) * 2 + strlen (argv[1]) + 1;
9280 result = XNEWVAR (char, len);
9281 for (ptr = result; *value; ptr += 2)
9283 ptr[0] = '\\';
9284 ptr[1] = *value++;
9287 strcpy (ptr, argv[1]);
9289 return result;
9292 /* if-exists built-in spec function.
9294 Checks to see if the file specified by the absolute pathname in
9295 ARGS exists. Returns that pathname if found.
9297 The usual use for this function is to check for a library file
9298 (whose name has been expanded with %s). */
9300 static const char *
9301 if_exists_spec_function (int argc, const char **argv)
9303 /* Must have only one argument. */
9304 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
9305 return argv[0];
9307 return NULL;
9310 /* if-exists-else built-in spec function.
9312 This is like if-exists, but takes an additional argument which
9313 is returned if the first argument does not exist. */
9315 static const char *
9316 if_exists_else_spec_function (int argc, const char **argv)
9318 /* Must have exactly two arguments. */
9319 if (argc != 2)
9320 return NULL;
9322 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
9323 return argv[0];
9325 return argv[1];
9328 /* sanitize built-in spec function.
9330 This returns non-NULL, if sanitizing address, thread or
9331 any of the undefined behavior sanitizers. */
9333 static const char *
9334 sanitize_spec_function (int argc, const char **argv)
9336 if (argc != 1)
9337 return NULL;
9339 if (strcmp (argv[0], "address") == 0)
9340 return (flag_sanitize & SANITIZE_USER_ADDRESS) ? "" : NULL;
9341 if (strcmp (argv[0], "kernel-address") == 0)
9342 return (flag_sanitize & SANITIZE_KERNEL_ADDRESS) ? "" : NULL;
9343 if (strcmp (argv[0], "thread") == 0)
9344 return (flag_sanitize & SANITIZE_THREAD) ? "" : NULL;
9345 if (strcmp (argv[0], "undefined") == 0)
9346 return ((flag_sanitize
9347 & (SANITIZE_UNDEFINED | SANITIZE_UNDEFINED_NONDEFAULT))
9348 && !flag_sanitize_undefined_trap_on_error) ? "" : NULL;
9349 if (strcmp (argv[0], "leak") == 0)
9350 return ((flag_sanitize
9351 & (SANITIZE_ADDRESS | SANITIZE_LEAK | SANITIZE_THREAD))
9352 == SANITIZE_LEAK) ? "" : NULL;
9353 return NULL;
9356 /* replace-outfile built-in spec function.
9358 This looks for the first argument in the outfiles array's name and
9359 replaces it with the second argument. */
9361 static const char *
9362 replace_outfile_spec_function (int argc, const char **argv)
9364 int i;
9365 /* Must have exactly two arguments. */
9366 if (argc != 2)
9367 abort ();
9369 for (i = 0; i < n_infiles; i++)
9371 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
9372 outfiles[i] = xstrdup (argv[1]);
9374 return NULL;
9377 /* remove-outfile built-in spec function.
9379 * This looks for the first argument in the outfiles array's name and
9380 * removes it. */
9382 static const char *
9383 remove_outfile_spec_function (int argc, const char **argv)
9385 int i;
9386 /* Must have exactly one argument. */
9387 if (argc != 1)
9388 abort ();
9390 for (i = 0; i < n_infiles; i++)
9392 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
9393 outfiles[i] = NULL;
9395 return NULL;
9398 /* Given two version numbers, compares the two numbers.
9399 A version number must match the regular expression
9400 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
9402 static int
9403 compare_version_strings (const char *v1, const char *v2)
9405 int rresult;
9406 regex_t r;
9408 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
9409 REG_EXTENDED | REG_NOSUB) != 0)
9410 abort ();
9411 rresult = regexec (&r, v1, 0, NULL, 0);
9412 if (rresult == REG_NOMATCH)
9413 fatal_error (input_location, "invalid version number %qs", v1);
9414 else if (rresult != 0)
9415 abort ();
9416 rresult = regexec (&r, v2, 0, NULL, 0);
9417 if (rresult == REG_NOMATCH)
9418 fatal_error (input_location, "invalid version number %qs", v2);
9419 else if (rresult != 0)
9420 abort ();
9422 return strverscmp (v1, v2);
9426 /* version_compare built-in spec function.
9428 This takes an argument of the following form:
9430 <comparison-op> <arg1> [<arg2>] <switch> <result>
9432 and produces "result" if the comparison evaluates to true,
9433 and nothing if it doesn't.
9435 The supported <comparison-op> values are:
9437 >= true if switch is a later (or same) version than arg1
9438 !> opposite of >=
9439 < true if switch is an earlier version than arg1
9440 !< opposite of <
9441 >< true if switch is arg1 or later, and earlier than arg2
9442 <> true if switch is earlier than arg1 or is arg2 or later
9444 If the switch is not present, the condition is false unless
9445 the first character of the <comparison-op> is '!'.
9447 For example,
9448 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
9449 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
9451 static const char *
9452 version_compare_spec_function (int argc, const char **argv)
9454 int comp1, comp2;
9455 size_t switch_len;
9456 const char *switch_value = NULL;
9457 int nargs = 1, i;
9458 bool result;
9460 if (argc < 3)
9461 fatal_error (input_location, "too few arguments to %%:version-compare");
9462 if (argv[0][0] == '\0')
9463 abort ();
9464 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
9465 nargs = 2;
9466 if (argc != nargs + 3)
9467 fatal_error (input_location, "too many arguments to %%:version-compare");
9469 switch_len = strlen (argv[nargs + 1]);
9470 for (i = 0; i < n_switches; i++)
9471 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
9472 && check_live_switch (i, switch_len))
9473 switch_value = switches[i].part1 + switch_len;
9475 if (switch_value == NULL)
9476 comp1 = comp2 = -1;
9477 else
9479 comp1 = compare_version_strings (switch_value, argv[1]);
9480 if (nargs == 2)
9481 comp2 = compare_version_strings (switch_value, argv[2]);
9482 else
9483 comp2 = -1; /* This value unused. */
9486 switch (argv[0][0] << 8 | argv[0][1])
9488 case '>' << 8 | '=':
9489 result = comp1 >= 0;
9490 break;
9491 case '!' << 8 | '<':
9492 result = comp1 >= 0 || switch_value == NULL;
9493 break;
9494 case '<' << 8:
9495 result = comp1 < 0;
9496 break;
9497 case '!' << 8 | '>':
9498 result = comp1 < 0 || switch_value == NULL;
9499 break;
9500 case '>' << 8 | '<':
9501 result = comp1 >= 0 && comp2 < 0;
9502 break;
9503 case '<' << 8 | '>':
9504 result = comp1 < 0 || comp2 >= 0;
9505 break;
9507 default:
9508 fatal_error (input_location,
9509 "unknown operator %qs in %%:version-compare", argv[0]);
9511 if (! result)
9512 return NULL;
9514 return argv[nargs + 2];
9517 /* %:include builtin spec function. This differs from %include in that it
9518 can be nested inside a spec, and thus be conditionalized. It takes
9519 one argument, the filename, and looks for it in the startfile path.
9520 The result is always NULL, i.e. an empty expansion. */
9522 static const char *
9523 include_spec_function (int argc, const char **argv)
9525 char *file;
9527 if (argc != 1)
9528 abort ();
9530 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
9531 read_specs (file ? file : argv[0], false, false);
9533 return NULL;
9536 /* %:find-file spec function. This function replaces its argument by
9537 the file found through find_file, that is the -print-file-name gcc
9538 program option. */
9539 static const char *
9540 find_file_spec_function (int argc, const char **argv)
9542 const char *file;
9544 if (argc != 1)
9545 abort ();
9547 file = find_file (argv[0]);
9548 return file;
9552 /* %:find-plugindir spec function. This function replaces its argument
9553 by the -iplugindir=<dir> option. `dir' is found through find_file, that
9554 is the -print-file-name gcc program option. */
9555 static const char *
9556 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
9558 const char *option;
9560 if (argc != 0)
9561 abort ();
9563 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
9564 return option;
9568 /* %:print-asm-header spec function. Print a banner to say that the
9569 following output is from the assembler. */
9571 static const char *
9572 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
9573 const char **argv ATTRIBUTE_UNUSED)
9575 printf (_("Assembler options\n=================\n\n"));
9576 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
9577 fflush (stdout);
9578 return NULL;
9581 /* Get a random number for -frandom-seed */
9583 static unsigned HOST_WIDE_INT
9584 get_random_number (void)
9586 unsigned HOST_WIDE_INT ret = 0;
9587 int fd;
9589 fd = open ("/dev/urandom", O_RDONLY);
9590 if (fd >= 0)
9592 read (fd, &ret, sizeof (HOST_WIDE_INT));
9593 close (fd);
9594 if (ret)
9595 return ret;
9598 /* Get some more or less random data. */
9599 #ifdef HAVE_GETTIMEOFDAY
9601 struct timeval tv;
9603 gettimeofday (&tv, NULL);
9604 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
9606 #else
9608 time_t now = time (NULL);
9610 if (now != (time_t)-1)
9611 ret = (unsigned) now;
9613 #endif
9615 return ret ^ getpid ();
9618 /* %:compare-debug-dump-opt spec function. Save the last argument,
9619 expected to be the last -fdump-final-insns option, or generate a
9620 temporary. */
9622 static const char *
9623 compare_debug_dump_opt_spec_function (int arg,
9624 const char **argv ATTRIBUTE_UNUSED)
9626 char *ret;
9627 char *name;
9628 int which;
9629 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
9631 if (arg != 0)
9632 fatal_error (input_location,
9633 "too many arguments to %%:compare-debug-dump-opt");
9635 do_spec_2 ("%{fdump-final-insns=*:%*}", NULL);
9636 do_spec_1 (" ", 0, NULL);
9638 if (argbuf.length () > 0
9639 && strcmp (argv[argbuf.length () - 1], "."))
9641 if (!compare_debug)
9642 return NULL;
9644 name = xstrdup (argv[argbuf.length () - 1]);
9645 ret = NULL;
9647 else
9649 const char *ext = NULL;
9651 if (argbuf.length () > 0)
9653 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}", NULL);
9654 ext = ".gkd";
9656 else if (!compare_debug)
9657 return NULL;
9658 else
9659 do_spec_2 ("%g.gkd", NULL);
9661 do_spec_1 (" ", 0, NULL);
9663 gcc_assert (argbuf.length () > 0);
9665 name = concat (argbuf.last (), ext, NULL);
9667 ret = concat ("-fdump-final-insns=", name, NULL);
9670 which = compare_debug < 0;
9671 debug_check_temp_file[which] = name;
9673 if (!which)
9675 unsigned HOST_WIDE_INT value = get_random_number ();
9677 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
9680 if (*random_seed)
9682 char *tmp = ret;
9683 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
9684 ret, NULL);
9685 free (tmp);
9688 if (which)
9689 *random_seed = 0;
9691 return ret;
9694 static const char *debug_auxbase_opt;
9696 /* %:compare-debug-self-opt spec function. Expands to the options
9697 that are to be passed in the second compilation of
9698 compare-debug. */
9700 static const char *
9701 compare_debug_self_opt_spec_function (int arg,
9702 const char **argv ATTRIBUTE_UNUSED)
9704 if (arg != 0)
9705 fatal_error (input_location,
9706 "too many arguments to %%:compare-debug-self-opt");
9708 if (compare_debug >= 0)
9709 return NULL;
9711 do_spec_2 ("%{c|S:%{o*:%*}}", NULL);
9712 do_spec_1 (" ", 0, NULL);
9714 if (argbuf.length () > 0)
9715 debug_auxbase_opt = concat ("-auxbase-strip ",
9716 argbuf.last (),
9717 NULL);
9718 else
9719 debug_auxbase_opt = NULL;
9721 return concat ("\
9722 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
9723 %<fdump-final-insns=* -w -S -o %j \
9724 %{!fcompare-debug-second:-fcompare-debug-second} \
9725 ", compare_debug_opt, NULL);
9728 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
9729 options that are to be passed in the second compilation of
9730 compare-debug. It expects, as an argument, the basename of the
9731 current input file name, with the .gk suffix appended to it. */
9733 static const char *
9734 compare_debug_auxbase_opt_spec_function (int arg,
9735 const char **argv)
9737 char *name;
9738 int len;
9740 if (arg == 0)
9741 fatal_error (input_location,
9742 "too few arguments to %%:compare-debug-auxbase-opt");
9744 if (arg != 1)
9745 fatal_error (input_location,
9746 "too many arguments to %%:compare-debug-auxbase-opt");
9748 if (compare_debug >= 0)
9749 return NULL;
9751 len = strlen (argv[0]);
9752 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
9753 fatal_error (input_location, "argument to %%:compare-debug-auxbase-opt "
9754 "does not end in .gk");
9756 if (debug_auxbase_opt)
9757 return debug_auxbase_opt;
9759 #define OPT "-auxbase "
9761 len -= 3;
9762 name = (char*) xmalloc (sizeof (OPT) + len);
9763 memcpy (name, OPT, sizeof (OPT) - 1);
9764 memcpy (name + sizeof (OPT) - 1, argv[0], len);
9765 name[sizeof (OPT) - 1 + len] = '\0';
9767 #undef OPT
9769 return name;
9772 /* %:pass-through-libs spec function. Finds all -l options and input
9773 file names in the lib spec passed to it, and makes a list of them
9774 prepended with the plugin option to cause them to be passed through
9775 to the final link after all the new object files have been added. */
9777 const char *
9778 pass_through_libs_spec_func (int argc, const char **argv)
9780 char *prepended = xstrdup (" ");
9781 int n;
9782 /* Shlemiel the painter's algorithm. Innately horrible, but at least
9783 we know that there will never be more than a handful of strings to
9784 concat, and it's only once per run, so it's not worth optimising. */
9785 for (n = 0; n < argc; n++)
9787 char *old = prepended;
9788 /* Anything that isn't an option is a full path to an output
9789 file; pass it through if it ends in '.a'. Among options,
9790 pass only -l. */
9791 if (argv[n][0] == '-' && argv[n][1] == 'l')
9793 const char *lopt = argv[n] + 2;
9794 /* Handle both joined and non-joined -l options. If for any
9795 reason there's a trailing -l with no joined or following
9796 arg just discard it. */
9797 if (!*lopt && ++n >= argc)
9798 break;
9799 else if (!*lopt)
9800 lopt = argv[n];
9801 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
9802 lopt, " ", NULL);
9804 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
9806 prepended = concat (prepended, "-plugin-opt=-pass-through=",
9807 argv[n], " ", NULL);
9809 if (prepended != old)
9810 free (old);
9812 return prepended;
9815 /* %:replace-extension spec function. Replaces the extension of the
9816 first argument with the second argument. */
9818 const char *
9819 replace_extension_spec_func (int argc, const char **argv)
9821 char *name;
9822 char *p;
9823 char *result;
9824 int i;
9826 if (argc != 2)
9827 fatal_error (input_location, "too few arguments to %%:replace-extension");
9829 name = xstrdup (argv[0]);
9831 for (i = strlen (name) - 1; i >= 0; i--)
9832 if (IS_DIR_SEPARATOR (name[i]))
9833 break;
9835 p = strrchr (name + i + 1, '.');
9836 if (p != NULL)
9837 *p = '\0';
9839 result = concat (name, argv[1], NULL);
9841 free (name);
9842 return result;
9845 /* Returns "" if ARGV[ARGC - 2] is greater than ARGV[ARGC-1].
9846 Otherwise, return NULL. */
9848 static const char *
9849 greater_than_spec_func (int argc, const char **argv)
9851 char *converted;
9853 if (argc == 1)
9854 return NULL;
9856 gcc_assert (argc >= 2);
9858 long arg = strtol (argv[argc - 2], &converted, 10);
9859 gcc_assert (converted != argv[argc - 2]);
9861 long lim = strtol (argv[argc - 1], &converted, 10);
9862 gcc_assert (converted != argv[argc - 1]);
9864 if (arg > lim)
9865 return "";
9867 return NULL;
9870 /* Returns "" if debug_info_level is greater than ARGV[ARGC-1].
9871 Otherwise, return NULL. */
9873 static const char *
9874 debug_level_greater_than_spec_func (int argc, const char **argv)
9876 char *converted;
9878 if (argc != 1)
9879 fatal_error (input_location,
9880 "wrong number of arguments to %%:debug-level-gt");
9882 long arg = strtol (argv[0], &converted, 10);
9883 gcc_assert (converted != argv[0]);
9885 if (debug_info_level > arg)
9886 return "";
9888 return NULL;
9891 /* Insert backslash before spaces in ORIG (usually a file path), to
9892 avoid being broken by spec parser.
9894 This function is needed as do_spec_1 treats white space (' ' and '\t')
9895 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
9896 the file name should be treated as a single argument rather than being
9897 broken into multiple. Solution is to insert '\\' before the space in a
9898 file name.
9900 This function converts and only converts all occurrence of ' '
9901 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
9902 "a b" -> "a\\ b"
9903 "a b" -> "a\\ \\ b"
9904 "a\tb" -> "a\\\tb"
9905 "a\\ b" -> "a\\\\ b"
9907 orig: input null-terminating string that was allocated by xalloc. The
9908 memory it points to might be freed in this function. Behavior undefined
9909 if ORIG wasn't xalloced or was freed already at entry.
9911 Return: ORIG if no conversion needed. Otherwise a newly allocated string
9912 that was converted from ORIG. */
9914 static char *
9915 convert_white_space (char *orig)
9917 int len, number_of_space = 0;
9919 for (len = 0; orig[len]; len++)
9920 if (orig[len] == ' ' || orig[len] == '\t') number_of_space++;
9922 if (number_of_space)
9924 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
9925 int j, k;
9926 for (j = 0, k = 0; j <= len; j++, k++)
9928 if (orig[j] == ' ' || orig[j] == '\t')
9929 new_spec[k++] = '\\';
9930 new_spec[k] = orig[j];
9932 free (orig);
9933 return new_spec;
9935 else
9936 return orig;
9939 static void
9940 path_prefix_reset (path_prefix *prefix)
9942 struct prefix_list *iter, *next;
9943 iter = prefix->plist;
9944 while (iter)
9946 next = iter->next;
9947 free (const_cast <char *> (iter->prefix));
9948 XDELETE (iter);
9949 iter = next;
9951 prefix->plist = 0;
9952 prefix->max_len = 0;
9955 /* Restore all state within gcc.c to the initial state, so that the driver
9956 code can be safely re-run in-process.
9958 Many const char * variables are referenced by static specs (see
9959 INIT_STATIC_SPEC above). These variables are restored to their default
9960 values by a simple loop over the static specs.
9962 For other variables, we directly restore them all to their initial
9963 values (often implicitly 0).
9965 Free the various obstacks in this file, along with "opts_obstack"
9966 from opts.c.
9968 This function also restores any environment variables that were changed. */
9970 void
9971 driver::finalize ()
9973 env.restore ();
9974 params_c_finalize ();
9975 diagnostic_finish (global_dc);
9977 is_cpp_driver = 0;
9978 at_file_supplied = 0;
9979 print_help_list = 0;
9980 print_version = 0;
9981 verbose_only_flag = 0;
9982 print_subprocess_help = 0;
9983 use_ld = NULL;
9984 report_times_to_file = NULL;
9985 target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
9986 target_system_root_changed = 0;
9987 target_sysroot_suffix = 0;
9988 target_sysroot_hdrs_suffix = 0;
9989 save_temps_flag = SAVE_TEMPS_NONE;
9990 save_temps_prefix = 0;
9991 save_temps_length = 0;
9992 spec_machine = DEFAULT_TARGET_MACHINE;
9993 greatest_status = 1;
9995 finalize_options_struct (&global_options);
9996 finalize_options_struct (&global_options_set);
9998 obstack_free (&obstack, NULL);
9999 obstack_free (&opts_obstack, NULL); /* in opts.c */
10000 obstack_free (&collect_obstack, NULL);
10002 link_command_spec = LINK_COMMAND_SPEC;
10004 obstack_free (&multilib_obstack, NULL);
10006 user_specs_head = NULL;
10007 user_specs_tail = NULL;
10009 /* Within the "compilers" vec, the fields "suffix" and "spec" were
10010 statically allocated for the default compilers, but dynamically
10011 allocated for additional compilers. Delete them for the latter. */
10012 for (int i = n_default_compilers; i < n_compilers; i++)
10014 free (const_cast <char *> (compilers[i].suffix));
10015 free (const_cast <char *> (compilers[i].spec));
10017 XDELETEVEC (compilers);
10018 compilers = NULL;
10019 n_compilers = 0;
10021 linker_options.truncate (0);
10022 assembler_options.truncate (0);
10023 preprocessor_options.truncate (0);
10025 path_prefix_reset (&exec_prefixes);
10026 path_prefix_reset (&startfile_prefixes);
10027 path_prefix_reset (&include_prefixes);
10029 machine_suffix = 0;
10030 just_machine_suffix = 0;
10031 gcc_exec_prefix = 0;
10032 gcc_libexec_prefix = 0;
10033 md_exec_prefix = MD_EXEC_PREFIX;
10034 md_startfile_prefix = MD_STARTFILE_PREFIX;
10035 md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
10036 multilib_dir = 0;
10037 multilib_os_dir = 0;
10038 multiarch_dir = 0;
10040 /* Free any specs dynamically-allocated by set_spec.
10041 These will be at the head of the list, before the
10042 statically-allocated ones. */
10043 if (specs)
10045 while (specs != static_specs)
10047 spec_list *next = specs->next;
10048 free (const_cast <char *> (specs->name));
10049 XDELETE (specs);
10050 specs = next;
10052 specs = 0;
10054 for (unsigned i = 0; i < ARRAY_SIZE (static_specs); i++)
10056 spec_list *sl = &static_specs[i];
10057 if (sl->alloc_p)
10059 if (0)
10060 free (const_cast <char *> (*(sl->ptr_spec)));
10061 sl->alloc_p = false;
10063 *(sl->ptr_spec) = sl->default_ptr;
10065 #ifdef EXTRA_SPECS
10066 extra_specs = NULL;
10067 #endif
10069 processing_spec_function = 0;
10071 clear_args ();
10073 have_c = 0;
10074 have_o = 0;
10076 temp_names = NULL;
10077 execution_count = 0;
10078 signal_count = 0;
10080 temp_filename = NULL;
10081 temp_filename_length = 0;
10082 always_delete_queue = NULL;
10083 failure_delete_queue = NULL;
10085 XDELETEVEC (switches);
10086 switches = NULL;
10087 n_switches = 0;
10088 n_switches_alloc = 0;
10090 compare_debug = 0;
10091 compare_debug_second = 0;
10092 compare_debug_opt = NULL;
10093 for (int i = 0; i < 2; i++)
10095 switches_debug_check[i] = NULL;
10096 n_switches_debug_check[i] = 0;
10097 n_switches_alloc_debug_check[i] = 0;
10098 debug_check_temp_file[i] = NULL;
10101 XDELETEVEC (infiles);
10102 infiles = NULL;
10103 n_infiles = 0;
10104 n_infiles_alloc = 0;
10106 combine_inputs = false;
10107 added_libraries = 0;
10108 XDELETEVEC (outfiles);
10109 outfiles = NULL;
10110 spec_lang = 0;
10111 last_language_n_infiles = 0;
10112 gcc_input_filename = NULL;
10113 input_file_number = 0;
10114 input_filename_length = 0;
10115 basename_length = 0;
10116 suffixed_basename_length = 0;
10117 input_basename = NULL;
10118 input_suffix = NULL;
10119 /* We don't need to purge "input_stat", just to unset "input_stat_set". */
10120 input_stat_set = 0;
10121 input_file_compiler = NULL;
10122 arg_going = 0;
10123 delete_this_arg = 0;
10124 this_is_output_file = 0;
10125 this_is_library_file = 0;
10126 this_is_linker_script = 0;
10127 input_from_pipe = 0;
10128 suffix_subst = NULL;
10130 mdswitches = NULL;
10131 n_mdswitches = 0;
10133 debug_auxbase_opt = NULL;
10135 used_arg.finalize ();
10138 /* PR jit/64810.
10139 Targets can provide configure-time default options in
10140 OPTION_DEFAULT_SPECS. The jit needs to access these, but
10141 they are expressed in the spec language.
10143 Run just enough of the driver to be able to expand these
10144 specs, and then call the callback CB on each
10145 such option. The options strings are *without* a leading
10146 '-' character e.g. ("march=x86-64"). Finally, clean up. */
10148 void
10149 driver_get_configure_time_options (void (*cb) (const char *option,
10150 void *user_data),
10151 void *user_data)
10153 size_t i;
10155 obstack_init (&obstack);
10156 init_opts_obstack ();
10157 n_switches = 0;
10159 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
10160 do_option_spec (option_default_specs[i].name,
10161 option_default_specs[i].spec);
10163 for (i = 0; (int) i < n_switches; i++)
10165 gcc_assert (switches[i].part1);
10166 (*cb) (switches[i].part1, user_data);
10169 obstack_free (&opts_obstack, NULL);
10170 obstack_free (&obstack, NULL);
10171 n_switches = 0;