Couple of testsuite adjustments
[official-gcc.git] / gcc / gcc.cc
blobca1c9e27a9461dd8545f76ac7c5ea4c3de5ca78e
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987-2022 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 #define INCLUDE_STRING
31 #include "config.h"
32 #include "system.h"
33 #include "coretypes.h"
34 #include "multilib.h" /* before tm.h */
35 #include "tm.h"
36 #include "xregex.h"
37 #include "obstack.h"
38 #include "intl.h"
39 #include "prefix.h"
40 #include "opt-suggestions.h"
41 #include "gcc.h"
42 #include "diagnostic.h"
43 #include "flags.h"
44 #include "opts.h"
45 #include "filenames.h"
46 #include "spellcheck.h"
47 #include "opts-jobserver.h"
48 #include "common/common-target.h"
52 /* Manage the manipulation of env vars.
54 We poison "getenv" and "putenv", so that all enviroment-handling is
55 done through this class. Note that poisoning happens in the
56 preprocessor at the identifier level, and doesn't distinguish between
57 env.getenv ();
58 and
59 getenv ();
60 Hence we need to use "get" for the accessor method, not "getenv". */
62 struct env_manager
64 public:
65 void init (bool can_restore, bool debug);
66 const char *get (const char *name);
67 void xput (const char *string);
68 void restore ();
70 private:
71 bool m_can_restore;
72 bool m_debug;
73 struct kv
75 char *m_key;
76 char *m_value;
78 vec<kv> m_keys;
82 /* The singleton instance of class env_manager. */
84 static env_manager env;
86 /* Initializer for class env_manager.
88 We can't do this as a constructor since we have a statically
89 allocated instance ("env" above). */
91 void
92 env_manager::init (bool can_restore, bool debug)
94 m_can_restore = can_restore;
95 m_debug = debug;
98 /* Get the value of NAME within the environment. Essentially
99 a wrapper for ::getenv, but adding logging, and the possibility
100 of caching results. */
102 const char *
103 env_manager::get (const char *name)
105 const char *result = ::getenv (name);
106 if (m_debug)
107 fprintf (stderr, "env_manager::getenv (%s) -> %s\n", name, result);
108 return result;
111 /* Put the given KEY=VALUE entry STRING into the environment.
112 If the env_manager was initialized with CAN_RESTORE set, then
113 also record the old value of KEY within the environment, so that it
114 can be later restored. */
116 void
117 env_manager::xput (const char *string)
119 if (m_debug)
120 fprintf (stderr, "env_manager::xput (%s)\n", string);
121 if (verbose_flag)
122 fnotice (stderr, "%s\n", string);
124 if (m_can_restore)
126 char *equals = strchr (const_cast <char *> (string), '=');
127 gcc_assert (equals);
129 struct kv kv;
130 kv.m_key = xstrndup (string, equals - string);
131 const char *cur_value = ::getenv (kv.m_key);
132 if (m_debug)
133 fprintf (stderr, "saving old value: %s\n",cur_value);
134 kv.m_value = cur_value ? xstrdup (cur_value) : NULL;
135 m_keys.safe_push (kv);
138 ::putenv (CONST_CAST (char *, string));
141 /* Undo any xputenv changes made since last restore.
142 Can only be called if the env_manager was initialized with
143 CAN_RESTORE enabled. */
145 void
146 env_manager::restore ()
148 unsigned int i;
149 struct kv *item;
151 gcc_assert (m_can_restore);
153 FOR_EACH_VEC_ELT_REVERSE (m_keys, i, item)
155 if (m_debug)
156 printf ("restoring saved key: %s value: %s\n", item->m_key, item->m_value);
157 if (item->m_value)
158 ::setenv (item->m_key, item->m_value, 1);
159 else
160 ::unsetenv (item->m_key);
161 free (item->m_key);
162 free (item->m_value);
165 m_keys.truncate (0);
168 /* Forbid other uses of getenv and putenv. */
169 #if (GCC_VERSION >= 3000)
170 #pragma GCC poison getenv putenv
171 #endif
175 /* By default there is no special suffix for target executables. */
176 #ifdef TARGET_EXECUTABLE_SUFFIX
177 #define HAVE_TARGET_EXECUTABLE_SUFFIX
178 #else
179 #define TARGET_EXECUTABLE_SUFFIX ""
180 #endif
182 /* By default there is no special suffix for host executables. */
183 #ifdef HOST_EXECUTABLE_SUFFIX
184 #define HAVE_HOST_EXECUTABLE_SUFFIX
185 #else
186 #define HOST_EXECUTABLE_SUFFIX ""
187 #endif
189 /* By default, the suffix for target object files is ".o". */
190 #ifdef TARGET_OBJECT_SUFFIX
191 #define HAVE_TARGET_OBJECT_SUFFIX
192 #else
193 #define TARGET_OBJECT_SUFFIX ".o"
194 #endif
196 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
198 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
199 #ifndef LIBRARY_PATH_ENV
200 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
201 #endif
203 /* If a stage of compilation returns an exit status >= 1,
204 compilation of that file ceases. */
206 #define MIN_FATAL_STATUS 1
208 /* Flag set by cppspec.cc to 1. */
209 int is_cpp_driver;
211 /* Flag set to nonzero if an @file argument has been supplied to gcc. */
212 static bool at_file_supplied;
214 /* Definition of string containing the arguments given to configure. */
215 #include "configargs.h"
217 /* Flag saying to print the command line options understood by gcc and its
218 sub-processes. */
220 static int print_help_list;
222 /* Flag saying to print the version of gcc and its sub-processes. */
224 static int print_version;
226 /* Flag that stores string prefix for which we provide bash completion. */
228 static const char *completion = NULL;
230 /* Flag indicating whether we should ONLY print the command and
231 arguments (like verbose_flag) without executing the command.
232 Displayed arguments are quoted so that the generated command
233 line is suitable for execution. This is intended for use in
234 shell scripts to capture the driver-generated command line. */
235 static int verbose_only_flag;
237 /* Flag indicating how to print command line options of sub-processes. */
239 static int print_subprocess_help;
241 /* Linker suffix passed to -fuse-ld=... */
242 static const char *use_ld;
244 /* Whether we should report subprocess execution times to a file. */
246 FILE *report_times_to_file = NULL;
248 /* Nonzero means place this string before uses of /, so that include
249 and library files can be found in an alternate location. */
251 #ifdef TARGET_SYSTEM_ROOT
252 #define DEFAULT_TARGET_SYSTEM_ROOT (TARGET_SYSTEM_ROOT)
253 #else
254 #define DEFAULT_TARGET_SYSTEM_ROOT (0)
255 #endif
256 static const char *target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
258 /* Nonzero means pass the updated target_system_root to the compiler. */
260 static int target_system_root_changed;
262 /* Nonzero means append this string to target_system_root. */
264 static const char *target_sysroot_suffix = 0;
266 /* Nonzero means append this string to target_system_root for headers. */
268 static const char *target_sysroot_hdrs_suffix = 0;
270 /* Nonzero means write "temp" files in source directory
271 and use the source file's name in them, and don't delete them. */
273 static enum save_temps {
274 SAVE_TEMPS_NONE, /* no -save-temps */
275 SAVE_TEMPS_CWD, /* -save-temps in current directory */
276 SAVE_TEMPS_DUMP, /* -save-temps in dumpdir */
277 SAVE_TEMPS_OBJ /* -save-temps in object directory */
278 } save_temps_flag;
280 /* Set this iff the dumppfx implied by a -save-temps=* option is to
281 override a -dumpdir option, if any. */
282 static bool save_temps_overrides_dumpdir = false;
284 /* -dumpdir, -dumpbase and -dumpbase-ext flags passed in, possibly
285 rearranged as they are to be passed down, e.g., dumpbase and
286 dumpbase_ext may be cleared if integrated with dumpdir or
287 dropped. */
288 static char *dumpdir, *dumpbase, *dumpbase_ext;
290 /* Usually the length of the string in dumpdir. However, during
291 linking, it may be shortened to omit a driver-added trailing dash,
292 by then replaced with a trailing period, that is still to be passed
293 to sub-processes in -dumpdir, but not to be generally used in spec
294 filename expansions. See maybe_run_linker. */
295 static size_t dumpdir_length = 0;
297 /* Set if the last character in dumpdir is (or was) a dash that the
298 driver added to dumpdir after dumpbase or linker output name. */
299 static bool dumpdir_trailing_dash_added = false;
301 /* Basename of dump and aux outputs, computed from dumpbase (given or
302 derived from output name), to override input_basename in non-%w %b
303 et al. */
304 static char *outbase;
305 static size_t outbase_length = 0;
307 /* The compiler version. */
309 static const char *compiler_version;
311 /* The target version. */
313 static const char *const spec_version = DEFAULT_TARGET_VERSION;
315 /* The target machine. */
317 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
318 static const char *spec_host_machine = DEFAULT_REAL_TARGET_MACHINE;
320 /* List of offload targets. Separated by colon. Empty string for
321 -foffload=disable. */
323 static char *offload_targets = NULL;
325 #if OFFLOAD_DEFAULTED
326 /* Set to true if -foffload has not been used and offload_targets
327 is set to the configured in default. */
328 static bool offload_targets_default;
329 #endif
331 /* Nonzero if cross-compiling.
332 When -b is used, the value comes from the `specs' file. */
334 #ifdef CROSS_DIRECTORY_STRUCTURE
335 static const char *cross_compile = "1";
336 #else
337 static const char *cross_compile = "0";
338 #endif
340 /* Greatest exit code of sub-processes that has been encountered up to
341 now. */
342 static int greatest_status = 1;
344 /* This is the obstack which we use to allocate many strings. */
346 static struct obstack obstack;
348 /* This is the obstack to build an environment variable to pass to
349 collect2 that describes all of the relevant switches of what to
350 pass the compiler in building the list of pointers to constructors
351 and destructors. */
353 static struct obstack collect_obstack;
355 /* Forward declaration for prototypes. */
356 struct path_prefix;
357 struct prefix_list;
359 static void init_spec (void);
360 static void store_arg (const char *, int, int);
361 static void insert_wrapper (const char *);
362 static char *load_specs (const char *);
363 static void read_specs (const char *, bool, bool);
364 static void set_spec (const char *, const char *, bool);
365 static struct compiler *lookup_compiler (const char *, size_t, const char *);
366 static char *build_search_list (const struct path_prefix *, const char *,
367 bool, bool);
368 static void xputenv (const char *);
369 static void putenv_from_prefixes (const struct path_prefix *, const char *,
370 bool);
371 static int access_check (const char *, int);
372 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
373 static char *find_a_program (const char *);
374 static void add_prefix (struct path_prefix *, const char *, const char *,
375 int, int, int);
376 static void add_sysrooted_prefix (struct path_prefix *, const char *,
377 const char *, int, int, int);
378 static char *skip_whitespace (char *);
379 static void delete_if_ordinary (const char *);
380 static void delete_temp_files (void);
381 static void delete_failure_queue (void);
382 static void clear_failure_queue (void);
383 static int check_live_switch (int, int);
384 static const char *handle_braces (const char *);
385 static inline bool input_suffix_matches (const char *, const char *);
386 static inline bool switch_matches (const char *, const char *, int);
387 static inline void mark_matching_switches (const char *, const char *, int);
388 static inline void process_marked_switches (void);
389 static const char *process_brace_body (const char *, const char *, const char *, int, int);
390 static const struct spec_function *lookup_spec_function (const char *);
391 static const char *eval_spec_function (const char *, const char *, const char *);
392 static const char *handle_spec_function (const char *, bool *, const char *);
393 static char *save_string (const char *, int);
394 static void set_collect_gcc_options (void);
395 static int do_spec_1 (const char *, int, const char *);
396 static int do_spec_2 (const char *, const char *);
397 static void do_option_spec (const char *, const char *);
398 static void do_self_spec (const char *);
399 static const char *find_file (const char *);
400 static int is_directory (const char *, bool);
401 static const char *validate_switches (const char *, bool, bool);
402 static void validate_all_switches (void);
403 static inline void validate_switches_from_spec (const char *, bool);
404 static void give_switch (int, int);
405 static int default_arg (const char *, int);
406 static void set_multilib_dir (void);
407 static void print_multilib_info (void);
408 static void display_help (void);
409 static void add_preprocessor_option (const char *, int);
410 static void add_assembler_option (const char *, int);
411 static void add_linker_option (const char *, int);
412 static void process_command (unsigned int, struct cl_decoded_option *);
413 static int execute (void);
414 static void alloc_args (void);
415 static void clear_args (void);
416 static void fatal_signal (int);
417 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
418 static void init_gcc_specs (struct obstack *, const char *, const char *,
419 const char *);
420 #endif
421 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
422 static const char *convert_filename (const char *, int, int);
423 #endif
425 static void try_generate_repro (const char **argv);
426 static const char *getenv_spec_function (int, const char **);
427 static const char *if_exists_spec_function (int, const char **);
428 static const char *if_exists_else_spec_function (int, const char **);
429 static const char *if_exists_then_else_spec_function (int, const char **);
430 static const char *sanitize_spec_function (int, const char **);
431 static const char *replace_outfile_spec_function (int, const char **);
432 static const char *remove_outfile_spec_function (int, const char **);
433 static const char *version_compare_spec_function (int, const char **);
434 static const char *include_spec_function (int, const char **);
435 static const char *find_file_spec_function (int, const char **);
436 static const char *find_plugindir_spec_function (int, const char **);
437 static const char *print_asm_header_spec_function (int, const char **);
438 static const char *compare_debug_dump_opt_spec_function (int, const char **);
439 static const char *compare_debug_self_opt_spec_function (int, const char **);
440 static const char *pass_through_libs_spec_func (int, const char **);
441 static const char *dumps_spec_func (int, const char **);
442 static const char *greater_than_spec_func (int, const char **);
443 static const char *debug_level_greater_than_spec_func (int, const char **);
444 static const char *dwarf_version_greater_than_spec_func (int, const char **);
445 static const char *find_fortran_preinclude_file (int, const char **);
446 static char *convert_white_space (char *);
447 static char *quote_spec (char *);
448 static char *quote_spec_arg (char *);
449 static bool not_actual_file_p (const char *);
452 /* The Specs Language
454 Specs are strings containing lines, each of which (if not blank)
455 is made up of a program name, and arguments separated by spaces.
456 The program name must be exact and start from root, since no path
457 is searched and it is unreliable to depend on the current working directory.
458 Redirection of input or output is not supported; the subprograms must
459 accept filenames saying what files to read and write.
461 In addition, the specs can contain %-sequences to substitute variable text
462 or for conditional text. Here is a table of all defined %-sequences.
463 Note that spaces are not generated automatically around the results of
464 expanding these sequences; therefore, you can concatenate them together
465 or with constant text in a single argument.
467 %% substitute one % into the program name or argument.
468 %" substitute an empty argument.
469 %i substitute the name of the input file being processed.
470 %b substitute the basename for outputs related with the input file
471 being processed. This is often a substring of the input file name,
472 up to (and not including) the last period but, unless %w is active,
473 it is affected by the directory selected by -save-temps=*, by
474 -dumpdir, and, in case of multiple compilations, even by -dumpbase
475 and -dumpbase-ext and, in case of linking, by the linker output
476 name. When %w is active, it derives the main output name only from
477 the input file base name; when it is not, it names aux/dump output
478 file.
479 %B same as %b, but include the input file suffix (text after the last
480 period).
481 %gSUFFIX
482 substitute a file name that has suffix SUFFIX and is chosen
483 once per compilation, and mark the argument a la %d. To reduce
484 exposure to denial-of-service attacks, the file name is now
485 chosen in a way that is hard to predict even when previously
486 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
487 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
488 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
489 had been pre-processed. Previously, %g was simply substituted
490 with a file name chosen once per compilation, without regard
491 to any appended suffix (which was therefore treated just like
492 ordinary text), making such attacks more likely to succeed.
493 %|SUFFIX
494 like %g, but if -pipe is in effect, expands simply to "-".
495 %mSUFFIX
496 like %g, but if -pipe is in effect, expands to nothing. (We have both
497 %| and %m to accommodate differences between system assemblers; see
498 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
499 %uSUFFIX
500 like %g, but generates a new temporary file name even if %uSUFFIX
501 was already seen.
502 %USUFFIX
503 substitutes the last file name generated with %uSUFFIX, generating a
504 new one if there is no such last file name. In the absence of any
505 %uSUFFIX, this is just like %gSUFFIX, except they don't share
506 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
507 would involve the generation of two distinct file names, one
508 for each `%g.s' and another for each `%U.s'. Previously, %U was
509 simply substituted with a file name chosen for the previous %u,
510 without regard to any appended suffix.
511 %jSUFFIX
512 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
513 writable, and if save-temps is off; otherwise, substitute the name
514 of a temporary file, just like %u. This temporary file is not
515 meant for communication between processes, but rather as a junk
516 disposal mechanism.
517 %.SUFFIX
518 substitutes .SUFFIX for the suffixes of a matched switch's args when
519 it is subsequently output with %*. SUFFIX is terminated by the next
520 space or %.
521 %d marks the argument containing or following the %d as a
522 temporary file name, so that file will be deleted if GCC exits
523 successfully. Unlike %g, this contributes no text to the argument.
524 %w marks the argument containing or following the %w as the
525 "output file" of this compilation. This puts the argument
526 into the sequence of arguments that %o will substitute later.
527 %V indicates that this compilation produces no "output file".
528 %W{...}
529 like %{...} but marks the last argument supplied within as a file
530 to be deleted on failure.
531 %@{...}
532 like %{...} but puts the result into a FILE and substitutes @FILE
533 if an @file argument has been supplied.
534 %o substitutes the names of all the output files, with spaces
535 automatically placed around them. You should write spaces
536 around the %o as well or the results are undefined.
537 %o is for use in the specs for running the linker.
538 Input files whose names have no recognized suffix are not compiled
539 at all, but they are included among the output files, so they will
540 be linked.
541 %O substitutes the suffix for object files. Note that this is
542 handled specially when it immediately follows %g, %u, or %U
543 (with or without a suffix argument) because of the need for
544 those to form complete file names. The handling is such that
545 %O is treated exactly as if it had already been substituted,
546 except that %g, %u, and %U do not currently support additional
547 SUFFIX characters following %O as they would following, for
548 example, `.o'.
549 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
550 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
551 and -B options) and -imultilib as necessary.
552 %s current argument is the name of a library or startup file of some sort.
553 Search for that file in a standard list of directories
554 and substitute the full name found.
555 %T current argument is the name of a linker script.
556 Search for that file in the current list of directories to scan for
557 libraries. If the file is located, insert a --script option into the
558 command line followed by the full path name found. If the file is
559 not found then generate an error message.
560 Note: the current working directory is not searched.
561 %eSTR Print STR as an error message. STR is terminated by a newline.
562 Use this when inconsistent options are detected.
563 %nSTR Print STR as a notice. STR is terminated by a newline.
564 %x{OPTION} Accumulate an option for %X.
565 %X Output the accumulated linker options specified by compilations.
566 %Y Output the accumulated assembler options specified by compilations.
567 %Z Output the accumulated preprocessor options specified by compilations.
568 %a process ASM_SPEC as a spec.
569 This allows config.h to specify part of the spec for running as.
570 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
571 used here. This can be used to run a post-processor after the
572 assembler has done its job.
573 %D Dump out a -L option for each directory in startfile_prefixes.
574 If multilib_dir is set, extra entries are generated with it affixed.
575 %l process LINK_SPEC as a spec.
576 %L process LIB_SPEC as a spec.
577 %M Output multilib_os_dir.
578 %G process LIBGCC_SPEC as a spec.
579 %R Output the concatenation of target_system_root and
580 target_sysroot_suffix.
581 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
582 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
583 %C process CPP_SPEC as a spec.
584 %1 process CC1_SPEC as a spec.
585 %2 process CC1PLUS_SPEC as a spec.
586 %* substitute the variable part of a matched option. (See below.)
587 Note that each comma in the substituted string is replaced by
588 a single space. A space is appended after the last substition
589 unless there is more text in current sequence.
590 %<S remove all occurrences of -S from the command line.
591 Note - this command is position dependent. % commands in the
592 spec string before this one will see -S, % commands in the
593 spec string after this one will not.
594 %>S Similar to "%<S", but keep it in the GCC command line.
595 %<S* remove all occurrences of all switches beginning with -S from the
596 command line.
597 %:function(args)
598 Call the named function FUNCTION, passing it ARGS. ARGS is
599 first processed as a nested spec string, then split into an
600 argument vector in the usual fashion. The function returns
601 a string which is processed as if it had appeared literally
602 as part of the current spec.
603 %{S} substitutes the -S switch, if that switch was given to GCC.
604 If that switch was not specified, this substitutes nothing.
605 Here S is a metasyntactic variable.
606 %{S*} substitutes all the switches specified to GCC whose names start
607 with -S. This is used for -o, -I, etc; switches that take
608 arguments. GCC considers `-o foo' as being one switch whose
609 name starts with `o'. %{o*} would substitute this text,
610 including the space; thus, two arguments would be generated.
611 %{S*&T*} likewise, but preserve order of S and T options (the order
612 of S and T in the spec is not significant). Can be any number
613 of ampersand-separated variables; for each the wild card is
614 optional. Useful for CPP as %{D*&U*&A*}.
616 %{S:X} substitutes X, if the -S switch was given to GCC.
617 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
618 %{S*:X} substitutes X if one or more switches whose names start
619 with -S was given to GCC. Normally X is substituted only
620 once, no matter how many such switches appeared. However,
621 if %* appears somewhere in X, then X will be substituted
622 once for each matching switch, with the %* replaced by the
623 part of that switch that matched the '*'. A space will be
624 appended after the last substition unless there is more
625 text in current sequence.
626 %{.S:X} substitutes X, if processing a file with suffix S.
627 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
628 %{,S:X} substitutes X, if processing a file which will use spec S.
629 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
631 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
632 combined with '!', '.', ',', and '*' as above binding stronger
633 than the OR.
634 If %* appears in X, all of the alternatives must be starred, and
635 only the first matching alternative is substituted.
636 %{%:function(args):X}
637 Call function named FUNCTION with args ARGS. If the function
638 returns non-NULL, then X is substituted, if it returns
639 NULL, it isn't substituted.
640 %{S:X; if S was given to GCC, substitutes X;
641 T:Y; else if T was given to GCC, substitutes Y;
642 :D} else substitutes D. There can be as many clauses as you need.
643 This may be combined with '.', '!', ',', '|', and '*' as above.
645 %(Spec) processes a specification defined in a specs file as *Spec:
647 The switch matching text S in a %{S}, %{S:X}, or similar construct can use
648 a backslash to ignore the special meaning of the character following it,
649 thus allowing literal matching of a character that is otherwise specially
650 treated. For example, %{std=iso9899\:1999:X} substitutes X if the
651 -std=iso9899:1999 option is given.
653 The conditional text X in a %{S:X} or similar construct may contain
654 other nested % constructs or spaces, or even newlines. They are
655 processed as usual, as described above. Trailing white space in X is
656 ignored. White space may also appear anywhere on the left side of the
657 colon in these constructs, except between . or * and the corresponding
658 word.
660 The -O, -f, -g, -m, and -W switches are handled specifically in these
661 constructs. If another value of -O or the negated form of a -f, -m, or
662 -W switch is found later in the command line, the earlier switch
663 value is ignored, except with {S*} where S is just one letter; this
664 passes all matching options.
666 The character | at the beginning of the predicate text is used to indicate
667 that a command should be piped to the following command, but only if -pipe
668 is specified.
670 Note that it is built into GCC which switches take arguments and which
671 do not. You might think it would be useful to generalize this to
672 allow each compiler's spec to say which switches take arguments. But
673 this cannot be done in a consistent fashion. GCC cannot even decide
674 which input files have been specified without knowing which switches
675 take arguments, and it must know which input files to compile in order
676 to tell which compilers to run.
678 GCC also knows implicitly that arguments starting in `-l' are to be
679 treated as compiler output files, and passed to the linker in their
680 proper position among the other output files. */
682 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
684 /* config.h can define ASM_SPEC to provide extra args to the assembler
685 or extra switch-translations. */
686 #ifndef ASM_SPEC
687 #define ASM_SPEC ""
688 #endif
690 /* config.h can define ASM_FINAL_SPEC to run a post processor after
691 the assembler has run. */
692 #ifndef ASM_FINAL_SPEC
693 #define ASM_FINAL_SPEC \
694 "%{gsplit-dwarf: \n\
695 objcopy --extract-dwo \
696 %{c:%{o*:%*}%{!o*:%w%b%O}}%{!c:%U%O} \
697 %b.dwo \n\
698 objcopy --strip-dwo \
699 %{c:%{o*:%*}%{!o*:%w%b%O}}%{!c:%U%O} \
701 #endif
703 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
704 or extra switch-translations. */
705 #ifndef CPP_SPEC
706 #define CPP_SPEC ""
707 #endif
709 /* Subtargets can define SUBTARGET_CC1_SPEC to provide extra args to cc1 and
710 cc1plus or extra switch-translations. The SUBTARGET_CC1_SPEC is appended
711 to CC1_SPEC in the initialization of cc1_spec. */
712 #ifndef SUBTARGET_CC1_SPEC
713 #define SUBTARGET_CC1_SPEC ""
714 #endif
716 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
717 or extra switch-translations. */
718 #ifndef CC1_SPEC
719 #define CC1_SPEC ""
720 #endif
722 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
723 or extra switch-translations. */
724 #ifndef CC1PLUS_SPEC
725 #define CC1PLUS_SPEC ""
726 #endif
728 /* config.h can define LINK_SPEC to provide extra args to the linker
729 or extra switch-translations. */
730 #ifndef LINK_SPEC
731 #define LINK_SPEC ""
732 #endif
734 /* config.h can define LIB_SPEC to override the default libraries. */
735 #ifndef LIB_SPEC
736 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
737 #endif
739 /* When using -fsplit-stack we need to wrap pthread_create, in order
740 to initialize the stack guard. We always use wrapping, rather than
741 shared library ordering, and we keep the wrapper function in
742 libgcc. This is not yet a real spec, though it could become one;
743 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
744 only works with GNU ld and gold. */
745 #ifdef HAVE_GOLD_NON_DEFAULT_SPLIT_STACK
746 #define STACK_SPLIT_SPEC " %{fsplit-stack: -fuse-ld=gold --wrap=pthread_create}"
747 #else
748 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
749 #endif
751 #ifndef LIBASAN_SPEC
752 #define STATIC_LIBASAN_LIBS \
753 " %{static-libasan|static:%:include(libsanitizer.spec)%(link_libasan)}"
754 #ifdef LIBASAN_EARLY_SPEC
755 #define LIBASAN_SPEC STATIC_LIBASAN_LIBS
756 #elif defined(HAVE_LD_STATIC_DYNAMIC)
757 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
758 "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
759 STATIC_LIBASAN_LIBS
760 #else
761 #define LIBASAN_SPEC "-lasan" STATIC_LIBASAN_LIBS
762 #endif
763 #endif
765 #ifndef LIBASAN_EARLY_SPEC
766 #define LIBASAN_EARLY_SPEC ""
767 #endif
769 #ifndef LIBHWASAN_SPEC
770 #define STATIC_LIBHWASAN_LIBS \
771 " %{static-libhwasan|static:%:include(libsanitizer.spec)%(link_libhwasan)}"
772 #ifdef LIBHWASAN_EARLY_SPEC
773 #define LIBHWASAN_SPEC STATIC_LIBHWASAN_LIBS
774 #elif defined(HAVE_LD_STATIC_DYNAMIC)
775 #define LIBHWASAN_SPEC "%{static-libhwasan:" LD_STATIC_OPTION \
776 "} -lhwasan %{static-libhwasan:" LD_DYNAMIC_OPTION "}" \
777 STATIC_LIBHWASAN_LIBS
778 #else
779 #define LIBHWASAN_SPEC "-lhwasan" STATIC_LIBHWASAN_LIBS
780 #endif
781 #endif
783 #ifndef LIBHWASAN_EARLY_SPEC
784 #define LIBHWASAN_EARLY_SPEC ""
785 #endif
787 #ifndef LIBTSAN_SPEC
788 #define STATIC_LIBTSAN_LIBS \
789 " %{static-libtsan|static:%:include(libsanitizer.spec)%(link_libtsan)}"
790 #ifdef LIBTSAN_EARLY_SPEC
791 #define LIBTSAN_SPEC STATIC_LIBTSAN_LIBS
792 #elif defined(HAVE_LD_STATIC_DYNAMIC)
793 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
794 "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}" \
795 STATIC_LIBTSAN_LIBS
796 #else
797 #define LIBTSAN_SPEC "-ltsan" STATIC_LIBTSAN_LIBS
798 #endif
799 #endif
801 #ifndef LIBTSAN_EARLY_SPEC
802 #define LIBTSAN_EARLY_SPEC ""
803 #endif
805 #ifndef LIBLSAN_SPEC
806 #define STATIC_LIBLSAN_LIBS \
807 " %{static-liblsan|static:%:include(libsanitizer.spec)%(link_liblsan)}"
808 #ifdef LIBLSAN_EARLY_SPEC
809 #define LIBLSAN_SPEC STATIC_LIBLSAN_LIBS
810 #elif defined(HAVE_LD_STATIC_DYNAMIC)
811 #define LIBLSAN_SPEC "%{static-liblsan:" LD_STATIC_OPTION \
812 "} -llsan %{static-liblsan:" LD_DYNAMIC_OPTION "}" \
813 STATIC_LIBLSAN_LIBS
814 #else
815 #define LIBLSAN_SPEC "-llsan" STATIC_LIBLSAN_LIBS
816 #endif
817 #endif
819 #ifndef LIBLSAN_EARLY_SPEC
820 #define LIBLSAN_EARLY_SPEC ""
821 #endif
823 #ifndef LIBUBSAN_SPEC
824 #define STATIC_LIBUBSAN_LIBS \
825 " %{static-libubsan|static:%:include(libsanitizer.spec)%(link_libubsan)}"
826 #ifdef HAVE_LD_STATIC_DYNAMIC
827 #define LIBUBSAN_SPEC "%{static-libubsan:" LD_STATIC_OPTION \
828 "} -lubsan %{static-libubsan:" LD_DYNAMIC_OPTION "}" \
829 STATIC_LIBUBSAN_LIBS
830 #else
831 #define LIBUBSAN_SPEC "-lubsan" STATIC_LIBUBSAN_LIBS
832 #endif
833 #endif
835 /* Linker options for compressed debug sections. */
836 #if HAVE_LD_COMPRESS_DEBUG == 0
837 /* No linker support. */
838 #define LINK_COMPRESS_DEBUG_SPEC \
839 " %{gz*:%e-gz is not supported in this configuration} "
840 #elif HAVE_LD_COMPRESS_DEBUG == 1
841 /* ELF gABI style. */
842 #define LINK_COMPRESS_DEBUG_SPEC \
843 " %{gz|gz=zlib:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
844 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
845 " %{gz*:%e-gz=zstd is not supported in this configuration} " \
846 " %{gz=zlib-gnu:}" /* Ignore silently zlib-gnu option value. */
847 #elif HAVE_LD_COMPRESS_DEBUG == 2
848 /* ELF gABI style and ZSTD. */
849 #define LINK_COMPRESS_DEBUG_SPEC \
850 " %{gz|gz=zlib:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
851 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
852 " %{gz=zstd:" LD_COMPRESS_DEBUG_OPTION "=zstd}" \
853 " %{gz=zlib-gnu:}" /* Ignore silently zlib-gnu option value. */
854 #else
855 #error Unknown value for HAVE_LD_COMPRESS_DEBUG.
856 #endif
858 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
859 included. */
860 #ifndef LIBGCC_SPEC
861 #if defined(REAL_LIBGCC_SPEC)
862 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
863 #elif defined(LINK_LIBGCC_SPECIAL_1)
864 /* Have gcc do the search for libgcc.a. */
865 #define LIBGCC_SPEC "libgcc.a%s"
866 #else
867 #define LIBGCC_SPEC "-lgcc"
868 #endif
869 #endif
871 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
872 #ifndef STARTFILE_SPEC
873 #define STARTFILE_SPEC \
874 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
875 #endif
877 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
878 #ifndef ENDFILE_SPEC
879 #define ENDFILE_SPEC ""
880 #endif
882 #ifndef LINKER_NAME
883 #define LINKER_NAME "collect2"
884 #endif
886 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
887 #define ASM_MAP " %{ffile-prefix-map=*:--debug-prefix-map %*} %{fdebug-prefix-map=*:--debug-prefix-map %*}"
888 #else
889 #define ASM_MAP ""
890 #endif
892 /* Assembler options for compressed debug sections. */
893 #if HAVE_LD_COMPRESS_DEBUG == 0
894 /* Reject if the linker cannot write compressed debug sections. */
895 #define ASM_COMPRESS_DEBUG_SPEC \
896 " %{gz*:%e-gz is not supported in this configuration} "
897 #else /* HAVE_LD_COMPRESS_DEBUG >= 1 */
898 #if HAVE_AS_COMPRESS_DEBUG == 0
899 /* No assembler support. Ignore silently. */
900 #define ASM_COMPRESS_DEBUG_SPEC \
901 " %{gz*:} "
902 #elif HAVE_AS_COMPRESS_DEBUG == 1
903 /* ELF gABI style. */
904 #define ASM_COMPRESS_DEBUG_SPEC \
905 " %{gz|gz=zlib:" AS_COMPRESS_DEBUG_OPTION "=zlib}" \
906 " %{gz=none:" AS_COMPRESS_DEBUG_OPTION "=none}" \
907 " %{gz=zlib-gnu:}" /* Ignore silently zlib-gnu option value. */
908 #elif HAVE_AS_COMPRESS_DEBUG == 2
909 /* ELF gABI style and ZSTD. */
910 #define ASM_COMPRESS_DEBUG_SPEC \
911 " %{gz|gz=zlib:" AS_COMPRESS_DEBUG_OPTION "=zlib}" \
912 " %{gz=none:" AS_COMPRESS_DEBUG_OPTION "=none}" \
913 " %{gz=zstd:" AS_COMPRESS_DEBUG_OPTION "=zstd}" \
914 " %{gz=zlib-gnu:}" /* Ignore silently zlib-gnu option value. */
915 #else
916 #error Unknown value for HAVE_AS_COMPRESS_DEBUG.
917 #endif
918 #endif /* HAVE_LD_COMPRESS_DEBUG >= 1 */
920 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
921 to the assembler, when compiling assembly sources only. */
922 #ifndef ASM_DEBUG_SPEC
923 # if defined(HAVE_AS_GDWARF_5_DEBUG_FLAG) && defined(HAVE_AS_WORKING_DWARF_N_FLAG)
924 /* If --gdwarf-N is supported and as can handle even compiler generated
925 .debug_line with it, supply --gdwarf-N in ASM_DEBUG_OPTION_SPEC rather
926 than in ASM_DEBUG_SPEC, so that it applies to both .s and .c etc.
927 compilations. */
928 # define ASM_DEBUG_DWARF_OPTION ""
929 # elif defined(HAVE_AS_GDWARF_5_DEBUG_FLAG) && !defined(HAVE_LD_BROKEN_PE_DWARF5)
930 # define ASM_DEBUG_DWARF_OPTION "%{%:dwarf-version-gt(4):--gdwarf-5;" \
931 "%:dwarf-version-gt(3):--gdwarf-4;" \
932 "%:dwarf-version-gt(2):--gdwarf-3;" \
933 ":--gdwarf2}"
934 # else
935 # define ASM_DEBUG_DWARF_OPTION "--gdwarf2"
936 # endif
937 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
938 # define ASM_DEBUG_SPEC "%{g*:%{%:debug-level-gt(0):" \
939 ASM_DEBUG_DWARF_OPTION "}}" ASM_MAP
940 # endif
941 # endif
942 #ifndef ASM_DEBUG_SPEC
943 # define ASM_DEBUG_SPEC ""
944 #endif
946 /* Define ASM_DEBUG_OPTION_SPEC to be a spec suitable for translating '-g'
947 to the assembler when compiling all sources. */
948 #ifndef ASM_DEBUG_OPTION_SPEC
949 # if defined(HAVE_AS_GDWARF_5_DEBUG_FLAG) && defined(HAVE_AS_WORKING_DWARF_N_FLAG)
950 # define ASM_DEBUG_OPTION_DWARF_OPT \
951 "%{%:dwarf-version-gt(4):--gdwarf-5 ;" \
952 "%:dwarf-version-gt(3):--gdwarf-4 ;" \
953 "%:dwarf-version-gt(2):--gdwarf-3 ;" \
954 ":--gdwarf2 }"
955 # if defined(DWARF2_DEBUGGING_INFO)
956 # define ASM_DEBUG_OPTION_SPEC "%{g*:%{%:debug-level-gt(0):" \
957 ASM_DEBUG_OPTION_DWARF_OPT "}}"
958 # endif
959 # endif
960 #endif
961 #ifndef ASM_DEBUG_OPTION_SPEC
962 # define ASM_DEBUG_OPTION_SPEC ""
963 #endif
965 /* Here is the spec for running the linker, after compiling all files. */
967 /* This is overridable by the target in case they need to specify the
968 -lgcc and -lc order specially, yet not require them to override all
969 of LINK_COMMAND_SPEC. */
970 #ifndef LINK_GCC_C_SEQUENCE_SPEC
971 #define LINK_GCC_C_SEQUENCE_SPEC "%G %{!nolibc:%L %G}"
972 #endif
974 #ifndef LINK_SSP_SPEC
975 #ifdef TARGET_LIBC_PROVIDES_SSP
976 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
977 "|fstack-protector-strong|fstack-protector-explicit:}"
978 #else
979 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
980 "|fstack-protector-strong|fstack-protector-explicit" \
981 ":-lssp_nonshared -lssp}"
982 #endif
983 #endif
985 #ifdef ENABLE_DEFAULT_PIE
986 #define PIE_SPEC "!no-pie"
987 #define NO_FPIE1_SPEC "fno-pie"
988 #define FPIE1_SPEC NO_FPIE1_SPEC ":;"
989 #define NO_FPIE2_SPEC "fno-PIE"
990 #define FPIE2_SPEC NO_FPIE2_SPEC ":;"
991 #define NO_FPIE_SPEC NO_FPIE1_SPEC "|" NO_FPIE2_SPEC
992 #define FPIE_SPEC NO_FPIE_SPEC ":;"
993 #define NO_FPIC1_SPEC "fno-pic"
994 #define FPIC1_SPEC NO_FPIC1_SPEC ":;"
995 #define NO_FPIC2_SPEC "fno-PIC"
996 #define FPIC2_SPEC NO_FPIC2_SPEC ":;"
997 #define NO_FPIC_SPEC NO_FPIC1_SPEC "|" NO_FPIC2_SPEC
998 #define FPIC_SPEC NO_FPIC_SPEC ":;"
999 #define NO_FPIE1_AND_FPIC1_SPEC NO_FPIE1_SPEC "|" NO_FPIC1_SPEC
1000 #define FPIE1_OR_FPIC1_SPEC NO_FPIE1_AND_FPIC1_SPEC ":;"
1001 #define NO_FPIE2_AND_FPIC2_SPEC NO_FPIE2_SPEC "|" NO_FPIC2_SPEC
1002 #define FPIE2_OR_FPIC2_SPEC NO_FPIE2_AND_FPIC2_SPEC ":;"
1003 #define NO_FPIE_AND_FPIC_SPEC NO_FPIE_SPEC "|" NO_FPIC_SPEC
1004 #define FPIE_OR_FPIC_SPEC NO_FPIE_AND_FPIC_SPEC ":;"
1005 #else
1006 #define PIE_SPEC "pie"
1007 #define FPIE1_SPEC "fpie"
1008 #define NO_FPIE1_SPEC FPIE1_SPEC ":;"
1009 #define FPIE2_SPEC "fPIE"
1010 #define NO_FPIE2_SPEC FPIE2_SPEC ":;"
1011 #define FPIE_SPEC FPIE1_SPEC "|" FPIE2_SPEC
1012 #define NO_FPIE_SPEC FPIE_SPEC ":;"
1013 #define FPIC1_SPEC "fpic"
1014 #define NO_FPIC1_SPEC FPIC1_SPEC ":;"
1015 #define FPIC2_SPEC "fPIC"
1016 #define NO_FPIC2_SPEC FPIC2_SPEC ":;"
1017 #define FPIC_SPEC FPIC1_SPEC "|" FPIC2_SPEC
1018 #define NO_FPIC_SPEC FPIC_SPEC ":;"
1019 #define FPIE1_OR_FPIC1_SPEC FPIE1_SPEC "|" FPIC1_SPEC
1020 #define NO_FPIE1_AND_FPIC1_SPEC FPIE1_OR_FPIC1_SPEC ":;"
1021 #define FPIE2_OR_FPIC2_SPEC FPIE2_SPEC "|" FPIC2_SPEC
1022 #define NO_FPIE2_AND_FPIC2_SPEC FPIE1_OR_FPIC2_SPEC ":;"
1023 #define FPIE_OR_FPIC_SPEC FPIE_SPEC "|" FPIC_SPEC
1024 #define NO_FPIE_AND_FPIC_SPEC FPIE_OR_FPIC_SPEC ":;"
1025 #endif
1027 #ifndef LINK_PIE_SPEC
1028 #ifdef HAVE_LD_PIE
1029 #ifndef LD_PIE_SPEC
1030 #define LD_PIE_SPEC "-pie"
1031 #endif
1032 #else
1033 #define LD_PIE_SPEC ""
1034 #endif
1035 #define LINK_PIE_SPEC "%{static|shared|r:;" PIE_SPEC ":" LD_PIE_SPEC "} "
1036 #endif
1038 #ifndef LINK_BUILDID_SPEC
1039 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
1040 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
1041 # endif
1042 #endif
1044 #ifndef LTO_PLUGIN_SPEC
1045 #define LTO_PLUGIN_SPEC ""
1046 #endif
1048 /* Conditional to test whether the LTO plugin is used or not.
1049 FIXME: For slim LTO we will need to enable plugin unconditionally. This
1050 still cause problems with PLUGIN_LD != LD and when plugin is built but
1051 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
1052 plugin only when LTO is enabled. We still honor explicit
1053 -fuse-linker-plugin if the linker used understands -plugin. */
1055 /* The linker has some plugin support. */
1056 #if HAVE_LTO_PLUGIN > 0
1057 /* The linker used has full plugin support, use LTO plugin by default. */
1058 #if HAVE_LTO_PLUGIN == 2
1059 #define PLUGIN_COND "!fno-use-linker-plugin:%{!fno-lto"
1060 #define PLUGIN_COND_CLOSE "}"
1061 #else
1062 /* The linker used has limited plugin support, use LTO plugin with explicit
1063 -fuse-linker-plugin. */
1064 #define PLUGIN_COND "fuse-linker-plugin"
1065 #define PLUGIN_COND_CLOSE ""
1066 #endif
1067 #define LINK_PLUGIN_SPEC \
1068 "%{" PLUGIN_COND": \
1069 -plugin %(linker_plugin_file) \
1070 -plugin-opt=%(lto_wrapper) \
1071 -plugin-opt=-fresolution=%u.res \
1072 " LTO_PLUGIN_SPEC "\
1073 %{flinker-output=*:-plugin-opt=-linker-output-known} \
1074 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
1075 }" PLUGIN_COND_CLOSE
1076 #else
1077 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
1078 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
1079 %e-fuse-linker-plugin is not supported in this configuration}"
1080 #endif
1082 /* Linker command line options for -fsanitize= early on the command line. */
1083 #ifndef SANITIZER_EARLY_SPEC
1084 #define SANITIZER_EARLY_SPEC "\
1085 %{!nostdlib:%{!r:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_EARLY_SPEC "} \
1086 %{%:sanitize(hwaddress):" LIBHWASAN_EARLY_SPEC "} \
1087 %{%:sanitize(thread):" LIBTSAN_EARLY_SPEC "} \
1088 %{%:sanitize(leak):" LIBLSAN_EARLY_SPEC "}}}}"
1089 #endif
1091 /* Linker command line options for -fsanitize= late on the command line. */
1092 #ifndef SANITIZER_SPEC
1093 #define SANITIZER_SPEC "\
1094 %{!nostdlib:%{!r:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_SPEC "\
1095 %{static:%ecannot specify -static with -fsanitize=address}}\
1096 %{%:sanitize(hwaddress):" LIBHWASAN_SPEC "\
1097 %{static:%ecannot specify -static with -fsanitize=hwaddress}}\
1098 %{%:sanitize(thread):" LIBTSAN_SPEC "\
1099 %{static:%ecannot specify -static with -fsanitize=thread}}\
1100 %{%:sanitize(undefined):" LIBUBSAN_SPEC "}\
1101 %{%:sanitize(leak):" LIBLSAN_SPEC "}}}}"
1102 #endif
1104 #ifndef POST_LINK_SPEC
1105 #define POST_LINK_SPEC ""
1106 #endif
1108 /* This is the spec to use, once the code for creating the vtable
1109 verification runtime library, libvtv.so, has been created. Currently
1110 the vtable verification runtime functions are in libstdc++, so we use
1111 the spec just below this one. */
1112 #ifndef VTABLE_VERIFICATION_SPEC
1113 #if ENABLE_VTABLE_VERIFY
1114 #define VTABLE_VERIFICATION_SPEC "\
1115 %{!nostdlib:%{!r:%{fvtable-verify=std: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}\
1116 %{fvtable-verify=preinit: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}}}"
1117 #else
1118 #define VTABLE_VERIFICATION_SPEC "\
1119 %{fvtable-verify=none:} \
1120 %{fvtable-verify=std: \
1121 %e-fvtable-verify=std is not supported in this configuration} \
1122 %{fvtable-verify=preinit: \
1123 %e-fvtable-verify=preinit is not supported in this configuration}"
1124 #endif
1125 #endif
1127 /* -u* was put back because both BSD and SysV seem to support it. */
1128 /* %{static|no-pie|static-pie:} simply prevents an error message:
1129 1. If the target machine doesn't handle -static.
1130 2. If PIE isn't enabled by default.
1131 3. If the target machine doesn't handle -static-pie.
1133 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
1134 scripts which exist in user specified directories, or in standard
1135 directories. */
1136 /* We pass any -flto flags on to the linker, which is expected
1137 to understand them. In practice, this means it had better be collect2. */
1138 /* %{e*} includes -export-dynamic; see comment in common.opt. */
1139 #ifndef LINK_COMMAND_SPEC
1140 #define LINK_COMMAND_SPEC "\
1141 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
1142 %(linker) " \
1143 LINK_PLUGIN_SPEC \
1144 "%{flto|flto=*:%<fcompare-debug*} \
1145 %{flto} %{fno-lto} %{flto=*} %l " LINK_PIE_SPEC \
1146 "%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
1147 "%X %{o*} %{e*} %{N} %{n} %{r}\
1148 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!r:%{!nostartfiles:%S}}} \
1149 %{static|no-pie|static-pie:} %@{L*} %(mfwrap) %(link_libgcc) " \
1150 VTABLE_VERIFICATION_SPEC " " SANITIZER_EARLY_SPEC " %o "" \
1151 %{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1):\
1152 %:include(libgomp.spec)%(link_gomp)}\
1153 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
1154 %(mflib) " STACK_SPLIT_SPEC "\
1155 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
1156 %{!nostdlib:%{!r:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}}\
1157 %{!nostdlib:%{!r:%{!nostartfiles:%E}}} %{T*} \n%(post_link) }}}}}}"
1158 #endif
1160 #ifndef LINK_LIBGCC_SPEC
1161 /* Generate -L options for startfile prefix list. */
1162 # define LINK_LIBGCC_SPEC "%D"
1163 #endif
1165 #ifndef STARTFILE_PREFIX_SPEC
1166 # define STARTFILE_PREFIX_SPEC ""
1167 #endif
1169 #ifndef SYSROOT_SPEC
1170 # define SYSROOT_SPEC "--sysroot=%R"
1171 #endif
1173 #ifndef SYSROOT_SUFFIX_SPEC
1174 # define SYSROOT_SUFFIX_SPEC ""
1175 #endif
1177 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
1178 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
1179 #endif
1181 static const char *asm_debug = ASM_DEBUG_SPEC;
1182 static const char *asm_debug_option = ASM_DEBUG_OPTION_SPEC;
1183 static const char *cpp_spec = CPP_SPEC;
1184 static const char *cc1_spec = CC1_SPEC SUBTARGET_CC1_SPEC;
1185 static const char *cc1plus_spec = CC1PLUS_SPEC;
1186 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
1187 static const char *link_ssp_spec = LINK_SSP_SPEC;
1188 static const char *asm_spec = ASM_SPEC;
1189 static const char *asm_final_spec = ASM_FINAL_SPEC;
1190 static const char *link_spec = LINK_SPEC;
1191 static const char *lib_spec = LIB_SPEC;
1192 static const char *link_gomp_spec = "";
1193 static const char *libgcc_spec = LIBGCC_SPEC;
1194 static const char *endfile_spec = ENDFILE_SPEC;
1195 static const char *startfile_spec = STARTFILE_SPEC;
1196 static const char *linker_name_spec = LINKER_NAME;
1197 static const char *linker_plugin_file_spec = "";
1198 static const char *lto_wrapper_spec = "";
1199 static const char *lto_gcc_spec = "";
1200 static const char *post_link_spec = POST_LINK_SPEC;
1201 static const char *link_command_spec = LINK_COMMAND_SPEC;
1202 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
1203 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
1204 static const char *sysroot_spec = SYSROOT_SPEC;
1205 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
1206 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
1207 static const char *self_spec = "";
1209 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
1210 There should be no need to override these in target dependent files,
1211 but we need to copy them to the specs file so that newer versions
1212 of the GCC driver can correctly drive older tool chains with the
1213 appropriate -B options. */
1215 /* When cpplib handles traditional preprocessing, get rid of this, and
1216 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
1217 that we default the front end language better. */
1218 static const char *trad_capable_cpp =
1219 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
1221 /* We don't wrap .d files in %W{} since a missing .d file, and
1222 therefore no dependency entry, confuses make into thinking a .o
1223 file that happens to exist is up-to-date. */
1224 static const char *cpp_unique_options =
1225 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %@{I*&F*} %{P} %I\
1226 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
1227 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
1228 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
1229 %{Mmodules} %{Mno-modules}\
1230 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
1231 %{remap} %{%:debug-level-gt(2):-dD}\
1232 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1233 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
1234 %{E|M|MM:%W{o*}}";
1236 /* This contains cpp options which are common with cc1_options and are passed
1237 only when preprocessing only to avoid duplication. We pass the cc1 spec
1238 options to the preprocessor so that it the cc1 spec may manipulate
1239 options used to set target flags. Those special target flags settings may
1240 in turn cause preprocessor symbols to be defined specially. */
1241 static const char *cpp_options =
1242 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
1243 %{f*} %{g*:%{%:debug-level-gt(0):%{g*}\
1244 %{!fno-working-directory:-fworking-directory}}} %{O*}\
1245 %{undef} %{save-temps*:-fpch-preprocess}";
1247 /* Pass -d* flags, possibly modifying -dumpdir, -dumpbase et al.
1249 Make it easy for a language to override the argument for the
1250 %:dumps specs function call. */
1251 #define DUMPS_OPTIONS(EXTS) \
1252 "%<dumpdir %<dumpbase %<dumpbase-ext %{d*} %:dumps(" EXTS ")"
1254 /* This contains cpp options which are not passed when the preprocessor
1255 output will be used by another program. */
1256 static const char *cpp_debug_options = DUMPS_OPTIONS ("");
1258 /* NB: This is shared amongst all front-ends, except for Ada. */
1259 static const char *cc1_options =
1260 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
1261 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1262 %1 %{!Q:-quiet} %(cpp_debug_options) %{m*} %{aux-info*}\
1263 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
1264 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
1265 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
1266 %{-target-help:--target-help}\
1267 %{-version:--version}\
1268 %{-help=*:--help=%*}\
1269 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %w%b.s}}}\
1270 %{fsyntax-only:-o %j} %{-param*}\
1271 %{coverage:-fprofile-arcs -ftest-coverage}\
1272 %{fprofile-arcs|fprofile-generate*|coverage:\
1273 %{!fprofile-update=single:\
1274 %{pthread:-fprofile-update=prefer-atomic}}}";
1276 static const char *asm_options =
1277 "%{-target-help:%:print-asm-header()} "
1278 #if HAVE_GNU_AS
1279 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
1280 to the assembler equivalents. */
1281 "%{v} %{w:-W} %{I*} "
1282 #endif
1283 "%(asm_debug_option)"
1284 ASM_COMPRESS_DEBUG_SPEC
1285 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
1287 static const char *invoke_as =
1288 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1289 "%{!fwpa*:\
1290 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1291 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
1293 #else
1294 "%{!fwpa*:\
1295 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1296 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
1298 #endif
1300 /* Some compilers have limits on line lengths, and the multilib_select
1301 and/or multilib_matches strings can be very long, so we build them at
1302 run time. */
1303 static struct obstack multilib_obstack;
1304 static const char *multilib_select;
1305 static const char *multilib_matches;
1306 static const char *multilib_defaults;
1307 static const char *multilib_exclusions;
1308 static const char *multilib_reuse;
1310 /* Check whether a particular argument is a default argument. */
1312 #ifndef MULTILIB_DEFAULTS
1313 #define MULTILIB_DEFAULTS { "" }
1314 #endif
1316 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
1318 #ifndef DRIVER_SELF_SPECS
1319 #define DRIVER_SELF_SPECS ""
1320 #endif
1322 /* Linking to libgomp implies pthreads. This is particularly important
1323 for targets that use different start files and suchlike. */
1324 #ifndef GOMP_SELF_SPECS
1325 #define GOMP_SELF_SPECS \
1326 "%{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1): " \
1327 "-pthread}"
1328 #endif
1330 /* Likewise for -fgnu-tm. */
1331 #ifndef GTM_SELF_SPECS
1332 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
1333 #endif
1335 static const char *const driver_self_specs[] = {
1336 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
1337 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS,
1338 /* This discards -fmultiflags at the end of self specs processing in the
1339 driver, so that it is effectively Ignored, without actually marking it as
1340 Ignored, which would get it discarded before self specs could remap it. */
1341 "%<fmultiflags"
1344 #ifndef OPTION_DEFAULT_SPECS
1345 #define OPTION_DEFAULT_SPECS { "", "" }
1346 #endif
1348 struct default_spec
1350 const char *name;
1351 const char *spec;
1354 static const struct default_spec
1355 option_default_specs[] = { OPTION_DEFAULT_SPECS };
1357 struct user_specs
1359 struct user_specs *next;
1360 const char *filename;
1363 static struct user_specs *user_specs_head, *user_specs_tail;
1366 /* Record the mapping from file suffixes for compilation specs. */
1368 struct compiler
1370 const char *suffix; /* Use this compiler for input files
1371 whose names end in this suffix. */
1373 const char *spec; /* To use this compiler, run this spec. */
1375 const char *cpp_spec; /* If non-NULL, substitute this spec
1376 for `%C', rather than the usual
1377 cpp_spec. */
1378 int combinable; /* If nonzero, compiler can deal with
1379 multiple source files at once (IMA). */
1380 int needs_preprocessing; /* If nonzero, source files need to
1381 be run through a preprocessor. */
1384 /* Pointer to a vector of `struct compiler' that gives the spec for
1385 compiling a file, based on its suffix.
1386 A file that does not end in any of these suffixes will be passed
1387 unchanged to the loader and nothing else will be done to it.
1389 An entry containing two 0s is used to terminate the vector.
1391 If multiple entries match a file, the last matching one is used. */
1393 static struct compiler *compilers;
1395 /* Number of entries in `compilers', not counting the null terminator. */
1397 static int n_compilers;
1399 /* The default list of file name suffixes and their compilation specs. */
1401 static const struct compiler default_compilers[] =
1403 /* Add lists of suffixes of known languages here. If those languages
1404 were not present when we built the driver, we will hit these copies
1405 and be given a more meaningful error than "file not used since
1406 linking is not done". */
1407 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
1408 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
1409 {".mii", "#Objective-C++", 0, 0, 0},
1410 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
1411 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
1412 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
1413 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
1414 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
1415 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
1416 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
1417 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
1418 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
1419 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
1420 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
1421 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1422 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1423 {".r", "#Ratfor", 0, 0, 0},
1424 {".go", "#Go", 0, 1, 0},
1425 {".d", "#D", 0, 1, 0}, {".dd", "#D", 0, 1, 0}, {".di", "#D", 0, 1, 0},
1426 /* Next come the entries for C. */
1427 {".c", "@c", 0, 0, 1},
1428 {"@c",
1429 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1430 external preprocessor if -save-temps is given. */
1431 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1432 %{!E:%{!M:%{!MM:\
1433 %{traditional:\
1434 %eGNU C no longer supports -traditional without -E}\
1435 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1436 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1437 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1438 %(cc1_options)}\
1439 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1440 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1441 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1442 {"-",
1443 "%{!E:%e-E or -x required when input is from standard input}\
1444 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1445 {".h", "@c-header", 0, 0, 0},
1446 {"@c-header",
1447 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1448 external preprocessor if -save-temps is given. */
1449 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1450 %{!E:%{!M:%{!MM:\
1451 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1452 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1453 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1454 %(cc1_options)\
1455 %{!fsyntax-only:%{!S:-o %g.s} \
1456 %{!fdump-ada-spec*:%{!o*:--output-pch %i.gch}\
1457 %W{o*:--output-pch %*}}%V}}\
1458 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1459 cc1 %(cpp_unique_options) %(cc1_options)\
1460 %{!fsyntax-only:%{!S:-o %g.s} \
1461 %{!fdump-ada-spec*:%{!o*:--output-pch %i.gch}\
1462 %W{o*:--output-pch %*}}%V}}}}}}}", 0, 0, 0},
1463 {".i", "@cpp-output", 0, 0, 0},
1464 {"@cpp-output",
1465 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1466 {".s", "@assembler", 0, 0, 0},
1467 {"@assembler",
1468 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1469 {".sx", "@assembler-with-cpp", 0, 0, 0},
1470 {".S", "@assembler-with-cpp", 0, 0, 0},
1471 {"@assembler-with-cpp",
1472 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1473 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1474 %{E|M|MM:%(cpp_debug_options)}\
1475 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1476 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1477 #else
1478 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1479 %{E|M|MM:%(cpp_debug_options)}\
1480 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1481 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1482 #endif
1483 , 0, 0, 0},
1485 #include "specs.h"
1486 /* Mark end of table. */
1487 {0, 0, 0, 0, 0}
1490 /* Number of elements in default_compilers, not counting the terminator. */
1492 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1494 typedef char *char_p; /* For DEF_VEC_P. */
1496 /* A vector of options to give to the linker.
1497 These options are accumulated by %x,
1498 and substituted into the linker command with %X. */
1499 static vec<char_p> linker_options;
1501 /* A vector of options to give to the assembler.
1502 These options are accumulated by -Wa,
1503 and substituted into the assembler command with %Y. */
1504 static vec<char_p> assembler_options;
1506 /* A vector of options to give to the preprocessor.
1507 These options are accumulated by -Wp,
1508 and substituted into the preprocessor command with %Z. */
1509 static vec<char_p> preprocessor_options;
1511 static char *
1512 skip_whitespace (char *p)
1514 while (1)
1516 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1517 be considered whitespace. */
1518 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1519 return p + 1;
1520 else if (*p == '\n' || *p == ' ' || *p == '\t')
1521 p++;
1522 else if (*p == '#')
1524 while (*p != '\n')
1525 p++;
1526 p++;
1528 else
1529 break;
1532 return p;
1534 /* Structures to keep track of prefixes to try when looking for files. */
1536 struct prefix_list
1538 const char *prefix; /* String to prepend to the path. */
1539 struct prefix_list *next; /* Next in linked list. */
1540 int require_machine_suffix; /* Don't use without machine_suffix. */
1541 /* 2 means try both machine_suffix and just_machine_suffix. */
1542 int priority; /* Sort key - priority within list. */
1543 int os_multilib; /* 1 if OS multilib scheme should be used,
1544 0 for GCC multilib scheme. */
1547 struct path_prefix
1549 struct prefix_list *plist; /* List of prefixes to try */
1550 int max_len; /* Max length of a prefix in PLIST */
1551 const char *name; /* Name of this list (used in config stuff) */
1554 /* List of prefixes to try when looking for executables. */
1556 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1558 /* List of prefixes to try when looking for startup (crt0) files. */
1560 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1562 /* List of prefixes to try when looking for include files. */
1564 static struct path_prefix include_prefixes = { 0, 0, "include" };
1566 /* Suffix to attach to directories searched for commands.
1567 This looks like `MACHINE/VERSION/'. */
1569 static const char *machine_suffix = 0;
1571 /* Suffix to attach to directories searched for commands.
1572 This is just `MACHINE/'. */
1574 static const char *just_machine_suffix = 0;
1576 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1578 static const char *gcc_exec_prefix;
1580 /* Adjusted value of standard_libexec_prefix. */
1582 static const char *gcc_libexec_prefix;
1584 /* Default prefixes to attach to command names. */
1586 #ifndef STANDARD_STARTFILE_PREFIX_1
1587 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1588 #endif
1589 #ifndef STANDARD_STARTFILE_PREFIX_2
1590 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1591 #endif
1593 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1594 #undef MD_EXEC_PREFIX
1595 #undef MD_STARTFILE_PREFIX
1596 #undef MD_STARTFILE_PREFIX_1
1597 #endif
1599 /* If no prefixes defined, use the null string, which will disable them. */
1600 #ifndef MD_EXEC_PREFIX
1601 #define MD_EXEC_PREFIX ""
1602 #endif
1603 #ifndef MD_STARTFILE_PREFIX
1604 #define MD_STARTFILE_PREFIX ""
1605 #endif
1606 #ifndef MD_STARTFILE_PREFIX_1
1607 #define MD_STARTFILE_PREFIX_1 ""
1608 #endif
1610 /* These directories are locations set at configure-time based on the
1611 --prefix option provided to configure. Their initializers are
1612 defined in Makefile.in. These paths are not *directly* used when
1613 gcc_exec_prefix is set because, in that case, we know where the
1614 compiler has been installed, and use paths relative to that
1615 location instead. */
1616 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1617 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1618 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1619 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1621 /* For native compilers, these are well-known paths containing
1622 components that may be provided by the system. For cross
1623 compilers, these paths are not used. */
1624 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1625 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1626 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1627 static const char *const standard_startfile_prefix_1
1628 = STANDARD_STARTFILE_PREFIX_1;
1629 static const char *const standard_startfile_prefix_2
1630 = STANDARD_STARTFILE_PREFIX_2;
1632 /* A relative path to be used in finding the location of tools
1633 relative to the driver. */
1634 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1636 /* A prefix to be used when this is an accelerator compiler. */
1637 static const char *const accel_dir_suffix = ACCEL_DIR_SUFFIX;
1639 /* Subdirectory to use for locating libraries. Set by
1640 set_multilib_dir based on the compilation options. */
1642 static const char *multilib_dir;
1644 /* Subdirectory to use for locating libraries in OS conventions. Set by
1645 set_multilib_dir based on the compilation options. */
1647 static const char *multilib_os_dir;
1649 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1650 set_multilib_dir based on the compilation options. */
1652 static const char *multiarch_dir;
1654 /* Structure to keep track of the specs that have been defined so far.
1655 These are accessed using %(specname) in a compiler or link
1656 spec. */
1658 struct spec_list
1660 /* The following 2 fields must be first */
1661 /* to allow EXTRA_SPECS to be initialized */
1662 const char *name; /* name of the spec. */
1663 const char *ptr; /* available ptr if no static pointer */
1665 /* The following fields are not initialized */
1666 /* by EXTRA_SPECS */
1667 const char **ptr_spec; /* pointer to the spec itself. */
1668 struct spec_list *next; /* Next spec in linked list. */
1669 int name_len; /* length of the name */
1670 bool user_p; /* whether string come from file spec. */
1671 bool alloc_p; /* whether string was allocated */
1672 const char *default_ptr; /* The default value of *ptr_spec. */
1675 #define INIT_STATIC_SPEC(NAME,PTR) \
1676 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false, \
1677 *PTR }
1679 /* List of statically defined specs. */
1680 static struct spec_list static_specs[] =
1682 INIT_STATIC_SPEC ("asm", &asm_spec),
1683 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1684 INIT_STATIC_SPEC ("asm_debug_option", &asm_debug_option),
1685 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1686 INIT_STATIC_SPEC ("asm_options", &asm_options),
1687 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1688 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1689 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1690 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1691 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1692 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1693 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1694 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1695 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1696 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1697 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1698 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1699 INIT_STATIC_SPEC ("link", &link_spec),
1700 INIT_STATIC_SPEC ("lib", &lib_spec),
1701 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1702 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1703 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1704 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1705 INIT_STATIC_SPEC ("version", &compiler_version),
1706 INIT_STATIC_SPEC ("multilib", &multilib_select),
1707 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1708 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1709 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1710 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1711 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1712 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1713 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1714 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1715 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1716 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1717 INIT_STATIC_SPEC ("post_link", &post_link_spec),
1718 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1719 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1720 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1721 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1722 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1723 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1724 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1725 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1726 INIT_STATIC_SPEC ("self_spec", &self_spec),
1729 #ifdef EXTRA_SPECS /* additional specs needed */
1730 /* Structure to keep track of just the first two args of a spec_list.
1731 That is all that the EXTRA_SPECS macro gives us. */
1732 struct spec_list_1
1734 const char *const name;
1735 const char *const ptr;
1738 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1739 static struct spec_list *extra_specs = (struct spec_list *) 0;
1740 #endif
1742 /* List of dynamically allocates specs that have been defined so far. */
1744 static struct spec_list *specs = (struct spec_list *) 0;
1746 /* List of static spec functions. */
1748 static const struct spec_function static_spec_functions[] =
1750 { "getenv", getenv_spec_function },
1751 { "if-exists", if_exists_spec_function },
1752 { "if-exists-else", if_exists_else_spec_function },
1753 { "if-exists-then-else", if_exists_then_else_spec_function },
1754 { "sanitize", sanitize_spec_function },
1755 { "replace-outfile", replace_outfile_spec_function },
1756 { "remove-outfile", remove_outfile_spec_function },
1757 { "version-compare", version_compare_spec_function },
1758 { "include", include_spec_function },
1759 { "find-file", find_file_spec_function },
1760 { "find-plugindir", find_plugindir_spec_function },
1761 { "print-asm-header", print_asm_header_spec_function },
1762 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1763 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1764 { "pass-through-libs", pass_through_libs_spec_func },
1765 { "dumps", dumps_spec_func },
1766 { "gt", greater_than_spec_func },
1767 { "debug-level-gt", debug_level_greater_than_spec_func },
1768 { "dwarf-version-gt", dwarf_version_greater_than_spec_func },
1769 { "fortran-preinclude-file", find_fortran_preinclude_file},
1770 #ifdef EXTRA_SPEC_FUNCTIONS
1771 EXTRA_SPEC_FUNCTIONS
1772 #endif
1773 { 0, 0 }
1776 static int processing_spec_function;
1778 /* Add appropriate libgcc specs to OBSTACK, taking into account
1779 various permutations of -shared-libgcc, -shared, and such. */
1781 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1783 #ifndef USE_LD_AS_NEEDED
1784 #define USE_LD_AS_NEEDED 0
1785 #endif
1787 static void
1788 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1789 const char *static_name, const char *eh_name)
1791 char *buf;
1793 #if USE_LD_AS_NEEDED
1794 buf = concat ("%{static|static-libgcc|static-pie:", static_name, " ", eh_name, "}"
1795 "%{!static:%{!static-libgcc:%{!static-pie:"
1796 "%{!shared-libgcc:",
1797 static_name, " " LD_AS_NEEDED_OPTION " ",
1798 shared_name, " " LD_NO_AS_NEEDED_OPTION
1800 "%{shared-libgcc:",
1801 shared_name, "%{!shared: ", static_name, "}"
1802 "}}"
1803 #else
1804 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1805 "%{!static:%{!static-libgcc:"
1806 "%{!shared:"
1807 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1808 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1810 #ifdef LINK_EH_SPEC
1811 "%{shared:"
1812 "%{shared-libgcc:", shared_name, "}"
1813 "%{!shared-libgcc:", static_name, "}"
1815 #else
1816 "%{shared:", shared_name, "}"
1817 #endif
1818 #endif
1819 "}}", NULL);
1821 obstack_grow (obstack, buf, strlen (buf));
1822 free (buf);
1824 #endif /* ENABLE_SHARED_LIBGCC */
1826 /* Initialize the specs lookup routines. */
1828 static void
1829 init_spec (void)
1831 struct spec_list *next = (struct spec_list *) 0;
1832 struct spec_list *sl = (struct spec_list *) 0;
1833 int i;
1835 if (specs)
1836 return; /* Already initialized. */
1838 if (verbose_flag)
1839 fnotice (stderr, "Using built-in specs.\n");
1841 #ifdef EXTRA_SPECS
1842 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1844 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1846 sl = &extra_specs[i];
1847 sl->name = extra_specs_1[i].name;
1848 sl->ptr = extra_specs_1[i].ptr;
1849 sl->next = next;
1850 sl->name_len = strlen (sl->name);
1851 sl->ptr_spec = &sl->ptr;
1852 gcc_assert (sl->ptr_spec != NULL);
1853 sl->default_ptr = sl->ptr;
1854 next = sl;
1856 #endif
1858 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1860 sl = &static_specs[i];
1861 sl->next = next;
1862 next = sl;
1865 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1866 /* ??? If neither -shared-libgcc nor --static-libgcc was
1867 seen, then we should be making an educated guess. Some proposed
1868 heuristics for ELF include:
1870 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1871 program will be doing dynamic loading, which will likely
1872 need the shared libgcc.
1874 (2) If "-ldl", then it's also a fair bet that we're doing
1875 dynamic loading.
1877 (3) For each ET_DYN we're linking against (either through -lfoo
1878 or /some/path/foo.so), check to see whether it or one of
1879 its dependencies depends on a shared libgcc.
1881 (4) If "-shared"
1883 If the runtime is fixed to look for program headers instead
1884 of calling __register_frame_info at all, for each object,
1885 use the shared libgcc if any EH symbol referenced.
1887 If crtstuff is fixed to not invoke __register_frame_info
1888 automatically, for each object, use the shared libgcc if
1889 any non-empty unwind section found.
1891 Doing any of this probably requires invoking an external program to
1892 do the actual object file scanning. */
1894 const char *p = libgcc_spec;
1895 int in_sep = 1;
1897 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1898 when given the proper command line arguments. */
1899 while (*p)
1901 if (in_sep && *p == '-' && startswith (p, "-lgcc"))
1903 init_gcc_specs (&obstack,
1904 "-lgcc_s"
1905 #ifdef USE_LIBUNWIND_EXCEPTIONS
1906 " -lunwind"
1907 #endif
1909 "-lgcc",
1910 "-lgcc_eh"
1911 #ifdef USE_LIBUNWIND_EXCEPTIONS
1912 # ifdef HAVE_LD_STATIC_DYNAMIC
1913 " %{!static:%{!static-pie:" LD_STATIC_OPTION "}} -lunwind"
1914 " %{!static:%{!static-pie:" LD_DYNAMIC_OPTION "}}"
1915 # else
1916 " -lunwind"
1917 # endif
1918 #endif
1921 p += 5;
1922 in_sep = 0;
1924 else if (in_sep && *p == 'l' && startswith (p, "libgcc.a%s"))
1926 /* Ug. We don't know shared library extensions. Hope that
1927 systems that use this form don't do shared libraries. */
1928 init_gcc_specs (&obstack,
1929 "-lgcc_s",
1930 "libgcc.a%s",
1931 "libgcc_eh.a%s"
1932 #ifdef USE_LIBUNWIND_EXCEPTIONS
1933 " -lunwind"
1934 #endif
1936 p += 10;
1937 in_sep = 0;
1939 else
1941 obstack_1grow (&obstack, *p);
1942 in_sep = (*p == ' ');
1943 p += 1;
1947 obstack_1grow (&obstack, '\0');
1948 libgcc_spec = XOBFINISH (&obstack, const char *);
1950 #endif
1951 #ifdef USE_AS_TRADITIONAL_FORMAT
1952 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1954 static const char tf[] = "--traditional-format ";
1955 obstack_grow (&obstack, tf, sizeof (tf) - 1);
1956 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1957 asm_spec = XOBFINISH (&obstack, const char *);
1959 #endif
1961 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1962 defined LINKER_HASH_STYLE
1963 # ifdef LINK_BUILDID_SPEC
1964 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1965 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof (LINK_BUILDID_SPEC) - 1);
1966 # endif
1967 # ifdef LINK_EH_SPEC
1968 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1969 obstack_grow (&obstack, LINK_EH_SPEC, sizeof (LINK_EH_SPEC) - 1);
1970 # endif
1971 # ifdef LINKER_HASH_STYLE
1972 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1973 before. */
1975 static const char hash_style[] = "--hash-style=";
1976 obstack_grow (&obstack, hash_style, sizeof (hash_style) - 1);
1977 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof (LINKER_HASH_STYLE) - 1);
1978 obstack_1grow (&obstack, ' ');
1980 # endif
1981 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1982 link_spec = XOBFINISH (&obstack, const char *);
1983 #endif
1985 specs = sl;
1988 /* Update the entry for SPEC in the static_specs table to point to VALUE,
1989 ensuring that we free the previous value if necessary. Set alloc_p for the
1990 entry to ALLOC_P: this determines whether we take ownership of VALUE (i.e.
1991 whether we need to free it later on). */
1992 static void
1993 set_static_spec (const char **spec, const char *value, bool alloc_p)
1995 struct spec_list *sl = NULL;
1997 for (unsigned i = 0; i < ARRAY_SIZE (static_specs); i++)
1999 if (static_specs[i].ptr_spec == spec)
2001 sl = static_specs + i;
2002 break;
2006 gcc_assert (sl);
2008 if (sl->alloc_p)
2010 const char *old = *spec;
2011 free (const_cast <char *> (old));
2014 *spec = value;
2015 sl->alloc_p = alloc_p;
2018 /* Update a static spec to a new string, taking ownership of that
2019 string's memory. */
2020 static void set_static_spec_owned (const char **spec, const char *val)
2022 return set_static_spec (spec, val, true);
2025 /* Update a static spec to point to a new value, but don't take
2026 ownership of (i.e. don't free) that string. */
2027 static void set_static_spec_shared (const char **spec, const char *val)
2029 return set_static_spec (spec, val, false);
2033 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
2034 removed; If the spec starts with a + then SPEC is added to the end of the
2035 current spec. */
2037 static void
2038 set_spec (const char *name, const char *spec, bool user_p)
2040 struct spec_list *sl;
2041 const char *old_spec;
2042 int name_len = strlen (name);
2043 int i;
2045 /* If this is the first call, initialize the statically allocated specs. */
2046 if (!specs)
2048 struct spec_list *next = (struct spec_list *) 0;
2049 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
2051 sl = &static_specs[i];
2052 sl->next = next;
2053 next = sl;
2055 specs = sl;
2058 /* See if the spec already exists. */
2059 for (sl = specs; sl; sl = sl->next)
2060 if (name_len == sl->name_len && !strcmp (sl->name, name))
2061 break;
2063 if (!sl)
2065 /* Not found - make it. */
2066 sl = XNEW (struct spec_list);
2067 sl->name = xstrdup (name);
2068 sl->name_len = name_len;
2069 sl->ptr_spec = &sl->ptr;
2070 sl->alloc_p = 0;
2071 *(sl->ptr_spec) = "";
2072 sl->next = specs;
2073 sl->default_ptr = NULL;
2074 specs = sl;
2077 old_spec = *(sl->ptr_spec);
2078 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
2079 ? concat (old_spec, spec + 1, NULL)
2080 : xstrdup (spec));
2082 #ifdef DEBUG_SPECS
2083 if (verbose_flag)
2084 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
2085 #endif
2087 /* Free the old spec. */
2088 if (old_spec && sl->alloc_p)
2089 free (CONST_CAST (char *, old_spec));
2091 sl->user_p = user_p;
2092 sl->alloc_p = true;
2095 /* Accumulate a command (program name and args), and run it. */
2097 typedef const char *const_char_p; /* For DEF_VEC_P. */
2099 /* Vector of pointers to arguments in the current line of specifications. */
2100 static vec<const_char_p> argbuf;
2102 /* Likewise, but for the current @file. */
2103 static vec<const_char_p> at_file_argbuf;
2105 /* Whether an @file is currently open. */
2106 static bool in_at_file = false;
2108 /* Were the options -c, -S or -E passed. */
2109 static int have_c = 0;
2111 /* Was the option -o passed. */
2112 static int have_o = 0;
2114 /* Was the option -E passed. */
2115 static int have_E = 0;
2117 /* Pointer to output file name passed in with -o. */
2118 static const char *output_file = 0;
2120 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
2121 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
2122 it here. */
2124 static struct temp_name {
2125 const char *suffix; /* suffix associated with the code. */
2126 int length; /* strlen (suffix). */
2127 int unique; /* Indicates whether %g or %u/%U was used. */
2128 const char *filename; /* associated filename. */
2129 int filename_length; /* strlen (filename). */
2130 struct temp_name *next;
2131 } *temp_names;
2133 /* Number of commands executed so far. */
2135 static int execution_count;
2137 /* Number of commands that exited with a signal. */
2139 static int signal_count;
2141 /* Allocate the argument vector. */
2143 static void
2144 alloc_args (void)
2146 argbuf.create (10);
2147 at_file_argbuf.create (10);
2150 /* Clear out the vector of arguments (after a command is executed). */
2152 static void
2153 clear_args (void)
2155 argbuf.truncate (0);
2156 at_file_argbuf.truncate (0);
2159 /* Add one argument to the vector at the end.
2160 This is done when a space is seen or at the end of the line.
2161 If DELETE_ALWAYS is nonzero, the arg is a filename
2162 and the file should be deleted eventually.
2163 If DELETE_FAILURE is nonzero, the arg is a filename
2164 and the file should be deleted if this compilation fails. */
2166 static void
2167 store_arg (const char *arg, int delete_always, int delete_failure)
2169 if (in_at_file)
2170 at_file_argbuf.safe_push (arg);
2171 else
2172 argbuf.safe_push (arg);
2174 if (delete_always || delete_failure)
2176 const char *p;
2177 /* If the temporary file we should delete is specified as
2178 part of a joined argument extract the filename. */
2179 if (arg[0] == '-'
2180 && (p = strrchr (arg, '=')))
2181 arg = p + 1;
2182 record_temp_file (arg, delete_always, delete_failure);
2186 /* Open a temporary @file into which subsequent arguments will be stored. */
2188 static void
2189 open_at_file (void)
2191 if (in_at_file)
2192 fatal_error (input_location, "cannot open nested response file");
2193 else
2194 in_at_file = true;
2197 /* Create a temporary @file name. */
2199 static char *make_at_file (void)
2201 static int fileno = 0;
2202 char filename[20];
2203 const char *base, *ext;
2205 if (!save_temps_flag)
2206 return make_temp_file ("");
2208 base = dumpbase;
2209 if (!(base && *base))
2210 base = dumpdir;
2211 if (!(base && *base))
2212 base = "a";
2214 sprintf (filename, ".args.%d", fileno++);
2215 ext = filename;
2217 if (base == dumpdir && dumpdir_trailing_dash_added)
2218 ext++;
2220 return concat (base, ext, NULL);
2223 /* Close the temporary @file and add @file to the argument list. */
2225 static void
2226 close_at_file (void)
2228 if (!in_at_file)
2229 fatal_error (input_location, "cannot close nonexistent response file");
2231 in_at_file = false;
2233 const unsigned int n_args = at_file_argbuf.length ();
2234 if (n_args == 0)
2235 return;
2237 char **argv = XALLOCAVEC (char *, n_args + 1);
2238 char *temp_file = make_at_file ();
2239 char *at_argument = concat ("@", temp_file, NULL);
2240 FILE *f = fopen (temp_file, "w");
2241 int status;
2242 unsigned int i;
2244 /* Copy the strings over. */
2245 for (i = 0; i < n_args; i++)
2246 argv[i] = CONST_CAST (char *, at_file_argbuf[i]);
2247 argv[i] = NULL;
2249 at_file_argbuf.truncate (0);
2251 if (f == NULL)
2252 fatal_error (input_location, "could not open temporary response file %s",
2253 temp_file);
2255 status = writeargv (argv, f);
2257 if (status)
2258 fatal_error (input_location,
2259 "could not write to temporary response file %s",
2260 temp_file);
2262 status = fclose (f);
2264 if (status == EOF)
2265 fatal_error (input_location, "could not close temporary response file %s",
2266 temp_file);
2268 store_arg (at_argument, 0, 0);
2270 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
2273 /* Load specs from a file name named FILENAME, replacing occurrences of
2274 various different types of line-endings, \r\n, \n\r and just \r, with
2275 a single \n. */
2277 static char *
2278 load_specs (const char *filename)
2280 int desc;
2281 int readlen;
2282 struct stat statbuf;
2283 char *buffer;
2284 char *buffer_p;
2285 char *specs;
2286 char *specs_p;
2288 if (verbose_flag)
2289 fnotice (stderr, "Reading specs from %s\n", filename);
2291 /* Open and stat the file. */
2292 desc = open (filename, O_RDONLY, 0);
2293 if (desc < 0)
2295 failed:
2296 /* This leaves DESC open, but the OS will save us. */
2297 fatal_error (input_location, "cannot read spec file %qs: %m", filename);
2300 if (stat (filename, &statbuf) < 0)
2301 goto failed;
2303 /* Read contents of file into BUFFER. */
2304 buffer = XNEWVEC (char, statbuf.st_size + 1);
2305 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
2306 if (readlen < 0)
2307 goto failed;
2308 buffer[readlen] = 0;
2309 close (desc);
2311 specs = XNEWVEC (char, readlen + 1);
2312 specs_p = specs;
2313 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
2315 int skip = 0;
2316 char c = *buffer_p;
2317 if (c == '\r')
2319 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
2320 skip = 1;
2321 else if (*(buffer_p + 1) == '\n') /* \r\n */
2322 skip = 1;
2323 else /* \r */
2324 c = '\n';
2326 if (! skip)
2327 *specs_p++ = c;
2329 *specs_p = '\0';
2331 free (buffer);
2332 return (specs);
2335 /* Read compilation specs from a file named FILENAME,
2336 replacing the default ones.
2338 A suffix which starts with `*' is a definition for
2339 one of the machine-specific sub-specs. The "suffix" should be
2340 *asm, *cc1, *cpp, *link, *startfile, etc.
2341 The corresponding spec is stored in asm_spec, etc.,
2342 rather than in the `compilers' vector.
2344 Anything invalid in the file is a fatal error. */
2346 static void
2347 read_specs (const char *filename, bool main_p, bool user_p)
2349 char *buffer;
2350 char *p;
2352 buffer = load_specs (filename);
2354 /* Scan BUFFER for specs, putting them in the vector. */
2355 p = buffer;
2356 while (1)
2358 char *suffix;
2359 char *spec;
2360 char *in, *out, *p1, *p2, *p3;
2362 /* Advance P in BUFFER to the next nonblank nocomment line. */
2363 p = skip_whitespace (p);
2364 if (*p == 0)
2365 break;
2367 /* Is this a special command that starts with '%'? */
2368 /* Don't allow this for the main specs file, since it would
2369 encourage people to overwrite it. */
2370 if (*p == '%' && !main_p)
2372 p1 = p;
2373 while (*p && *p != '\n')
2374 p++;
2376 /* Skip '\n'. */
2377 p++;
2379 if (startswith (p1, "%include")
2380 && (p1[sizeof "%include" - 1] == ' '
2381 || p1[sizeof "%include" - 1] == '\t'))
2383 char *new_filename;
2385 p1 += sizeof ("%include");
2386 while (*p1 == ' ' || *p1 == '\t')
2387 p1++;
2389 if (*p1++ != '<' || p[-2] != '>')
2390 fatal_error (input_location,
2391 "specs %%include syntax malformed after "
2392 "%ld characters",
2393 (long) (p1 - buffer + 1));
2395 p[-2] = '\0';
2396 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2397 read_specs (new_filename ? new_filename : p1, false, user_p);
2398 continue;
2400 else if (startswith (p1, "%include_noerr")
2401 && (p1[sizeof "%include_noerr" - 1] == ' '
2402 || p1[sizeof "%include_noerr" - 1] == '\t'))
2404 char *new_filename;
2406 p1 += sizeof "%include_noerr";
2407 while (*p1 == ' ' || *p1 == '\t')
2408 p1++;
2410 if (*p1++ != '<' || p[-2] != '>')
2411 fatal_error (input_location,
2412 "specs %%include syntax malformed after "
2413 "%ld characters",
2414 (long) (p1 - buffer + 1));
2416 p[-2] = '\0';
2417 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2418 if (new_filename)
2419 read_specs (new_filename, false, user_p);
2420 else if (verbose_flag)
2421 fnotice (stderr, "could not find specs file %s\n", p1);
2422 continue;
2424 else if (startswith (p1, "%rename")
2425 && (p1[sizeof "%rename" - 1] == ' '
2426 || p1[sizeof "%rename" - 1] == '\t'))
2428 int name_len;
2429 struct spec_list *sl;
2430 struct spec_list *newsl;
2432 /* Get original name. */
2433 p1 += sizeof "%rename";
2434 while (*p1 == ' ' || *p1 == '\t')
2435 p1++;
2437 if (! ISALPHA ((unsigned char) *p1))
2438 fatal_error (input_location,
2439 "specs %%rename syntax malformed after "
2440 "%ld characters",
2441 (long) (p1 - buffer));
2443 p2 = p1;
2444 while (*p2 && !ISSPACE ((unsigned char) *p2))
2445 p2++;
2447 if (*p2 != ' ' && *p2 != '\t')
2448 fatal_error (input_location,
2449 "specs %%rename syntax malformed after "
2450 "%ld characters",
2451 (long) (p2 - buffer));
2453 name_len = p2 - p1;
2454 *p2++ = '\0';
2455 while (*p2 == ' ' || *p2 == '\t')
2456 p2++;
2458 if (! ISALPHA ((unsigned char) *p2))
2459 fatal_error (input_location,
2460 "specs %%rename syntax malformed after "
2461 "%ld characters",
2462 (long) (p2 - buffer));
2464 /* Get new spec name. */
2465 p3 = p2;
2466 while (*p3 && !ISSPACE ((unsigned char) *p3))
2467 p3++;
2469 if (p3 != p - 1)
2470 fatal_error (input_location,
2471 "specs %%rename syntax malformed after "
2472 "%ld characters",
2473 (long) (p3 - buffer));
2474 *p3 = '\0';
2476 for (sl = specs; sl; sl = sl->next)
2477 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2478 break;
2480 if (!sl)
2481 fatal_error (input_location,
2482 "specs %s spec was not found to be renamed", p1);
2484 if (strcmp (p1, p2) == 0)
2485 continue;
2487 for (newsl = specs; newsl; newsl = newsl->next)
2488 if (strcmp (newsl->name, p2) == 0)
2489 fatal_error (input_location,
2490 "%s: attempt to rename spec %qs to "
2491 "already defined spec %qs",
2492 filename, p1, p2);
2494 if (verbose_flag)
2496 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
2497 #ifdef DEBUG_SPECS
2498 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
2499 #endif
2502 set_spec (p2, *(sl->ptr_spec), user_p);
2503 if (sl->alloc_p)
2504 free (CONST_CAST (char *, *(sl->ptr_spec)));
2506 *(sl->ptr_spec) = "";
2507 sl->alloc_p = 0;
2508 continue;
2510 else
2511 fatal_error (input_location,
2512 "specs unknown %% command after %ld characters",
2513 (long) (p1 - buffer));
2516 /* Find the colon that should end the suffix. */
2517 p1 = p;
2518 while (*p1 && *p1 != ':' && *p1 != '\n')
2519 p1++;
2521 /* The colon shouldn't be missing. */
2522 if (*p1 != ':')
2523 fatal_error (input_location,
2524 "specs file malformed after %ld characters",
2525 (long) (p1 - buffer));
2527 /* Skip back over trailing whitespace. */
2528 p2 = p1;
2529 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2530 p2--;
2532 /* Copy the suffix to a string. */
2533 suffix = save_string (p, p2 - p);
2534 /* Find the next line. */
2535 p = skip_whitespace (p1 + 1);
2536 if (p[1] == 0)
2537 fatal_error (input_location,
2538 "specs file malformed after %ld characters",
2539 (long) (p - buffer));
2541 p1 = p;
2542 /* Find next blank line or end of string. */
2543 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2544 p1++;
2546 /* Specs end at the blank line and do not include the newline. */
2547 spec = save_string (p, p1 - p);
2548 p = p1;
2550 /* Delete backslash-newline sequences from the spec. */
2551 in = spec;
2552 out = spec;
2553 while (*in != 0)
2555 if (in[0] == '\\' && in[1] == '\n')
2556 in += 2;
2557 else if (in[0] == '#')
2558 while (*in && *in != '\n')
2559 in++;
2561 else
2562 *out++ = *in++;
2564 *out = 0;
2566 if (suffix[0] == '*')
2568 if (! strcmp (suffix, "*link_command"))
2569 link_command_spec = spec;
2570 else
2572 set_spec (suffix + 1, spec, user_p);
2573 free (spec);
2576 else
2578 /* Add this pair to the vector. */
2579 compilers
2580 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
2582 compilers[n_compilers].suffix = suffix;
2583 compilers[n_compilers].spec = spec;
2584 n_compilers++;
2585 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2588 if (*suffix == 0)
2589 link_command_spec = spec;
2592 if (link_command_spec == 0)
2593 fatal_error (input_location, "spec file has no spec for linking");
2595 XDELETEVEC (buffer);
2598 /* Record the names of temporary files we tell compilers to write,
2599 and delete them at the end of the run. */
2601 /* This is the common prefix we use to make temp file names.
2602 It is chosen once for each run of this program.
2603 It is substituted into a spec by %g or %j.
2604 Thus, all temp file names contain this prefix.
2605 In practice, all temp file names start with this prefix.
2607 This prefix comes from the envvar TMPDIR if it is defined;
2608 otherwise, from the P_tmpdir macro if that is defined;
2609 otherwise, in /usr/tmp or /tmp;
2610 or finally the current directory if all else fails. */
2612 static const char *temp_filename;
2614 /* Length of the prefix. */
2616 static int temp_filename_length;
2618 /* Define the list of temporary files to delete. */
2620 struct temp_file
2622 const char *name;
2623 struct temp_file *next;
2626 /* Queue of files to delete on success or failure of compilation. */
2627 static struct temp_file *always_delete_queue;
2628 /* Queue of files to delete on failure of compilation. */
2629 static struct temp_file *failure_delete_queue;
2631 /* Record FILENAME as a file to be deleted automatically.
2632 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2633 otherwise delete it in any case.
2634 FAIL_DELETE nonzero means delete it if a compilation step fails;
2635 otherwise delete it in any case. */
2637 void
2638 record_temp_file (const char *filename, int always_delete, int fail_delete)
2640 char *const name = xstrdup (filename);
2642 if (always_delete)
2644 struct temp_file *temp;
2645 for (temp = always_delete_queue; temp; temp = temp->next)
2646 if (! filename_cmp (name, temp->name))
2648 free (name);
2649 goto already1;
2652 temp = XNEW (struct temp_file);
2653 temp->next = always_delete_queue;
2654 temp->name = name;
2655 always_delete_queue = temp;
2657 already1:;
2660 if (fail_delete)
2662 struct temp_file *temp;
2663 for (temp = failure_delete_queue; temp; temp = temp->next)
2664 if (! filename_cmp (name, temp->name))
2666 free (name);
2667 goto already2;
2670 temp = XNEW (struct temp_file);
2671 temp->next = failure_delete_queue;
2672 temp->name = name;
2673 failure_delete_queue = temp;
2675 already2:;
2679 /* Delete all the temporary files whose names we previously recorded. */
2681 #ifndef DELETE_IF_ORDINARY
2682 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2683 do \
2685 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2686 if (unlink (NAME) < 0) \
2687 if (VERBOSE_FLAG) \
2688 error ("%s: %m", (NAME)); \
2689 } while (0)
2690 #endif
2692 static void
2693 delete_if_ordinary (const char *name)
2695 struct stat st;
2696 #ifdef DEBUG
2697 int i, c;
2699 printf ("Delete %s? (y or n) ", name);
2700 fflush (stdout);
2701 i = getchar ();
2702 if (i != '\n')
2703 while ((c = getchar ()) != '\n' && c != EOF)
2706 if (i == 'y' || i == 'Y')
2707 #endif /* DEBUG */
2708 DELETE_IF_ORDINARY (name, st, verbose_flag);
2711 static void
2712 delete_temp_files (void)
2714 struct temp_file *temp;
2716 for (temp = always_delete_queue; temp; temp = temp->next)
2717 delete_if_ordinary (temp->name);
2718 always_delete_queue = 0;
2721 /* Delete all the files to be deleted on error. */
2723 static void
2724 delete_failure_queue (void)
2726 struct temp_file *temp;
2728 for (temp = failure_delete_queue; temp; temp = temp->next)
2729 delete_if_ordinary (temp->name);
2732 static void
2733 clear_failure_queue (void)
2735 failure_delete_queue = 0;
2738 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2739 returns non-NULL.
2740 If DO_MULTI is true iterate over the paths twice, first with multilib
2741 suffix then without, otherwise iterate over the paths once without
2742 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2743 to avoid visiting the same path twice, but we could do better. For
2744 instance, /usr/lib/../lib is considered different from /usr/lib.
2745 At least EXTRA_SPACE chars past the end of the path passed to
2746 CALLBACK are available for use by the callback.
2747 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2749 Returns the value returned by CALLBACK. */
2751 static void *
2752 for_each_path (const struct path_prefix *paths,
2753 bool do_multi,
2754 size_t extra_space,
2755 void *(*callback) (char *, void *),
2756 void *callback_info)
2758 struct prefix_list *pl;
2759 const char *multi_dir = NULL;
2760 const char *multi_os_dir = NULL;
2761 const char *multiarch_suffix = NULL;
2762 const char *multi_suffix;
2763 const char *just_multi_suffix;
2764 char *path = NULL;
2765 void *ret = NULL;
2766 bool skip_multi_dir = false;
2767 bool skip_multi_os_dir = false;
2769 multi_suffix = machine_suffix;
2770 just_multi_suffix = just_machine_suffix;
2771 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2773 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2774 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2775 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2777 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2778 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2779 if (multiarch_dir)
2780 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2782 while (1)
2784 size_t multi_dir_len = 0;
2785 size_t multi_os_dir_len = 0;
2786 size_t multiarch_len = 0;
2787 size_t suffix_len;
2788 size_t just_suffix_len;
2789 size_t len;
2791 if (multi_dir)
2792 multi_dir_len = strlen (multi_dir);
2793 if (multi_os_dir)
2794 multi_os_dir_len = strlen (multi_os_dir);
2795 if (multiarch_suffix)
2796 multiarch_len = strlen (multiarch_suffix);
2797 suffix_len = strlen (multi_suffix);
2798 just_suffix_len = strlen (just_multi_suffix);
2800 if (path == NULL)
2802 len = paths->max_len + extra_space + 1;
2803 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2804 path = XNEWVEC (char, len);
2807 for (pl = paths->plist; pl != 0; pl = pl->next)
2809 len = strlen (pl->prefix);
2810 memcpy (path, pl->prefix, len);
2812 /* Look first in MACHINE/VERSION subdirectory. */
2813 if (!skip_multi_dir)
2815 memcpy (path + len, multi_suffix, suffix_len + 1);
2816 ret = callback (path, callback_info);
2817 if (ret)
2818 break;
2821 /* Some paths are tried with just the machine (ie. target)
2822 subdir. This is used for finding as, ld, etc. */
2823 if (!skip_multi_dir
2824 && pl->require_machine_suffix == 2)
2826 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2827 ret = callback (path, callback_info);
2828 if (ret)
2829 break;
2832 /* Now try the multiarch path. */
2833 if (!skip_multi_dir
2834 && !pl->require_machine_suffix && multiarch_dir)
2836 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2837 ret = callback (path, callback_info);
2838 if (ret)
2839 break;
2842 /* Now try the base path. */
2843 if (!pl->require_machine_suffix
2844 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2846 const char *this_multi;
2847 size_t this_multi_len;
2849 if (pl->os_multilib)
2851 this_multi = multi_os_dir;
2852 this_multi_len = multi_os_dir_len;
2854 else
2856 this_multi = multi_dir;
2857 this_multi_len = multi_dir_len;
2860 if (this_multi_len)
2861 memcpy (path + len, this_multi, this_multi_len + 1);
2862 else
2863 path[len] = '\0';
2865 ret = callback (path, callback_info);
2866 if (ret)
2867 break;
2870 if (pl)
2871 break;
2873 if (multi_dir == NULL && multi_os_dir == NULL)
2874 break;
2876 /* Run through the paths again, this time without multilibs.
2877 Don't repeat any we have already seen. */
2878 if (multi_dir)
2880 free (CONST_CAST (char *, multi_dir));
2881 multi_dir = NULL;
2882 free (CONST_CAST (char *, multi_suffix));
2883 multi_suffix = machine_suffix;
2884 free (CONST_CAST (char *, just_multi_suffix));
2885 just_multi_suffix = just_machine_suffix;
2887 else
2888 skip_multi_dir = true;
2889 if (multi_os_dir)
2891 free (CONST_CAST (char *, multi_os_dir));
2892 multi_os_dir = NULL;
2894 else
2895 skip_multi_os_dir = true;
2898 if (multi_dir)
2900 free (CONST_CAST (char *, multi_dir));
2901 free (CONST_CAST (char *, multi_suffix));
2902 free (CONST_CAST (char *, just_multi_suffix));
2904 if (multi_os_dir)
2905 free (CONST_CAST (char *, multi_os_dir));
2906 if (ret != path)
2907 free (path);
2908 return ret;
2911 /* Callback for build_search_list. Adds path to obstack being built. */
2913 struct add_to_obstack_info {
2914 struct obstack *ob;
2915 bool check_dir;
2916 bool first_time;
2919 static void *
2920 add_to_obstack (char *path, void *data)
2922 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2924 if (info->check_dir && !is_directory (path, false))
2925 return NULL;
2927 if (!info->first_time)
2928 obstack_1grow (info->ob, PATH_SEPARATOR);
2930 obstack_grow (info->ob, path, strlen (path));
2932 info->first_time = false;
2933 return NULL;
2936 /* Add or change the value of an environment variable, outputting the
2937 change to standard error if in verbose mode. */
2938 static void
2939 xputenv (const char *string)
2941 env.xput (string);
2944 /* Build a list of search directories from PATHS.
2945 PREFIX is a string to prepend to the list.
2946 If CHECK_DIR_P is true we ensure the directory exists.
2947 If DO_MULTI is true, multilib paths are output first, then
2948 non-multilib paths.
2949 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2950 It is also used by the --print-search-dirs flag. */
2952 static char *
2953 build_search_list (const struct path_prefix *paths, const char *prefix,
2954 bool check_dir, bool do_multi)
2956 struct add_to_obstack_info info;
2958 info.ob = &collect_obstack;
2959 info.check_dir = check_dir;
2960 info.first_time = true;
2962 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2963 obstack_1grow (&collect_obstack, '=');
2965 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2967 obstack_1grow (&collect_obstack, '\0');
2968 return XOBFINISH (&collect_obstack, char *);
2971 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2972 for collect. */
2974 static void
2975 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2976 bool do_multi)
2978 xputenv (build_search_list (paths, env_var, true, do_multi));
2981 /* Check whether NAME can be accessed in MODE. This is like access,
2982 except that it never considers directories to be executable. */
2984 static int
2985 access_check (const char *name, int mode)
2987 if (mode == X_OK)
2989 struct stat st;
2991 if (stat (name, &st) < 0
2992 || S_ISDIR (st.st_mode))
2993 return -1;
2996 return access (name, mode);
2999 /* Callback for find_a_file. Appends the file name to the directory
3000 path. If the resulting file exists in the right mode, return the
3001 full pathname to the file. */
3003 struct file_at_path_info {
3004 const char *name;
3005 const char *suffix;
3006 int name_len;
3007 int suffix_len;
3008 int mode;
3011 static void *
3012 file_at_path (char *path, void *data)
3014 struct file_at_path_info *info = (struct file_at_path_info *) data;
3015 size_t len = strlen (path);
3017 memcpy (path + len, info->name, info->name_len);
3018 len += info->name_len;
3020 /* Some systems have a suffix for executable files.
3021 So try appending that first. */
3022 if (info->suffix_len)
3024 memcpy (path + len, info->suffix, info->suffix_len + 1);
3025 if (access_check (path, info->mode) == 0)
3026 return path;
3029 path[len] = '\0';
3030 if (access_check (path, info->mode) == 0)
3031 return path;
3033 return NULL;
3036 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
3037 access to check permissions. If DO_MULTI is true, search multilib
3038 paths then non-multilib paths, otherwise do not search multilib paths.
3039 Return 0 if not found, otherwise return its name, allocated with malloc. */
3041 static char *
3042 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
3043 bool do_multi)
3045 struct file_at_path_info info;
3047 /* Find the filename in question (special case for absolute paths). */
3049 if (IS_ABSOLUTE_PATH (name))
3051 if (access (name, mode) == 0)
3052 return xstrdup (name);
3054 return NULL;
3057 info.name = name;
3058 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
3059 info.name_len = strlen (info.name);
3060 info.suffix_len = strlen (info.suffix);
3061 info.mode = mode;
3063 return (char*) for_each_path (pprefix, do_multi,
3064 info.name_len + info.suffix_len,
3065 file_at_path, &info);
3068 /* Specialization of find_a_file for programs that also takes into account
3069 configure-specified default programs. */
3071 static char*
3072 find_a_program (const char *name)
3074 /* Do not search if default matches query. */
3076 #ifdef DEFAULT_ASSEMBLER
3077 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, X_OK) == 0)
3078 return xstrdup (DEFAULT_ASSEMBLER);
3079 #endif
3081 #ifdef DEFAULT_LINKER
3082 if (! strcmp (name, "ld") && access (DEFAULT_LINKER, X_OK) == 0)
3083 return xstrdup (DEFAULT_LINKER);
3084 #endif
3086 #ifdef DEFAULT_DSYMUTIL
3087 if (! strcmp (name, "dsymutil") && access (DEFAULT_DSYMUTIL, X_OK) == 0)
3088 return xstrdup (DEFAULT_DSYMUTIL);
3089 #endif
3091 return find_a_file (&exec_prefixes, name, X_OK, false);
3094 /* Ranking of prefixes in the sort list. -B prefixes are put before
3095 all others. */
3097 enum path_prefix_priority
3099 PREFIX_PRIORITY_B_OPT,
3100 PREFIX_PRIORITY_LAST
3103 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
3104 order according to PRIORITY. Within each PRIORITY, new entries are
3105 appended.
3107 If WARN is nonzero, we will warn if no file is found
3108 through this prefix. WARN should point to an int
3109 which will be set to 1 if this entry is used.
3111 COMPONENT is the value to be passed to update_path.
3113 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
3114 the complete value of machine_suffix.
3115 2 means try both machine_suffix and just_machine_suffix. */
3117 static void
3118 add_prefix (struct path_prefix *pprefix, const char *prefix,
3119 const char *component, /* enum prefix_priority */ int priority,
3120 int require_machine_suffix, int os_multilib)
3122 struct prefix_list *pl, **prev;
3123 int len;
3125 for (prev = &pprefix->plist;
3126 (*prev) != NULL && (*prev)->priority <= priority;
3127 prev = &(*prev)->next)
3130 /* Keep track of the longest prefix. */
3132 prefix = update_path (prefix, component);
3133 len = strlen (prefix);
3134 if (len > pprefix->max_len)
3135 pprefix->max_len = len;
3137 pl = XNEW (struct prefix_list);
3138 pl->prefix = prefix;
3139 pl->require_machine_suffix = require_machine_suffix;
3140 pl->priority = priority;
3141 pl->os_multilib = os_multilib;
3143 /* Insert after PREV. */
3144 pl->next = (*prev);
3145 (*prev) = pl;
3148 /* Same as add_prefix, but prepending target_system_root to prefix. */
3149 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
3150 static void
3151 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
3152 const char *component,
3153 /* enum prefix_priority */ int priority,
3154 int require_machine_suffix, int os_multilib)
3156 if (!IS_ABSOLUTE_PATH (prefix))
3157 fatal_error (input_location, "system path %qs is not absolute", prefix);
3159 if (target_system_root)
3161 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
3162 size_t sysroot_len = strlen (target_system_root);
3164 if (sysroot_len > 0
3165 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
3166 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
3168 if (target_sysroot_suffix)
3169 prefix = concat (sysroot_no_trailing_dir_separator,
3170 target_sysroot_suffix, prefix, NULL);
3171 else
3172 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
3174 free (sysroot_no_trailing_dir_separator);
3176 /* We have to override this because GCC's notion of sysroot
3177 moves along with GCC. */
3178 component = "GCC";
3181 add_prefix (pprefix, prefix, component, priority,
3182 require_machine_suffix, os_multilib);
3185 /* Same as add_prefix, but prepending target_sysroot_hdrs_suffix to prefix. */
3187 static void
3188 add_sysrooted_hdrs_prefix (struct path_prefix *pprefix, const char *prefix,
3189 const char *component,
3190 /* enum prefix_priority */ int priority,
3191 int require_machine_suffix, int os_multilib)
3193 if (!IS_ABSOLUTE_PATH (prefix))
3194 fatal_error (input_location, "system path %qs is not absolute", prefix);
3196 if (target_system_root)
3198 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
3199 size_t sysroot_len = strlen (target_system_root);
3201 if (sysroot_len > 0
3202 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
3203 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
3205 if (target_sysroot_hdrs_suffix)
3206 prefix = concat (sysroot_no_trailing_dir_separator,
3207 target_sysroot_hdrs_suffix, prefix, NULL);
3208 else
3209 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
3211 free (sysroot_no_trailing_dir_separator);
3213 /* We have to override this because GCC's notion of sysroot
3214 moves along with GCC. */
3215 component = "GCC";
3218 add_prefix (pprefix, prefix, component, priority,
3219 require_machine_suffix, os_multilib);
3223 /* Execute the command specified by the arguments on the current line of spec.
3224 When using pipes, this includes several piped-together commands
3225 with `|' between them.
3227 Return 0 if successful, -1 if failed. */
3229 static int
3230 execute (void)
3232 int i;
3233 int n_commands; /* # of command. */
3234 char *string;
3235 struct pex_obj *pex;
3236 struct command
3238 const char *prog; /* program name. */
3239 const char **argv; /* vector of args. */
3241 const char *arg;
3243 struct command *commands; /* each command buffer with above info. */
3245 gcc_assert (!processing_spec_function);
3247 if (wrapper_string)
3249 string = find_a_program (argbuf[0]);
3250 if (string)
3251 argbuf[0] = string;
3252 insert_wrapper (wrapper_string);
3255 /* Count # of piped commands. */
3256 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
3257 if (strcmp (arg, "|") == 0)
3258 n_commands++;
3260 /* Get storage for each command. */
3261 commands = XALLOCAVEC (struct command, n_commands);
3263 /* Split argbuf into its separate piped processes,
3264 and record info about each one.
3265 Also search for the programs that are to be run. */
3267 argbuf.safe_push (0);
3269 commands[0].prog = argbuf[0]; /* first command. */
3270 commands[0].argv = argbuf.address ();
3272 if (!wrapper_string)
3274 string = find_a_program(commands[0].prog);
3275 if (string)
3276 commands[0].argv[0] = string;
3279 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
3280 if (arg && strcmp (arg, "|") == 0)
3281 { /* each command. */
3282 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
3283 fatal_error (input_location, "%<-pipe%> not supported");
3284 #endif
3285 argbuf[i] = 0; /* Termination of command args. */
3286 commands[n_commands].prog = argbuf[i + 1];
3287 commands[n_commands].argv
3288 = &(argbuf.address ())[i + 1];
3289 string = find_a_program(commands[n_commands].prog);
3290 if (string)
3291 commands[n_commands].argv[0] = string;
3292 n_commands++;
3295 /* If -v, print what we are about to do, and maybe query. */
3297 if (verbose_flag)
3299 /* For help listings, put a blank line between sub-processes. */
3300 if (print_help_list)
3301 fputc ('\n', stderr);
3303 /* Print each piped command as a separate line. */
3304 for (i = 0; i < n_commands; i++)
3306 const char *const *j;
3308 if (verbose_only_flag)
3310 for (j = commands[i].argv; *j; j++)
3312 const char *p;
3313 for (p = *j; *p; ++p)
3314 if (!ISALNUM ((unsigned char) *p)
3315 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
3316 break;
3317 if (*p || !*j)
3319 fprintf (stderr, " \"");
3320 for (p = *j; *p; ++p)
3322 if (*p == '"' || *p == '\\' || *p == '$')
3323 fputc ('\\', stderr);
3324 fputc (*p, stderr);
3326 fputc ('"', stderr);
3328 /* If it's empty, print "". */
3329 else if (!**j)
3330 fprintf (stderr, " \"\"");
3331 else
3332 fprintf (stderr, " %s", *j);
3335 else
3336 for (j = commands[i].argv; *j; j++)
3337 /* If it's empty, print "". */
3338 if (!**j)
3339 fprintf (stderr, " \"\"");
3340 else
3341 fprintf (stderr, " %s", *j);
3343 /* Print a pipe symbol after all but the last command. */
3344 if (i + 1 != n_commands)
3345 fprintf (stderr, " |");
3346 fprintf (stderr, "\n");
3348 fflush (stderr);
3349 if (verbose_only_flag != 0)
3351 /* verbose_only_flag should act as if the spec was
3352 executed, so increment execution_count before
3353 returning. This prevents spurious warnings about
3354 unused linker input files, etc. */
3355 execution_count++;
3356 return 0;
3358 #ifdef DEBUG
3359 fnotice (stderr, "\nGo ahead? (y or n) ");
3360 fflush (stderr);
3361 i = getchar ();
3362 if (i != '\n')
3363 while (getchar () != '\n')
3366 if (i != 'y' && i != 'Y')
3367 return 0;
3368 #endif /* DEBUG */
3371 #ifdef ENABLE_VALGRIND_CHECKING
3372 /* Run the each command through valgrind. To simplify prepending the
3373 path to valgrind and the option "-q" (for quiet operation unless
3374 something triggers), we allocate a separate argv array. */
3376 for (i = 0; i < n_commands; i++)
3378 const char **argv;
3379 int argc;
3380 int j;
3382 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
3385 argv = XALLOCAVEC (const char *, argc + 3);
3387 argv[0] = VALGRIND_PATH;
3388 argv[1] = "-q";
3389 for (j = 2; j < argc + 2; j++)
3390 argv[j] = commands[i].argv[j - 2];
3391 argv[j] = NULL;
3393 commands[i].argv = argv;
3394 commands[i].prog = argv[0];
3396 #endif
3398 /* Run each piped subprocess. */
3400 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
3401 ? PEX_RECORD_TIMES : 0),
3402 progname, temp_filename);
3403 if (pex == NULL)
3404 fatal_error (input_location, "%<pex_init%> failed: %m");
3406 for (i = 0; i < n_commands; i++)
3408 const char *errmsg;
3409 int err;
3410 const char *string = commands[i].argv[0];
3412 errmsg = pex_run (pex,
3413 ((i + 1 == n_commands ? PEX_LAST : 0)
3414 | (string == commands[i].prog ? PEX_SEARCH : 0)),
3415 string, CONST_CAST (char **, commands[i].argv),
3416 NULL, NULL, &err);
3417 if (errmsg != NULL)
3419 errno = err;
3420 fatal_error (input_location,
3421 err ? G_("cannot execute %qs: %s: %m")
3422 : G_("cannot execute %qs: %s"),
3423 string, errmsg);
3426 if (i && string != commands[i].prog)
3427 free (CONST_CAST (char *, string));
3430 execution_count++;
3432 /* Wait for all the subprocesses to finish. */
3435 int *statuses;
3436 struct pex_time *times = NULL;
3437 int ret_code = 0;
3439 statuses = XALLOCAVEC (int, n_commands);
3440 if (!pex_get_status (pex, n_commands, statuses))
3441 fatal_error (input_location, "failed to get exit status: %m");
3443 if (report_times || report_times_to_file)
3445 times = XALLOCAVEC (struct pex_time, n_commands);
3446 if (!pex_get_times (pex, n_commands, times))
3447 fatal_error (input_location, "failed to get process times: %m");
3450 pex_free (pex);
3452 for (i = 0; i < n_commands; ++i)
3454 int status = statuses[i];
3456 if (WIFSIGNALED (status))
3457 switch (WTERMSIG (status))
3459 case SIGINT:
3460 case SIGTERM:
3461 /* SIGQUIT and SIGKILL are not available on MinGW. */
3462 #ifdef SIGQUIT
3463 case SIGQUIT:
3464 #endif
3465 #ifdef SIGKILL
3466 case SIGKILL:
3467 #endif
3468 /* The user (or environment) did something to the
3469 inferior. Making this an ICE confuses the user into
3470 thinking there's a compiler bug. Much more likely is
3471 the user or OOM killer nuked it. */
3472 fatal_error (input_location,
3473 "%s signal terminated program %s",
3474 strsignal (WTERMSIG (status)),
3475 commands[i].prog);
3476 break;
3478 #ifdef SIGPIPE
3479 case SIGPIPE:
3480 /* SIGPIPE is a special case. It happens in -pipe mode
3481 when the compiler dies before the preprocessor is
3482 done, or the assembler dies before the compiler is
3483 done. There's generally been an error already, and
3484 this is just fallout. So don't generate another
3485 error unless we would otherwise have succeeded. */
3486 if (signal_count || greatest_status >= MIN_FATAL_STATUS)
3488 signal_count++;
3489 ret_code = -1;
3490 break;
3492 #endif
3493 /* FALLTHROUGH */
3495 default:
3496 /* The inferior failed to catch the signal. */
3497 internal_error_no_backtrace ("%s signal terminated program %s",
3498 strsignal (WTERMSIG (status)),
3499 commands[i].prog);
3501 else if (WIFEXITED (status)
3502 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
3504 /* For ICEs in cc1, cc1obj, cc1plus see if it is
3505 reproducible or not. */
3506 const char *p;
3507 if (flag_report_bug
3508 && WEXITSTATUS (status) == ICE_EXIT_CODE
3509 && i == 0
3510 && (p = strrchr (commands[0].argv[0], DIR_SEPARATOR))
3511 && startswith (p + 1, "cc1"))
3512 try_generate_repro (commands[0].argv);
3513 if (WEXITSTATUS (status) > greatest_status)
3514 greatest_status = WEXITSTATUS (status);
3515 ret_code = -1;
3518 if (report_times || report_times_to_file)
3520 struct pex_time *pt = &times[i];
3521 double ut, st;
3523 ut = ((double) pt->user_seconds
3524 + (double) pt->user_microseconds / 1.0e6);
3525 st = ((double) pt->system_seconds
3526 + (double) pt->system_microseconds / 1.0e6);
3528 if (ut + st != 0)
3530 if (report_times)
3531 fnotice (stderr, "# %s %.2f %.2f\n",
3532 commands[i].prog, ut, st);
3534 if (report_times_to_file)
3536 int c = 0;
3537 const char *const *j;
3539 fprintf (report_times_to_file, "%g %g", ut, st);
3541 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
3543 const char *p;
3544 for (p = *j; *p; ++p)
3545 if (*p == '"' || *p == '\\' || *p == '$'
3546 || ISSPACE (*p))
3547 break;
3549 if (*p)
3551 fprintf (report_times_to_file, " \"");
3552 for (p = *j; *p; ++p)
3554 if (*p == '"' || *p == '\\' || *p == '$')
3555 fputc ('\\', report_times_to_file);
3556 fputc (*p, report_times_to_file);
3558 fputc ('"', report_times_to_file);
3560 else
3561 fprintf (report_times_to_file, " %s", *j);
3564 fputc ('\n', report_times_to_file);
3570 if (commands[0].argv[0] != commands[0].prog)
3571 free (CONST_CAST (char *, commands[0].argv[0]));
3573 return ret_code;
3577 static struct switchstr *switches;
3579 static int n_switches;
3581 static int n_switches_alloc;
3583 /* Set to zero if -fcompare-debug is disabled, positive if it's
3584 enabled and we're running the first compilation, negative if it's
3585 enabled and we're running the second compilation. For most of the
3586 time, it's in the range -1..1, but it can be temporarily set to 2
3587 or 3 to indicate that the -fcompare-debug flags didn't come from
3588 the command-line, but rather from the GCC_COMPARE_DEBUG environment
3589 variable, until a synthesized -fcompare-debug flag is added to the
3590 command line. */
3591 int compare_debug;
3593 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
3594 int compare_debug_second;
3596 /* Set to the flags that should be passed to the second compilation in
3597 a -fcompare-debug compilation. */
3598 const char *compare_debug_opt;
3600 static struct switchstr *switches_debug_check[2];
3602 static int n_switches_debug_check[2];
3604 static int n_switches_alloc_debug_check[2];
3606 static char *debug_check_temp_file[2];
3608 /* Language is one of three things:
3610 1) The name of a real programming language.
3611 2) NULL, indicating that no one has figured out
3612 what it is yet.
3613 3) '*', indicating that the file should be passed
3614 to the linker. */
3615 struct infile
3617 const char *name;
3618 const char *language;
3619 struct compiler *incompiler;
3620 bool compiled;
3621 bool preprocessed;
3624 /* Also a vector of input files specified. */
3626 static struct infile *infiles;
3628 int n_infiles;
3630 static int n_infiles_alloc;
3632 /* True if undefined environment variables encountered during spec processing
3633 are ok to ignore, typically when we're running for --help or --version. */
3635 static bool spec_undefvar_allowed;
3637 /* True if multiple input files are being compiled to a single
3638 assembly file. */
3640 static bool combine_inputs;
3642 /* This counts the number of libraries added by lang_specific_driver, so that
3643 we can tell if there were any user supplied any files or libraries. */
3645 static int added_libraries;
3647 /* And a vector of corresponding output files is made up later. */
3649 const char **outfiles;
3651 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3653 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3654 is true if we should look for an executable suffix. DO_OBJ
3655 is true if we should look for an object suffix. */
3657 static const char *
3658 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3659 int do_obj ATTRIBUTE_UNUSED)
3661 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3662 int i;
3663 #endif
3664 int len;
3666 if (name == NULL)
3667 return NULL;
3669 len = strlen (name);
3671 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3672 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3673 if (do_obj && len > 2
3674 && name[len - 2] == '.'
3675 && name[len - 1] == 'o')
3677 obstack_grow (&obstack, name, len - 2);
3678 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3679 name = XOBFINISH (&obstack, const char *);
3681 #endif
3683 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3684 /* If there is no filetype, make it the executable suffix (which includes
3685 the "."). But don't get confused if we have just "-o". */
3686 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || not_actual_file_p (name))
3687 return name;
3689 for (i = len - 1; i >= 0; i--)
3690 if (IS_DIR_SEPARATOR (name[i]))
3691 break;
3693 for (i++; i < len; i++)
3694 if (name[i] == '.')
3695 return name;
3697 obstack_grow (&obstack, name, len);
3698 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3699 strlen (TARGET_EXECUTABLE_SUFFIX));
3700 name = XOBFINISH (&obstack, const char *);
3701 #endif
3703 return name;
3705 #endif
3707 /* Display the command line switches accepted by gcc. */
3708 static void
3709 display_help (void)
3711 printf (_("Usage: %s [options] file...\n"), progname);
3712 fputs (_("Options:\n"), stdout);
3714 fputs (_(" -pass-exit-codes Exit with highest error code from a phase.\n"), stdout);
3715 fputs (_(" --help Display this information.\n"), stdout);
3716 fputs (_(" --target-help Display target specific command line options "
3717 "(including assembler and linker options).\n"), stdout);
3718 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...].\n"), stdout);
3719 fputs (_(" Display specific types of command line options.\n"), stdout);
3720 if (! verbose_flag)
3721 fputs (_(" (Use '-v --help' to display command line options of sub-processes).\n"), stdout);
3722 fputs (_(" --version Display compiler version information.\n"), stdout);
3723 fputs (_(" -dumpspecs Display all of the built in spec strings.\n"), stdout);
3724 fputs (_(" -dumpversion Display the version of the compiler.\n"), stdout);
3725 fputs (_(" -dumpmachine Display the compiler's target processor.\n"), stdout);
3726 fputs (_(" -foffload=<targets> Specify offloading targets.\n"), stdout);
3727 fputs (_(" -print-search-dirs Display the directories in the compiler's search path.\n"), stdout);
3728 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library.\n"), stdout);
3729 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>.\n"), stdout);
3730 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>.\n"), stdout);
3731 fputs (_("\
3732 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3733 a component in the library path.\n"), stdout);
3734 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc.\n"), stdout);
3735 fputs (_("\
3736 -print-multi-lib Display the mapping between command line options and\n\
3737 multiple library search directories.\n"), stdout);
3738 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries.\n"), stdout);
3739 fputs (_(" -print-sysroot Display the target libraries directory.\n"), stdout);
3740 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers.\n"), stdout);
3741 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler.\n"), stdout);
3742 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor.\n"), stdout);
3743 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker.\n"), stdout);
3744 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler.\n"), stdout);
3745 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor.\n"), stdout);
3746 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker.\n"), stdout);
3747 fputs (_(" -save-temps Do not delete intermediate files.\n"), stdout);
3748 fputs (_(" -save-temps=<arg> Do not delete intermediate files.\n"), stdout);
3749 fputs (_("\
3750 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3751 prefixes to other gcc components.\n"), stdout);
3752 fputs (_(" -pipe Use pipes rather than intermediate files.\n"), stdout);
3753 fputs (_(" -time Time the execution of each subprocess.\n"), stdout);
3754 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>.\n"), stdout);
3755 fputs (_(" -std=<standard> Assume that the input sources are for <standard>.\n"), stdout);
3756 fputs (_("\
3757 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3758 and libraries.\n"), stdout);
3759 fputs (_(" -B <directory> Add <directory> to the compiler's search paths.\n"), stdout);
3760 fputs (_(" -v Display the programs invoked by the compiler.\n"), stdout);
3761 fputs (_(" -### Like -v but options quoted and commands not executed.\n"), stdout);
3762 fputs (_(" -E Preprocess only; do not compile, assemble or link.\n"), stdout);
3763 fputs (_(" -S Compile only; do not assemble or link.\n"), stdout);
3764 fputs (_(" -c Compile and assemble, but do not link.\n"), stdout);
3765 fputs (_(" -o <file> Place the output into <file>.\n"), stdout);
3766 fputs (_(" -pie Create a dynamically linked position independent\n\
3767 executable.\n"), stdout);
3768 fputs (_(" -shared Create a shared library.\n"), stdout);
3769 fputs (_("\
3770 -x <language> Specify the language of the following input files.\n\
3771 Permissible languages include: c c++ assembler none\n\
3772 'none' means revert to the default behavior of\n\
3773 guessing the language based on the file's extension.\n\
3774 "), stdout);
3776 printf (_("\
3777 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3778 passed on to the various sub-processes invoked by %s. In order to pass\n\
3779 other options on to these processes the -W<letter> options must be used.\n\
3780 "), progname);
3782 /* The rest of the options are displayed by invocations of the various
3783 sub-processes. */
3786 static void
3787 add_preprocessor_option (const char *option, int len)
3789 preprocessor_options.safe_push (save_string (option, len));
3792 static void
3793 add_assembler_option (const char *option, int len)
3795 assembler_options.safe_push (save_string (option, len));
3798 static void
3799 add_linker_option (const char *option, int len)
3801 linker_options.safe_push (save_string (option, len));
3804 /* Allocate space for an input file in infiles. */
3806 static void
3807 alloc_infile (void)
3809 if (n_infiles_alloc == 0)
3811 n_infiles_alloc = 16;
3812 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3814 else if (n_infiles_alloc == n_infiles)
3816 n_infiles_alloc *= 2;
3817 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3821 /* Store an input file with the given NAME and LANGUAGE in
3822 infiles. */
3824 static void
3825 add_infile (const char *name, const char *language)
3827 alloc_infile ();
3828 infiles[n_infiles].name = name;
3829 infiles[n_infiles++].language = language;
3832 /* Allocate space for a switch in switches. */
3834 static void
3835 alloc_switch (void)
3837 if (n_switches_alloc == 0)
3839 n_switches_alloc = 16;
3840 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3842 else if (n_switches_alloc == n_switches)
3844 n_switches_alloc *= 2;
3845 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3849 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3850 as validated if VALIDATED and KNOWN if it is an internal switch. */
3852 static void
3853 save_switch (const char *opt, size_t n_args, const char *const *args,
3854 bool validated, bool known)
3856 alloc_switch ();
3857 switches[n_switches].part1 = opt + 1;
3858 if (n_args == 0)
3859 switches[n_switches].args = 0;
3860 else
3862 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3863 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3864 switches[n_switches].args[n_args] = NULL;
3867 switches[n_switches].live_cond = 0;
3868 switches[n_switches].validated = validated;
3869 switches[n_switches].known = known;
3870 switches[n_switches].ordering = 0;
3871 n_switches++;
3874 /* Set the SOURCE_DATE_EPOCH environment variable to the current time if it is
3875 not set already. */
3877 static void
3878 set_source_date_epoch_envvar ()
3880 /* Array size is 21 = ceil(log_10(2^64)) + 1 to hold string representations
3881 of 64 bit integers. */
3882 char source_date_epoch[21];
3883 time_t tt;
3885 errno = 0;
3886 tt = time (NULL);
3887 if (tt < (time_t) 0 || errno != 0)
3888 tt = (time_t) 0;
3890 snprintf (source_date_epoch, 21, "%llu", (unsigned long long) tt);
3891 /* Using setenv instead of xputenv because we want the variable to remain
3892 after finalizing so that it's still set in the second run when using
3893 -fcompare-debug. */
3894 setenv ("SOURCE_DATE_EPOCH", source_date_epoch, 0);
3897 /* Handle an option DECODED that is unknown to the option-processing
3898 machinery. */
3900 static bool
3901 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3903 const char *opt = decoded->arg;
3904 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3905 && !(decoded->errors & CL_ERR_NEGATIVE))
3907 /* Leave unknown -Wno-* options for the compiler proper, to be
3908 diagnosed only if there are warnings. */
3909 save_switch (decoded->canonical_option[0],
3910 decoded->canonical_option_num_elements - 1,
3911 &decoded->canonical_option[1], false, true);
3912 return false;
3914 if (decoded->opt_index == OPT_SPECIAL_unknown)
3916 /* Give it a chance to define it a spec file. */
3917 save_switch (decoded->canonical_option[0],
3918 decoded->canonical_option_num_elements - 1,
3919 &decoded->canonical_option[1], false, false);
3920 return false;
3922 else
3923 return true;
3926 /* Handle an option DECODED that is not marked as CL_DRIVER.
3927 LANG_MASK will always be CL_DRIVER. */
3929 static void
3930 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3931 unsigned int lang_mask ATTRIBUTE_UNUSED)
3933 /* At this point, non-driver options are accepted (and expected to
3934 be passed down by specs) unless marked to be rejected by the
3935 driver. Options to be rejected by the driver but accepted by the
3936 compilers proper are treated just like completely unknown
3937 options. */
3938 const struct cl_option *option = &cl_options[decoded->opt_index];
3940 if (option->cl_reject_driver)
3941 error ("unrecognized command-line option %qs",
3942 decoded->orig_option_with_args_text);
3943 else
3944 save_switch (decoded->canonical_option[0],
3945 decoded->canonical_option_num_elements - 1,
3946 &decoded->canonical_option[1], false, true);
3949 static const char *spec_lang = 0;
3950 static int last_language_n_infiles;
3953 /* Check that GCC is configured to support the offload target. */
3955 static bool
3956 check_offload_target_name (const char *target, ptrdiff_t len)
3958 const char *n, *c = OFFLOAD_TARGETS;
3959 while (c)
3961 n = strchr (c, ',');
3962 if (n == NULL)
3963 n = strchr (c, '\0');
3964 if (len == n - c && strncmp (target, c, n - c) == 0)
3965 break;
3966 c = *n ? n + 1 : NULL;
3968 if (!c)
3970 auto_vec<const char*> candidates;
3971 size_t olen = strlen (OFFLOAD_TARGETS) + 1;
3972 char *cand = XALLOCAVEC (char, olen);
3973 memcpy (cand, OFFLOAD_TARGETS, olen);
3974 for (c = strtok (cand, ","); c; c = strtok (NULL, ","))
3975 candidates.safe_push (c);
3976 candidates.safe_push ("default");
3977 candidates.safe_push ("disable");
3979 char *target2 = XALLOCAVEC (char, len + 1);
3980 memcpy (target2, target, len);
3981 target2[len] = '\0';
3983 error ("GCC is not configured to support %qs as %<-foffload=%> argument",
3984 target2);
3986 char *s;
3987 const char *hint = candidates_list_and_hint (target2, s, candidates);
3988 if (hint)
3989 inform (UNKNOWN_LOCATION,
3990 "valid %<-foffload=%> arguments are: %s; "
3991 "did you mean %qs?", s, hint);
3992 else
3993 inform (UNKNOWN_LOCATION, "valid %<-foffload=%> arguments are: %s", s);
3994 XDELETEVEC (s);
3995 return false;
3997 return true;
4000 /* Sanity check for -foffload-options. */
4002 static void
4003 check_foffload_target_names (const char *arg)
4005 const char *cur, *next, *end;
4006 /* If option argument starts with '-' then no target is specified and we
4007 do not need to parse it. */
4008 if (arg[0] == '-')
4009 return;
4010 end = strchr (arg, '=');
4011 if (end == NULL)
4013 error ("%<=%>options missing after %<-foffload-options=%>target");
4014 return;
4017 cur = arg;
4018 while (cur < end)
4020 next = strchr (cur, ',');
4021 if (next == NULL)
4022 next = end;
4023 next = (next > end) ? end : next;
4025 /* Retain non-supported targets after printing an error as those will not
4026 be processed; each enabled target only processes its triplet. */
4027 check_offload_target_name (cur, next - cur);
4028 cur = next + 1;
4032 /* Parse -foffload option argument. */
4034 static void
4035 handle_foffload_option (const char *arg)
4037 const char *c, *cur, *n, *next, *end;
4038 char *target;
4040 /* If option argument starts with '-' then no target is specified and we
4041 do not need to parse it. */
4042 if (arg[0] == '-')
4043 return;
4045 end = strchr (arg, '=');
4046 if (end == NULL)
4047 end = strchr (arg, '\0');
4048 cur = arg;
4050 while (cur < end)
4052 next = strchr (cur, ',');
4053 if (next == NULL)
4054 next = end;
4055 next = (next > end) ? end : next;
4057 target = XNEWVEC (char, next - cur + 1);
4058 memcpy (target, cur, next - cur);
4059 target[next - cur] = '\0';
4061 /* Reset offloading list and continue. */
4062 if (strcmp (target, "default") == 0)
4064 free (offload_targets);
4065 offload_targets = NULL;
4066 goto next_item;
4069 /* If 'disable' is passed to the option, clean the list of
4070 offload targets and return, even if more targets follow.
4071 Likewise if GCC is not configured to support that offload target. */
4072 if (strcmp (target, "disable") == 0
4073 || !check_offload_target_name (target, next - cur))
4075 free (offload_targets);
4076 offload_targets = xstrdup ("");
4077 return;
4080 if (!offload_targets)
4082 offload_targets = target;
4083 target = NULL;
4085 else
4087 /* Check that the target hasn't already presented in the list. */
4088 c = offload_targets;
4091 n = strchr (c, ':');
4092 if (n == NULL)
4093 n = strchr (c, '\0');
4095 if (next - cur == n - c && strncmp (c, target, n - c) == 0)
4096 break;
4098 c = n + 1;
4100 while (*n);
4102 /* If duplicate is not found, append the target to the list. */
4103 if (c > n)
4105 size_t offload_targets_len = strlen (offload_targets);
4106 offload_targets
4107 = XRESIZEVEC (char, offload_targets,
4108 offload_targets_len + 1 + next - cur + 1);
4109 offload_targets[offload_targets_len++] = ':';
4110 memcpy (offload_targets + offload_targets_len, target, next - cur + 1);
4113 next_item:
4114 cur = next + 1;
4115 XDELETEVEC (target);
4119 /* Handle a driver option; arguments and return value as for
4120 handle_option. */
4122 static bool
4123 driver_handle_option (struct gcc_options *opts,
4124 struct gcc_options *opts_set,
4125 const struct cl_decoded_option *decoded,
4126 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
4127 location_t loc,
4128 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
4129 diagnostic_context *dc,
4130 void (*) (void))
4132 size_t opt_index = decoded->opt_index;
4133 const char *arg = decoded->arg;
4134 const char *compare_debug_replacement_opt;
4135 int value = decoded->value;
4136 bool validated = false;
4137 bool do_save = true;
4139 gcc_assert (opts == &global_options);
4140 gcc_assert (opts_set == &global_options_set);
4141 gcc_assert (kind == DK_UNSPECIFIED);
4142 gcc_assert (loc == UNKNOWN_LOCATION);
4143 gcc_assert (dc == global_dc);
4145 switch (opt_index)
4147 case OPT_dumpspecs:
4149 struct spec_list *sl;
4150 init_spec ();
4151 for (sl = specs; sl; sl = sl->next)
4152 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
4153 if (link_command_spec)
4154 printf ("*link_command:\n%s\n\n", link_command_spec);
4155 exit (0);
4158 case OPT_dumpversion:
4159 printf ("%s\n", spec_version);
4160 exit (0);
4162 case OPT_dumpmachine:
4163 printf ("%s\n", spec_machine);
4164 exit (0);
4166 case OPT_dumpfullversion:
4167 printf ("%s\n", BASEVER);
4168 exit (0);
4170 case OPT__version:
4171 print_version = 1;
4173 /* CPP driver cannot obtain switch from cc1_options. */
4174 if (is_cpp_driver)
4175 add_preprocessor_option ("--version", strlen ("--version"));
4176 add_assembler_option ("--version", strlen ("--version"));
4177 add_linker_option ("--version", strlen ("--version"));
4178 break;
4180 case OPT__completion_:
4181 validated = true;
4182 completion = decoded->arg;
4183 break;
4185 case OPT__help:
4186 print_help_list = 1;
4188 /* CPP driver cannot obtain switch from cc1_options. */
4189 if (is_cpp_driver)
4190 add_preprocessor_option ("--help", 6);
4191 add_assembler_option ("--help", 6);
4192 add_linker_option ("--help", 6);
4193 break;
4195 case OPT__help_:
4196 print_subprocess_help = 2;
4197 break;
4199 case OPT__target_help:
4200 print_subprocess_help = 1;
4202 /* CPP driver cannot obtain switch from cc1_options. */
4203 if (is_cpp_driver)
4204 add_preprocessor_option ("--target-help", 13);
4205 add_assembler_option ("--target-help", 13);
4206 add_linker_option ("--target-help", 13);
4207 break;
4209 case OPT__no_sysroot_suffix:
4210 case OPT_pass_exit_codes:
4211 case OPT_print_search_dirs:
4212 case OPT_print_file_name_:
4213 case OPT_print_prog_name_:
4214 case OPT_print_multi_lib:
4215 case OPT_print_multi_directory:
4216 case OPT_print_sysroot:
4217 case OPT_print_multi_os_directory:
4218 case OPT_print_multiarch:
4219 case OPT_print_sysroot_headers_suffix:
4220 case OPT_time:
4221 case OPT_wrapper:
4222 /* These options set the variables specified in common.opt
4223 automatically, and do not need to be saved for spec
4224 processing. */
4225 do_save = false;
4226 break;
4228 case OPT_print_libgcc_file_name:
4229 print_file_name = "libgcc.a";
4230 do_save = false;
4231 break;
4233 case OPT_fuse_ld_bfd:
4234 use_ld = ".bfd";
4235 break;
4237 case OPT_fuse_ld_gold:
4238 use_ld = ".gold";
4239 break;
4241 case OPT_fuse_ld_mold:
4242 use_ld = ".mold";
4243 break;
4245 case OPT_fcompare_debug_second:
4246 compare_debug_second = 1;
4247 break;
4249 case OPT_fcompare_debug:
4250 switch (value)
4252 case 0:
4253 compare_debug_replacement_opt = "-fcompare-debug=";
4254 arg = "";
4255 goto compare_debug_with_arg;
4257 case 1:
4258 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
4259 arg = "-gtoggle";
4260 goto compare_debug_with_arg;
4262 default:
4263 gcc_unreachable ();
4265 break;
4267 case OPT_fcompare_debug_:
4268 compare_debug_replacement_opt = decoded->canonical_option[0];
4269 compare_debug_with_arg:
4270 gcc_assert (decoded->canonical_option_num_elements == 1);
4271 gcc_assert (arg != NULL);
4272 if (*arg)
4273 compare_debug = 1;
4274 else
4275 compare_debug = -1;
4276 if (compare_debug < 0)
4277 compare_debug_opt = NULL;
4278 else
4279 compare_debug_opt = arg;
4280 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
4281 set_source_date_epoch_envvar ();
4282 return true;
4284 case OPT_fdiagnostics_color_:
4285 diagnostic_color_init (dc, value);
4286 break;
4288 case OPT_fdiagnostics_urls_:
4289 diagnostic_urls_init (dc, value);
4290 break;
4292 case OPT_fdiagnostics_format_:
4293 diagnostic_output_format_init (dc, opts->x_dump_base_name,
4294 (enum diagnostics_output_format)value);
4295 break;
4297 case OPT_Wa_:
4299 int prev, j;
4300 /* Pass the rest of this option to the assembler. */
4302 /* Split the argument at commas. */
4303 prev = 0;
4304 for (j = 0; arg[j]; j++)
4305 if (arg[j] == ',')
4307 add_assembler_option (arg + prev, j - prev);
4308 prev = j + 1;
4311 /* Record the part after the last comma. */
4312 add_assembler_option (arg + prev, j - prev);
4314 do_save = false;
4315 break;
4317 case OPT_Wp_:
4319 int prev, j;
4320 /* Pass the rest of this option to the preprocessor. */
4322 /* Split the argument at commas. */
4323 prev = 0;
4324 for (j = 0; arg[j]; j++)
4325 if (arg[j] == ',')
4327 add_preprocessor_option (arg + prev, j - prev);
4328 prev = j + 1;
4331 /* Record the part after the last comma. */
4332 add_preprocessor_option (arg + prev, j - prev);
4334 do_save = false;
4335 break;
4337 case OPT_Wl_:
4339 int prev, j;
4340 /* Split the argument at commas. */
4341 prev = 0;
4342 for (j = 0; arg[j]; j++)
4343 if (arg[j] == ',')
4345 add_infile (save_string (arg + prev, j - prev), "*");
4346 prev = j + 1;
4348 /* Record the part after the last comma. */
4349 add_infile (arg + prev, "*");
4351 do_save = false;
4352 break;
4354 case OPT_Xlinker:
4355 add_infile (arg, "*");
4356 do_save = false;
4357 break;
4359 case OPT_Xpreprocessor:
4360 add_preprocessor_option (arg, strlen (arg));
4361 do_save = false;
4362 break;
4364 case OPT_Xassembler:
4365 add_assembler_option (arg, strlen (arg));
4366 do_save = false;
4367 break;
4369 case OPT_l:
4370 /* POSIX allows separation of -l and the lib arg; canonicalize
4371 by concatenating -l with its arg */
4372 add_infile (concat ("-l", arg, NULL), "*");
4373 do_save = false;
4374 break;
4376 case OPT_L:
4377 /* Similarly, canonicalize -L for linkers that may not accept
4378 separate arguments. */
4379 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
4380 return true;
4382 case OPT_F:
4383 /* Likewise -F. */
4384 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
4385 return true;
4387 case OPT_save_temps:
4388 if (!save_temps_flag)
4389 save_temps_flag = SAVE_TEMPS_DUMP;
4390 validated = true;
4391 break;
4393 case OPT_save_temps_:
4394 if (strcmp (arg, "cwd") == 0)
4395 save_temps_flag = SAVE_TEMPS_CWD;
4396 else if (strcmp (arg, "obj") == 0
4397 || strcmp (arg, "object") == 0)
4398 save_temps_flag = SAVE_TEMPS_OBJ;
4399 else
4400 fatal_error (input_location, "%qs is an unknown %<-save-temps%> option",
4401 decoded->orig_option_with_args_text);
4402 save_temps_overrides_dumpdir = true;
4403 break;
4405 case OPT_dumpdir:
4406 free (dumpdir);
4407 dumpdir = xstrdup (arg);
4408 save_temps_overrides_dumpdir = false;
4409 break;
4411 case OPT_dumpbase:
4412 free (dumpbase);
4413 dumpbase = xstrdup (arg);
4414 break;
4416 case OPT_dumpbase_ext:
4417 free (dumpbase_ext);
4418 dumpbase_ext = xstrdup (arg);
4419 break;
4421 case OPT_no_canonical_prefixes:
4422 /* Already handled as a special case, so ignored here. */
4423 do_save = false;
4424 break;
4426 case OPT_pipe:
4427 validated = true;
4428 /* These options set the variables specified in common.opt
4429 automatically, but do need to be saved for spec
4430 processing. */
4431 break;
4433 case OPT_specs_:
4435 struct user_specs *user = XNEW (struct user_specs);
4437 user->next = (struct user_specs *) 0;
4438 user->filename = arg;
4439 if (user_specs_tail)
4440 user_specs_tail->next = user;
4441 else
4442 user_specs_head = user;
4443 user_specs_tail = user;
4445 validated = true;
4446 break;
4448 case OPT__sysroot_:
4449 target_system_root = arg;
4450 target_system_root_changed = 1;
4451 /* Saving this option is useful to let self-specs decide to
4452 provide a default one. */
4453 do_save = true;
4454 validated = true;
4455 break;
4457 case OPT_time_:
4458 if (report_times_to_file)
4459 fclose (report_times_to_file);
4460 report_times_to_file = fopen (arg, "a");
4461 do_save = false;
4462 break;
4464 case OPT____:
4465 /* "-###"
4466 This is similar to -v except that there is no execution
4467 of the commands and the echoed arguments are quoted. It
4468 is intended for use in shell scripts to capture the
4469 driver-generated command line. */
4470 verbose_only_flag++;
4471 verbose_flag = 1;
4472 do_save = false;
4473 break;
4475 case OPT_B:
4477 size_t len = strlen (arg);
4479 /* Catch the case where the user has forgotten to append a
4480 directory separator to the path. Note, they may be using
4481 -B to add an executable name prefix, eg "i386-elf-", in
4482 order to distinguish between multiple installations of
4483 GCC in the same directory. Hence we must check to see
4484 if appending a directory separator actually makes a
4485 valid directory name. */
4486 if (!IS_DIR_SEPARATOR (arg[len - 1])
4487 && is_directory (arg, false))
4489 char *tmp = XNEWVEC (char, len + 2);
4490 strcpy (tmp, arg);
4491 tmp[len] = DIR_SEPARATOR;
4492 tmp[++len] = 0;
4493 arg = tmp;
4496 add_prefix (&exec_prefixes, arg, NULL,
4497 PREFIX_PRIORITY_B_OPT, 0, 0);
4498 add_prefix (&startfile_prefixes, arg, NULL,
4499 PREFIX_PRIORITY_B_OPT, 0, 0);
4500 add_prefix (&include_prefixes, arg, NULL,
4501 PREFIX_PRIORITY_B_OPT, 0, 0);
4503 validated = true;
4504 break;
4506 case OPT_E:
4507 have_E = true;
4508 break;
4510 case OPT_x:
4511 spec_lang = arg;
4512 if (!strcmp (spec_lang, "none"))
4513 /* Suppress the warning if -xnone comes after the last input
4514 file, because alternate command interfaces like g++ might
4515 find it useful to place -xnone after each input file. */
4516 spec_lang = 0;
4517 else
4518 last_language_n_infiles = n_infiles;
4519 do_save = false;
4520 break;
4522 case OPT_o:
4523 have_o = 1;
4524 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
4525 arg = convert_filename (arg, ! have_c, 0);
4526 #endif
4527 output_file = arg;
4528 /* On some systems, ld cannot handle "-o" without a space. So
4529 split the option from its argument. */
4530 save_switch ("-o", 1, &arg, validated, true);
4531 return true;
4533 #ifdef ENABLE_DEFAULT_PIE
4534 case OPT_pie:
4535 /* -pie is turned on by default. */
4536 #endif
4538 case OPT_static_libgcc:
4539 case OPT_shared_libgcc:
4540 case OPT_static_libgfortran:
4541 case OPT_static_libquadmath:
4542 case OPT_static_libphobos:
4543 case OPT_static_libstdc__:
4544 /* These are always valid, since gcc.cc itself understands the
4545 first two, gfortranspec.cc understands -static-libgfortran,
4546 d-spec.cc understands -static-libphobos, g++spec.cc
4547 understands -static-libstdc++ and libgfortran.spec handles
4548 -static-libquadmath. */
4549 validated = true;
4550 break;
4552 case OPT_fwpa:
4553 flag_wpa = "";
4554 break;
4556 case OPT_foffload_options_:
4557 check_foffload_target_names (arg);
4558 break;
4560 case OPT_foffload_:
4561 handle_foffload_option (arg);
4562 if (arg[0] == '-' || NULL != strchr (arg, '='))
4563 save_switch (concat ("-foffload-options=", arg, NULL),
4564 0, NULL, validated, true);
4565 do_save = false;
4566 break;
4568 default:
4569 /* Various driver options need no special processing at this
4570 point, having been handled in a prescan above or being
4571 handled by specs. */
4572 break;
4575 if (do_save)
4576 save_switch (decoded->canonical_option[0],
4577 decoded->canonical_option_num_elements - 1,
4578 &decoded->canonical_option[1], validated, true);
4579 return true;
4582 /* Return true if F2 is F1 followed by a single suffix, i.e., by a
4583 period and additional characters other than a period. */
4585 static inline bool
4586 adds_single_suffix_p (const char *f2, const char *f1)
4588 size_t len = strlen (f1);
4590 return (strncmp (f1, f2, len) == 0
4591 && f2[len] == '.'
4592 && strchr (f2 + len + 1, '.') == NULL);
4595 /* Put the driver's standard set of option handlers in *HANDLERS. */
4597 static void
4598 set_option_handlers (struct cl_option_handlers *handlers)
4600 handlers->unknown_option_callback = driver_unknown_option_callback;
4601 handlers->wrong_lang_callback = driver_wrong_lang_callback;
4602 handlers->num_handlers = 3;
4603 handlers->handlers[0].handler = driver_handle_option;
4604 handlers->handlers[0].mask = CL_DRIVER;
4605 handlers->handlers[1].handler = common_handle_option;
4606 handlers->handlers[1].mask = CL_COMMON;
4607 handlers->handlers[2].handler = target_handle_option;
4608 handlers->handlers[2].mask = CL_TARGET;
4612 /* Return the index into infiles for the single non-library
4613 non-lto-wpa input file, -1 if there isn't any, or -2 if there is
4614 more than one. */
4615 static inline int
4616 single_input_file_index ()
4618 int ret = -1;
4620 for (int i = 0; i < n_infiles; i++)
4622 if (infiles[i].language
4623 && (infiles[i].language[0] == '*'
4624 || (flag_wpa
4625 && strcmp (infiles[i].language, "lto") == 0)))
4626 continue;
4628 if (ret != -1)
4629 return -2;
4631 ret = i;
4634 return ret;
4637 /* Create the vector `switches' and its contents.
4638 Store its length in `n_switches'. */
4640 static void
4641 process_command (unsigned int decoded_options_count,
4642 struct cl_decoded_option *decoded_options)
4644 const char *temp;
4645 char *temp1;
4646 char *tooldir_prefix, *tooldir_prefix2;
4647 char *(*get_relative_prefix) (const char *, const char *,
4648 const char *) = NULL;
4649 struct cl_option_handlers handlers;
4650 unsigned int j;
4652 gcc_exec_prefix = env.get ("GCC_EXEC_PREFIX");
4654 n_switches = 0;
4655 n_infiles = 0;
4656 added_libraries = 0;
4658 /* Figure compiler version from version string. */
4660 compiler_version = temp1 = xstrdup (version_string);
4662 for (; *temp1; ++temp1)
4664 if (*temp1 == ' ')
4666 *temp1 = '\0';
4667 break;
4671 /* Handle any -no-canonical-prefixes flag early, to assign the function
4672 that builds relative prefixes. This function creates default search
4673 paths that are needed later in normal option handling. */
4675 for (j = 1; j < decoded_options_count; j++)
4677 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
4679 get_relative_prefix = make_relative_prefix_ignore_links;
4680 break;
4683 if (! get_relative_prefix)
4684 get_relative_prefix = make_relative_prefix;
4686 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
4687 see if we can create it from the pathname specified in
4688 decoded_options[0].arg. */
4690 gcc_libexec_prefix = standard_libexec_prefix;
4691 #ifndef VMS
4692 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
4693 if (!gcc_exec_prefix)
4695 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
4696 standard_bindir_prefix,
4697 standard_exec_prefix);
4698 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
4699 standard_bindir_prefix,
4700 standard_libexec_prefix);
4701 if (gcc_exec_prefix)
4702 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
4704 else
4706 /* make_relative_prefix requires a program name, but
4707 GCC_EXEC_PREFIX is typically a directory name with a trailing
4708 / (which is ignored by make_relative_prefix), so append a
4709 program name. */
4710 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
4711 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
4712 standard_exec_prefix,
4713 standard_libexec_prefix);
4715 /* The path is unrelocated, so fallback to the original setting. */
4716 if (!gcc_libexec_prefix)
4717 gcc_libexec_prefix = standard_libexec_prefix;
4719 free (tmp_prefix);
4721 #else
4722 #endif
4723 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
4724 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
4725 or an automatically created GCC_EXEC_PREFIX from
4726 decoded_options[0].arg. */
4728 /* Do language-specific adjustment/addition of flags. */
4729 lang_specific_driver (&decoded_options, &decoded_options_count,
4730 &added_libraries);
4732 if (gcc_exec_prefix)
4734 int len = strlen (gcc_exec_prefix);
4736 if (len > (int) sizeof ("/lib/gcc/") - 1
4737 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
4739 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
4740 if (IS_DIR_SEPARATOR (*temp)
4741 && filename_ncmp (temp + 1, "lib", 3) == 0
4742 && IS_DIR_SEPARATOR (temp[4])
4743 && filename_ncmp (temp + 5, "gcc", 3) == 0)
4744 len -= sizeof ("/lib/gcc/") - 1;
4747 set_std_prefix (gcc_exec_prefix, len);
4748 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
4749 PREFIX_PRIORITY_LAST, 0, 0);
4750 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
4751 PREFIX_PRIORITY_LAST, 0, 0);
4754 /* COMPILER_PATH and LIBRARY_PATH have values
4755 that are lists of directory names with colons. */
4757 temp = env.get ("COMPILER_PATH");
4758 if (temp)
4760 const char *startp, *endp;
4761 char *nstore = (char *) alloca (strlen (temp) + 3);
4763 startp = endp = temp;
4764 while (1)
4766 if (*endp == PATH_SEPARATOR || *endp == 0)
4768 strncpy (nstore, startp, endp - startp);
4769 if (endp == startp)
4770 strcpy (nstore, concat (".", dir_separator_str, NULL));
4771 else if (!IS_DIR_SEPARATOR (endp[-1]))
4773 nstore[endp - startp] = DIR_SEPARATOR;
4774 nstore[endp - startp + 1] = 0;
4776 else
4777 nstore[endp - startp] = 0;
4778 add_prefix (&exec_prefixes, nstore, 0,
4779 PREFIX_PRIORITY_LAST, 0, 0);
4780 add_prefix (&include_prefixes, nstore, 0,
4781 PREFIX_PRIORITY_LAST, 0, 0);
4782 if (*endp == 0)
4783 break;
4784 endp = startp = endp + 1;
4786 else
4787 endp++;
4791 temp = env.get (LIBRARY_PATH_ENV);
4792 if (temp && *cross_compile == '0')
4794 const char *startp, *endp;
4795 char *nstore = (char *) alloca (strlen (temp) + 3);
4797 startp = endp = temp;
4798 while (1)
4800 if (*endp == PATH_SEPARATOR || *endp == 0)
4802 strncpy (nstore, startp, endp - startp);
4803 if (endp == startp)
4804 strcpy (nstore, concat (".", dir_separator_str, NULL));
4805 else if (!IS_DIR_SEPARATOR (endp[-1]))
4807 nstore[endp - startp] = DIR_SEPARATOR;
4808 nstore[endp - startp + 1] = 0;
4810 else
4811 nstore[endp - startp] = 0;
4812 add_prefix (&startfile_prefixes, nstore, NULL,
4813 PREFIX_PRIORITY_LAST, 0, 1);
4814 if (*endp == 0)
4815 break;
4816 endp = startp = endp + 1;
4818 else
4819 endp++;
4823 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
4824 temp = env.get ("LPATH");
4825 if (temp && *cross_compile == '0')
4827 const char *startp, *endp;
4828 char *nstore = (char *) alloca (strlen (temp) + 3);
4830 startp = endp = temp;
4831 while (1)
4833 if (*endp == PATH_SEPARATOR || *endp == 0)
4835 strncpy (nstore, startp, endp - startp);
4836 if (endp == startp)
4837 strcpy (nstore, concat (".", dir_separator_str, NULL));
4838 else if (!IS_DIR_SEPARATOR (endp[-1]))
4840 nstore[endp - startp] = DIR_SEPARATOR;
4841 nstore[endp - startp + 1] = 0;
4843 else
4844 nstore[endp - startp] = 0;
4845 add_prefix (&startfile_prefixes, nstore, NULL,
4846 PREFIX_PRIORITY_LAST, 0, 1);
4847 if (*endp == 0)
4848 break;
4849 endp = startp = endp + 1;
4851 else
4852 endp++;
4856 /* Process the options and store input files and switches in their
4857 vectors. */
4859 last_language_n_infiles = -1;
4861 set_option_handlers (&handlers);
4863 for (j = 1; j < decoded_options_count; j++)
4865 switch (decoded_options[j].opt_index)
4867 case OPT_S:
4868 case OPT_c:
4869 case OPT_E:
4870 have_c = 1;
4871 break;
4873 if (have_c)
4874 break;
4877 for (j = 1; j < decoded_options_count; j++)
4879 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
4881 const char *arg = decoded_options[j].arg;
4883 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4884 arg = convert_filename (arg, 0, access (arg, F_OK));
4885 #endif
4886 add_infile (arg, spec_lang);
4888 continue;
4891 read_cmdline_option (&global_options, &global_options_set,
4892 decoded_options + j, UNKNOWN_LOCATION,
4893 CL_DRIVER, &handlers, global_dc);
4896 /* If the user didn't specify any, default to all configured offload
4897 targets. */
4898 if (ENABLE_OFFLOADING && offload_targets == NULL)
4900 handle_foffload_option (OFFLOAD_TARGETS);
4901 #if OFFLOAD_DEFAULTED
4902 offload_targets_default = true;
4903 #endif
4906 /* Handle -gtoggle as it would later in toplev.cc:process_options to
4907 make the debug-level-gt spec function work as expected. */
4908 if (flag_gtoggle)
4910 if (debug_info_level == DINFO_LEVEL_NONE)
4911 debug_info_level = DINFO_LEVEL_NORMAL;
4912 else
4913 debug_info_level = DINFO_LEVEL_NONE;
4916 if (output_file
4917 && strcmp (output_file, "-") != 0
4918 && strcmp (output_file, HOST_BIT_BUCKET) != 0)
4920 int i;
4921 for (i = 0; i < n_infiles; i++)
4922 if ((!infiles[i].language || infiles[i].language[0] != '*')
4923 && canonical_filename_eq (infiles[i].name, output_file))
4924 fatal_error (input_location,
4925 "input file %qs is the same as output file",
4926 output_file);
4929 if (output_file != NULL && output_file[0] == '\0')
4930 fatal_error (input_location, "output filename may not be empty");
4932 /* -dumpdir and -save-temps=* both specify the location of aux/dump
4933 outputs; the one that appears last prevails. When compiling
4934 multiple sources, an explicit dumpbase (minus -ext) may be
4935 combined with an explicit or implicit dumpdir, whereas when
4936 linking, a specified or implied link output name (minus
4937 extension) may be combined with a prevailing -save-temps=* or an
4938 otherwise implied dumpdir, but not override a prevailing
4939 -dumpdir. Primary outputs (e.g., linker output when linking
4940 without -o, or .i, .s or .o outputs when processing multiple
4941 inputs with -E, -S or -c, respectively) are NOT affected by these
4942 -save-temps=/-dump* options, always landing in the current
4943 directory and with the same basename as the input when an output
4944 name is not given, but when they're intermediate outputs, they
4945 are named like other aux outputs, so the options affect their
4946 location and name.
4948 Here are some examples. There are several more in the
4949 documentation of -o and -dump*, and some quite exhaustive tests
4950 in gcc.misc-tests/outputs.exp.
4952 When compiling any number of sources, no -dump* nor
4953 -save-temps=*, all outputs in cwd without prefix:
4955 # gcc -c b.c -gsplit-dwarf
4956 -> cc1 [-dumpdir ./] -dumpbase b.c -dumpbase-ext .c # b.o b.dwo
4958 # gcc -c b.c d.c -gsplit-dwarf
4959 -> cc1 [-dumpdir ./] -dumpbase b.c -dumpbase-ext .c # b.o b.dwo
4960 && cc1 [-dumpdir ./] -dumpbase d.c -dumpbase-ext .c # d.o d.dwo
4962 When compiling and linking, no -dump* nor -save-temps=*, .o
4963 outputs are temporary, aux outputs land in the dir of the output,
4964 prefixed with the basename of the linker output:
4966 # gcc b.c d.c -o ab -gsplit-dwarf
4967 -> cc1 -dumpdir ab- -dumpbase b.c -dumpbase-ext .c # ab-b.dwo
4968 && cc1 -dumpdir ab- -dumpbase d.c -dumpbase-ext .c # ab-d.dwo
4969 && link ... -o ab
4971 # gcc b.c d.c [-o a.out] -gsplit-dwarf
4972 -> cc1 -dumpdir a- -dumpbase b.c -dumpbase-ext .c # a-b.dwo
4973 && cc1 -dumpdir a- -dumpbase d.c -dumpbase-ext .c # a-d.dwo
4974 && link ... [-o a.out]
4976 When compiling and linking, a prevailing -dumpdir fully overrides
4977 the prefix of aux outputs given by the output name:
4979 # gcc -dumpdir f b.c d.c -gsplit-dwarf [-o [dir/]whatever]
4980 -> cc1 -dumpdir f -dumpbase b.c -dumpbase-ext .c # fb.dwo
4981 && cc1 -dumpdir f -dumpbase d.c -dumpbase-ext .c # fd.dwo
4982 && link ... [-o whatever]
4984 When compiling multiple inputs, an explicit -dumpbase is combined
4985 with -dumpdir, affecting aux outputs, but not the .o outputs:
4987 # gcc -dumpdir f -dumpbase g- b.c d.c -gsplit-dwarf -c
4988 -> cc1 -dumpdir fg- -dumpbase b.c -dumpbase-ext .c # b.o fg-b.dwo
4989 && cc1 -dumpdir fg- -dumpbase d.c -dumpbase-ext .c # d.o fg-d.dwo
4991 When compiling and linking with -save-temps, the .o outputs that
4992 would have been temporary become aux outputs, so they get
4993 affected by -dump* flags:
4995 # gcc -dumpdir f -dumpbase g- -save-temps b.c d.c
4996 -> cc1 -dumpdir fg- -dumpbase b.c -dumpbase-ext .c # fg-b.o
4997 && cc1 -dumpdir fg- -dumpbase d.c -dumpbase-ext .c # fg-d.o
4998 && link
5000 If -save-temps=* prevails over -dumpdir, however, the explicit
5001 -dumpdir is discarded, as if it wasn't there. The basename of
5002 the implicit linker output, a.out or a.exe, becomes a- as the aux
5003 output prefix for all compilations:
5005 # gcc [-dumpdir f] -save-temps=cwd b.c d.c
5006 -> cc1 -dumpdir a- -dumpbase b.c -dumpbase-ext .c # a-b.o
5007 && cc1 -dumpdir a- -dumpbase d.c -dumpbase-ext .c # a-d.o
5008 && link
5010 A single -dumpbase, applying to multiple inputs, overrides the
5011 linker output name, implied or explicit, as the aux output prefix:
5013 # gcc [-dumpdir f] -dumpbase g- -save-temps=cwd b.c d.c
5014 -> cc1 -dumpdir g- -dumpbase b.c -dumpbase-ext .c # g-b.o
5015 && cc1 -dumpdir g- -dumpbase d.c -dumpbase-ext .c # g-d.o
5016 && link
5018 # gcc [-dumpdir f] -dumpbase g- -save-temps=cwd b.c d.c -o dir/h.out
5019 -> cc1 -dumpdir g- -dumpbase b.c -dumpbase-ext .c # g-b.o
5020 && cc1 -dumpdir g- -dumpbase d.c -dumpbase-ext .c # g-d.o
5021 && link -o dir/h.out
5023 Now, if the linker output is NOT overridden as a prefix, but
5024 -save-temps=* overrides implicit or explicit -dumpdir, the
5025 effective dump dir combines the dir selected by the -save-temps=*
5026 option with the basename of the specified or implied link output:
5028 # gcc [-dumpdir f] -save-temps=cwd b.c d.c -o dir/h.out
5029 -> cc1 -dumpdir h- -dumpbase b.c -dumpbase-ext .c # h-b.o
5030 && cc1 -dumpdir h- -dumpbase d.c -dumpbase-ext .c # h-d.o
5031 && link -o dir/h.out
5033 # gcc [-dumpdir f] -save-temps=obj b.c d.c -o dir/h.out
5034 -> cc1 -dumpdir dir/h- -dumpbase b.c -dumpbase-ext .c # dir/h-b.o
5035 && cc1 -dumpdir dir/h- -dumpbase d.c -dumpbase-ext .c # dir/h-d.o
5036 && link -o dir/h.out
5038 But then again, a single -dumpbase applying to multiple inputs
5039 gets used instead of the linker output basename in the combined
5040 dumpdir:
5042 # gcc [-dumpdir f] -dumpbase g- -save-temps=obj b.c d.c -o dir/h.out
5043 -> cc1 -dumpdir dir/g- -dumpbase b.c -dumpbase-ext .c # dir/g-b.o
5044 && cc1 -dumpdir dir/g- -dumpbase d.c -dumpbase-ext .c # dir/g-d.o
5045 && link -o dir/h.out
5047 With a single input being compiled, the output basename does NOT
5048 affect the dumpdir prefix.
5050 # gcc -save-temps=obj b.c -gsplit-dwarf -c -o dir/b.o
5051 -> cc1 -dumpdir dir/ -dumpbase b.c -dumpbase-ext .c # dir/b.o dir/b.dwo
5053 but when compiling and linking even a single file, it does:
5055 # gcc -save-temps=obj b.c -o dir/h.out
5056 -> cc1 -dumpdir dir/h- -dumpbase b.c -dumpbase-ext .c # dir/h-b.o
5058 unless an explicit -dumpdir prevails:
5060 # gcc -save-temps[=obj] -dumpdir g- b.c -o dir/h.out
5061 -> cc1 -dumpdir g- -dumpbase b.c -dumpbase-ext .c # g-b.o
5065 bool explicit_dumpdir = dumpdir;
5067 if ((!save_temps_overrides_dumpdir && explicit_dumpdir)
5068 || (output_file && not_actual_file_p (output_file)))
5070 /* Do nothing. */
5073 /* If -save-temps=obj and -o name, create the prefix to use for %b.
5074 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
5075 else if (save_temps_flag != SAVE_TEMPS_CWD && output_file != NULL)
5077 free (dumpdir);
5078 dumpdir = NULL;
5079 temp = lbasename (output_file);
5080 if (temp != output_file)
5081 dumpdir = xstrndup (output_file,
5082 strlen (output_file) - strlen (temp));
5084 else if (dumpdir)
5086 free (dumpdir);
5087 dumpdir = NULL;
5090 if (save_temps_flag)
5091 save_temps_flag = SAVE_TEMPS_DUMP;
5093 /* If there is any pathname component in an explicit -dumpbase, it
5094 overrides dumpdir entirely, so discard it right away. Although
5095 the presence of an explicit -dumpdir matters for the driver, it
5096 shouldn't matter for other processes, that get all that's needed
5097 from the -dumpdir and -dumpbase always passed to them. */
5098 if (dumpdir && dumpbase && lbasename (dumpbase) != dumpbase)
5100 free (dumpdir);
5101 dumpdir = NULL;
5104 /* Check that dumpbase_ext matches the end of dumpbase, drop it
5105 otherwise. */
5106 if (dumpbase_ext && dumpbase && *dumpbase)
5108 int lendb = strlen (dumpbase);
5109 int lendbx = strlen (dumpbase_ext);
5111 /* -dumpbase-ext must be a suffix proper; discard it if it
5112 matches all of -dumpbase, as that would make for an empty
5113 basename. */
5114 if (lendbx >= lendb
5115 || strcmp (dumpbase + lendb - lendbx, dumpbase_ext) != 0)
5117 free (dumpbase_ext);
5118 dumpbase_ext = NULL;
5122 /* -dumpbase with multiple sources goes into dumpdir. With a single
5123 source, it does only if linking and if dumpdir was not explicitly
5124 specified. */
5125 if (dumpbase && *dumpbase
5126 && (single_input_file_index () == -2
5127 || (!have_c && !explicit_dumpdir)))
5129 char *prefix;
5131 if (dumpbase_ext)
5132 /* We checked that they match above. */
5133 dumpbase[strlen (dumpbase) - strlen (dumpbase_ext)] = '\0';
5135 if (dumpdir)
5136 prefix = concat (dumpdir, dumpbase, "-", NULL);
5137 else
5138 prefix = concat (dumpbase, "-", NULL);
5140 free (dumpdir);
5141 free (dumpbase);
5142 free (dumpbase_ext);
5143 dumpbase = dumpbase_ext = NULL;
5144 dumpdir = prefix;
5145 dumpdir_trailing_dash_added = true;
5148 /* If dumpbase was not brought into dumpdir but we're linking, bring
5149 output_file into dumpdir unless dumpdir was explicitly specified.
5150 The test for !explicit_dumpdir is further below, because we want
5151 to use the obase computation for a ghost outbase, passed to
5152 GCC_COLLECT_OPTIONS. */
5153 else if (!have_c && (!explicit_dumpdir || (dumpbase && !*dumpbase)))
5155 /* If we get here, we know dumpbase was not specified, or it was
5156 specified as an empty string. If it was anything else, it
5157 would have combined with dumpdir above, because the condition
5158 for dumpbase to be used when present is broader than the
5159 condition that gets us here. */
5160 gcc_assert (!dumpbase || !*dumpbase);
5162 const char *obase;
5163 char *tofree = NULL;
5164 if (!output_file || not_actual_file_p (output_file))
5165 obase = "a";
5166 else
5168 obase = lbasename (output_file);
5169 size_t blen = strlen (obase), xlen;
5170 /* Drop the suffix if it's dumpbase_ext, if given,
5171 otherwise .exe or the target executable suffix, or if the
5172 output was explicitly named a.out, but not otherwise. */
5173 if (dumpbase_ext
5174 ? (blen > (xlen = strlen (dumpbase_ext))
5175 && strcmp ((temp = (obase + blen - xlen)),
5176 dumpbase_ext) == 0)
5177 : ((temp = strrchr (obase + 1, '.'))
5178 && (xlen = strlen (temp))
5179 && (strcmp (temp, ".exe") == 0
5180 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
5181 || strcmp (temp, TARGET_EXECUTABLE_SUFFIX) == 0
5182 #endif
5183 || strcmp (obase, "a.out") == 0)))
5185 tofree = xstrndup (obase, blen - xlen);
5186 obase = tofree;
5190 /* We wish to save this basename to the -dumpdir passed through
5191 GCC_COLLECT_OPTIONS within maybe_run_linker, for e.g. LTO,
5192 but we do NOT wish to add it to e.g. %b, so we keep
5193 outbase_length as zero. */
5194 gcc_assert (!outbase);
5195 outbase_length = 0;
5197 /* If we're building [dir1/]foo[.exe] out of a single input
5198 [dir2/]foo.c that shares the same basename, dump to
5199 [dir2/]foo.c.* rather than duplicating the basename into
5200 [dir2/]foo-foo.c.*. */
5201 int idxin;
5202 if (dumpbase
5203 || ((idxin = single_input_file_index ()) >= 0
5204 && adds_single_suffix_p (lbasename (infiles[idxin].name),
5205 obase)))
5207 if (obase == tofree)
5208 outbase = tofree;
5209 else
5211 outbase = xstrdup (obase);
5212 free (tofree);
5214 obase = tofree = NULL;
5216 else
5218 if (dumpdir)
5220 char *p = concat (dumpdir, obase, "-", NULL);
5221 free (dumpdir);
5222 dumpdir = p;
5224 else
5225 dumpdir = concat (obase, "-", NULL);
5227 dumpdir_trailing_dash_added = true;
5229 free (tofree);
5230 obase = tofree = NULL;
5233 if (!explicit_dumpdir || dumpbase)
5235 /* Absent -dumpbase and present -dumpbase-ext have been applied
5236 to the linker output name, so compute fresh defaults for each
5237 compilation. */
5238 free (dumpbase_ext);
5239 dumpbase_ext = NULL;
5243 /* Now, if we're compiling, or if we haven't used the dumpbase
5244 above, then outbase (%B) is derived from dumpbase, if given, or
5245 from the output name, given or implied. We can't precompute
5246 implied output names, but that's ok, since they're derived from
5247 input names. Just make sure we skip this if dumpbase is the
5248 empty string: we want to use input names then, so don't set
5249 outbase. */
5250 if ((dumpbase || have_c)
5251 && !(dumpbase && !*dumpbase))
5253 gcc_assert (!outbase);
5255 if (dumpbase)
5257 gcc_assert (single_input_file_index () != -2);
5258 /* We do not want lbasename here; dumpbase with dirnames
5259 overrides dumpdir entirely, even if dumpdir is
5260 specified. */
5261 if (dumpbase_ext)
5262 /* We've already checked above that the suffix matches. */
5263 outbase = xstrndup (dumpbase,
5264 strlen (dumpbase) - strlen (dumpbase_ext));
5265 else
5266 outbase = xstrdup (dumpbase);
5268 else if (output_file && !not_actual_file_p (output_file))
5270 outbase = xstrdup (lbasename (output_file));
5271 char *p = strrchr (outbase + 1, '.');
5272 if (p)
5273 *p = '\0';
5276 if (outbase)
5277 outbase_length = strlen (outbase);
5280 /* If there is any pathname component in an explicit -dumpbase, do
5281 not use dumpdir, but retain it to pass it on to the compiler. */
5282 if (dumpdir)
5283 dumpdir_length = strlen (dumpdir);
5284 else
5285 dumpdir_length = 0;
5287 /* Check that dumpbase_ext, if still present, still matches the end
5288 of dumpbase, if present, and drop it otherwise. We only retained
5289 it above when dumpbase was absent to maybe use it to drop the
5290 extension from output_name before combining it with dumpdir. We
5291 won't deal with -dumpbase-ext when -dumpbase is not explicitly
5292 given, even if just to activate backward-compatible dumpbase:
5293 dropping it on the floor is correct, expected and documented
5294 behavior. Attempting to deal with a -dumpbase-ext that might
5295 match the end of some input filename, or of the combination of
5296 the output basename with the suffix of the input filename,
5297 possible with an intermediate .gk extension for -fcompare-debug,
5298 is just calling for trouble. */
5299 if (dumpbase_ext)
5301 if (!dumpbase || !*dumpbase)
5303 free (dumpbase_ext);
5304 dumpbase_ext = NULL;
5306 else
5307 gcc_assert (strcmp (dumpbase + strlen (dumpbase)
5308 - strlen (dumpbase_ext), dumpbase_ext) == 0);
5311 if (save_temps_flag && use_pipes)
5313 /* -save-temps overrides -pipe, so that temp files are produced */
5314 if (save_temps_flag)
5315 warning (0, "%<-pipe%> ignored because %<-save-temps%> specified");
5316 use_pipes = 0;
5319 if (!compare_debug)
5321 const char *gcd = env.get ("GCC_COMPARE_DEBUG");
5323 if (gcd && gcd[0] == '-')
5325 compare_debug = 2;
5326 compare_debug_opt = gcd;
5328 else if (gcd && *gcd && strcmp (gcd, "0"))
5330 compare_debug = 3;
5331 compare_debug_opt = "-gtoggle";
5334 else if (compare_debug < 0)
5336 compare_debug = 0;
5337 gcc_assert (!compare_debug_opt);
5340 /* Set up the search paths. We add directories that we expect to
5341 contain GNU Toolchain components before directories specified by
5342 the machine description so that we will find GNU components (like
5343 the GNU assembler) before those of the host system. */
5345 /* If we don't know where the toolchain has been installed, use the
5346 configured-in locations. */
5347 if (!gcc_exec_prefix)
5349 #ifndef OS2
5350 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
5351 PREFIX_PRIORITY_LAST, 1, 0);
5352 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
5353 PREFIX_PRIORITY_LAST, 2, 0);
5354 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
5355 PREFIX_PRIORITY_LAST, 2, 0);
5356 #endif
5357 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
5358 PREFIX_PRIORITY_LAST, 1, 0);
5361 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
5362 tooldir_prefix2 = concat (tooldir_base_prefix, spec_machine,
5363 dir_separator_str, NULL);
5365 /* Look for tools relative to the location from which the driver is
5366 running, or, if that is not available, the configured prefix. */
5367 tooldir_prefix
5368 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
5369 spec_host_machine, dir_separator_str, spec_version,
5370 accel_dir_suffix, dir_separator_str, tooldir_prefix2, NULL);
5371 free (tooldir_prefix2);
5373 add_prefix (&exec_prefixes,
5374 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
5375 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
5376 add_prefix (&startfile_prefixes,
5377 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
5378 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
5379 free (tooldir_prefix);
5381 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
5382 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
5383 then consider it to relocate with the rest of the GCC installation
5384 if GCC_EXEC_PREFIX is set.
5385 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
5386 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
5388 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
5389 standard_bindir_prefix,
5390 target_system_root);
5391 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
5393 target_system_root = tmp_prefix;
5394 target_system_root_changed = 1;
5397 #endif
5399 /* More prefixes are enabled in main, after we read the specs file
5400 and determine whether this is cross-compilation or not. */
5402 if (n_infiles != 0 && n_infiles == last_language_n_infiles && spec_lang != 0)
5403 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
5405 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
5406 environment variable. */
5407 if (compare_debug == 2 || compare_debug == 3)
5409 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
5410 save_switch (opt, 0, NULL, false, true);
5411 compare_debug = 1;
5414 /* Ensure we only invoke each subprocess once. */
5415 if (n_infiles == 0
5416 && (print_subprocess_help || print_help_list || print_version))
5418 /* Create a dummy input file, so that we can pass
5419 the help option on to the various sub-processes. */
5420 add_infile ("help-dummy", "c");
5423 /* Decide if undefined variable references are allowed in specs. */
5425 /* -v alone is safe. --version and --help alone or together are safe. Note
5426 that -v would make them unsafe, as they'd then be run for subprocesses as
5427 well, the location of which might depend on variables possibly coming
5428 from self-specs. Note also that the command name is counted in
5429 decoded_options_count. */
5431 unsigned help_version_count = 0;
5433 if (print_version)
5434 help_version_count++;
5436 if (print_help_list)
5437 help_version_count++;
5439 spec_undefvar_allowed =
5440 ((verbose_flag && decoded_options_count == 2)
5441 || help_version_count == decoded_options_count - 1);
5443 alloc_switch ();
5444 switches[n_switches].part1 = 0;
5445 alloc_infile ();
5446 infiles[n_infiles].name = 0;
5449 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
5450 and place that in the environment. */
5452 static void
5453 set_collect_gcc_options (void)
5455 int i;
5456 int first_time;
5458 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
5459 the compiler. */
5460 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
5461 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
5463 first_time = TRUE;
5464 for (i = 0; (int) i < n_switches; i++)
5466 const char *const *args;
5467 const char *p, *q;
5468 if (!first_time)
5469 obstack_grow (&collect_obstack, " ", 1);
5471 first_time = FALSE;
5473 /* Ignore elided switches. */
5474 if ((switches[i].live_cond
5475 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
5476 == SWITCH_IGNORE)
5477 continue;
5479 obstack_grow (&collect_obstack, "'-", 2);
5480 q = switches[i].part1;
5481 while ((p = strchr (q, '\'')))
5483 obstack_grow (&collect_obstack, q, p - q);
5484 obstack_grow (&collect_obstack, "'\\''", 4);
5485 q = ++p;
5487 obstack_grow (&collect_obstack, q, strlen (q));
5488 obstack_grow (&collect_obstack, "'", 1);
5490 for (args = switches[i].args; args && *args; args++)
5492 obstack_grow (&collect_obstack, " '", 2);
5493 q = *args;
5494 while ((p = strchr (q, '\'')))
5496 obstack_grow (&collect_obstack, q, p - q);
5497 obstack_grow (&collect_obstack, "'\\''", 4);
5498 q = ++p;
5500 obstack_grow (&collect_obstack, q, strlen (q));
5501 obstack_grow (&collect_obstack, "'", 1);
5505 if (dumpdir)
5507 if (!first_time)
5508 obstack_grow (&collect_obstack, " ", 1);
5509 first_time = FALSE;
5511 obstack_grow (&collect_obstack, "'-dumpdir' '", 12);
5512 const char *p, *q;
5514 q = dumpdir;
5515 while ((p = strchr (q, '\'')))
5517 obstack_grow (&collect_obstack, q, p - q);
5518 obstack_grow (&collect_obstack, "'\\''", 4);
5519 q = ++p;
5521 obstack_grow (&collect_obstack, q, strlen (q));
5523 obstack_grow (&collect_obstack, "'", 1);
5526 obstack_grow (&collect_obstack, "\0", 1);
5527 xputenv (XOBFINISH (&collect_obstack, char *));
5530 /* Process a spec string, accumulating and running commands. */
5532 /* These variables describe the input file name.
5533 input_file_number is the index on outfiles of this file,
5534 so that the output file name can be stored for later use by %o.
5535 input_basename is the start of the part of the input file
5536 sans all directory names, and basename_length is the number
5537 of characters starting there excluding the suffix .c or whatever. */
5539 static const char *gcc_input_filename;
5540 static int input_file_number;
5541 size_t input_filename_length;
5542 static int basename_length;
5543 static int suffixed_basename_length;
5544 static const char *input_basename;
5545 static const char *input_suffix;
5546 #ifndef HOST_LACKS_INODE_NUMBERS
5547 static struct stat input_stat;
5548 #endif
5549 static int input_stat_set;
5551 /* The compiler used to process the current input file. */
5552 static struct compiler *input_file_compiler;
5554 /* These are variables used within do_spec and do_spec_1. */
5556 /* Nonzero if an arg has been started and not yet terminated
5557 (with space, tab or newline). */
5558 static int arg_going;
5560 /* Nonzero means %d or %g has been seen; the next arg to be terminated
5561 is a temporary file name. */
5562 static int delete_this_arg;
5564 /* Nonzero means %w has been seen; the next arg to be terminated
5565 is the output file name of this compilation. */
5566 static int this_is_output_file;
5568 /* Nonzero means %s has been seen; the next arg to be terminated
5569 is the name of a library file and we should try the standard
5570 search dirs for it. */
5571 static int this_is_library_file;
5573 /* Nonzero means %T has been seen; the next arg to be terminated
5574 is the name of a linker script and we should try all of the
5575 standard search dirs for it. If it is found insert a --script
5576 command line switch and then substitute the full path in place,
5577 otherwise generate an error message. */
5578 static int this_is_linker_script;
5580 /* Nonzero means that the input of this command is coming from a pipe. */
5581 static int input_from_pipe;
5583 /* Nonnull means substitute this for any suffix when outputting a switches
5584 arguments. */
5585 static const char *suffix_subst;
5587 /* If there is an argument being accumulated, terminate it and store it. */
5589 static void
5590 end_going_arg (void)
5592 if (arg_going)
5594 const char *string;
5596 obstack_1grow (&obstack, 0);
5597 string = XOBFINISH (&obstack, const char *);
5598 if (this_is_library_file)
5599 string = find_file (string);
5600 if (this_is_linker_script)
5602 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
5604 if (full_script_path == NULL)
5606 error ("unable to locate default linker script %qs in the library search paths", string);
5607 /* Script was not found on search path. */
5608 return;
5610 store_arg ("--script", false, false);
5611 string = full_script_path;
5613 store_arg (string, delete_this_arg, this_is_output_file);
5614 if (this_is_output_file)
5615 outfiles[input_file_number] = string;
5616 arg_going = 0;
5621 /* Parse the WRAPPER string which is a comma separated list of the command line
5622 and insert them into the beginning of argbuf. */
5624 static void
5625 insert_wrapper (const char *wrapper)
5627 int n = 0;
5628 int i;
5629 char *buf = xstrdup (wrapper);
5630 char *p = buf;
5631 unsigned int old_length = argbuf.length ();
5635 n++;
5636 while (*p == ',')
5637 p++;
5639 while ((p = strchr (p, ',')) != NULL);
5641 argbuf.safe_grow (old_length + n, true);
5642 memmove (argbuf.address () + n,
5643 argbuf.address (),
5644 old_length * sizeof (const_char_p));
5646 i = 0;
5647 p = buf;
5650 while (*p == ',')
5652 *p = 0;
5653 p++;
5655 argbuf[i] = p;
5656 i++;
5658 while ((p = strchr (p, ',')) != NULL);
5659 gcc_assert (i == n);
5662 /* Process the spec SPEC and run the commands specified therein.
5663 Returns 0 if the spec is successfully processed; -1 if failed. */
5666 do_spec (const char *spec)
5668 int value;
5670 value = do_spec_2 (spec, NULL);
5672 /* Force out any unfinished command.
5673 If -pipe, this forces out the last command if it ended in `|'. */
5674 if (value == 0)
5676 if (argbuf.length () > 0
5677 && !strcmp (argbuf.last (), "|"))
5678 argbuf.pop ();
5680 set_collect_gcc_options ();
5682 if (argbuf.length () > 0)
5683 value = execute ();
5686 return value;
5689 /* Process the spec SPEC, with SOFT_MATCHED_PART designating the current value
5690 of a matched * pattern which may be re-injected by way of %*. */
5692 static int
5693 do_spec_2 (const char *spec, const char *soft_matched_part)
5695 int result;
5697 clear_args ();
5698 arg_going = 0;
5699 delete_this_arg = 0;
5700 this_is_output_file = 0;
5701 this_is_library_file = 0;
5702 this_is_linker_script = 0;
5703 input_from_pipe = 0;
5704 suffix_subst = NULL;
5706 result = do_spec_1 (spec, 0, soft_matched_part);
5708 end_going_arg ();
5710 return result;
5713 /* Process the given spec string and add any new options to the end
5714 of the switches/n_switches array. */
5716 static void
5717 do_option_spec (const char *name, const char *spec)
5719 unsigned int i, value_count, value_len;
5720 const char *p, *q, *value;
5721 char *tmp_spec, *tmp_spec_p;
5723 if (configure_default_options[0].name == NULL)
5724 return;
5726 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
5727 if (strcmp (configure_default_options[i].name, name) == 0)
5728 break;
5729 if (i == ARRAY_SIZE (configure_default_options))
5730 return;
5732 value = configure_default_options[i].value;
5733 value_len = strlen (value);
5735 /* Compute the size of the final spec. */
5736 value_count = 0;
5737 p = spec;
5738 while ((p = strstr (p, "%(VALUE)")) != NULL)
5740 p ++;
5741 value_count ++;
5744 /* Replace each %(VALUE) by the specified value. */
5745 tmp_spec = (char *) alloca (strlen (spec) + 1
5746 + value_count * (value_len - strlen ("%(VALUE)")));
5747 tmp_spec_p = tmp_spec;
5748 q = spec;
5749 while ((p = strstr (q, "%(VALUE)")) != NULL)
5751 memcpy (tmp_spec_p, q, p - q);
5752 tmp_spec_p = tmp_spec_p + (p - q);
5753 memcpy (tmp_spec_p, value, value_len);
5754 tmp_spec_p += value_len;
5755 q = p + strlen ("%(VALUE)");
5757 strcpy (tmp_spec_p, q);
5759 do_self_spec (tmp_spec);
5762 /* Process the given spec string and add any new options to the end
5763 of the switches/n_switches array. */
5765 static void
5766 do_self_spec (const char *spec)
5768 int i;
5770 do_spec_2 (spec, NULL);
5771 do_spec_1 (" ", 0, NULL);
5773 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
5774 do_self_specs adds the replacements to switches array, so it shouldn't
5775 be processed afterwards. */
5776 for (i = 0; i < n_switches; i++)
5777 if ((switches[i].live_cond & SWITCH_IGNORE))
5778 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
5780 if (argbuf.length () > 0)
5782 const char **argbuf_copy;
5783 struct cl_decoded_option *decoded_options;
5784 struct cl_option_handlers handlers;
5785 unsigned int decoded_options_count;
5786 unsigned int j;
5788 /* Create a copy of argbuf with a dummy argv[0] entry for
5789 decode_cmdline_options_to_array. */
5790 argbuf_copy = XNEWVEC (const char *,
5791 argbuf.length () + 1);
5792 argbuf_copy[0] = "";
5793 memcpy (argbuf_copy + 1, argbuf.address (),
5794 argbuf.length () * sizeof (const char *));
5796 decode_cmdline_options_to_array (argbuf.length () + 1,
5797 argbuf_copy,
5798 CL_DRIVER, &decoded_options,
5799 &decoded_options_count);
5800 free (argbuf_copy);
5802 set_option_handlers (&handlers);
5804 for (j = 1; j < decoded_options_count; j++)
5806 switch (decoded_options[j].opt_index)
5808 case OPT_SPECIAL_input_file:
5809 /* Specs should only generate options, not input
5810 files. */
5811 if (strcmp (decoded_options[j].arg, "-") != 0)
5812 fatal_error (input_location,
5813 "switch %qs does not start with %<-%>",
5814 decoded_options[j].arg);
5815 else
5816 fatal_error (input_location,
5817 "spec-generated switch is just %<-%>");
5818 break;
5820 case OPT_fcompare_debug_second:
5821 case OPT_fcompare_debug:
5822 case OPT_fcompare_debug_:
5823 case OPT_o:
5824 /* Avoid duplicate processing of some options from
5825 compare-debug specs; just save them here. */
5826 save_switch (decoded_options[j].canonical_option[0],
5827 (decoded_options[j].canonical_option_num_elements
5828 - 1),
5829 &decoded_options[j].canonical_option[1], false, true);
5830 break;
5832 default:
5833 read_cmdline_option (&global_options, &global_options_set,
5834 decoded_options + j, UNKNOWN_LOCATION,
5835 CL_DRIVER, &handlers, global_dc);
5836 break;
5840 free (decoded_options);
5842 alloc_switch ();
5843 switches[n_switches].part1 = 0;
5847 /* Callback for processing %D and %I specs. */
5849 struct spec_path_info {
5850 const char *option;
5851 const char *append;
5852 size_t append_len;
5853 bool omit_relative;
5854 bool separate_options;
5857 static void *
5858 spec_path (char *path, void *data)
5860 struct spec_path_info *info = (struct spec_path_info *) data;
5861 size_t len = 0;
5862 char save = 0;
5864 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
5865 return NULL;
5867 if (info->append_len != 0)
5869 len = strlen (path);
5870 memcpy (path + len, info->append, info->append_len + 1);
5873 if (!is_directory (path, true))
5874 return NULL;
5876 do_spec_1 (info->option, 1, NULL);
5877 if (info->separate_options)
5878 do_spec_1 (" ", 0, NULL);
5880 if (info->append_len == 0)
5882 len = strlen (path);
5883 save = path[len - 1];
5884 if (IS_DIR_SEPARATOR (path[len - 1]))
5885 path[len - 1] = '\0';
5888 do_spec_1 (path, 1, NULL);
5889 do_spec_1 (" ", 0, NULL);
5891 /* Must not damage the original path. */
5892 if (info->append_len == 0)
5893 path[len - 1] = save;
5895 return NULL;
5898 /* True if we should compile INFILE. */
5900 static bool
5901 compile_input_file_p (struct infile *infile)
5903 if ((!infile->language) || (infile->language[0] != '*'))
5904 if (infile->incompiler == input_file_compiler)
5905 return true;
5906 return false;
5909 /* Process each member of VEC as a spec. */
5911 static void
5912 do_specs_vec (vec<char_p> vec)
5914 for (char *opt : vec)
5916 do_spec_1 (opt, 1, NULL);
5917 /* Make each accumulated option a separate argument. */
5918 do_spec_1 (" ", 0, NULL);
5922 /* Add options passed via -Xassembler or -Wa to COLLECT_AS_OPTIONS. */
5924 static void
5925 putenv_COLLECT_AS_OPTIONS (vec<char_p> vec)
5927 if (vec.is_empty ())
5928 return;
5930 obstack_init (&collect_obstack);
5931 obstack_grow (&collect_obstack, "COLLECT_AS_OPTIONS=",
5932 strlen ("COLLECT_AS_OPTIONS="));
5934 char *opt;
5935 unsigned ix;
5937 FOR_EACH_VEC_ELT (vec, ix, opt)
5939 obstack_1grow (&collect_obstack, '\'');
5940 obstack_grow (&collect_obstack, opt, strlen (opt));
5941 obstack_1grow (&collect_obstack, '\'');
5942 if (ix < vec.length () - 1)
5943 obstack_1grow(&collect_obstack, ' ');
5946 obstack_1grow (&collect_obstack, '\0');
5947 xputenv (XOBFINISH (&collect_obstack, char *));
5950 /* Process the sub-spec SPEC as a portion of a larger spec.
5951 This is like processing a whole spec except that we do
5952 not initialize at the beginning and we do not supply a
5953 newline by default at the end.
5954 INSWITCH nonzero means don't process %-sequences in SPEC;
5955 in this case, % is treated as an ordinary character.
5956 This is used while substituting switches.
5957 INSWITCH nonzero also causes SPC not to terminate an argument.
5959 Value is zero unless a line was finished
5960 and the command on that line reported an error. */
5962 static int
5963 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
5965 const char *p = spec;
5966 int c;
5967 int i;
5968 int value;
5970 /* If it's an empty string argument to a switch, keep it as is. */
5971 if (inswitch && !*p)
5972 arg_going = 1;
5974 while ((c = *p++))
5975 /* If substituting a switch, treat all chars like letters.
5976 Otherwise, NL, SPC, TAB and % are special. */
5977 switch (inswitch ? 'a' : c)
5979 case '\n':
5980 end_going_arg ();
5982 if (argbuf.length () > 0
5983 && !strcmp (argbuf.last (), "|"))
5985 /* A `|' before the newline means use a pipe here,
5986 but only if -pipe was specified.
5987 Otherwise, execute now and don't pass the `|' as an arg. */
5988 if (use_pipes)
5990 input_from_pipe = 1;
5991 break;
5993 else
5994 argbuf.pop ();
5997 set_collect_gcc_options ();
5999 if (argbuf.length () > 0)
6001 value = execute ();
6002 if (value)
6003 return value;
6005 /* Reinitialize for a new command, and for a new argument. */
6006 clear_args ();
6007 arg_going = 0;
6008 delete_this_arg = 0;
6009 this_is_output_file = 0;
6010 this_is_library_file = 0;
6011 this_is_linker_script = 0;
6012 input_from_pipe = 0;
6013 break;
6015 case '|':
6016 end_going_arg ();
6018 /* Use pipe */
6019 obstack_1grow (&obstack, c);
6020 arg_going = 1;
6021 break;
6023 case '\t':
6024 case ' ':
6025 end_going_arg ();
6027 /* Reinitialize for a new argument. */
6028 delete_this_arg = 0;
6029 this_is_output_file = 0;
6030 this_is_library_file = 0;
6031 this_is_linker_script = 0;
6032 break;
6034 case '%':
6035 switch (c = *p++)
6037 case 0:
6038 fatal_error (input_location, "spec %qs invalid", spec);
6040 case 'b':
6041 /* Don't use %b in the linker command. */
6042 gcc_assert (suffixed_basename_length);
6043 if (!this_is_output_file && dumpdir_length)
6044 obstack_grow (&obstack, dumpdir, dumpdir_length);
6045 if (this_is_output_file || !outbase_length)
6046 obstack_grow (&obstack, input_basename, basename_length);
6047 else
6048 obstack_grow (&obstack, outbase, outbase_length);
6049 if (compare_debug < 0)
6050 obstack_grow (&obstack, ".gk", 3);
6051 arg_going = 1;
6052 break;
6054 case 'B':
6055 /* Don't use %B in the linker command. */
6056 gcc_assert (suffixed_basename_length);
6057 if (!this_is_output_file && dumpdir_length)
6058 obstack_grow (&obstack, dumpdir, dumpdir_length);
6059 if (this_is_output_file || !outbase_length)
6060 obstack_grow (&obstack, input_basename, basename_length);
6061 else
6062 obstack_grow (&obstack, outbase, outbase_length);
6063 if (compare_debug < 0)
6064 obstack_grow (&obstack, ".gk", 3);
6065 obstack_grow (&obstack, input_basename + basename_length,
6066 suffixed_basename_length - basename_length);
6068 arg_going = 1;
6069 break;
6071 case 'd':
6072 delete_this_arg = 2;
6073 break;
6075 /* Dump out the directories specified with LIBRARY_PATH,
6076 followed by the absolute directories
6077 that we search for startfiles. */
6078 case 'D':
6080 struct spec_path_info info;
6082 info.option = "-L";
6083 info.append_len = 0;
6084 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
6085 /* Used on systems which record the specified -L dirs
6086 and use them to search for dynamic linking.
6087 Relative directories always come from -B,
6088 and it is better not to use them for searching
6089 at run time. In particular, stage1 loses. */
6090 info.omit_relative = true;
6091 #else
6092 info.omit_relative = false;
6093 #endif
6094 info.separate_options = false;
6096 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
6098 break;
6100 case 'e':
6101 /* %efoo means report an error with `foo' as error message
6102 and don't execute any more commands for this file. */
6104 const char *q = p;
6105 char *buf;
6106 while (*p != 0 && *p != '\n')
6107 p++;
6108 buf = (char *) alloca (p - q + 1);
6109 strncpy (buf, q, p - q);
6110 buf[p - q] = 0;
6111 error ("%s", _(buf));
6112 return -1;
6114 break;
6115 case 'n':
6116 /* %nfoo means report a notice with `foo' on stderr. */
6118 const char *q = p;
6119 char *buf;
6120 while (*p != 0 && *p != '\n')
6121 p++;
6122 buf = (char *) alloca (p - q + 1);
6123 strncpy (buf, q, p - q);
6124 buf[p - q] = 0;
6125 inform (UNKNOWN_LOCATION, "%s", _(buf));
6126 if (*p)
6127 p++;
6129 break;
6131 case 'j':
6133 struct stat st;
6135 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
6136 defined, and it is not a directory, and it is
6137 writable, use it. Otherwise, treat this like any
6138 other temporary file. */
6140 if ((!save_temps_flag)
6141 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
6142 && (access (HOST_BIT_BUCKET, W_OK) == 0))
6144 obstack_grow (&obstack, HOST_BIT_BUCKET,
6145 strlen (HOST_BIT_BUCKET));
6146 delete_this_arg = 0;
6147 arg_going = 1;
6148 break;
6151 goto create_temp_file;
6152 case '|':
6153 if (use_pipes)
6155 obstack_1grow (&obstack, '-');
6156 delete_this_arg = 0;
6157 arg_going = 1;
6159 /* consume suffix */
6160 while (*p == '.' || ISALNUM ((unsigned char) *p))
6161 p++;
6162 if (p[0] == '%' && p[1] == 'O')
6163 p += 2;
6165 break;
6167 goto create_temp_file;
6168 case 'm':
6169 if (use_pipes)
6171 /* consume suffix */
6172 while (*p == '.' || ISALNUM ((unsigned char) *p))
6173 p++;
6174 if (p[0] == '%' && p[1] == 'O')
6175 p += 2;
6177 break;
6179 goto create_temp_file;
6180 case 'g':
6181 case 'u':
6182 case 'U':
6183 create_temp_file:
6185 struct temp_name *t;
6186 int suffix_length;
6187 const char *suffix = p;
6188 char *saved_suffix = NULL;
6190 while (*p == '.' || ISALNUM ((unsigned char) *p))
6191 p++;
6192 suffix_length = p - suffix;
6193 if (p[0] == '%' && p[1] == 'O')
6195 p += 2;
6196 /* We don't support extra suffix characters after %O. */
6197 if (*p == '.' || ISALNUM ((unsigned char) *p))
6198 fatal_error (input_location,
6199 "spec %qs has invalid %<%%0%c%>", spec, *p);
6200 if (suffix_length == 0)
6201 suffix = TARGET_OBJECT_SUFFIX;
6202 else
6204 saved_suffix
6205 = XNEWVEC (char, suffix_length
6206 + strlen (TARGET_OBJECT_SUFFIX) + 1);
6207 strncpy (saved_suffix, suffix, suffix_length);
6208 strcpy (saved_suffix + suffix_length,
6209 TARGET_OBJECT_SUFFIX);
6211 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
6214 if (compare_debug < 0)
6216 suffix = concat (".gk", suffix, NULL);
6217 suffix_length += 3;
6220 /* If -save-temps was specified, use that for the
6221 temp file. */
6222 if (save_temps_flag)
6224 char *tmp;
6225 bool adjusted_suffix = false;
6226 if (suffix_length
6227 && !outbase_length && !basename_length
6228 && !dumpdir_trailing_dash_added)
6230 adjusted_suffix = true;
6231 suffix++;
6232 suffix_length--;
6234 temp_filename_length
6235 = dumpdir_length + suffix_length + 1;
6236 if (outbase_length)
6237 temp_filename_length += outbase_length;
6238 else
6239 temp_filename_length += basename_length;
6240 tmp = (char *) alloca (temp_filename_length);
6241 if (dumpdir_length)
6242 memcpy (tmp, dumpdir, dumpdir_length);
6243 if (outbase_length)
6244 memcpy (tmp + dumpdir_length, outbase,
6245 outbase_length);
6246 else if (basename_length)
6247 memcpy (tmp + dumpdir_length, input_basename,
6248 basename_length);
6249 memcpy (tmp + temp_filename_length - suffix_length - 1,
6250 suffix, suffix_length);
6251 if (adjusted_suffix)
6253 adjusted_suffix = false;
6254 suffix--;
6255 suffix_length++;
6257 tmp[temp_filename_length - 1] = '\0';
6258 temp_filename = tmp;
6260 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
6262 #ifndef HOST_LACKS_INODE_NUMBERS
6263 struct stat st_temp;
6265 /* Note, set_input() resets input_stat_set to 0. */
6266 if (input_stat_set == 0)
6268 input_stat_set = stat (gcc_input_filename,
6269 &input_stat);
6270 if (input_stat_set >= 0)
6271 input_stat_set = 1;
6274 /* If we have the stat for the gcc_input_filename
6275 and we can do the stat for the temp_filename
6276 then the they could still refer to the same
6277 file if st_dev/st_ino's are the same. */
6278 if (input_stat_set != 1
6279 || stat (temp_filename, &st_temp) < 0
6280 || input_stat.st_dev != st_temp.st_dev
6281 || input_stat.st_ino != st_temp.st_ino)
6282 #else
6283 /* Just compare canonical pathnames. */
6284 char* input_realname = lrealpath (gcc_input_filename);
6285 char* temp_realname = lrealpath (temp_filename);
6286 bool files_differ = filename_cmp (input_realname, temp_realname);
6287 free (input_realname);
6288 free (temp_realname);
6289 if (files_differ)
6290 #endif
6292 temp_filename
6293 = save_string (temp_filename,
6294 temp_filename_length - 1);
6295 obstack_grow (&obstack, temp_filename,
6296 temp_filename_length);
6297 arg_going = 1;
6298 delete_this_arg = 0;
6299 break;
6304 /* See if we already have an association of %g/%u/%U and
6305 suffix. */
6306 for (t = temp_names; t; t = t->next)
6307 if (t->length == suffix_length
6308 && strncmp (t->suffix, suffix, suffix_length) == 0
6309 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
6310 break;
6312 /* Make a new association if needed. %u and %j
6313 require one. */
6314 if (t == 0 || c == 'u' || c == 'j')
6316 if (t == 0)
6318 t = XNEW (struct temp_name);
6319 t->next = temp_names;
6320 temp_names = t;
6322 t->length = suffix_length;
6323 if (saved_suffix)
6325 t->suffix = saved_suffix;
6326 saved_suffix = NULL;
6328 else
6329 t->suffix = save_string (suffix, suffix_length);
6330 t->unique = (c == 'u' || c == 'U' || c == 'j');
6331 temp_filename = make_temp_file (t->suffix);
6332 temp_filename_length = strlen (temp_filename);
6333 t->filename = temp_filename;
6334 t->filename_length = temp_filename_length;
6337 free (saved_suffix);
6339 obstack_grow (&obstack, t->filename, t->filename_length);
6340 delete_this_arg = 1;
6342 arg_going = 1;
6343 break;
6345 case 'i':
6346 if (combine_inputs)
6348 /* We are going to expand `%i' into `@FILE', where FILE
6349 is a newly-created temporary filename. The filenames
6350 that would usually be expanded in place of %o will be
6351 written to the temporary file. */
6352 if (at_file_supplied)
6353 open_at_file ();
6355 for (i = 0; (int) i < n_infiles; i++)
6356 if (compile_input_file_p (&infiles[i]))
6358 store_arg (infiles[i].name, 0, 0);
6359 infiles[i].compiled = true;
6362 if (at_file_supplied)
6363 close_at_file ();
6365 else
6367 obstack_grow (&obstack, gcc_input_filename,
6368 input_filename_length);
6369 arg_going = 1;
6371 break;
6373 case 'I':
6375 struct spec_path_info info;
6377 if (multilib_dir)
6379 do_spec_1 ("-imultilib", 1, NULL);
6380 /* Make this a separate argument. */
6381 do_spec_1 (" ", 0, NULL);
6382 do_spec_1 (multilib_dir, 1, NULL);
6383 do_spec_1 (" ", 0, NULL);
6386 if (multiarch_dir)
6388 do_spec_1 ("-imultiarch", 1, NULL);
6389 /* Make this a separate argument. */
6390 do_spec_1 (" ", 0, NULL);
6391 do_spec_1 (multiarch_dir, 1, NULL);
6392 do_spec_1 (" ", 0, NULL);
6395 if (gcc_exec_prefix)
6397 do_spec_1 ("-iprefix", 1, NULL);
6398 /* Make this a separate argument. */
6399 do_spec_1 (" ", 0, NULL);
6400 do_spec_1 (gcc_exec_prefix, 1, NULL);
6401 do_spec_1 (" ", 0, NULL);
6404 if (target_system_root_changed ||
6405 (target_system_root && target_sysroot_hdrs_suffix))
6407 do_spec_1 ("-isysroot", 1, NULL);
6408 /* Make this a separate argument. */
6409 do_spec_1 (" ", 0, NULL);
6410 do_spec_1 (target_system_root, 1, NULL);
6411 if (target_sysroot_hdrs_suffix)
6412 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
6413 do_spec_1 (" ", 0, NULL);
6416 info.option = "-isystem";
6417 info.append = "include";
6418 info.append_len = strlen (info.append);
6419 info.omit_relative = false;
6420 info.separate_options = true;
6422 for_each_path (&include_prefixes, false, info.append_len,
6423 spec_path, &info);
6425 info.append = "include-fixed";
6426 if (*sysroot_hdrs_suffix_spec)
6427 info.append = concat (info.append, dir_separator_str,
6428 multilib_dir, NULL);
6429 else if (multiarch_dir)
6431 /* For multiarch, search include-fixed/<multiarch-dir>
6432 before include-fixed. */
6433 info.append = concat (info.append, dir_separator_str,
6434 multiarch_dir, NULL);
6435 info.append_len = strlen (info.append);
6436 for_each_path (&include_prefixes, false, info.append_len,
6437 spec_path, &info);
6439 info.append = "include-fixed";
6441 info.append_len = strlen (info.append);
6442 for_each_path (&include_prefixes, false, info.append_len,
6443 spec_path, &info);
6445 break;
6447 case 'o':
6448 /* We are going to expand `%o' into `@FILE', where FILE
6449 is a newly-created temporary filename. The filenames
6450 that would usually be expanded in place of %o will be
6451 written to the temporary file. */
6452 if (at_file_supplied)
6453 open_at_file ();
6455 for (i = 0; i < n_infiles + lang_specific_extra_outfiles; i++)
6456 if (outfiles[i])
6457 store_arg (outfiles[i], 0, 0);
6459 if (at_file_supplied)
6460 close_at_file ();
6461 break;
6463 case 'O':
6464 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
6465 arg_going = 1;
6466 break;
6468 case 's':
6469 this_is_library_file = 1;
6470 break;
6472 case 'T':
6473 this_is_linker_script = 1;
6474 break;
6476 case 'V':
6477 outfiles[input_file_number] = NULL;
6478 break;
6480 case 'w':
6481 this_is_output_file = 1;
6482 break;
6484 case 'W':
6486 unsigned int cur_index = argbuf.length ();
6487 /* Handle the {...} following the %W. */
6488 if (*p != '{')
6489 fatal_error (input_location,
6490 "spec %qs has invalid %<%%W%c%>", spec, *p);
6491 p = handle_braces (p + 1);
6492 if (p == 0)
6493 return -1;
6494 end_going_arg ();
6495 /* If any args were output, mark the last one for deletion
6496 on failure. */
6497 if (argbuf.length () != cur_index)
6498 record_temp_file (argbuf.last (), 0, 1);
6499 break;
6502 case '@':
6503 /* Handle the {...} following the %@. */
6504 if (*p != '{')
6505 fatal_error (input_location,
6506 "spec %qs has invalid %<%%@%c%>", spec, *p);
6507 if (at_file_supplied)
6508 open_at_file ();
6509 p = handle_braces (p + 1);
6510 if (at_file_supplied)
6511 close_at_file ();
6512 if (p == 0)
6513 return -1;
6514 break;
6516 /* %x{OPTION} records OPTION for %X to output. */
6517 case 'x':
6519 const char *p1 = p;
6520 char *string;
6522 /* Skip past the option value and make a copy. */
6523 if (*p != '{')
6524 fatal_error (input_location,
6525 "spec %qs has invalid %<%%x%c%>", spec, *p);
6526 while (*p++ != '}')
6528 string = save_string (p1 + 1, p - p1 - 2);
6530 /* See if we already recorded this option. */
6531 for (const char *opt : linker_options)
6532 if (! strcmp (string, opt))
6534 free (string);
6535 return 0;
6538 /* This option is new; add it. */
6539 add_linker_option (string, strlen (string));
6540 free (string);
6542 break;
6544 /* Dump out the options accumulated previously using %x. */
6545 case 'X':
6546 do_specs_vec (linker_options);
6547 break;
6549 /* Dump out the options accumulated previously using -Wa,. */
6550 case 'Y':
6551 do_specs_vec (assembler_options);
6552 break;
6554 /* Dump out the options accumulated previously using -Wp,. */
6555 case 'Z':
6556 do_specs_vec (preprocessor_options);
6557 break;
6559 /* Here are digits and numbers that just process
6560 a certain constant string as a spec. */
6562 case '1':
6563 value = do_spec_1 (cc1_spec, 0, NULL);
6564 if (value != 0)
6565 return value;
6566 break;
6568 case '2':
6569 value = do_spec_1 (cc1plus_spec, 0, NULL);
6570 if (value != 0)
6571 return value;
6572 break;
6574 case 'a':
6575 value = do_spec_1 (asm_spec, 0, NULL);
6576 if (value != 0)
6577 return value;
6578 break;
6580 case 'A':
6581 value = do_spec_1 (asm_final_spec, 0, NULL);
6582 if (value != 0)
6583 return value;
6584 break;
6586 case 'C':
6588 const char *const spec
6589 = (input_file_compiler->cpp_spec
6590 ? input_file_compiler->cpp_spec
6591 : cpp_spec);
6592 value = do_spec_1 (spec, 0, NULL);
6593 if (value != 0)
6594 return value;
6596 break;
6598 case 'E':
6599 value = do_spec_1 (endfile_spec, 0, NULL);
6600 if (value != 0)
6601 return value;
6602 break;
6604 case 'l':
6605 value = do_spec_1 (link_spec, 0, NULL);
6606 if (value != 0)
6607 return value;
6608 break;
6610 case 'L':
6611 value = do_spec_1 (lib_spec, 0, NULL);
6612 if (value != 0)
6613 return value;
6614 break;
6616 case 'M':
6617 if (multilib_os_dir == NULL)
6618 obstack_1grow (&obstack, '.');
6619 else
6620 obstack_grow (&obstack, multilib_os_dir,
6621 strlen (multilib_os_dir));
6622 break;
6624 case 'G':
6625 value = do_spec_1 (libgcc_spec, 0, NULL);
6626 if (value != 0)
6627 return value;
6628 break;
6630 case 'R':
6631 /* We assume there is a directory
6632 separator at the end of this string. */
6633 if (target_system_root)
6635 obstack_grow (&obstack, target_system_root,
6636 strlen (target_system_root));
6637 if (target_sysroot_suffix)
6638 obstack_grow (&obstack, target_sysroot_suffix,
6639 strlen (target_sysroot_suffix));
6641 break;
6643 case 'S':
6644 value = do_spec_1 (startfile_spec, 0, NULL);
6645 if (value != 0)
6646 return value;
6647 break;
6649 /* Here we define characters other than letters and digits. */
6651 case '{':
6652 p = handle_braces (p);
6653 if (p == 0)
6654 return -1;
6655 break;
6657 case ':':
6658 p = handle_spec_function (p, NULL, soft_matched_part);
6659 if (p == 0)
6660 return -1;
6661 break;
6663 case '%':
6664 obstack_1grow (&obstack, '%');
6665 break;
6667 case '.':
6669 unsigned len = 0;
6671 while (p[len] && p[len] != ' ' && p[len] != '%')
6672 len++;
6673 suffix_subst = save_string (p - 1, len + 1);
6674 p += len;
6676 break;
6678 /* Henceforth ignore the option(s) matching the pattern
6679 after the %<. */
6680 case '<':
6681 case '>':
6683 unsigned len = 0;
6684 int have_wildcard = 0;
6685 int i;
6686 int switch_option;
6688 if (c == '>')
6689 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
6690 else
6691 switch_option = SWITCH_IGNORE;
6693 while (p[len] && p[len] != ' ' && p[len] != '\t')
6694 len++;
6696 if (p[len-1] == '*')
6697 have_wildcard = 1;
6699 for (i = 0; i < n_switches; i++)
6700 if (!strncmp (switches[i].part1, p, len - have_wildcard)
6701 && (have_wildcard || switches[i].part1[len] == '\0'))
6703 switches[i].live_cond |= switch_option;
6704 /* User switch be validated from validate_all_switches.
6705 when the definition is seen from the spec file.
6706 If not defined anywhere, will be rejected. */
6707 if (switches[i].known)
6708 switches[i].validated = true;
6711 p += len;
6713 break;
6715 case '*':
6716 if (soft_matched_part)
6718 if (soft_matched_part[0])
6719 do_spec_1 (soft_matched_part, 1, NULL);
6720 /* Only insert a space after the substitution if it is at the
6721 end of the current sequence. So if:
6723 "%{foo=*:bar%*}%{foo=*:one%*two}"
6725 matches -foo=hello then it will produce:
6727 barhello onehellotwo
6729 if (*p == 0 || *p == '}')
6730 do_spec_1 (" ", 0, NULL);
6732 else
6733 /* Catch the case where a spec string contains something like
6734 '%{foo:%*}'. i.e. there is no * in the pattern on the left
6735 hand side of the :. */
6736 error ("spec failure: %<%%*%> has not been initialized by pattern match");
6737 break;
6739 /* Process a string found as the value of a spec given by name.
6740 This feature allows individual machine descriptions
6741 to add and use their own specs. */
6742 case '(':
6744 const char *name = p;
6745 struct spec_list *sl;
6746 int len;
6748 /* The string after the S/P is the name of a spec that is to be
6749 processed. */
6750 while (*p && *p != ')')
6751 p++;
6753 /* See if it's in the list. */
6754 for (len = p - name, sl = specs; sl; sl = sl->next)
6755 if (sl->name_len == len && !strncmp (sl->name, name, len))
6757 name = *(sl->ptr_spec);
6758 #ifdef DEBUG_SPECS
6759 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
6760 sl->name, name);
6761 #endif
6762 break;
6765 if (sl)
6767 value = do_spec_1 (name, 0, NULL);
6768 if (value != 0)
6769 return value;
6772 /* Discard the closing paren. */
6773 if (*p)
6774 p++;
6776 break;
6778 case '"':
6779 /* End a previous argument, if there is one, then issue an
6780 empty argument. */
6781 end_going_arg ();
6782 arg_going = 1;
6783 end_going_arg ();
6784 break;
6786 default:
6787 error ("spec failure: unrecognized spec option %qc", c);
6788 break;
6790 break;
6792 case '\\':
6793 /* Backslash: treat next character as ordinary. */
6794 c = *p++;
6796 /* When adding more cases that previously matched default, make
6797 sure to adjust quote_spec_char_p as well. */
6799 /* Fall through. */
6800 default:
6801 /* Ordinary character: put it into the current argument. */
6802 obstack_1grow (&obstack, c);
6803 arg_going = 1;
6806 /* End of string. If we are processing a spec function, we need to
6807 end any pending argument. */
6808 if (processing_spec_function)
6809 end_going_arg ();
6811 return 0;
6814 /* Look up a spec function. */
6816 static const struct spec_function *
6817 lookup_spec_function (const char *name)
6819 const struct spec_function *sf;
6821 for (sf = static_spec_functions; sf->name != NULL; sf++)
6822 if (strcmp (sf->name, name) == 0)
6823 return sf;
6825 return NULL;
6828 /* Evaluate a spec function. */
6830 static const char *
6831 eval_spec_function (const char *func, const char *args,
6832 const char *soft_matched_part)
6834 const struct spec_function *sf;
6835 const char *funcval;
6837 /* Saved spec processing context. */
6838 vec<const_char_p> save_argbuf;
6840 int save_arg_going;
6841 int save_delete_this_arg;
6842 int save_this_is_output_file;
6843 int save_this_is_library_file;
6844 int save_input_from_pipe;
6845 int save_this_is_linker_script;
6846 const char *save_suffix_subst;
6848 int save_growing_size;
6849 void *save_growing_value = NULL;
6851 sf = lookup_spec_function (func);
6852 if (sf == NULL)
6853 fatal_error (input_location, "unknown spec function %qs", func);
6855 /* Push the spec processing context. */
6856 save_argbuf = argbuf;
6858 save_arg_going = arg_going;
6859 save_delete_this_arg = delete_this_arg;
6860 save_this_is_output_file = this_is_output_file;
6861 save_this_is_library_file = this_is_library_file;
6862 save_this_is_linker_script = this_is_linker_script;
6863 save_input_from_pipe = input_from_pipe;
6864 save_suffix_subst = suffix_subst;
6866 /* If we have some object growing now, finalize it so the args and function
6867 eval proceed from a cleared context. This is needed to prevent the first
6868 constructed arg from mistakenly including the growing value. We'll push
6869 this value back on the obstack once the function evaluation is done, to
6870 restore a consistent processing context for our caller. This is fine as
6871 the address of growing objects isn't guaranteed to remain stable until
6872 they are finalized, and we expect this situation to be rare enough for
6873 the extra copy not to be an issue. */
6874 save_growing_size = obstack_object_size (&obstack);
6875 if (save_growing_size > 0)
6876 save_growing_value = obstack_finish (&obstack);
6878 /* Create a new spec processing context, and build the function
6879 arguments. */
6881 alloc_args ();
6882 if (do_spec_2 (args, soft_matched_part) < 0)
6883 fatal_error (input_location, "error in arguments to spec function %qs",
6884 func);
6886 /* argbuf_index is an index for the next argument to be inserted, and
6887 so contains the count of the args already inserted. */
6889 funcval = (*sf->func) (argbuf.length (),
6890 argbuf.address ());
6892 /* Pop the spec processing context. */
6893 argbuf.release ();
6894 argbuf = save_argbuf;
6896 arg_going = save_arg_going;
6897 delete_this_arg = save_delete_this_arg;
6898 this_is_output_file = save_this_is_output_file;
6899 this_is_library_file = save_this_is_library_file;
6900 this_is_linker_script = save_this_is_linker_script;
6901 input_from_pipe = save_input_from_pipe;
6902 suffix_subst = save_suffix_subst;
6904 if (save_growing_size > 0)
6905 obstack_grow (&obstack, save_growing_value, save_growing_size);
6907 return funcval;
6910 /* Handle a spec function call of the form:
6912 %:function(args)
6914 ARGS is processed as a spec in a separate context and split into an
6915 argument vector in the normal fashion. The function returns a string
6916 containing a spec which we then process in the caller's context, or
6917 NULL if no processing is required.
6919 If RETVAL_NONNULL is not NULL, then store a bool whether function
6920 returned non-NULL.
6922 SOFT_MATCHED_PART holds the current value of a matched * pattern, which
6923 may be re-expanded with a %* as part of the function arguments. */
6925 static const char *
6926 handle_spec_function (const char *p, bool *retval_nonnull,
6927 const char *soft_matched_part)
6929 char *func, *args;
6930 const char *endp, *funcval;
6931 int count;
6933 processing_spec_function++;
6935 /* Get the function name. */
6936 for (endp = p; *endp != '\0'; endp++)
6938 if (*endp == '(') /* ) */
6939 break;
6940 /* Only allow [A-Za-z0-9], -, and _ in function names. */
6941 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
6942 fatal_error (input_location, "malformed spec function name");
6944 if (*endp != '(') /* ) */
6945 fatal_error (input_location, "no arguments for spec function");
6946 func = save_string (p, endp - p);
6947 p = ++endp;
6949 /* Get the arguments. */
6950 for (count = 0; *endp != '\0'; endp++)
6952 /* ( */
6953 if (*endp == ')')
6955 if (count == 0)
6956 break;
6957 count--;
6959 else if (*endp == '(') /* ) */
6960 count++;
6962 /* ( */
6963 if (*endp != ')')
6964 fatal_error (input_location, "malformed spec function arguments");
6965 args = save_string (p, endp - p);
6966 p = ++endp;
6968 /* p now points to just past the end of the spec function expression. */
6970 funcval = eval_spec_function (func, args, soft_matched_part);
6971 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
6972 p = NULL;
6973 if (retval_nonnull)
6974 *retval_nonnull = funcval != NULL;
6976 free (func);
6977 free (args);
6979 processing_spec_function--;
6981 return p;
6984 /* Inline subroutine of handle_braces. Returns true if the current
6985 input suffix matches the atom bracketed by ATOM and END_ATOM. */
6986 static inline bool
6987 input_suffix_matches (const char *atom, const char *end_atom)
6989 return (input_suffix
6990 && !strncmp (input_suffix, atom, end_atom - atom)
6991 && input_suffix[end_atom - atom] == '\0');
6994 /* Subroutine of handle_braces. Returns true if the current
6995 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
6996 static bool
6997 input_spec_matches (const char *atom, const char *end_atom)
6999 return (input_file_compiler
7000 && input_file_compiler->suffix
7001 && input_file_compiler->suffix[0] != '\0'
7002 && !strncmp (input_file_compiler->suffix + 1, atom,
7003 end_atom - atom)
7004 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
7007 /* Subroutine of handle_braces. Returns true if a switch
7008 matching the atom bracketed by ATOM and END_ATOM appeared on the
7009 command line. */
7010 static bool
7011 switch_matches (const char *atom, const char *end_atom, int starred)
7013 int i;
7014 int len = end_atom - atom;
7015 int plen = starred ? len : -1;
7017 for (i = 0; i < n_switches; i++)
7018 if (!strncmp (switches[i].part1, atom, len)
7019 && (starred || switches[i].part1[len] == '\0')
7020 && check_live_switch (i, plen))
7021 return true;
7023 /* Check if a switch with separated form matching the atom.
7024 We check -D and -U switches. */
7025 else if (switches[i].args != 0)
7027 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
7028 && *switches[i].part1 == atom[0])
7030 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
7031 && (starred || (switches[i].part1[1] == '\0'
7032 && switches[i].args[0][len - 1] == '\0'))
7033 && check_live_switch (i, (starred ? 1 : -1)))
7034 return true;
7038 return false;
7041 /* Inline subroutine of handle_braces. Mark all of the switches which
7042 match ATOM (extends to END_ATOM; STARRED indicates whether there
7043 was a star after the atom) for later processing. */
7044 static inline void
7045 mark_matching_switches (const char *atom, const char *end_atom, int starred)
7047 int i;
7048 int len = end_atom - atom;
7049 int plen = starred ? len : -1;
7051 for (i = 0; i < n_switches; i++)
7052 if (!strncmp (switches[i].part1, atom, len)
7053 && (starred || switches[i].part1[len] == '\0')
7054 && check_live_switch (i, plen))
7055 switches[i].ordering = 1;
7058 /* Inline subroutine of handle_braces. Process all the currently
7059 marked switches through give_switch, and clear the marks. */
7060 static inline void
7061 process_marked_switches (void)
7063 int i;
7065 for (i = 0; i < n_switches; i++)
7066 if (switches[i].ordering == 1)
7068 switches[i].ordering = 0;
7069 give_switch (i, 0);
7073 /* Handle a %{ ... } construct. P points just inside the leading {.
7074 Returns a pointer one past the end of the brace block, or 0
7075 if we call do_spec_1 and that returns -1. */
7077 static const char *
7078 handle_braces (const char *p)
7080 const char *atom, *end_atom;
7081 const char *d_atom = NULL, *d_end_atom = NULL;
7082 char *esc_buf = NULL, *d_esc_buf = NULL;
7083 int esc;
7084 const char *orig = p;
7086 bool a_is_suffix;
7087 bool a_is_spectype;
7088 bool a_is_starred;
7089 bool a_is_negated;
7090 bool a_matched;
7092 bool a_must_be_last = false;
7093 bool ordered_set = false;
7094 bool disjunct_set = false;
7095 bool disj_matched = false;
7096 bool disj_starred = true;
7097 bool n_way_choice = false;
7098 bool n_way_matched = false;
7100 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
7104 if (a_must_be_last)
7105 goto invalid;
7107 /* Scan one "atom" (S in the description above of %{}, possibly
7108 with '!', '.', '@', ',', or '*' modifiers). */
7109 a_matched = false;
7110 a_is_suffix = false;
7111 a_is_starred = false;
7112 a_is_negated = false;
7113 a_is_spectype = false;
7115 SKIP_WHITE ();
7116 if (*p == '!')
7117 p++, a_is_negated = true;
7119 SKIP_WHITE ();
7120 if (*p == '%' && p[1] == ':')
7122 atom = NULL;
7123 end_atom = NULL;
7124 p = handle_spec_function (p + 2, &a_matched, NULL);
7126 else
7128 if (*p == '.')
7129 p++, a_is_suffix = true;
7130 else if (*p == ',')
7131 p++, a_is_spectype = true;
7133 atom = p;
7134 esc = 0;
7135 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
7136 || *p == ',' || *p == '.' || *p == '@' || *p == '\\')
7138 if (*p == '\\')
7140 p++;
7141 if (!*p)
7142 fatal_error (input_location,
7143 "braced spec %qs ends in escape", orig);
7144 esc++;
7146 p++;
7148 end_atom = p;
7150 if (esc)
7152 const char *ap;
7153 char *ep;
7155 if (esc_buf && esc_buf != d_esc_buf)
7156 free (esc_buf);
7157 esc_buf = NULL;
7158 ep = esc_buf = (char *) xmalloc (end_atom - atom - esc + 1);
7159 for (ap = atom; ap != end_atom; ap++, ep++)
7161 if (*ap == '\\')
7162 ap++;
7163 *ep = *ap;
7165 *ep = '\0';
7166 atom = esc_buf;
7167 end_atom = ep;
7170 if (*p == '*')
7171 p++, a_is_starred = 1;
7174 SKIP_WHITE ();
7175 switch (*p)
7177 case '&': case '}':
7178 /* Substitute the switch(es) indicated by the current atom. */
7179 ordered_set = true;
7180 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
7181 || a_is_spectype || atom == end_atom)
7182 goto invalid;
7184 mark_matching_switches (atom, end_atom, a_is_starred);
7186 if (*p == '}')
7187 process_marked_switches ();
7188 break;
7190 case '|': case ':':
7191 /* Substitute some text if the current atom appears as a switch
7192 or suffix. */
7193 disjunct_set = true;
7194 if (ordered_set)
7195 goto invalid;
7197 if (atom && atom == end_atom)
7199 if (!n_way_choice || disj_matched || *p == '|'
7200 || a_is_negated || a_is_suffix || a_is_spectype
7201 || a_is_starred)
7202 goto invalid;
7204 /* An empty term may appear as the last choice of an
7205 N-way choice set; it means "otherwise". */
7206 a_must_be_last = true;
7207 disj_matched = !n_way_matched;
7208 disj_starred = false;
7210 else
7212 if ((a_is_suffix || a_is_spectype) && a_is_starred)
7213 goto invalid;
7215 if (!a_is_starred)
7216 disj_starred = false;
7218 /* Don't bother testing this atom if we already have a
7219 match. */
7220 if (!disj_matched && !n_way_matched)
7222 if (atom == NULL)
7223 /* a_matched is already set by handle_spec_function. */;
7224 else if (a_is_suffix)
7225 a_matched = input_suffix_matches (atom, end_atom);
7226 else if (a_is_spectype)
7227 a_matched = input_spec_matches (atom, end_atom);
7228 else
7229 a_matched = switch_matches (atom, end_atom, a_is_starred);
7231 if (a_matched != a_is_negated)
7233 disj_matched = true;
7234 d_atom = atom;
7235 d_end_atom = end_atom;
7236 d_esc_buf = esc_buf;
7241 if (*p == ':')
7243 /* Found the body, that is, the text to substitute if the
7244 current disjunction matches. */
7245 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
7246 disj_matched && !n_way_matched);
7247 if (p == 0)
7248 goto done;
7250 /* If we have an N-way choice, reset state for the next
7251 disjunction. */
7252 if (*p == ';')
7254 n_way_choice = true;
7255 n_way_matched |= disj_matched;
7256 disj_matched = false;
7257 disj_starred = true;
7258 d_atom = d_end_atom = NULL;
7261 break;
7263 default:
7264 goto invalid;
7267 while (*p++ != '}');
7269 done:
7270 if (d_esc_buf && d_esc_buf != esc_buf)
7271 free (d_esc_buf);
7272 if (esc_buf)
7273 free (esc_buf);
7275 return p;
7277 invalid:
7278 fatal_error (input_location, "braced spec %qs is invalid at %qc", orig, *p);
7280 #undef SKIP_WHITE
7283 /* Subroutine of handle_braces. Scan and process a brace substitution body
7284 (X in the description of %{} syntax). P points one past the colon;
7285 ATOM and END_ATOM bracket the first atom which was found to be true
7286 (present) in the current disjunction; STARRED indicates whether all
7287 the atoms in the current disjunction were starred (for syntax validation);
7288 MATCHED indicates whether the disjunction matched or not, and therefore
7289 whether or not the body is to be processed through do_spec_1 or just
7290 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
7291 returns -1. */
7293 static const char *
7294 process_brace_body (const char *p, const char *atom, const char *end_atom,
7295 int starred, int matched)
7297 const char *body, *end_body;
7298 unsigned int nesting_level;
7299 bool have_subst = false;
7301 /* Locate the closing } or ;, honoring nested braces.
7302 Trim trailing whitespace. */
7303 body = p;
7304 nesting_level = 1;
7305 for (;;)
7307 if (*p == '{')
7308 nesting_level++;
7309 else if (*p == '}')
7311 if (!--nesting_level)
7312 break;
7314 else if (*p == ';' && nesting_level == 1)
7315 break;
7316 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
7317 have_subst = true;
7318 else if (*p == '\0')
7319 goto invalid;
7320 p++;
7323 end_body = p;
7324 while (end_body[-1] == ' ' || end_body[-1] == '\t')
7325 end_body--;
7327 if (have_subst && !starred)
7328 goto invalid;
7330 if (matched)
7332 /* Copy the substitution body to permanent storage and execute it.
7333 If have_subst is false, this is a simple matter of running the
7334 body through do_spec_1... */
7335 char *string = save_string (body, end_body - body);
7336 if (!have_subst)
7338 if (do_spec_1 (string, 0, NULL) < 0)
7340 free (string);
7341 return 0;
7344 else
7346 /* ... but if have_subst is true, we have to process the
7347 body once for each matching switch, with %* set to the
7348 variant part of the switch. */
7349 unsigned int hard_match_len = end_atom - atom;
7350 int i;
7352 for (i = 0; i < n_switches; i++)
7353 if (!strncmp (switches[i].part1, atom, hard_match_len)
7354 && check_live_switch (i, hard_match_len))
7356 if (do_spec_1 (string, 0,
7357 &switches[i].part1[hard_match_len]) < 0)
7359 free (string);
7360 return 0;
7362 /* Pass any arguments this switch has. */
7363 give_switch (i, 1);
7364 suffix_subst = NULL;
7367 free (string);
7370 return p;
7372 invalid:
7373 fatal_error (input_location, "braced spec body %qs is invalid", body);
7376 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
7377 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
7378 spec, or -1 if either exact match or %* is used.
7380 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
7381 whose value does not begin with "no-" is obsoleted by the same value
7382 with the "no-", similarly for a switch with the "no-" prefix. */
7384 static int
7385 check_live_switch (int switchnum, int prefix_length)
7387 const char *name = switches[switchnum].part1;
7388 int i;
7390 /* If we already processed this switch and determined if it was
7391 live or not, return our past determination. */
7392 if (switches[switchnum].live_cond != 0)
7393 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
7394 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
7395 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
7396 == 0);
7398 /* In the common case of {<at-most-one-letter>*}, a negating
7399 switch would always match, so ignore that case. We will just
7400 send the conflicting switches to the compiler phase. */
7401 if (prefix_length >= 0 && prefix_length <= 1)
7402 return 1;
7404 /* Now search for duplicate in a manner that depends on the name. */
7405 switch (*name)
7407 case 'O':
7408 for (i = switchnum + 1; i < n_switches; i++)
7409 if (switches[i].part1[0] == 'O')
7411 switches[switchnum].validated = true;
7412 switches[switchnum].live_cond = SWITCH_FALSE;
7413 return 0;
7415 break;
7417 case 'W': case 'f': case 'm': case 'g':
7418 if (startswith (name + 1, "no-"))
7420 /* We have Xno-YYY, search for XYYY. */
7421 for (i = switchnum + 1; i < n_switches; i++)
7422 if (switches[i].part1[0] == name[0]
7423 && ! strcmp (&switches[i].part1[1], &name[4]))
7425 /* --specs are validated with the validate_switches mechanism. */
7426 if (switches[switchnum].known)
7427 switches[switchnum].validated = true;
7428 switches[switchnum].live_cond = SWITCH_FALSE;
7429 return 0;
7432 else
7434 /* We have XYYY, search for Xno-YYY. */
7435 for (i = switchnum + 1; i < n_switches; i++)
7436 if (switches[i].part1[0] == name[0]
7437 && switches[i].part1[1] == 'n'
7438 && switches[i].part1[2] == 'o'
7439 && switches[i].part1[3] == '-'
7440 && !strcmp (&switches[i].part1[4], &name[1]))
7442 /* --specs are validated with the validate_switches mechanism. */
7443 if (switches[switchnum].known)
7444 switches[switchnum].validated = true;
7445 switches[switchnum].live_cond = SWITCH_FALSE;
7446 return 0;
7449 break;
7452 /* Otherwise the switch is live. */
7453 switches[switchnum].live_cond |= SWITCH_LIVE;
7454 return 1;
7457 /* Pass a switch to the current accumulating command
7458 in the same form that we received it.
7459 SWITCHNUM identifies the switch; it is an index into
7460 the vector of switches gcc received, which is `switches'.
7461 This cannot fail since it never finishes a command line.
7463 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
7465 static void
7466 give_switch (int switchnum, int omit_first_word)
7468 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
7469 return;
7471 if (!omit_first_word)
7473 do_spec_1 ("-", 0, NULL);
7474 do_spec_1 (switches[switchnum].part1, 1, NULL);
7477 if (switches[switchnum].args != 0)
7479 const char **p;
7480 for (p = switches[switchnum].args; *p; p++)
7482 const char *arg = *p;
7484 do_spec_1 (" ", 0, NULL);
7485 if (suffix_subst)
7487 unsigned length = strlen (arg);
7488 int dot = 0;
7490 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
7491 if (arg[length] == '.')
7493 (CONST_CAST (char *, arg))[length] = 0;
7494 dot = 1;
7495 break;
7497 do_spec_1 (arg, 1, NULL);
7498 if (dot)
7499 (CONST_CAST (char *, arg))[length] = '.';
7500 do_spec_1 (suffix_subst, 1, NULL);
7502 else
7503 do_spec_1 (arg, 1, NULL);
7507 do_spec_1 (" ", 0, NULL);
7508 switches[switchnum].validated = true;
7511 /* Print GCC configuration (e.g. version, thread model, target,
7512 configuration_arguments) to a given FILE. */
7514 static void
7515 print_configuration (FILE *file)
7517 int n;
7518 const char *thrmod;
7520 fnotice (file, "Target: %s\n", spec_machine);
7521 fnotice (file, "Configured with: %s\n", configuration_arguments);
7523 #ifdef THREAD_MODEL_SPEC
7524 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
7525 but there's no point in doing all this processing just to get
7526 thread_model back. */
7527 obstack_init (&obstack);
7528 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
7529 obstack_1grow (&obstack, '\0');
7530 thrmod = XOBFINISH (&obstack, const char *);
7531 #else
7532 thrmod = thread_model;
7533 #endif
7535 fnotice (file, "Thread model: %s\n", thrmod);
7536 fnotice (file, "Supported LTO compression algorithms: zlib");
7537 #ifdef HAVE_ZSTD_H
7538 fnotice (file, " zstd");
7539 #endif
7540 fnotice (file, "\n");
7542 /* compiler_version is truncated at the first space when initialized
7543 from version string, so truncate version_string at the first space
7544 before comparing. */
7545 for (n = 0; version_string[n]; n++)
7546 if (version_string[n] == ' ')
7547 break;
7549 if (! strncmp (version_string, compiler_version, n)
7550 && compiler_version[n] == 0)
7551 fnotice (file, "gcc version %s %s\n", version_string,
7552 pkgversion_string);
7553 else
7554 fnotice (file, "gcc driver version %s %sexecuting gcc version %s\n",
7555 version_string, pkgversion_string, compiler_version);
7559 #define RETRY_ICE_ATTEMPTS 3
7561 /* Returns true if FILE1 and FILE2 contain equivalent data, 0 otherwise. */
7563 static bool
7564 files_equal_p (char *file1, char *file2)
7566 struct stat st1, st2;
7567 off_t n, len;
7568 int fd1, fd2;
7569 const int bufsize = 8192;
7570 char *buf = XNEWVEC (char, bufsize);
7572 fd1 = open (file1, O_RDONLY);
7573 fd2 = open (file2, O_RDONLY);
7575 if (fd1 < 0 || fd2 < 0)
7576 goto error;
7578 if (fstat (fd1, &st1) < 0 || fstat (fd2, &st2) < 0)
7579 goto error;
7581 if (st1.st_size != st2.st_size)
7582 goto error;
7584 for (n = st1.st_size; n; n -= len)
7586 len = n;
7587 if ((int) len > bufsize / 2)
7588 len = bufsize / 2;
7590 if (read (fd1, buf, len) != (int) len
7591 || read (fd2, buf + bufsize / 2, len) != (int) len)
7593 goto error;
7596 if (memcmp (buf, buf + bufsize / 2, len) != 0)
7597 goto error;
7600 free (buf);
7601 close (fd1);
7602 close (fd2);
7604 return 1;
7606 error:
7607 free (buf);
7608 close (fd1);
7609 close (fd2);
7610 return 0;
7613 /* Check that compiler's output doesn't differ across runs.
7614 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are arrays of files, containing
7615 stdout and stderr for each compiler run. Return true if all of
7616 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are equivalent. */
7618 static bool
7619 check_repro (char **temp_stdout_files, char **temp_stderr_files)
7621 int i;
7622 for (i = 0; i < RETRY_ICE_ATTEMPTS - 2; ++i)
7624 if (!files_equal_p (temp_stdout_files[i], temp_stdout_files[i + 1])
7625 || !files_equal_p (temp_stderr_files[i], temp_stderr_files[i + 1]))
7627 fnotice (stderr, "The bug is not reproducible, so it is"
7628 " likely a hardware or OS problem.\n");
7629 break;
7632 return i == RETRY_ICE_ATTEMPTS - 2;
7635 enum attempt_status {
7636 ATTEMPT_STATUS_FAIL_TO_RUN,
7637 ATTEMPT_STATUS_SUCCESS,
7638 ATTEMPT_STATUS_ICE
7642 /* Run compiler with arguments NEW_ARGV to reproduce the ICE, storing stdout
7643 to OUT_TEMP and stderr to ERR_TEMP. If APPEND is TRUE, append to OUT_TEMP
7644 and ERR_TEMP instead of truncating. If EMIT_SYSTEM_INFO is TRUE, also write
7645 GCC configuration into to ERR_TEMP. Return ATTEMPT_STATUS_FAIL_TO_RUN if
7646 compiler failed to run, ATTEMPT_STATUS_ICE if compiled ICE-ed and
7647 ATTEMPT_STATUS_SUCCESS otherwise. */
7649 static enum attempt_status
7650 run_attempt (const char **new_argv, const char *out_temp,
7651 const char *err_temp, int emit_system_info, int append)
7654 if (emit_system_info)
7656 FILE *file_out = fopen (err_temp, "a");
7657 print_configuration (file_out);
7658 fputs ("\n", file_out);
7659 fclose (file_out);
7662 int exit_status;
7663 const char *errmsg;
7664 struct pex_obj *pex;
7665 int err;
7666 int pex_flags = PEX_USE_PIPES | PEX_LAST;
7667 enum attempt_status status = ATTEMPT_STATUS_FAIL_TO_RUN;
7669 if (append)
7670 pex_flags |= PEX_STDOUT_APPEND | PEX_STDERR_APPEND;
7672 pex = pex_init (PEX_USE_PIPES, new_argv[0], NULL);
7673 if (!pex)
7674 fatal_error (input_location, "%<pex_init%> failed: %m");
7676 errmsg = pex_run (pex, pex_flags, new_argv[0],
7677 CONST_CAST2 (char *const *, const char **, &new_argv[1]),
7678 out_temp, err_temp, &err);
7679 if (errmsg != NULL)
7681 errno = err;
7682 fatal_error (input_location,
7683 err ? G_ ("cannot execute %qs: %s: %m")
7684 : G_ ("cannot execute %qs: %s"),
7685 new_argv[0], errmsg);
7688 if (!pex_get_status (pex, 1, &exit_status))
7689 goto out;
7691 switch (WEXITSTATUS (exit_status))
7693 case ICE_EXIT_CODE:
7694 status = ATTEMPT_STATUS_ICE;
7695 break;
7697 case SUCCESS_EXIT_CODE:
7698 status = ATTEMPT_STATUS_SUCCESS;
7699 break;
7701 default:
7705 out:
7706 pex_free (pex);
7707 return status;
7710 /* This routine reads lines from IN file, adds C++ style comments
7711 at the begining of each line and writes result into OUT. */
7713 static void
7714 insert_comments (const char *file_in, const char *file_out)
7716 FILE *in = fopen (file_in, "rb");
7717 FILE *out = fopen (file_out, "wb");
7718 char line[256];
7720 bool add_comment = true;
7721 while (fgets (line, sizeof (line), in))
7723 if (add_comment)
7724 fputs ("// ", out);
7725 fputs (line, out);
7726 add_comment = strchr (line, '\n') != NULL;
7729 fclose (in);
7730 fclose (out);
7733 /* This routine adds preprocessed source code into the given ERR_FILE.
7734 To do this, it adds "-E" to NEW_ARGV and execute RUN_ATTEMPT routine to
7735 add information in report file. RUN_ATTEMPT should return
7736 ATTEMPT_STATUS_SUCCESS, in other case we cannot generate the report. */
7738 static void
7739 do_report_bug (const char **new_argv, const int nargs,
7740 char **out_file, char **err_file)
7742 int i, status;
7743 int fd = open (*out_file, O_RDWR | O_APPEND);
7744 if (fd < 0)
7745 return;
7746 write (fd, "\n//", 3);
7747 for (i = 0; i < nargs; i++)
7749 write (fd, " ", 1);
7750 write (fd, new_argv[i], strlen (new_argv[i]));
7752 write (fd, "\n\n", 2);
7753 close (fd);
7754 new_argv[nargs] = "-E";
7755 new_argv[nargs + 1] = NULL;
7757 status = run_attempt (new_argv, *out_file, *err_file, 0, 1);
7759 if (status == ATTEMPT_STATUS_SUCCESS)
7761 fnotice (stderr, "Preprocessed source stored into %s file,"
7762 " please attach this to your bugreport.\n", *out_file);
7763 /* Make sure it is not deleted. */
7764 free (*out_file);
7765 *out_file = NULL;
7769 /* Try to reproduce ICE. If bug is reproducible, generate report .err file
7770 containing GCC configuration, backtrace, compiler's command line options
7771 and preprocessed source code. */
7773 static void
7774 try_generate_repro (const char **argv)
7776 int i, nargs, out_arg = -1, quiet = 0, attempt;
7777 const char **new_argv;
7778 char *temp_files[RETRY_ICE_ATTEMPTS * 2];
7779 char **temp_stdout_files = &temp_files[0];
7780 char **temp_stderr_files = &temp_files[RETRY_ICE_ATTEMPTS];
7782 if (gcc_input_filename == NULL || ! strcmp (gcc_input_filename, "-"))
7783 return;
7785 for (nargs = 0; argv[nargs] != NULL; ++nargs)
7786 /* Only retry compiler ICEs, not preprocessor ones. */
7787 if (! strcmp (argv[nargs], "-E"))
7788 return;
7789 else if (argv[nargs][0] == '-' && argv[nargs][1] == 'o')
7791 if (out_arg == -1)
7792 out_arg = nargs;
7793 else
7794 return;
7796 /* If the compiler is going to output any time information,
7797 it might varry between invocations. */
7798 else if (! strcmp (argv[nargs], "-quiet"))
7799 quiet = 1;
7800 else if (! strcmp (argv[nargs], "-ftime-report"))
7801 return;
7803 if (out_arg == -1 || !quiet)
7804 return;
7806 memset (temp_files, '\0', sizeof (temp_files));
7807 new_argv = XALLOCAVEC (const char *, nargs + 4);
7808 memcpy (new_argv, argv, (nargs + 1) * sizeof (const char *));
7809 new_argv[nargs++] = "-frandom-seed=0";
7810 new_argv[nargs++] = "-fdump-noaddr";
7811 new_argv[nargs] = NULL;
7812 if (new_argv[out_arg][2] == '\0')
7813 new_argv[out_arg + 1] = "-";
7814 else
7815 new_argv[out_arg] = "-o-";
7817 int status;
7818 for (attempt = 0; attempt < RETRY_ICE_ATTEMPTS; ++attempt)
7820 int emit_system_info = 0;
7821 int append = 0;
7822 temp_stdout_files[attempt] = make_temp_file (".out");
7823 temp_stderr_files[attempt] = make_temp_file (".err");
7825 if (attempt == RETRY_ICE_ATTEMPTS - 1)
7827 append = 1;
7828 emit_system_info = 1;
7831 status = run_attempt (new_argv, temp_stdout_files[attempt],
7832 temp_stderr_files[attempt], emit_system_info,
7833 append);
7835 if (status != ATTEMPT_STATUS_ICE)
7837 fnotice (stderr, "The bug is not reproducible, so it is"
7838 " likely a hardware or OS problem.\n");
7839 goto out;
7843 if (!check_repro (temp_stdout_files, temp_stderr_files))
7844 goto out;
7847 /* Insert commented out backtrace into report file. */
7848 char **stderr_commented = &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1];
7849 insert_comments (temp_stderr_files[RETRY_ICE_ATTEMPTS - 1],
7850 *stderr_commented);
7852 /* In final attempt we append compiler options and preprocesssed code to last
7853 generated .out file with configuration and backtrace. */
7854 char **err = &temp_stderr_files[RETRY_ICE_ATTEMPTS - 1];
7855 do_report_bug (new_argv, nargs, stderr_commented, err);
7858 out:
7859 for (i = 0; i < RETRY_ICE_ATTEMPTS * 2; i++)
7860 if (temp_files[i])
7862 unlink (temp_stdout_files[i]);
7863 free (temp_stdout_files[i]);
7867 /* Search for a file named NAME trying various prefixes including the
7868 user's -B prefix and some standard ones.
7869 Return the absolute file name found. If nothing is found, return NAME. */
7871 static const char *
7872 find_file (const char *name)
7874 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
7875 return newname ? newname : name;
7878 /* Determine whether a directory exists. If LINKER, return 0 for
7879 certain fixed names not needed by the linker. */
7881 static int
7882 is_directory (const char *path1, bool linker)
7884 int len1;
7885 char *path;
7886 char *cp;
7887 struct stat st;
7889 /* Ensure the string ends with "/.". The resulting path will be a
7890 directory even if the given path is a symbolic link. */
7891 len1 = strlen (path1);
7892 path = (char *) alloca (3 + len1);
7893 memcpy (path, path1, len1);
7894 cp = path + len1;
7895 if (!IS_DIR_SEPARATOR (cp[-1]))
7896 *cp++ = DIR_SEPARATOR;
7897 *cp++ = '.';
7898 *cp = '\0';
7900 /* Exclude directories that the linker is known to search. */
7901 if (linker
7902 && IS_DIR_SEPARATOR (path[0])
7903 && ((cp - path == 6
7904 && filename_ncmp (path + 1, "lib", 3) == 0)
7905 || (cp - path == 10
7906 && filename_ncmp (path + 1, "usr", 3) == 0
7907 && IS_DIR_SEPARATOR (path[4])
7908 && filename_ncmp (path + 5, "lib", 3) == 0)))
7909 return 0;
7911 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
7914 /* Set up the various global variables to indicate that we're processing
7915 the input file named FILENAME. */
7917 void
7918 set_input (const char *filename)
7920 const char *p;
7922 gcc_input_filename = filename;
7923 input_filename_length = strlen (gcc_input_filename);
7924 input_basename = lbasename (gcc_input_filename);
7926 /* Find a suffix starting with the last period,
7927 and set basename_length to exclude that suffix. */
7928 basename_length = strlen (input_basename);
7929 suffixed_basename_length = basename_length;
7930 p = input_basename + basename_length;
7931 while (p != input_basename && *p != '.')
7932 --p;
7933 if (*p == '.' && p != input_basename)
7935 basename_length = p - input_basename;
7936 input_suffix = p + 1;
7938 else
7939 input_suffix = "";
7941 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
7942 we will need to do a stat on the gcc_input_filename. The
7943 INPUT_STAT_SET signals that the stat is needed. */
7944 input_stat_set = 0;
7947 /* On fatal signals, delete all the temporary files. */
7949 static void
7950 fatal_signal (int signum)
7952 signal (signum, SIG_DFL);
7953 delete_failure_queue ();
7954 delete_temp_files ();
7955 /* Get the same signal again, this time not handled,
7956 so its normal effect occurs. */
7957 kill (getpid (), signum);
7960 /* Compare the contents of the two files named CMPFILE[0] and
7961 CMPFILE[1]. Return zero if they're identical, nonzero
7962 otherwise. */
7964 static int
7965 compare_files (char *cmpfile[])
7967 int ret = 0;
7968 FILE *temp[2] = { NULL, NULL };
7969 int i;
7971 #if HAVE_MMAP_FILE
7973 size_t length[2];
7974 void *map[2] = { NULL, NULL };
7976 for (i = 0; i < 2; i++)
7978 struct stat st;
7980 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
7982 error ("%s: could not determine length of compare-debug file %s",
7983 gcc_input_filename, cmpfile[i]);
7984 ret = 1;
7985 break;
7988 length[i] = st.st_size;
7991 if (!ret && length[0] != length[1])
7993 error ("%s: %<-fcompare-debug%> failure (length)", gcc_input_filename);
7994 ret = 1;
7997 if (!ret)
7998 for (i = 0; i < 2; i++)
8000 int fd = open (cmpfile[i], O_RDONLY);
8001 if (fd < 0)
8003 error ("%s: could not open compare-debug file %s",
8004 gcc_input_filename, cmpfile[i]);
8005 ret = 1;
8006 break;
8009 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
8010 close (fd);
8012 if (map[i] == (void *) MAP_FAILED)
8014 ret = -1;
8015 break;
8019 if (!ret)
8021 if (memcmp (map[0], map[1], length[0]) != 0)
8023 error ("%s: %<-fcompare-debug%> failure", gcc_input_filename);
8024 ret = 1;
8028 for (i = 0; i < 2; i++)
8029 if (map[i])
8030 munmap ((caddr_t) map[i], length[i]);
8032 if (ret >= 0)
8033 return ret;
8035 ret = 0;
8037 #endif
8039 for (i = 0; i < 2; i++)
8041 temp[i] = fopen (cmpfile[i], "r");
8042 if (!temp[i])
8044 error ("%s: could not open compare-debug file %s",
8045 gcc_input_filename, cmpfile[i]);
8046 ret = 1;
8047 break;
8051 if (!ret && temp[0] && temp[1])
8052 for (;;)
8054 int c0, c1;
8055 c0 = fgetc (temp[0]);
8056 c1 = fgetc (temp[1]);
8058 if (c0 != c1)
8060 error ("%s: %<-fcompare-debug%> failure",
8061 gcc_input_filename);
8062 ret = 1;
8063 break;
8066 if (c0 == EOF)
8067 break;
8070 for (i = 1; i >= 0; i--)
8072 if (temp[i])
8073 fclose (temp[i]);
8076 return ret;
8079 driver::driver (bool can_finalize, bool debug) :
8080 explicit_link_files (NULL),
8081 decoded_options (NULL)
8083 env.init (can_finalize, debug);
8086 driver::~driver ()
8088 XDELETEVEC (explicit_link_files);
8089 XDELETEVEC (decoded_options);
8092 /* driver::main is implemented as a series of driver:: method calls. */
8095 driver::main (int argc, char **argv)
8097 bool early_exit;
8099 set_progname (argv[0]);
8100 expand_at_files (&argc, &argv);
8101 decode_argv (argc, const_cast <const char **> (argv));
8102 global_initializations ();
8103 build_multilib_strings ();
8104 set_up_specs ();
8105 putenv_COLLECT_AS_OPTIONS (assembler_options);
8106 putenv_COLLECT_GCC (argv[0]);
8107 maybe_putenv_COLLECT_LTO_WRAPPER ();
8108 maybe_putenv_OFFLOAD_TARGETS ();
8109 handle_unrecognized_options ();
8111 if (completion)
8113 m_option_proposer.suggest_completion (completion);
8114 return 0;
8117 if (!maybe_print_and_exit ())
8118 return 0;
8120 early_exit = prepare_infiles ();
8121 if (early_exit)
8122 return get_exit_code ();
8124 do_spec_on_infiles ();
8125 maybe_run_linker (argv[0]);
8126 final_actions ();
8127 return get_exit_code ();
8130 /* Locate the final component of argv[0] after any leading path, and set
8131 the program name accordingly. */
8133 void
8134 driver::set_progname (const char *argv0) const
8136 const char *p = argv0 + strlen (argv0);
8137 while (p != argv0 && !IS_DIR_SEPARATOR (p[-1]))
8138 --p;
8139 progname = p;
8141 xmalloc_set_program_name (progname);
8144 /* Expand any @ files within the command-line args,
8145 setting at_file_supplied if any were expanded. */
8147 void
8148 driver::expand_at_files (int *argc, char ***argv) const
8150 char **old_argv = *argv;
8152 expandargv (argc, argv);
8154 /* Determine if any expansions were made. */
8155 if (*argv != old_argv)
8156 at_file_supplied = true;
8159 /* Decode the command-line arguments from argc/argv into the
8160 decoded_options array. */
8162 void
8163 driver::decode_argv (int argc, const char **argv)
8165 init_opts_obstack ();
8166 init_options_struct (&global_options, &global_options_set);
8168 decode_cmdline_options_to_array (argc, argv,
8169 CL_DRIVER,
8170 &decoded_options, &decoded_options_count);
8173 /* Perform various initializations and setup. */
8175 void
8176 driver::global_initializations ()
8178 /* Unlock the stdio streams. */
8179 unlock_std_streams ();
8181 gcc_init_libintl ();
8183 diagnostic_initialize (global_dc, 0);
8184 diagnostic_color_init (global_dc);
8185 diagnostic_urls_init (global_dc);
8187 #ifdef GCC_DRIVER_HOST_INITIALIZATION
8188 /* Perform host dependent initialization when needed. */
8189 GCC_DRIVER_HOST_INITIALIZATION;
8190 #endif
8192 if (atexit (delete_temp_files) != 0)
8193 fatal_error (input_location, "atexit failed");
8195 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
8196 signal (SIGINT, fatal_signal);
8197 #ifdef SIGHUP
8198 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
8199 signal (SIGHUP, fatal_signal);
8200 #endif
8201 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
8202 signal (SIGTERM, fatal_signal);
8203 #ifdef SIGPIPE
8204 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
8205 signal (SIGPIPE, fatal_signal);
8206 #endif
8207 #ifdef SIGCHLD
8208 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
8209 receive the signal. A different setting is inheritable */
8210 signal (SIGCHLD, SIG_DFL);
8211 #endif
8213 /* Parsing and gimplification sometimes need quite large stack.
8214 Increase stack size limits if possible. */
8215 stack_limit_increase (64 * 1024 * 1024);
8217 /* Allocate the argument vector. */
8218 alloc_args ();
8220 obstack_init (&obstack);
8223 /* Build multilib_select, et. al from the separate lines that make up each
8224 multilib selection. */
8226 void
8227 driver::build_multilib_strings () const
8230 const char *p;
8231 const char *const *q = multilib_raw;
8232 int need_space;
8234 obstack_init (&multilib_obstack);
8235 while ((p = *q++) != (char *) 0)
8236 obstack_grow (&multilib_obstack, p, strlen (p));
8238 obstack_1grow (&multilib_obstack, 0);
8239 multilib_select = XOBFINISH (&multilib_obstack, const char *);
8241 q = multilib_matches_raw;
8242 while ((p = *q++) != (char *) 0)
8243 obstack_grow (&multilib_obstack, p, strlen (p));
8245 obstack_1grow (&multilib_obstack, 0);
8246 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
8248 q = multilib_exclusions_raw;
8249 while ((p = *q++) != (char *) 0)
8250 obstack_grow (&multilib_obstack, p, strlen (p));
8252 obstack_1grow (&multilib_obstack, 0);
8253 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
8255 q = multilib_reuse_raw;
8256 while ((p = *q++) != (char *) 0)
8257 obstack_grow (&multilib_obstack, p, strlen (p));
8259 obstack_1grow (&multilib_obstack, 0);
8260 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
8262 need_space = FALSE;
8263 for (size_t i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
8265 if (need_space)
8266 obstack_1grow (&multilib_obstack, ' ');
8267 obstack_grow (&multilib_obstack,
8268 multilib_defaults_raw[i],
8269 strlen (multilib_defaults_raw[i]));
8270 need_space = TRUE;
8273 obstack_1grow (&multilib_obstack, 0);
8274 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
8278 /* Set up the spec-handling machinery. */
8280 void
8281 driver::set_up_specs () const
8283 const char *spec_machine_suffix;
8284 char *specs_file;
8285 size_t i;
8287 #ifdef INIT_ENVIRONMENT
8288 /* Set up any other necessary machine specific environment variables. */
8289 xputenv (INIT_ENVIRONMENT);
8290 #endif
8292 /* Make a table of what switches there are (switches, n_switches).
8293 Make a table of specified input files (infiles, n_infiles).
8294 Decode switches that are handled locally. */
8296 process_command (decoded_options_count, decoded_options);
8298 /* Initialize the vector of specs to just the default.
8299 This means one element containing 0s, as a terminator. */
8301 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
8302 memcpy (compilers, default_compilers, sizeof default_compilers);
8303 n_compilers = n_default_compilers;
8305 /* Read specs from a file if there is one. */
8307 machine_suffix = concat (spec_host_machine, dir_separator_str, spec_version,
8308 accel_dir_suffix, dir_separator_str, NULL);
8309 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
8311 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
8312 /* Read the specs file unless it is a default one. */
8313 if (specs_file != 0 && strcmp (specs_file, "specs"))
8314 read_specs (specs_file, true, false);
8315 else
8316 init_spec ();
8318 #ifdef ACCEL_COMPILER
8319 spec_machine_suffix = machine_suffix;
8320 #else
8321 spec_machine_suffix = just_machine_suffix;
8322 #endif
8324 /* We need to check standard_exec_prefix/spec_machine_suffix/specs
8325 for any override of as, ld and libraries. */
8326 specs_file = (char *) alloca (strlen (standard_exec_prefix)
8327 + strlen (spec_machine_suffix) + sizeof ("specs"));
8328 strcpy (specs_file, standard_exec_prefix);
8329 strcat (specs_file, spec_machine_suffix);
8330 strcat (specs_file, "specs");
8331 if (access (specs_file, R_OK) == 0)
8332 read_specs (specs_file, true, false);
8334 /* Process any configure-time defaults specified for the command line
8335 options, via OPTION_DEFAULT_SPECS. */
8336 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
8337 do_option_spec (option_default_specs[i].name,
8338 option_default_specs[i].spec);
8340 /* Process DRIVER_SELF_SPECS, adding any new options to the end
8341 of the command line. */
8343 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
8344 do_self_spec (driver_self_specs[i]);
8346 /* If not cross-compiling, look for executables in the standard
8347 places. */
8348 if (*cross_compile == '0')
8350 if (*md_exec_prefix)
8352 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
8353 PREFIX_PRIORITY_LAST, 0, 0);
8357 /* Process sysroot_suffix_spec. */
8358 if (*sysroot_suffix_spec != 0
8359 && !no_sysroot_suffix
8360 && do_spec_2 (sysroot_suffix_spec, NULL) == 0)
8362 if (argbuf.length () > 1)
8363 error ("spec failure: more than one argument to "
8364 "%<SYSROOT_SUFFIX_SPEC%>");
8365 else if (argbuf.length () == 1)
8366 target_sysroot_suffix = xstrdup (argbuf.last ());
8369 #ifdef HAVE_LD_SYSROOT
8370 /* Pass the --sysroot option to the linker, if it supports that. If
8371 there is a sysroot_suffix_spec, it has already been processed by
8372 this point, so target_system_root really is the system root we
8373 should be using. */
8374 if (target_system_root)
8376 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
8377 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
8378 set_spec ("link", XOBFINISH (&obstack, const char *), false);
8380 #endif
8382 /* Process sysroot_hdrs_suffix_spec. */
8383 if (*sysroot_hdrs_suffix_spec != 0
8384 && !no_sysroot_suffix
8385 && do_spec_2 (sysroot_hdrs_suffix_spec, NULL) == 0)
8387 if (argbuf.length () > 1)
8388 error ("spec failure: more than one argument "
8389 "to %<SYSROOT_HEADERS_SUFFIX_SPEC%>");
8390 else if (argbuf.length () == 1)
8391 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
8394 /* Look for startfiles in the standard places. */
8395 if (*startfile_prefix_spec != 0
8396 && do_spec_2 (startfile_prefix_spec, NULL) == 0
8397 && do_spec_1 (" ", 0, NULL) == 0)
8399 for (const char *arg : argbuf)
8400 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
8401 PREFIX_PRIORITY_LAST, 0, 1);
8403 /* We should eventually get rid of all these and stick to
8404 startfile_prefix_spec exclusively. */
8405 else if (*cross_compile == '0' || target_system_root)
8407 if (*md_startfile_prefix)
8408 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
8409 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
8411 if (*md_startfile_prefix_1)
8412 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
8413 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
8415 /* If standard_startfile_prefix is relative, base it on
8416 standard_exec_prefix. This lets us move the installed tree
8417 as a unit. If GCC_EXEC_PREFIX is defined, base
8418 standard_startfile_prefix on that as well.
8420 If the prefix is relative, only search it for native compilers;
8421 otherwise we will search a directory containing host libraries. */
8422 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
8423 add_sysrooted_prefix (&startfile_prefixes,
8424 standard_startfile_prefix, "BINUTILS",
8425 PREFIX_PRIORITY_LAST, 0, 1);
8426 else if (*cross_compile == '0')
8428 add_prefix (&startfile_prefixes,
8429 concat (gcc_exec_prefix
8430 ? gcc_exec_prefix : standard_exec_prefix,
8431 machine_suffix,
8432 standard_startfile_prefix, NULL),
8433 NULL, PREFIX_PRIORITY_LAST, 0, 1);
8436 /* Sysrooted prefixes are relocated because target_system_root is
8437 also relocated by gcc_exec_prefix. */
8438 if (*standard_startfile_prefix_1)
8439 add_sysrooted_prefix (&startfile_prefixes,
8440 standard_startfile_prefix_1, "BINUTILS",
8441 PREFIX_PRIORITY_LAST, 0, 1);
8442 if (*standard_startfile_prefix_2)
8443 add_sysrooted_prefix (&startfile_prefixes,
8444 standard_startfile_prefix_2, "BINUTILS",
8445 PREFIX_PRIORITY_LAST, 0, 1);
8448 /* Process any user specified specs in the order given on the command
8449 line. */
8450 for (struct user_specs *uptr = user_specs_head; uptr; uptr = uptr->next)
8452 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
8453 R_OK, true);
8454 read_specs (filename ? filename : uptr->filename, false, true);
8457 /* Process any user self specs. */
8459 struct spec_list *sl;
8460 for (sl = specs; sl; sl = sl->next)
8461 if (sl->name_len == sizeof "self_spec" - 1
8462 && !strcmp (sl->name, "self_spec"))
8463 do_self_spec (*sl->ptr_spec);
8466 if (compare_debug)
8468 enum save_temps save;
8470 if (!compare_debug_second)
8472 n_switches_debug_check[1] = n_switches;
8473 n_switches_alloc_debug_check[1] = n_switches_alloc;
8474 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
8475 n_switches_alloc);
8477 do_self_spec ("%:compare-debug-self-opt()");
8478 n_switches_debug_check[0] = n_switches;
8479 n_switches_alloc_debug_check[0] = n_switches_alloc;
8480 switches_debug_check[0] = switches;
8482 n_switches = n_switches_debug_check[1];
8483 n_switches_alloc = n_switches_alloc_debug_check[1];
8484 switches = switches_debug_check[1];
8487 /* Avoid crash when computing %j in this early. */
8488 save = save_temps_flag;
8489 save_temps_flag = SAVE_TEMPS_NONE;
8491 compare_debug = -compare_debug;
8492 do_self_spec ("%:compare-debug-self-opt()");
8494 save_temps_flag = save;
8496 if (!compare_debug_second)
8498 n_switches_debug_check[1] = n_switches;
8499 n_switches_alloc_debug_check[1] = n_switches_alloc;
8500 switches_debug_check[1] = switches;
8501 compare_debug = -compare_debug;
8502 n_switches = n_switches_debug_check[0];
8503 n_switches_alloc = n_switches_debug_check[0];
8504 switches = switches_debug_check[0];
8509 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
8510 if (gcc_exec_prefix)
8511 gcc_exec_prefix = concat (gcc_exec_prefix, spec_host_machine,
8512 dir_separator_str, spec_version,
8513 accel_dir_suffix, dir_separator_str, NULL);
8515 /* Now we have the specs.
8516 Set the `valid' bits for switches that match anything in any spec. */
8518 validate_all_switches ();
8520 /* Now that we have the switches and the specs, set
8521 the subdirectory based on the options. */
8522 set_multilib_dir ();
8525 /* Set up to remember the pathname of gcc and any options
8526 needed for collect. We use argv[0] instead of progname because
8527 we need the complete pathname. */
8529 void
8530 driver::putenv_COLLECT_GCC (const char *argv0) const
8532 obstack_init (&collect_obstack);
8533 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
8534 obstack_grow (&collect_obstack, argv0, strlen (argv0) + 1);
8535 xputenv (XOBFINISH (&collect_obstack, char *));
8538 /* Set up to remember the pathname of the lto wrapper. */
8540 void
8541 driver::maybe_putenv_COLLECT_LTO_WRAPPER () const
8543 char *lto_wrapper_file;
8545 if (have_c)
8546 lto_wrapper_file = NULL;
8547 else
8548 lto_wrapper_file = find_a_program ("lto-wrapper");
8549 if (lto_wrapper_file)
8551 lto_wrapper_file = convert_white_space (lto_wrapper_file);
8552 set_static_spec_owned (&lto_wrapper_spec, lto_wrapper_file);
8553 obstack_init (&collect_obstack);
8554 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
8555 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
8556 obstack_grow (&collect_obstack, lto_wrapper_spec,
8557 strlen (lto_wrapper_spec) + 1);
8558 xputenv (XOBFINISH (&collect_obstack, char *));
8563 /* Set up to remember the names of offload targets. */
8565 void
8566 driver::maybe_putenv_OFFLOAD_TARGETS () const
8568 if (offload_targets && offload_targets[0] != '\0')
8570 obstack_grow (&collect_obstack, "OFFLOAD_TARGET_NAMES=",
8571 sizeof ("OFFLOAD_TARGET_NAMES=") - 1);
8572 obstack_grow (&collect_obstack, offload_targets,
8573 strlen (offload_targets) + 1);
8574 xputenv (XOBFINISH (&collect_obstack, char *));
8575 #if OFFLOAD_DEFAULTED
8576 if (offload_targets_default)
8577 xputenv ("OFFLOAD_TARGET_DEFAULT=1");
8578 #endif
8581 free (offload_targets);
8582 offload_targets = NULL;
8585 /* Reject switches that no pass was interested in. */
8587 void
8588 driver::handle_unrecognized_options ()
8590 for (size_t i = 0; (int) i < n_switches; i++)
8591 if (! switches[i].validated)
8593 const char *hint = m_option_proposer.suggest_option (switches[i].part1);
8594 if (hint)
8595 error ("unrecognized command-line option %<-%s%>;"
8596 " did you mean %<-%s%>?",
8597 switches[i].part1, hint);
8598 else
8599 error ("unrecognized command-line option %<-%s%>",
8600 switches[i].part1);
8604 /* Handle the various -print-* options, returning 0 if the driver
8605 should exit, or nonzero if the driver should continue. */
8608 driver::maybe_print_and_exit () const
8610 if (print_search_dirs)
8612 printf (_("install: %s%s\n"),
8613 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
8614 gcc_exec_prefix ? "" : machine_suffix);
8615 printf (_("programs: %s\n"),
8616 build_search_list (&exec_prefixes, "", false, false));
8617 printf (_("libraries: %s\n"),
8618 build_search_list (&startfile_prefixes, "", false, true));
8619 return (0);
8622 if (print_file_name)
8624 printf ("%s\n", find_file (print_file_name));
8625 return (0);
8628 if (print_prog_name)
8630 if (use_ld != NULL && ! strcmp (print_prog_name, "ld"))
8632 /* Append USE_LD to the default linker. */
8633 #ifdef DEFAULT_LINKER
8634 char *ld;
8635 # ifdef HAVE_HOST_EXECUTABLE_SUFFIX
8636 int len = (sizeof (DEFAULT_LINKER)
8637 - sizeof (HOST_EXECUTABLE_SUFFIX));
8638 ld = NULL;
8639 if (len > 0)
8641 char *default_linker = xstrdup (DEFAULT_LINKER);
8642 /* Strip HOST_EXECUTABLE_SUFFIX if DEFAULT_LINKER contains
8643 HOST_EXECUTABLE_SUFFIX. */
8644 if (! strcmp (&default_linker[len], HOST_EXECUTABLE_SUFFIX))
8646 default_linker[len] = '\0';
8647 ld = concat (default_linker, use_ld,
8648 HOST_EXECUTABLE_SUFFIX, NULL);
8651 if (ld == NULL)
8652 # endif
8653 ld = concat (DEFAULT_LINKER, use_ld, NULL);
8654 if (access (ld, X_OK) == 0)
8656 printf ("%s\n", ld);
8657 return (0);
8659 #endif
8660 print_prog_name = concat (print_prog_name, use_ld, NULL);
8662 char *newname = find_a_program (print_prog_name);
8663 printf ("%s\n", (newname ? newname : print_prog_name));
8664 return (0);
8667 if (print_multi_lib)
8669 print_multilib_info ();
8670 return (0);
8673 if (print_multi_directory)
8675 if (multilib_dir == NULL)
8676 printf (".\n");
8677 else
8678 printf ("%s\n", multilib_dir);
8679 return (0);
8682 if (print_multiarch)
8684 if (multiarch_dir == NULL)
8685 printf ("\n");
8686 else
8687 printf ("%s\n", multiarch_dir);
8688 return (0);
8691 if (print_sysroot)
8693 if (target_system_root)
8695 if (target_sysroot_suffix)
8696 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
8697 else
8698 printf ("%s\n", target_system_root);
8700 return (0);
8703 if (print_multi_os_directory)
8705 if (multilib_os_dir == NULL)
8706 printf (".\n");
8707 else
8708 printf ("%s\n", multilib_os_dir);
8709 return (0);
8712 if (print_sysroot_headers_suffix)
8714 if (*sysroot_hdrs_suffix_spec)
8716 printf("%s\n", (target_sysroot_hdrs_suffix
8717 ? target_sysroot_hdrs_suffix
8718 : ""));
8719 return (0);
8721 else
8722 /* The error status indicates that only one set of fixed
8723 headers should be built. */
8724 fatal_error (input_location,
8725 "not configured with sysroot headers suffix");
8728 if (print_help_list)
8730 display_help ();
8732 if (! verbose_flag)
8734 printf (_("\nFor bug reporting instructions, please see:\n"));
8735 printf ("%s.\n", bug_report_url);
8737 return (0);
8740 /* We do not exit here. Instead we have created a fake input file
8741 called 'help-dummy' which needs to be compiled, and we pass this
8742 on the various sub-processes, along with the --help switch.
8743 Ensure their output appears after ours. */
8744 fputc ('\n', stdout);
8745 fflush (stdout);
8748 if (print_version)
8750 printf (_("%s %s%s\n"), progname, pkgversion_string,
8751 version_string);
8752 printf ("Copyright %s 2022 Free Software Foundation, Inc.\n",
8753 _("(C)"));
8754 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
8755 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
8756 stdout);
8757 if (! verbose_flag)
8758 return 0;
8760 /* We do not exit here. We use the same mechanism of --help to print
8761 the version of the sub-processes. */
8762 fputc ('\n', stdout);
8763 fflush (stdout);
8766 if (verbose_flag)
8768 print_configuration (stderr);
8769 if (n_infiles == 0)
8770 return (0);
8773 return 1;
8776 /* Figure out what to do with each input file.
8777 Return true if we need to exit early from "main", false otherwise. */
8779 bool
8780 driver::prepare_infiles ()
8782 size_t i;
8783 int lang_n_infiles = 0;
8785 if (n_infiles == added_libraries)
8786 fatal_error (input_location, "no input files");
8788 if (seen_error ())
8789 /* Early exit needed from main. */
8790 return true;
8792 /* Make a place to record the compiler output file names
8793 that correspond to the input files. */
8795 i = n_infiles;
8796 i += lang_specific_extra_outfiles;
8797 outfiles = XCNEWVEC (const char *, i);
8799 /* Record which files were specified explicitly as link input. */
8801 explicit_link_files = XCNEWVEC (char, n_infiles);
8803 combine_inputs = have_o || flag_wpa;
8805 for (i = 0; (int) i < n_infiles; i++)
8807 const char *name = infiles[i].name;
8808 struct compiler *compiler = lookup_compiler (name,
8809 strlen (name),
8810 infiles[i].language);
8812 if (compiler && !(compiler->combinable))
8813 combine_inputs = false;
8815 if (lang_n_infiles > 0 && compiler != input_file_compiler
8816 && infiles[i].language && infiles[i].language[0] != '*')
8817 infiles[i].incompiler = compiler;
8818 else if (compiler)
8820 lang_n_infiles++;
8821 input_file_compiler = compiler;
8822 infiles[i].incompiler = compiler;
8824 else
8826 /* Since there is no compiler for this input file, assume it is a
8827 linker file. */
8828 explicit_link_files[i] = 1;
8829 infiles[i].incompiler = NULL;
8831 infiles[i].compiled = false;
8832 infiles[i].preprocessed = false;
8835 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
8836 fatal_error (input_location,
8837 "cannot specify %<-o%> with %<-c%>, %<-S%> or %<-E%> "
8838 "with multiple files");
8840 /* No early exit needed from main; we can continue. */
8841 return false;
8844 /* Run the spec machinery on each input file. */
8846 void
8847 driver::do_spec_on_infiles () const
8849 size_t i;
8851 for (i = 0; (int) i < n_infiles; i++)
8853 int this_file_error = 0;
8855 /* Tell do_spec what to substitute for %i. */
8857 input_file_number = i;
8858 set_input (infiles[i].name);
8860 if (infiles[i].compiled)
8861 continue;
8863 /* Use the same thing in %o, unless cp->spec says otherwise. */
8865 outfiles[i] = gcc_input_filename;
8867 /* Figure out which compiler from the file's suffix. */
8869 input_file_compiler
8870 = lookup_compiler (infiles[i].name, input_filename_length,
8871 infiles[i].language);
8873 if (input_file_compiler)
8875 /* Ok, we found an applicable compiler. Run its spec. */
8877 if (input_file_compiler->spec[0] == '#')
8879 error ("%s: %s compiler not installed on this system",
8880 gcc_input_filename, &input_file_compiler->spec[1]);
8881 this_file_error = 1;
8883 else
8885 int value;
8887 if (compare_debug)
8889 free (debug_check_temp_file[0]);
8890 debug_check_temp_file[0] = NULL;
8892 free (debug_check_temp_file[1]);
8893 debug_check_temp_file[1] = NULL;
8896 value = do_spec (input_file_compiler->spec);
8897 infiles[i].compiled = true;
8898 if (value < 0)
8899 this_file_error = 1;
8900 else if (compare_debug && debug_check_temp_file[0])
8902 if (verbose_flag)
8903 inform (UNKNOWN_LOCATION,
8904 "recompiling with %<-fcompare-debug%>");
8906 compare_debug = -compare_debug;
8907 n_switches = n_switches_debug_check[1];
8908 n_switches_alloc = n_switches_alloc_debug_check[1];
8909 switches = switches_debug_check[1];
8911 value = do_spec (input_file_compiler->spec);
8913 compare_debug = -compare_debug;
8914 n_switches = n_switches_debug_check[0];
8915 n_switches_alloc = n_switches_alloc_debug_check[0];
8916 switches = switches_debug_check[0];
8918 if (value < 0)
8920 error ("during %<-fcompare-debug%> recompilation");
8921 this_file_error = 1;
8924 gcc_assert (debug_check_temp_file[1]
8925 && filename_cmp (debug_check_temp_file[0],
8926 debug_check_temp_file[1]));
8928 if (verbose_flag)
8929 inform (UNKNOWN_LOCATION, "comparing final insns dumps");
8931 if (compare_files (debug_check_temp_file))
8932 this_file_error = 1;
8935 if (compare_debug)
8937 free (debug_check_temp_file[0]);
8938 debug_check_temp_file[0] = NULL;
8940 free (debug_check_temp_file[1]);
8941 debug_check_temp_file[1] = NULL;
8946 /* If this file's name does not contain a recognized suffix,
8947 record it as explicit linker input. */
8949 else
8950 explicit_link_files[i] = 1;
8952 /* Clear the delete-on-failure queue, deleting the files in it
8953 if this compilation failed. */
8955 if (this_file_error)
8957 delete_failure_queue ();
8958 errorcount++;
8960 /* If this compilation succeeded, don't delete those files later. */
8961 clear_failure_queue ();
8964 /* Reset the input file name to the first compile/object file name, for use
8965 with %b in LINK_SPEC. We use the first input file that we can find
8966 a compiler to compile it instead of using infiles.language since for
8967 languages other than C we use aliases that we then lookup later. */
8968 if (n_infiles > 0)
8970 int i;
8972 for (i = 0; i < n_infiles ; i++)
8973 if (infiles[i].incompiler
8974 || (infiles[i].language && infiles[i].language[0] != '*'))
8976 set_input (infiles[i].name);
8977 break;
8981 if (!seen_error ())
8983 /* Make sure INPUT_FILE_NUMBER points to first available open
8984 slot. */
8985 input_file_number = n_infiles;
8986 if (lang_specific_pre_link ())
8987 errorcount++;
8991 /* If we have to run the linker, do it now. */
8993 void
8994 driver::maybe_run_linker (const char *argv0) const
8996 size_t i;
8997 int linker_was_run = 0;
8998 int num_linker_inputs;
9000 /* Determine if there are any linker input files. */
9001 num_linker_inputs = 0;
9002 for (i = 0; (int) i < n_infiles; i++)
9003 if (explicit_link_files[i] || outfiles[i] != NULL)
9004 num_linker_inputs++;
9006 /* Arrange for temporary file names created during linking to take
9007 on names related with the linker output rather than with the
9008 inputs when appropriate. */
9009 if (outbase && *outbase)
9011 if (dumpdir)
9013 char *tofree = dumpdir;
9014 gcc_checking_assert (strlen (dumpdir) == dumpdir_length);
9015 dumpdir = concat (dumpdir, outbase, ".", NULL);
9016 free (tofree);
9018 else
9019 dumpdir = concat (outbase, ".", NULL);
9020 dumpdir_length += strlen (outbase) + 1;
9021 dumpdir_trailing_dash_added = true;
9023 else if (dumpdir_trailing_dash_added)
9025 gcc_assert (dumpdir[dumpdir_length - 1] == '-');
9026 dumpdir[dumpdir_length - 1] = '.';
9029 if (dumpdir_trailing_dash_added)
9031 gcc_assert (dumpdir_length > 0);
9032 gcc_assert (dumpdir[dumpdir_length - 1] == '.');
9033 dumpdir_length--;
9036 free (outbase);
9037 input_basename = outbase = NULL;
9038 outbase_length = suffixed_basename_length = basename_length = 0;
9040 /* Run ld to link all the compiler output files. */
9042 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
9044 int tmp = execution_count;
9046 detect_jobserver ();
9048 if (! have_c)
9050 #if HAVE_LTO_PLUGIN > 0
9051 #if HAVE_LTO_PLUGIN == 2
9052 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
9053 #else
9054 const char *fuse_linker_plugin = "fuse-linker-plugin";
9055 #endif
9056 #endif
9058 /* We'll use ld if we can't find collect2. */
9059 if (! strcmp (linker_name_spec, "collect2"))
9061 char *s = find_a_program ("collect2");
9062 if (s == NULL)
9063 set_static_spec_shared (&linker_name_spec, "ld");
9066 #if HAVE_LTO_PLUGIN > 0
9067 #if HAVE_LTO_PLUGIN == 2
9068 if (!switch_matches (fno_use_linker_plugin,
9069 fno_use_linker_plugin
9070 + strlen (fno_use_linker_plugin), 0))
9071 #else
9072 if (switch_matches (fuse_linker_plugin,
9073 fuse_linker_plugin
9074 + strlen (fuse_linker_plugin), 0))
9075 #endif
9077 char *temp_spec = find_a_file (&exec_prefixes,
9078 LTOPLUGINSONAME, R_OK,
9079 false);
9080 if (!temp_spec)
9081 fatal_error (input_location,
9082 "%<-fuse-linker-plugin%>, but %s not found",
9083 LTOPLUGINSONAME);
9084 linker_plugin_file_spec = convert_white_space (temp_spec);
9086 #endif
9087 set_static_spec_shared (&lto_gcc_spec, argv0);
9090 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
9091 for collect. */
9092 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
9093 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
9095 if (print_subprocess_help == 1)
9097 printf (_("\nLinker options\n==============\n\n"));
9098 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
9099 " to the linker.\n\n"));
9100 fflush (stdout);
9102 int value = do_spec (link_command_spec);
9103 if (value < 0)
9104 errorcount = 1;
9105 linker_was_run = (tmp != execution_count);
9108 /* If options said don't run linker,
9109 complain about input files to be given to the linker. */
9111 if (! linker_was_run && !seen_error ())
9112 for (i = 0; (int) i < n_infiles; i++)
9113 if (explicit_link_files[i]
9114 && !(infiles[i].language && infiles[i].language[0] == '*'))
9116 warning (0, "%s: linker input file unused because linking not done",
9117 outfiles[i]);
9118 if (access (outfiles[i], F_OK) < 0)
9119 /* This is can be an indication the user specifed an errorneous
9120 separated option value, (or used the wrong prefix for an
9121 option). */
9122 error ("%s: linker input file not found: %m", outfiles[i]);
9126 /* The end of "main". */
9128 void
9129 driver::final_actions () const
9131 /* Delete some or all of the temporary files we made. */
9133 if (seen_error ())
9134 delete_failure_queue ();
9135 delete_temp_files ();
9137 if (print_help_list)
9139 printf (("\nFor bug reporting instructions, please see:\n"));
9140 printf ("%s\n", bug_report_url);
9144 /* Detect whether jobserver is active and working. If not drop
9145 --jobserver-auth from MAKEFLAGS. */
9147 void
9148 driver::detect_jobserver () const
9150 jobserver_info jinfo;
9151 if (!jinfo.is_active && !jinfo.skipped_makeflags.empty ())
9152 xputenv (xstrdup (jinfo.skipped_makeflags.c_str ()));
9155 /* Determine what the exit code of the driver should be. */
9158 driver::get_exit_code () const
9160 return (signal_count != 0 ? 2
9161 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
9162 : 0);
9165 /* Find the proper compilation spec for the file name NAME,
9166 whose length is LENGTH. LANGUAGE is the specified language,
9167 or 0 if this file is to be passed to the linker. */
9169 static struct compiler *
9170 lookup_compiler (const char *name, size_t length, const char *language)
9172 struct compiler *cp;
9174 /* If this was specified by the user to be a linker input, indicate that. */
9175 if (language != 0 && language[0] == '*')
9176 return 0;
9178 /* Otherwise, look for the language, if one is spec'd. */
9179 if (language != 0)
9181 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
9182 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
9184 if (name != NULL && strcmp (name, "-") == 0
9185 && (strcmp (cp->suffix, "@c-header") == 0
9186 || strcmp (cp->suffix, "@c++-header") == 0)
9187 && !have_E)
9188 fatal_error (input_location,
9189 "cannot use %<-%> as input filename for a "
9190 "precompiled header");
9192 return cp;
9195 error ("language %s not recognized", language);
9196 return 0;
9199 /* Look for a suffix. */
9200 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
9202 if (/* The suffix `-' matches only the file name `-'. */
9203 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
9204 || (strlen (cp->suffix) < length
9205 /* See if the suffix matches the end of NAME. */
9206 && !strcmp (cp->suffix,
9207 name + length - strlen (cp->suffix))
9209 break;
9212 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
9213 /* Look again, but case-insensitively this time. */
9214 if (cp < compilers)
9215 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
9217 if (/* The suffix `-' matches only the file name `-'. */
9218 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
9219 || (strlen (cp->suffix) < length
9220 /* See if the suffix matches the end of NAME. */
9221 && ((!strcmp (cp->suffix,
9222 name + length - strlen (cp->suffix))
9223 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
9224 && !strcasecmp (cp->suffix,
9225 name + length - strlen (cp->suffix)))
9227 break;
9229 #endif
9231 if (cp >= compilers)
9233 if (cp->spec[0] != '@')
9234 /* A non-alias entry: return it. */
9235 return cp;
9237 /* An alias entry maps a suffix to a language.
9238 Search for the language; pass 0 for NAME and LENGTH
9239 to avoid infinite recursion if language not found. */
9240 return lookup_compiler (NULL, 0, cp->spec + 1);
9242 return 0;
9245 static char *
9246 save_string (const char *s, int len)
9248 char *result = XNEWVEC (char, len + 1);
9250 gcc_checking_assert (strlen (s) >= (unsigned int) len);
9251 memcpy (result, s, len);
9252 result[len] = 0;
9253 return result;
9257 static inline void
9258 validate_switches_from_spec (const char *spec, bool user)
9260 const char *p = spec;
9261 char c;
9262 while ((c = *p++))
9263 if (c == '%'
9264 && (*p == '{'
9265 || *p == '<'
9266 || (*p == 'W' && *++p == '{')
9267 || (*p == '@' && *++p == '{')))
9268 /* We have a switch spec. */
9269 p = validate_switches (p + 1, user, *p == '{');
9272 static void
9273 validate_all_switches (void)
9275 struct compiler *comp;
9276 struct spec_list *spec;
9278 for (comp = compilers; comp->spec; comp++)
9279 validate_switches_from_spec (comp->spec, false);
9281 /* Look through the linked list of specs read from the specs file. */
9282 for (spec = specs; spec; spec = spec->next)
9283 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
9285 validate_switches_from_spec (link_command_spec, false);
9288 /* Look at the switch-name that comes after START and mark as valid
9289 all supplied switches that match it. If BRACED, handle other
9290 switches after '|' and '&', and specs after ':' until ';' or '}',
9291 going back for more switches after ';'. Without BRACED, handle
9292 only one atom. Return a pointer to whatever follows the handled
9293 items, after the closing brace if BRACED. */
9295 static const char *
9296 validate_switches (const char *start, bool user_spec, bool braced)
9298 const char *p = start;
9299 const char *atom;
9300 size_t len;
9301 int i;
9302 bool suffix = false;
9303 bool starred = false;
9305 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
9307 next_member:
9308 SKIP_WHITE ();
9310 if (*p == '!')
9311 p++;
9313 SKIP_WHITE ();
9314 if (*p == '.' || *p == ',')
9315 suffix = true, p++;
9317 atom = p;
9318 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
9319 || *p == ',' || *p == '.' || *p == '@')
9320 p++;
9321 len = p - atom;
9323 if (*p == '*')
9324 starred = true, p++;
9326 SKIP_WHITE ();
9328 if (!suffix)
9330 /* Mark all matching switches as valid. */
9331 for (i = 0; i < n_switches; i++)
9332 if (!strncmp (switches[i].part1, atom, len)
9333 && (starred || switches[i].part1[len] == '\0')
9334 && (switches[i].known || user_spec))
9335 switches[i].validated = true;
9338 if (!braced)
9339 return p;
9341 if (*p) p++;
9342 if (*p && (p[-1] == '|' || p[-1] == '&'))
9343 goto next_member;
9345 if (*p && p[-1] == ':')
9347 while (*p && *p != ';' && *p != '}')
9349 if (*p == '%')
9351 p++;
9352 if (*p == '{' || *p == '<')
9353 p = validate_switches (p+1, user_spec, *p == '{');
9354 else if (p[0] == 'W' && p[1] == '{')
9355 p = validate_switches (p+2, user_spec, true);
9356 else if (p[0] == '@' && p[1] == '{')
9357 p = validate_switches (p+2, user_spec, true);
9359 else
9360 p++;
9363 if (*p) p++;
9364 if (*p && p[-1] == ';')
9365 goto next_member;
9368 return p;
9369 #undef SKIP_WHITE
9372 struct mdswitchstr
9374 const char *str;
9375 int len;
9378 static struct mdswitchstr *mdswitches;
9379 static int n_mdswitches;
9381 /* Check whether a particular argument was used. The first time we
9382 canonicalize the switches to keep only the ones we care about. */
9384 struct used_arg_t
9386 public:
9387 int operator () (const char *p, int len);
9388 void finalize ();
9390 private:
9391 struct mswitchstr
9393 const char *str;
9394 const char *replace;
9395 int len;
9396 int rep_len;
9399 mswitchstr *mswitches;
9400 int n_mswitches;
9404 used_arg_t used_arg;
9407 used_arg_t::operator () (const char *p, int len)
9409 int i, j;
9411 if (!mswitches)
9413 struct mswitchstr *matches;
9414 const char *q;
9415 int cnt = 0;
9417 /* Break multilib_matches into the component strings of string
9418 and replacement string. */
9419 for (q = multilib_matches; *q != '\0'; q++)
9420 if (*q == ';')
9421 cnt++;
9423 matches
9424 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
9425 i = 0;
9426 q = multilib_matches;
9427 while (*q != '\0')
9429 matches[i].str = q;
9430 while (*q != ' ')
9432 if (*q == '\0')
9434 invalid_matches:
9435 fatal_error (input_location, "multilib spec %qs is invalid",
9436 multilib_matches);
9438 q++;
9440 matches[i].len = q - matches[i].str;
9442 matches[i].replace = ++q;
9443 while (*q != ';' && *q != '\0')
9445 if (*q == ' ')
9446 goto invalid_matches;
9447 q++;
9449 matches[i].rep_len = q - matches[i].replace;
9450 i++;
9451 if (*q == ';')
9452 q++;
9455 /* Now build a list of the replacement string for switches that we care
9456 about. Make sure we allocate at least one entry. This prevents
9457 xmalloc from calling fatal, and prevents us from re-executing this
9458 block of code. */
9459 mswitches
9460 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
9461 for (i = 0; i < n_switches; i++)
9462 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
9464 int xlen = strlen (switches[i].part1);
9465 for (j = 0; j < cnt; j++)
9466 if (xlen == matches[j].len
9467 && ! strncmp (switches[i].part1, matches[j].str, xlen))
9469 mswitches[n_mswitches].str = matches[j].replace;
9470 mswitches[n_mswitches].len = matches[j].rep_len;
9471 mswitches[n_mswitches].replace = (char *) 0;
9472 mswitches[n_mswitches].rep_len = 0;
9473 n_mswitches++;
9474 break;
9478 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
9479 on the command line nor any options mutually incompatible with
9480 them. */
9481 for (i = 0; i < n_mdswitches; i++)
9483 const char *r;
9485 for (q = multilib_options; *q != '\0'; *q && q++)
9487 while (*q == ' ')
9488 q++;
9490 r = q;
9491 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
9492 || strchr (" /", q[mdswitches[i].len]) == NULL)
9494 while (*q != ' ' && *q != '/' && *q != '\0')
9495 q++;
9496 if (*q != '/')
9497 break;
9498 q++;
9501 if (*q != ' ' && *q != '\0')
9503 while (*r != ' ' && *r != '\0')
9505 q = r;
9506 while (*q != ' ' && *q != '/' && *q != '\0')
9507 q++;
9509 if (used_arg (r, q - r))
9510 break;
9512 if (*q != '/')
9514 mswitches[n_mswitches].str = mdswitches[i].str;
9515 mswitches[n_mswitches].len = mdswitches[i].len;
9516 mswitches[n_mswitches].replace = (char *) 0;
9517 mswitches[n_mswitches].rep_len = 0;
9518 n_mswitches++;
9519 break;
9522 r = q + 1;
9524 break;
9530 for (i = 0; i < n_mswitches; i++)
9531 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
9532 return 1;
9534 return 0;
9537 void used_arg_t::finalize ()
9539 XDELETEVEC (mswitches);
9540 mswitches = NULL;
9541 n_mswitches = 0;
9545 static int
9546 default_arg (const char *p, int len)
9548 int i;
9550 for (i = 0; i < n_mdswitches; i++)
9551 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
9552 return 1;
9554 return 0;
9557 /* Work out the subdirectory to use based on the options. The format of
9558 multilib_select is a list of elements. Each element is a subdirectory
9559 name followed by a list of options followed by a semicolon. The format
9560 of multilib_exclusions is the same, but without the preceding
9561 directory. First gcc will check the exclusions, if none of the options
9562 beginning with an exclamation point are present, and all of the other
9563 options are present, then we will ignore this completely. Passing
9564 that, gcc will consider each multilib_select in turn using the same
9565 rules for matching the options. If a match is found, that subdirectory
9566 will be used.
9567 A subdirectory name is optionally followed by a colon and the corresponding
9568 multiarch name. */
9570 static void
9571 set_multilib_dir (void)
9573 const char *p;
9574 unsigned int this_path_len;
9575 const char *this_path, *this_arg;
9576 const char *start, *end;
9577 int not_arg;
9578 int ok, ndfltok, first;
9580 n_mdswitches = 0;
9581 start = multilib_defaults;
9582 while (*start == ' ' || *start == '\t')
9583 start++;
9584 while (*start != '\0')
9586 n_mdswitches++;
9587 while (*start != ' ' && *start != '\t' && *start != '\0')
9588 start++;
9589 while (*start == ' ' || *start == '\t')
9590 start++;
9593 if (n_mdswitches)
9595 int i = 0;
9597 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
9598 for (start = multilib_defaults; *start != '\0'; start = end + 1)
9600 while (*start == ' ' || *start == '\t')
9601 start++;
9603 if (*start == '\0')
9604 break;
9606 for (end = start + 1;
9607 *end != ' ' && *end != '\t' && *end != '\0'; end++)
9610 obstack_grow (&multilib_obstack, start, end - start);
9611 obstack_1grow (&multilib_obstack, 0);
9612 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
9613 mdswitches[i++].len = end - start;
9615 if (*end == '\0')
9616 break;
9620 p = multilib_exclusions;
9621 while (*p != '\0')
9623 /* Ignore newlines. */
9624 if (*p == '\n')
9626 ++p;
9627 continue;
9630 /* Check the arguments. */
9631 ok = 1;
9632 while (*p != ';')
9634 if (*p == '\0')
9636 invalid_exclusions:
9637 fatal_error (input_location, "multilib exclusions %qs is invalid",
9638 multilib_exclusions);
9641 if (! ok)
9643 ++p;
9644 continue;
9647 this_arg = p;
9648 while (*p != ' ' && *p != ';')
9650 if (*p == '\0')
9651 goto invalid_exclusions;
9652 ++p;
9655 if (*this_arg != '!')
9656 not_arg = 0;
9657 else
9659 not_arg = 1;
9660 ++this_arg;
9663 ok = used_arg (this_arg, p - this_arg);
9664 if (not_arg)
9665 ok = ! ok;
9667 if (*p == ' ')
9668 ++p;
9671 if (ok)
9672 return;
9674 ++p;
9677 first = 1;
9678 p = multilib_select;
9680 /* Append multilib reuse rules if any. With those rules, we can reuse
9681 one multilib for certain different options sets. */
9682 if (strlen (multilib_reuse) > 0)
9683 p = concat (p, multilib_reuse, NULL);
9685 while (*p != '\0')
9687 /* Ignore newlines. */
9688 if (*p == '\n')
9690 ++p;
9691 continue;
9694 /* Get the initial path. */
9695 this_path = p;
9696 while (*p != ' ')
9698 if (*p == '\0')
9700 invalid_select:
9701 fatal_error (input_location, "multilib select %qs %qs is invalid",
9702 multilib_select, multilib_reuse);
9704 ++p;
9706 this_path_len = p - this_path;
9708 /* Check the arguments. */
9709 ok = 1;
9710 ndfltok = 1;
9711 ++p;
9712 while (*p != ';')
9714 if (*p == '\0')
9715 goto invalid_select;
9717 if (! ok)
9719 ++p;
9720 continue;
9723 this_arg = p;
9724 while (*p != ' ' && *p != ';')
9726 if (*p == '\0')
9727 goto invalid_select;
9728 ++p;
9731 if (*this_arg != '!')
9732 not_arg = 0;
9733 else
9735 not_arg = 1;
9736 ++this_arg;
9739 /* If this is a default argument, we can just ignore it.
9740 This is true even if this_arg begins with '!'. Beginning
9741 with '!' does not mean that this argument is necessarily
9742 inappropriate for this library: it merely means that
9743 there is a more specific library which uses this
9744 argument. If this argument is a default, we need not
9745 consider that more specific library. */
9746 ok = used_arg (this_arg, p - this_arg);
9747 if (not_arg)
9748 ok = ! ok;
9750 if (! ok)
9751 ndfltok = 0;
9753 if (default_arg (this_arg, p - this_arg))
9754 ok = 1;
9756 if (*p == ' ')
9757 ++p;
9760 if (ok && first)
9762 if (this_path_len != 1
9763 || this_path[0] != '.')
9765 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
9766 char *q;
9768 strncpy (new_multilib_dir, this_path, this_path_len);
9769 new_multilib_dir[this_path_len] = '\0';
9770 q = strchr (new_multilib_dir, ':');
9771 if (q != NULL)
9772 *q = '\0';
9773 multilib_dir = new_multilib_dir;
9775 first = 0;
9778 if (ndfltok)
9780 const char *q = this_path, *end = this_path + this_path_len;
9782 while (q < end && *q != ':')
9783 q++;
9784 if (q < end)
9786 const char *q2 = q + 1, *ml_end = end;
9787 char *new_multilib_os_dir;
9789 while (q2 < end && *q2 != ':')
9790 q2++;
9791 if (*q2 == ':')
9792 ml_end = q2;
9793 if (ml_end - q == 1)
9794 multilib_os_dir = xstrdup (".");
9795 else
9797 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
9798 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
9799 new_multilib_os_dir[ml_end - q - 1] = '\0';
9800 multilib_os_dir = new_multilib_os_dir;
9803 if (q2 < end && *q2 == ':')
9805 char *new_multiarch_dir = XNEWVEC (char, end - q2);
9806 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
9807 new_multiarch_dir[end - q2 - 1] = '\0';
9808 multiarch_dir = new_multiarch_dir;
9810 break;
9814 ++p;
9817 multilib_dir =
9818 targetm_common.compute_multilib (
9819 switches,
9820 n_switches,
9821 multilib_dir,
9822 multilib_defaults,
9823 multilib_select,
9824 multilib_matches,
9825 multilib_exclusions,
9826 multilib_reuse);
9828 if (multilib_dir == NULL && multilib_os_dir != NULL
9829 && strcmp (multilib_os_dir, ".") == 0)
9831 free (CONST_CAST (char *, multilib_os_dir));
9832 multilib_os_dir = NULL;
9834 else if (multilib_dir != NULL && multilib_os_dir == NULL)
9835 multilib_os_dir = multilib_dir;
9838 /* Print out the multiple library subdirectory selection
9839 information. This prints out a series of lines. Each line looks
9840 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
9841 required. Only the desired options are printed out, the negative
9842 matches. The options are print without a leading dash. There are
9843 no spaces to make it easy to use the information in the shell.
9844 Each subdirectory is printed only once. This assumes the ordering
9845 generated by the genmultilib script. Also, we leave out ones that match
9846 the exclusions. */
9848 static void
9849 print_multilib_info (void)
9851 const char *p = multilib_select;
9852 const char *last_path = 0, *this_path;
9853 int skip;
9854 int not_arg;
9855 unsigned int last_path_len = 0;
9857 while (*p != '\0')
9859 skip = 0;
9860 /* Ignore newlines. */
9861 if (*p == '\n')
9863 ++p;
9864 continue;
9867 /* Get the initial path. */
9868 this_path = p;
9869 while (*p != ' ')
9871 if (*p == '\0')
9873 invalid_select:
9874 fatal_error (input_location,
9875 "multilib select %qs is invalid", multilib_select);
9878 ++p;
9881 /* When --disable-multilib was used but target defines
9882 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
9883 with .:: for multiarch configurations) are there just to find
9884 multilib_os_dir, so skip them from output. */
9885 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
9886 skip = 1;
9888 /* Check for matches with the multilib_exclusions. We don't bother
9889 with the '!' in either list. If any of the exclusion rules match
9890 all of its options with the select rule, we skip it. */
9892 const char *e = multilib_exclusions;
9893 const char *this_arg;
9895 while (*e != '\0')
9897 int m = 1;
9898 /* Ignore newlines. */
9899 if (*e == '\n')
9901 ++e;
9902 continue;
9905 /* Check the arguments. */
9906 while (*e != ';')
9908 const char *q;
9909 int mp = 0;
9911 if (*e == '\0')
9913 invalid_exclusion:
9914 fatal_error (input_location,
9915 "multilib exclusion %qs is invalid",
9916 multilib_exclusions);
9919 if (! m)
9921 ++e;
9922 continue;
9925 this_arg = e;
9927 while (*e != ' ' && *e != ';')
9929 if (*e == '\0')
9930 goto invalid_exclusion;
9931 ++e;
9934 q = p + 1;
9935 while (*q != ';')
9937 const char *arg;
9938 int len = e - this_arg;
9940 if (*q == '\0')
9941 goto invalid_select;
9943 arg = q;
9945 while (*q != ' ' && *q != ';')
9947 if (*q == '\0')
9948 goto invalid_select;
9949 ++q;
9952 if (! strncmp (arg, this_arg,
9953 (len < q - arg) ? q - arg : len)
9954 || default_arg (this_arg, e - this_arg))
9956 mp = 1;
9957 break;
9960 if (*q == ' ')
9961 ++q;
9964 if (! mp)
9965 m = 0;
9967 if (*e == ' ')
9968 ++e;
9971 if (m)
9973 skip = 1;
9974 break;
9977 if (*e != '\0')
9978 ++e;
9982 if (! skip)
9984 /* If this is a duplicate, skip it. */
9985 skip = (last_path != 0
9986 && (unsigned int) (p - this_path) == last_path_len
9987 && ! filename_ncmp (last_path, this_path, last_path_len));
9989 last_path = this_path;
9990 last_path_len = p - this_path;
9993 /* If all required arguments are default arguments, and no default
9994 arguments appear in the ! argument list, then we can skip it.
9995 We will already have printed a directory identical to this one
9996 which does not require that default argument. */
9997 if (! skip)
9999 const char *q;
10000 bool default_arg_ok = false;
10002 q = p + 1;
10003 while (*q != ';')
10005 const char *arg;
10007 if (*q == '\0')
10008 goto invalid_select;
10010 if (*q == '!')
10012 not_arg = 1;
10013 q++;
10015 else
10016 not_arg = 0;
10017 arg = q;
10019 while (*q != ' ' && *q != ';')
10021 if (*q == '\0')
10022 goto invalid_select;
10023 ++q;
10026 if (default_arg (arg, q - arg))
10028 /* Stop checking if any default arguments appeared in not
10029 list. */
10030 if (not_arg)
10032 default_arg_ok = false;
10033 break;
10036 default_arg_ok = true;
10038 else if (!not_arg)
10040 /* Stop checking if any required argument is not provided by
10041 default arguments. */
10042 default_arg_ok = false;
10043 break;
10046 if (*q == ' ')
10047 ++q;
10050 /* Make sure all default argument is OK for this multi-lib set. */
10051 if (default_arg_ok)
10052 skip = 1;
10053 else
10054 skip = 0;
10057 if (! skip)
10059 const char *p1;
10061 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
10062 putchar (*p1);
10063 putchar (';');
10066 ++p;
10067 while (*p != ';')
10069 int use_arg;
10071 if (*p == '\0')
10072 goto invalid_select;
10074 if (skip)
10076 ++p;
10077 continue;
10080 use_arg = *p != '!';
10082 if (use_arg)
10083 putchar ('@');
10085 while (*p != ' ' && *p != ';')
10087 if (*p == '\0')
10088 goto invalid_select;
10089 if (use_arg)
10090 putchar (*p);
10091 ++p;
10094 if (*p == ' ')
10095 ++p;
10098 if (! skip)
10100 /* If there are extra options, print them now. */
10101 if (multilib_extra && *multilib_extra)
10103 int print_at = TRUE;
10104 const char *q;
10106 for (q = multilib_extra; *q != '\0'; q++)
10108 if (*q == ' ')
10109 print_at = TRUE;
10110 else
10112 if (print_at)
10113 putchar ('@');
10114 putchar (*q);
10115 print_at = FALSE;
10120 putchar ('\n');
10123 ++p;
10127 /* getenv built-in spec function.
10129 Returns the value of the environment variable given by its first argument,
10130 concatenated with the second argument. If the variable is not defined, a
10131 fatal error is issued unless such undefs are internally allowed, in which
10132 case the variable name prefixed by a '/' is used as the variable value.
10134 The leading '/' allows using the result at a spot where a full path would
10135 normally be expected and when the actual value doesn't really matter since
10136 undef vars are allowed. */
10138 static const char *
10139 getenv_spec_function (int argc, const char **argv)
10141 const char *value;
10142 const char *varname;
10144 char *result;
10145 char *ptr;
10146 size_t len;
10148 if (argc != 2)
10149 return NULL;
10151 varname = argv[0];
10152 value = env.get (varname);
10154 /* If the variable isn't defined and this is allowed, craft our expected
10155 return value. Assume variable names used in specs strings don't contain
10156 any active spec character so don't need escaping. */
10157 if (!value && spec_undefvar_allowed)
10159 result = XNEWVAR (char, strlen(varname) + 2);
10160 sprintf (result, "/%s", varname);
10161 return result;
10164 if (!value)
10165 fatal_error (input_location,
10166 "environment variable %qs not defined", varname);
10168 /* We have to escape every character of the environment variable so
10169 they are not interpreted as active spec characters. A
10170 particularly painful case is when we are reading a variable
10171 holding a windows path complete with \ separators. */
10172 len = strlen (value) * 2 + strlen (argv[1]) + 1;
10173 result = XNEWVAR (char, len);
10174 for (ptr = result; *value; ptr += 2)
10176 ptr[0] = '\\';
10177 ptr[1] = *value++;
10180 strcpy (ptr, argv[1]);
10182 return result;
10185 /* if-exists built-in spec function.
10187 Checks to see if the file specified by the absolute pathname in
10188 ARGS exists. Returns that pathname if found.
10190 The usual use for this function is to check for a library file
10191 (whose name has been expanded with %s). */
10193 static const char *
10194 if_exists_spec_function (int argc, const char **argv)
10196 /* Must have only one argument. */
10197 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
10198 return argv[0];
10200 return NULL;
10203 /* if-exists-else built-in spec function.
10205 This is like if-exists, but takes an additional argument which
10206 is returned if the first argument does not exist. */
10208 static const char *
10209 if_exists_else_spec_function (int argc, const char **argv)
10211 /* Must have exactly two arguments. */
10212 if (argc != 2)
10213 return NULL;
10215 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
10216 return argv[0];
10218 return argv[1];
10221 /* if-exists-then-else built-in spec function.
10223 Checks to see if the file specified by the absolute pathname in
10224 the first arg exists. Returns the second arg if so, otherwise returns
10225 the third arg if it is present. */
10227 static const char *
10228 if_exists_then_else_spec_function (int argc, const char **argv)
10231 /* Must have two or three arguments. */
10232 if (argc != 2 && argc != 3)
10233 return NULL;
10235 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
10236 return argv[1];
10238 if (argc == 3)
10239 return argv[2];
10241 return NULL;
10244 /* sanitize built-in spec function.
10246 This returns non-NULL, if sanitizing address, thread or
10247 any of the undefined behavior sanitizers. */
10249 static const char *
10250 sanitize_spec_function (int argc, const char **argv)
10252 if (argc != 1)
10253 return NULL;
10255 if (strcmp (argv[0], "address") == 0)
10256 return (flag_sanitize & SANITIZE_USER_ADDRESS) ? "" : NULL;
10257 if (strcmp (argv[0], "hwaddress") == 0)
10258 return (flag_sanitize & SANITIZE_USER_HWADDRESS) ? "" : NULL;
10259 if (strcmp (argv[0], "kernel-address") == 0)
10260 return (flag_sanitize & SANITIZE_KERNEL_ADDRESS) ? "" : NULL;
10261 if (strcmp (argv[0], "kernel-hwaddress") == 0)
10262 return (flag_sanitize & SANITIZE_KERNEL_HWADDRESS) ? "" : NULL;
10263 if (strcmp (argv[0], "thread") == 0)
10264 return (flag_sanitize & SANITIZE_THREAD) ? "" : NULL;
10265 if (strcmp (argv[0], "undefined") == 0)
10266 return ((flag_sanitize
10267 & ~flag_sanitize_trap
10268 & (SANITIZE_UNDEFINED | SANITIZE_UNDEFINED_NONDEFAULT)))
10269 ? "" : NULL;
10270 if (strcmp (argv[0], "leak") == 0)
10271 return ((flag_sanitize
10272 & (SANITIZE_ADDRESS | SANITIZE_LEAK | SANITIZE_THREAD))
10273 == SANITIZE_LEAK) ? "" : NULL;
10274 return NULL;
10277 /* replace-outfile built-in spec function.
10279 This looks for the first argument in the outfiles array's name and
10280 replaces it with the second argument. */
10282 static const char *
10283 replace_outfile_spec_function (int argc, const char **argv)
10285 int i;
10286 /* Must have exactly two arguments. */
10287 if (argc != 2)
10288 abort ();
10290 for (i = 0; i < n_infiles; i++)
10292 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
10293 outfiles[i] = xstrdup (argv[1]);
10295 return NULL;
10298 /* remove-outfile built-in spec function.
10300 * This looks for the first argument in the outfiles array's name and
10301 * removes it. */
10303 static const char *
10304 remove_outfile_spec_function (int argc, const char **argv)
10306 int i;
10307 /* Must have exactly one argument. */
10308 if (argc != 1)
10309 abort ();
10311 for (i = 0; i < n_infiles; i++)
10313 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
10314 outfiles[i] = NULL;
10316 return NULL;
10319 /* Given two version numbers, compares the two numbers.
10320 A version number must match the regular expression
10321 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
10323 static int
10324 compare_version_strings (const char *v1, const char *v2)
10326 int rresult;
10327 regex_t r;
10329 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
10330 REG_EXTENDED | REG_NOSUB) != 0)
10331 abort ();
10332 rresult = regexec (&r, v1, 0, NULL, 0);
10333 if (rresult == REG_NOMATCH)
10334 fatal_error (input_location, "invalid version number %qs", v1);
10335 else if (rresult != 0)
10336 abort ();
10337 rresult = regexec (&r, v2, 0, NULL, 0);
10338 if (rresult == REG_NOMATCH)
10339 fatal_error (input_location, "invalid version number %qs", v2);
10340 else if (rresult != 0)
10341 abort ();
10343 return strverscmp (v1, v2);
10347 /* version_compare built-in spec function.
10349 This takes an argument of the following form:
10351 <comparison-op> <arg1> [<arg2>] <switch> <result>
10353 and produces "result" if the comparison evaluates to true,
10354 and nothing if it doesn't.
10356 The supported <comparison-op> values are:
10358 >= true if switch is a later (or same) version than arg1
10359 !> opposite of >=
10360 < true if switch is an earlier version than arg1
10361 !< opposite of <
10362 >< true if switch is arg1 or later, and earlier than arg2
10363 <> true if switch is earlier than arg1 or is arg2 or later
10365 If the switch is not present, the condition is false unless
10366 the first character of the <comparison-op> is '!'.
10368 For example,
10369 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
10370 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
10372 static const char *
10373 version_compare_spec_function (int argc, const char **argv)
10375 int comp1, comp2;
10376 size_t switch_len;
10377 const char *switch_value = NULL;
10378 int nargs = 1, i;
10379 bool result;
10381 if (argc < 3)
10382 fatal_error (input_location, "too few arguments to %%:version-compare");
10383 if (argv[0][0] == '\0')
10384 abort ();
10385 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
10386 nargs = 2;
10387 if (argc != nargs + 3)
10388 fatal_error (input_location, "too many arguments to %%:version-compare");
10390 switch_len = strlen (argv[nargs + 1]);
10391 for (i = 0; i < n_switches; i++)
10392 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
10393 && check_live_switch (i, switch_len))
10394 switch_value = switches[i].part1 + switch_len;
10396 if (switch_value == NULL)
10397 comp1 = comp2 = -1;
10398 else
10400 comp1 = compare_version_strings (switch_value, argv[1]);
10401 if (nargs == 2)
10402 comp2 = compare_version_strings (switch_value, argv[2]);
10403 else
10404 comp2 = -1; /* This value unused. */
10407 switch (argv[0][0] << 8 | argv[0][1])
10409 case '>' << 8 | '=':
10410 result = comp1 >= 0;
10411 break;
10412 case '!' << 8 | '<':
10413 result = comp1 >= 0 || switch_value == NULL;
10414 break;
10415 case '<' << 8:
10416 result = comp1 < 0;
10417 break;
10418 case '!' << 8 | '>':
10419 result = comp1 < 0 || switch_value == NULL;
10420 break;
10421 case '>' << 8 | '<':
10422 result = comp1 >= 0 && comp2 < 0;
10423 break;
10424 case '<' << 8 | '>':
10425 result = comp1 < 0 || comp2 >= 0;
10426 break;
10428 default:
10429 fatal_error (input_location,
10430 "unknown operator %qs in %%:version-compare", argv[0]);
10432 if (! result)
10433 return NULL;
10435 return argv[nargs + 2];
10438 /* %:include builtin spec function. This differs from %include in that it
10439 can be nested inside a spec, and thus be conditionalized. It takes
10440 one argument, the filename, and looks for it in the startfile path.
10441 The result is always NULL, i.e. an empty expansion. */
10443 static const char *
10444 include_spec_function (int argc, const char **argv)
10446 char *file;
10448 if (argc != 1)
10449 abort ();
10451 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
10452 read_specs (file ? file : argv[0], false, false);
10454 return NULL;
10457 /* %:find-file spec function. This function replaces its argument by
10458 the file found through find_file, that is the -print-file-name gcc
10459 program option. */
10460 static const char *
10461 find_file_spec_function (int argc, const char **argv)
10463 const char *file;
10465 if (argc != 1)
10466 abort ();
10468 file = find_file (argv[0]);
10469 return file;
10473 /* %:find-plugindir spec function. This function replaces its argument
10474 by the -iplugindir=<dir> option. `dir' is found through find_file, that
10475 is the -print-file-name gcc program option. */
10476 static const char *
10477 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
10479 const char *option;
10481 if (argc != 0)
10482 abort ();
10484 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
10485 return option;
10489 /* %:print-asm-header spec function. Print a banner to say that the
10490 following output is from the assembler. */
10492 static const char *
10493 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
10494 const char **argv ATTRIBUTE_UNUSED)
10496 printf (_("Assembler options\n=================\n\n"));
10497 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
10498 fflush (stdout);
10499 return NULL;
10502 /* Get a random number for -frandom-seed */
10504 static unsigned HOST_WIDE_INT
10505 get_random_number (void)
10507 unsigned HOST_WIDE_INT ret = 0;
10508 int fd;
10510 fd = open ("/dev/urandom", O_RDONLY);
10511 if (fd >= 0)
10513 read (fd, &ret, sizeof (HOST_WIDE_INT));
10514 close (fd);
10515 if (ret)
10516 return ret;
10519 /* Get some more or less random data. */
10520 #ifdef HAVE_GETTIMEOFDAY
10522 struct timeval tv;
10524 gettimeofday (&tv, NULL);
10525 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
10527 #else
10529 time_t now = time (NULL);
10531 if (now != (time_t)-1)
10532 ret = (unsigned) now;
10534 #endif
10536 return ret ^ getpid ();
10539 /* %:compare-debug-dump-opt spec function. Save the last argument,
10540 expected to be the last -fdump-final-insns option, or generate a
10541 temporary. */
10543 static const char *
10544 compare_debug_dump_opt_spec_function (int arg,
10545 const char **argv ATTRIBUTE_UNUSED)
10547 char *ret;
10548 char *name;
10549 int which;
10550 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
10552 if (arg != 0)
10553 fatal_error (input_location,
10554 "too many arguments to %%:compare-debug-dump-opt");
10556 do_spec_2 ("%{fdump-final-insns=*:%*}", NULL);
10557 do_spec_1 (" ", 0, NULL);
10559 if (argbuf.length () > 0
10560 && strcmp (argv[argbuf.length () - 1], ".") != 0)
10562 if (!compare_debug)
10563 return NULL;
10565 name = xstrdup (argv[argbuf.length () - 1]);
10566 ret = NULL;
10568 else
10570 if (argbuf.length () > 0)
10571 do_spec_2 ("%B.gkd", NULL);
10572 else if (!compare_debug)
10573 return NULL;
10574 else
10575 do_spec_2 ("%{!save-temps*:%g.gkd}%{save-temps*:%B.gkd}", NULL);
10577 do_spec_1 (" ", 0, NULL);
10579 gcc_assert (argbuf.length () > 0);
10581 name = xstrdup (argbuf.last ());
10583 char *arg = quote_spec (xstrdup (name));
10584 ret = concat ("-fdump-final-insns=", arg, NULL);
10585 free (arg);
10588 which = compare_debug < 0;
10589 debug_check_temp_file[which] = name;
10591 if (!which)
10593 unsigned HOST_WIDE_INT value = get_random_number ();
10595 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
10598 if (*random_seed)
10600 char *tmp = ret;
10601 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
10602 ret, NULL);
10603 free (tmp);
10606 if (which)
10607 *random_seed = 0;
10609 return ret;
10612 /* %:compare-debug-self-opt spec function. Expands to the options
10613 that are to be passed in the second compilation of
10614 compare-debug. */
10616 static const char *
10617 compare_debug_self_opt_spec_function (int arg,
10618 const char **argv ATTRIBUTE_UNUSED)
10620 if (arg != 0)
10621 fatal_error (input_location,
10622 "too many arguments to %%:compare-debug-self-opt");
10624 if (compare_debug >= 0)
10625 return NULL;
10627 return concat ("\
10628 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
10629 %<fdump-final-insns=* -w -S -o %j \
10630 %{!fcompare-debug-second:-fcompare-debug-second} \
10631 ", compare_debug_opt, NULL);
10634 /* %:pass-through-libs spec function. Finds all -l options and input
10635 file names in the lib spec passed to it, and makes a list of them
10636 prepended with the plugin option to cause them to be passed through
10637 to the final link after all the new object files have been added. */
10639 const char *
10640 pass_through_libs_spec_func (int argc, const char **argv)
10642 char *prepended = xstrdup (" ");
10643 int n;
10644 /* Shlemiel the painter's algorithm. Innately horrible, but at least
10645 we know that there will never be more than a handful of strings to
10646 concat, and it's only once per run, so it's not worth optimising. */
10647 for (n = 0; n < argc; n++)
10649 char *old = prepended;
10650 /* Anything that isn't an option is a full path to an output
10651 file; pass it through if it ends in '.a'. Among options,
10652 pass only -l. */
10653 if (argv[n][0] == '-' && argv[n][1] == 'l')
10655 const char *lopt = argv[n] + 2;
10656 /* Handle both joined and non-joined -l options. If for any
10657 reason there's a trailing -l with no joined or following
10658 arg just discard it. */
10659 if (!*lopt && ++n >= argc)
10660 break;
10661 else if (!*lopt)
10662 lopt = argv[n];
10663 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
10664 lopt, " ", NULL);
10666 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
10668 prepended = concat (prepended, "-plugin-opt=-pass-through=",
10669 argv[n], " ", NULL);
10671 if (prepended != old)
10672 free (old);
10674 return prepended;
10677 static bool
10678 not_actual_file_p (const char *name)
10680 return (strcmp (name, "-") == 0
10681 || strcmp (name, HOST_BIT_BUCKET) == 0);
10684 /* %:dumps spec function. Take an optional argument that overrides
10685 the default extension for -dumpbase and -dumpbase-ext.
10686 Return -dumpdir, -dumpbase and -dumpbase-ext, if needed. */
10687 const char *
10688 dumps_spec_func (int argc, const char **argv ATTRIBUTE_UNUSED)
10690 const char *ext = dumpbase_ext;
10691 char *p;
10693 char *args[3] = { NULL, NULL, NULL };
10694 int nargs = 0;
10696 /* Do not compute a default for -dumpbase-ext when -dumpbase was
10697 given explicitly. */
10698 if (dumpbase && *dumpbase && !ext)
10699 ext = "";
10701 if (argc == 1)
10703 /* Do not override the explicitly-specified -dumpbase-ext with
10704 the specs-provided overrider. */
10705 if (!ext)
10706 ext = argv[0];
10708 else if (argc != 0)
10709 fatal_error (input_location, "too many arguments for %%:dumps");
10711 if (dumpdir)
10713 p = quote_spec_arg (xstrdup (dumpdir));
10714 args[nargs++] = concat (" -dumpdir ", p, NULL);
10715 free (p);
10718 if (!ext)
10719 ext = input_basename + basename_length;
10721 /* Use the precomputed outbase, or compute dumpbase from
10722 input_basename, just like %b would. */
10723 char *base;
10725 if (dumpbase && *dumpbase)
10727 base = xstrdup (dumpbase);
10728 p = base + outbase_length;
10729 gcc_checking_assert (strncmp (base, outbase, outbase_length) == 0);
10730 gcc_checking_assert (strcmp (p, ext) == 0);
10732 else if (outbase_length)
10734 base = xstrndup (outbase, outbase_length);
10735 p = NULL;
10737 else
10739 base = xstrndup (input_basename, suffixed_basename_length);
10740 p = base + basename_length;
10743 if (compare_debug < 0 || !p || strcmp (p, ext) != 0)
10745 if (p)
10746 *p = '\0';
10748 const char *gk;
10749 if (compare_debug < 0)
10750 gk = ".gk";
10751 else
10752 gk = "";
10754 p = concat (base, gk, ext, NULL);
10756 free (base);
10757 base = p;
10760 base = quote_spec_arg (base);
10761 args[nargs++] = concat (" -dumpbase ", base, NULL);
10762 free (base);
10764 if (*ext)
10766 p = quote_spec_arg (xstrdup (ext));
10767 args[nargs++] = concat (" -dumpbase-ext ", p, NULL);
10768 free (p);
10771 const char *ret = concat (args[0], args[1], args[2], NULL);
10772 while (nargs > 0)
10773 free (args[--nargs]);
10775 return ret;
10778 /* Returns "" if ARGV[ARGC - 2] is greater than ARGV[ARGC-1].
10779 Otherwise, return NULL. */
10781 static const char *
10782 greater_than_spec_func (int argc, const char **argv)
10784 char *converted;
10786 if (argc == 1)
10787 return NULL;
10789 gcc_assert (argc >= 2);
10791 long arg = strtol (argv[argc - 2], &converted, 10);
10792 gcc_assert (converted != argv[argc - 2]);
10794 long lim = strtol (argv[argc - 1], &converted, 10);
10795 gcc_assert (converted != argv[argc - 1]);
10797 if (arg > lim)
10798 return "";
10800 return NULL;
10803 /* Returns "" if debug_info_level is greater than ARGV[ARGC-1].
10804 Otherwise, return NULL. */
10806 static const char *
10807 debug_level_greater_than_spec_func (int argc, const char **argv)
10809 char *converted;
10811 if (argc != 1)
10812 fatal_error (input_location,
10813 "wrong number of arguments to %%:debug-level-gt");
10815 long arg = strtol (argv[0], &converted, 10);
10816 gcc_assert (converted != argv[0]);
10818 if (debug_info_level > arg)
10819 return "";
10821 return NULL;
10824 /* Returns "" if dwarf_version is greater than ARGV[ARGC-1].
10825 Otherwise, return NULL. */
10827 static const char *
10828 dwarf_version_greater_than_spec_func (int argc, const char **argv)
10830 char *converted;
10832 if (argc != 1)
10833 fatal_error (input_location,
10834 "wrong number of arguments to %%:dwarf-version-gt");
10836 long arg = strtol (argv[0], &converted, 10);
10837 gcc_assert (converted != argv[0]);
10839 if (dwarf_version > arg)
10840 return "";
10842 return NULL;
10845 static void
10846 path_prefix_reset (path_prefix *prefix)
10848 struct prefix_list *iter, *next;
10849 iter = prefix->plist;
10850 while (iter)
10852 next = iter->next;
10853 free (const_cast <char *> (iter->prefix));
10854 XDELETE (iter);
10855 iter = next;
10857 prefix->plist = 0;
10858 prefix->max_len = 0;
10861 /* The function takes 3 arguments: OPTION name, file name and location
10862 where we search for Fortran modules.
10863 When the FILE is found by find_file, return OPTION=path_to_file. */
10865 static const char *
10866 find_fortran_preinclude_file (int argc, const char **argv)
10868 char *result = NULL;
10869 if (argc != 3)
10870 return NULL;
10872 struct path_prefix prefixes = { 0, 0, "preinclude" };
10874 /* Search first for 'finclude' folder location for a header file
10875 installed by the compiler (similar to omp_lib.h). */
10876 add_prefix (&prefixes, argv[2], NULL, 0, 0, 0);
10877 #ifdef TOOL_INCLUDE_DIR
10878 /* Then search: <prefix>/<target>/<include>/finclude */
10879 add_prefix (&prefixes, TOOL_INCLUDE_DIR "/finclude/",
10880 NULL, 0, 0, 0);
10881 #endif
10882 #ifdef NATIVE_SYSTEM_HEADER_DIR
10883 /* Then search: <sysroot>/usr/include/finclude/<multilib> */
10884 add_sysrooted_hdrs_prefix (&prefixes, NATIVE_SYSTEM_HEADER_DIR "/finclude/",
10885 NULL, 0, 0, 0);
10886 #endif
10888 const char *path = find_a_file (&include_prefixes, argv[1], R_OK, false);
10889 if (path != NULL)
10890 result = concat (argv[0], path, NULL);
10891 else
10893 path = find_a_file (&prefixes, argv[1], R_OK, false);
10894 if (path != NULL)
10895 result = concat (argv[0], path, NULL);
10898 path_prefix_reset (&prefixes);
10899 return result;
10902 /* If any character in ORIG fits QUOTE_P (_, P), reallocate the string
10903 so as to precede every one of them with a backslash. Return the
10904 original string or the reallocated one. */
10906 static inline char *
10907 quote_string (char *orig, bool (*quote_p)(char, void *), void *p)
10909 int len, number_of_space = 0;
10911 for (len = 0; orig[len]; len++)
10912 if (quote_p (orig[len], p))
10913 number_of_space++;
10915 if (number_of_space)
10917 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
10918 int j, k;
10919 for (j = 0, k = 0; j <= len; j++, k++)
10921 if (quote_p (orig[j], p))
10922 new_spec[k++] = '\\';
10923 new_spec[k] = orig[j];
10925 free (orig);
10926 return new_spec;
10928 else
10929 return orig;
10932 /* Return true iff C is any of the characters convert_white_space
10933 should quote. */
10935 static inline bool
10936 whitespace_to_convert_p (char c, void *)
10938 return (c == ' ' || c == '\t');
10941 /* Insert backslash before spaces in ORIG (usually a file path), to
10942 avoid being broken by spec parser.
10944 This function is needed as do_spec_1 treats white space (' ' and '\t')
10945 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
10946 the file name should be treated as a single argument rather than being
10947 broken into multiple. Solution is to insert '\\' before the space in a
10948 file name.
10950 This function converts and only converts all occurrence of ' '
10951 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
10952 "a b" -> "a\\ b"
10953 "a b" -> "a\\ \\ b"
10954 "a\tb" -> "a\\\tb"
10955 "a\\ b" -> "a\\\\ b"
10957 orig: input null-terminating string that was allocated by xalloc. The
10958 memory it points to might be freed in this function. Behavior undefined
10959 if ORIG wasn't xalloced or was freed already at entry.
10961 Return: ORIG if no conversion needed. Otherwise a newly allocated string
10962 that was converted from ORIG. */
10964 static char *
10965 convert_white_space (char *orig)
10967 return quote_string (orig, whitespace_to_convert_p, NULL);
10970 /* Return true iff C matches any of the spec active characters. */
10971 static inline bool
10972 quote_spec_char_p (char c, void *)
10974 switch (c)
10976 case ' ':
10977 case '\t':
10978 case '\n':
10979 case '|':
10980 case '%':
10981 case '\\':
10982 return true;
10984 default:
10985 return false;
10989 /* Like convert_white_space, but deactivate all active spec chars by
10990 quoting them. */
10992 static inline char *
10993 quote_spec (char *orig)
10995 return quote_string (orig, quote_spec_char_p, NULL);
10998 /* Like quote_spec, but also turn an empty string into the spec for an
10999 empty argument. */
11001 static inline char *
11002 quote_spec_arg (char *orig)
11004 if (!*orig)
11006 free (orig);
11007 return xstrdup ("%\"");
11010 return quote_spec (orig);
11013 /* Restore all state within gcc.cc to the initial state, so that the driver
11014 code can be safely re-run in-process.
11016 Many const char * variables are referenced by static specs (see
11017 INIT_STATIC_SPEC above). These variables are restored to their default
11018 values by a simple loop over the static specs.
11020 For other variables, we directly restore them all to their initial
11021 values (often implicitly 0).
11023 Free the various obstacks in this file, along with "opts_obstack"
11024 from opts.cc.
11026 This function also restores any environment variables that were changed. */
11028 void
11029 driver::finalize ()
11031 env.restore ();
11032 diagnostic_finish (global_dc);
11034 is_cpp_driver = 0;
11035 at_file_supplied = 0;
11036 print_help_list = 0;
11037 print_version = 0;
11038 verbose_only_flag = 0;
11039 print_subprocess_help = 0;
11040 use_ld = NULL;
11041 report_times_to_file = NULL;
11042 target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
11043 target_system_root_changed = 0;
11044 target_sysroot_suffix = 0;
11045 target_sysroot_hdrs_suffix = 0;
11046 save_temps_flag = SAVE_TEMPS_NONE;
11047 save_temps_overrides_dumpdir = false;
11048 dumpdir_trailing_dash_added = false;
11049 free (dumpdir);
11050 free (dumpbase);
11051 free (dumpbase_ext);
11052 free (outbase);
11053 dumpdir = dumpbase = dumpbase_ext = outbase = NULL;
11054 dumpdir_length = outbase_length = 0;
11055 spec_machine = DEFAULT_TARGET_MACHINE;
11056 greatest_status = 1;
11058 obstack_free (&obstack, NULL);
11059 obstack_free (&opts_obstack, NULL); /* in opts.cc */
11060 obstack_free (&collect_obstack, NULL);
11062 link_command_spec = LINK_COMMAND_SPEC;
11064 obstack_free (&multilib_obstack, NULL);
11066 user_specs_head = NULL;
11067 user_specs_tail = NULL;
11069 /* Within the "compilers" vec, the fields "suffix" and "spec" were
11070 statically allocated for the default compilers, but dynamically
11071 allocated for additional compilers. Delete them for the latter. */
11072 for (int i = n_default_compilers; i < n_compilers; i++)
11074 free (const_cast <char *> (compilers[i].suffix));
11075 free (const_cast <char *> (compilers[i].spec));
11077 XDELETEVEC (compilers);
11078 compilers = NULL;
11079 n_compilers = 0;
11081 linker_options.truncate (0);
11082 assembler_options.truncate (0);
11083 preprocessor_options.truncate (0);
11085 path_prefix_reset (&exec_prefixes);
11086 path_prefix_reset (&startfile_prefixes);
11087 path_prefix_reset (&include_prefixes);
11089 machine_suffix = 0;
11090 just_machine_suffix = 0;
11091 gcc_exec_prefix = 0;
11092 gcc_libexec_prefix = 0;
11093 set_static_spec_shared (&md_exec_prefix, MD_EXEC_PREFIX);
11094 set_static_spec_shared (&md_startfile_prefix, MD_STARTFILE_PREFIX);
11095 set_static_spec_shared (&md_startfile_prefix_1, MD_STARTFILE_PREFIX_1);
11096 multilib_dir = 0;
11097 multilib_os_dir = 0;
11098 multiarch_dir = 0;
11100 /* Free any specs dynamically-allocated by set_spec.
11101 These will be at the head of the list, before the
11102 statically-allocated ones. */
11103 if (specs)
11105 while (specs != static_specs)
11107 spec_list *next = specs->next;
11108 free (const_cast <char *> (specs->name));
11109 XDELETE (specs);
11110 specs = next;
11112 specs = 0;
11114 for (unsigned i = 0; i < ARRAY_SIZE (static_specs); i++)
11116 spec_list *sl = &static_specs[i];
11117 if (sl->alloc_p)
11119 free (const_cast <char *> (*(sl->ptr_spec)));
11120 sl->alloc_p = false;
11122 *(sl->ptr_spec) = sl->default_ptr;
11124 #ifdef EXTRA_SPECS
11125 extra_specs = NULL;
11126 #endif
11128 processing_spec_function = 0;
11130 clear_args ();
11132 have_c = 0;
11133 have_o = 0;
11135 temp_names = NULL;
11136 execution_count = 0;
11137 signal_count = 0;
11139 temp_filename = NULL;
11140 temp_filename_length = 0;
11141 always_delete_queue = NULL;
11142 failure_delete_queue = NULL;
11144 XDELETEVEC (switches);
11145 switches = NULL;
11146 n_switches = 0;
11147 n_switches_alloc = 0;
11149 compare_debug = 0;
11150 compare_debug_second = 0;
11151 compare_debug_opt = NULL;
11152 for (int i = 0; i < 2; i++)
11154 switches_debug_check[i] = NULL;
11155 n_switches_debug_check[i] = 0;
11156 n_switches_alloc_debug_check[i] = 0;
11157 debug_check_temp_file[i] = NULL;
11160 XDELETEVEC (infiles);
11161 infiles = NULL;
11162 n_infiles = 0;
11163 n_infiles_alloc = 0;
11165 combine_inputs = false;
11166 added_libraries = 0;
11167 XDELETEVEC (outfiles);
11168 outfiles = NULL;
11169 spec_lang = 0;
11170 last_language_n_infiles = 0;
11171 gcc_input_filename = NULL;
11172 input_file_number = 0;
11173 input_filename_length = 0;
11174 basename_length = 0;
11175 suffixed_basename_length = 0;
11176 input_basename = NULL;
11177 input_suffix = NULL;
11178 /* We don't need to purge "input_stat", just to unset "input_stat_set". */
11179 input_stat_set = 0;
11180 input_file_compiler = NULL;
11181 arg_going = 0;
11182 delete_this_arg = 0;
11183 this_is_output_file = 0;
11184 this_is_library_file = 0;
11185 this_is_linker_script = 0;
11186 input_from_pipe = 0;
11187 suffix_subst = NULL;
11189 mdswitches = NULL;
11190 n_mdswitches = 0;
11192 used_arg.finalize ();
11195 /* PR jit/64810.
11196 Targets can provide configure-time default options in
11197 OPTION_DEFAULT_SPECS. The jit needs to access these, but
11198 they are expressed in the spec language.
11200 Run just enough of the driver to be able to expand these
11201 specs, and then call the callback CB on each
11202 such option. The options strings are *without* a leading
11203 '-' character e.g. ("march=x86-64"). Finally, clean up. */
11205 void
11206 driver_get_configure_time_options (void (*cb) (const char *option,
11207 void *user_data),
11208 void *user_data)
11210 size_t i;
11212 obstack_init (&obstack);
11213 init_opts_obstack ();
11214 n_switches = 0;
11216 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
11217 do_option_spec (option_default_specs[i].name,
11218 option_default_specs[i].spec);
11220 for (i = 0; (int) i < n_switches; i++)
11222 gcc_assert (switches[i].part1);
11223 (*cb) (switches[i].part1, user_data);
11226 obstack_free (&opts_obstack, NULL);
11227 obstack_free (&obstack, NULL);
11228 n_switches = 0;