c++: Attribute deprecated/unavailable divergence
[official-gcc.git] / gcc / gcc.cc
bloba4d863ca45704e0fe90b734a964281f779c61119
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 #include "config.h"
31 #include "system.h"
32 #include "coretypes.h"
33 #include "multilib.h" /* before tm.h */
34 #include "tm.h"
35 #include "xregex.h"
36 #include "obstack.h"
37 #include "intl.h"
38 #include "prefix.h"
39 #include "opt-suggestions.h"
40 #include "gcc.h"
41 #include "diagnostic.h"
42 #include "flags.h"
43 #include "opts.h"
44 #include "filenames.h"
45 #include "spellcheck.h"
49 /* Manage the manipulation of env vars.
51 We poison "getenv" and "putenv", so that all enviroment-handling is
52 done through this class. Note that poisoning happens in the
53 preprocessor at the identifier level, and doesn't distinguish between
54 env.getenv ();
55 and
56 getenv ();
57 Hence we need to use "get" for the accessor method, not "getenv". */
59 struct env_manager
61 public:
62 void init (bool can_restore, bool debug);
63 const char *get (const char *name);
64 void xput (const char *string);
65 void restore ();
67 private:
68 bool m_can_restore;
69 bool m_debug;
70 struct kv
72 char *m_key;
73 char *m_value;
75 vec<kv> m_keys;
79 /* The singleton instance of class env_manager. */
81 static env_manager env;
83 /* Initializer for class env_manager.
85 We can't do this as a constructor since we have a statically
86 allocated instance ("env" above). */
88 void
89 env_manager::init (bool can_restore, bool debug)
91 m_can_restore = can_restore;
92 m_debug = debug;
95 /* Get the value of NAME within the environment. Essentially
96 a wrapper for ::getenv, but adding logging, and the possibility
97 of caching results. */
99 const char *
100 env_manager::get (const char *name)
102 const char *result = ::getenv (name);
103 if (m_debug)
104 fprintf (stderr, "env_manager::getenv (%s) -> %s\n", name, result);
105 return result;
108 /* Put the given KEY=VALUE entry STRING into the environment.
109 If the env_manager was initialized with CAN_RESTORE set, then
110 also record the old value of KEY within the environment, so that it
111 can be later restored. */
113 void
114 env_manager::xput (const char *string)
116 if (m_debug)
117 fprintf (stderr, "env_manager::xput (%s)\n", string);
118 if (verbose_flag)
119 fnotice (stderr, "%s\n", string);
121 if (m_can_restore)
123 char *equals = strchr (const_cast <char *> (string), '=');
124 gcc_assert (equals);
126 struct kv kv;
127 kv.m_key = xstrndup (string, equals - string);
128 const char *cur_value = ::getenv (kv.m_key);
129 if (m_debug)
130 fprintf (stderr, "saving old value: %s\n",cur_value);
131 kv.m_value = cur_value ? xstrdup (cur_value) : NULL;
132 m_keys.safe_push (kv);
135 ::putenv (CONST_CAST (char *, string));
138 /* Undo any xputenv changes made since last restore.
139 Can only be called if the env_manager was initialized with
140 CAN_RESTORE enabled. */
142 void
143 env_manager::restore ()
145 unsigned int i;
146 struct kv *item;
148 gcc_assert (m_can_restore);
150 FOR_EACH_VEC_ELT_REVERSE (m_keys, i, item)
152 if (m_debug)
153 printf ("restoring saved key: %s value: %s\n", item->m_key, item->m_value);
154 if (item->m_value)
155 ::setenv (item->m_key, item->m_value, 1);
156 else
157 ::unsetenv (item->m_key);
158 free (item->m_key);
159 free (item->m_value);
162 m_keys.truncate (0);
165 /* Forbid other uses of getenv and putenv. */
166 #if (GCC_VERSION >= 3000)
167 #pragma GCC poison getenv putenv
168 #endif
172 /* By default there is no special suffix for target executables. */
173 #ifdef TARGET_EXECUTABLE_SUFFIX
174 #define HAVE_TARGET_EXECUTABLE_SUFFIX
175 #else
176 #define TARGET_EXECUTABLE_SUFFIX ""
177 #endif
179 /* By default there is no special suffix for host executables. */
180 #ifdef HOST_EXECUTABLE_SUFFIX
181 #define HAVE_HOST_EXECUTABLE_SUFFIX
182 #else
183 #define HOST_EXECUTABLE_SUFFIX ""
184 #endif
186 /* By default, the suffix for target object files is ".o". */
187 #ifdef TARGET_OBJECT_SUFFIX
188 #define HAVE_TARGET_OBJECT_SUFFIX
189 #else
190 #define TARGET_OBJECT_SUFFIX ".o"
191 #endif
193 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
195 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
196 #ifndef LIBRARY_PATH_ENV
197 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
198 #endif
200 /* If a stage of compilation returns an exit status >= 1,
201 compilation of that file ceases. */
203 #define MIN_FATAL_STATUS 1
205 /* Flag set by cppspec.cc to 1. */
206 int is_cpp_driver;
208 /* Flag set to nonzero if an @file argument has been supplied to gcc. */
209 static bool at_file_supplied;
211 /* Definition of string containing the arguments given to configure. */
212 #include "configargs.h"
214 /* Flag saying to print the command line options understood by gcc and its
215 sub-processes. */
217 static int print_help_list;
219 /* Flag saying to print the version of gcc and its sub-processes. */
221 static int print_version;
223 /* Flag that stores string prefix for which we provide bash completion. */
225 static const char *completion = NULL;
227 /* Flag indicating whether we should ONLY print the command and
228 arguments (like verbose_flag) without executing the command.
229 Displayed arguments are quoted so that the generated command
230 line is suitable for execution. This is intended for use in
231 shell scripts to capture the driver-generated command line. */
232 static int verbose_only_flag;
234 /* Flag indicating how to print command line options of sub-processes. */
236 static int print_subprocess_help;
238 /* Linker suffix passed to -fuse-ld=... */
239 static const char *use_ld;
241 /* Whether we should report subprocess execution times to a file. */
243 FILE *report_times_to_file = NULL;
245 /* Nonzero means place this string before uses of /, so that include
246 and library files can be found in an alternate location. */
248 #ifdef TARGET_SYSTEM_ROOT
249 #define DEFAULT_TARGET_SYSTEM_ROOT (TARGET_SYSTEM_ROOT)
250 #else
251 #define DEFAULT_TARGET_SYSTEM_ROOT (0)
252 #endif
253 static const char *target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
255 /* Nonzero means pass the updated target_system_root to the compiler. */
257 static int target_system_root_changed;
259 /* Nonzero means append this string to target_system_root. */
261 static const char *target_sysroot_suffix = 0;
263 /* Nonzero means append this string to target_system_root for headers. */
265 static const char *target_sysroot_hdrs_suffix = 0;
267 /* Nonzero means write "temp" files in source directory
268 and use the source file's name in them, and don't delete them. */
270 static enum save_temps {
271 SAVE_TEMPS_NONE, /* no -save-temps */
272 SAVE_TEMPS_CWD, /* -save-temps in current directory */
273 SAVE_TEMPS_DUMP, /* -save-temps in dumpdir */
274 SAVE_TEMPS_OBJ /* -save-temps in object directory */
275 } save_temps_flag;
277 /* Set this iff the dumppfx implied by a -save-temps=* option is to
278 override a -dumpdir option, if any. */
279 static bool save_temps_overrides_dumpdir = false;
281 /* -dumpdir, -dumpbase and -dumpbase-ext flags passed in, possibly
282 rearranged as they are to be passed down, e.g., dumpbase and
283 dumpbase_ext may be cleared if integrated with dumpdir or
284 dropped. */
285 static char *dumpdir, *dumpbase, *dumpbase_ext;
287 /* Usually the length of the string in dumpdir. However, during
288 linking, it may be shortened to omit a driver-added trailing dash,
289 by then replaced with a trailing period, that is still to be passed
290 to sub-processes in -dumpdir, but not to be generally used in spec
291 filename expansions. See maybe_run_linker. */
292 static size_t dumpdir_length = 0;
294 /* Set if the last character in dumpdir is (or was) a dash that the
295 driver added to dumpdir after dumpbase or linker output name. */
296 static bool dumpdir_trailing_dash_added = false;
298 /* Basename of dump and aux outputs, computed from dumpbase (given or
299 derived from output name), to override input_basename in non-%w %b
300 et al. */
301 static char *outbase;
302 static size_t outbase_length = 0;
304 /* The compiler version. */
306 static const char *compiler_version;
308 /* The target version. */
310 static const char *const spec_version = DEFAULT_TARGET_VERSION;
312 /* The target machine. */
314 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
315 static const char *spec_host_machine = DEFAULT_REAL_TARGET_MACHINE;
317 /* List of offload targets. Separated by colon. Empty string for
318 -foffload=disable. */
320 static char *offload_targets = NULL;
322 #if OFFLOAD_DEFAULTED
323 /* Set to true if -foffload has not been used and offload_targets
324 is set to the configured in default. */
325 static bool offload_targets_default;
326 #endif
328 /* Nonzero if cross-compiling.
329 When -b is used, the value comes from the `specs' file. */
331 #ifdef CROSS_DIRECTORY_STRUCTURE
332 static const char *cross_compile = "1";
333 #else
334 static const char *cross_compile = "0";
335 #endif
337 /* Greatest exit code of sub-processes that has been encountered up to
338 now. */
339 static int greatest_status = 1;
341 /* This is the obstack which we use to allocate many strings. */
343 static struct obstack obstack;
345 /* This is the obstack to build an environment variable to pass to
346 collect2 that describes all of the relevant switches of what to
347 pass the compiler in building the list of pointers to constructors
348 and destructors. */
350 static struct obstack collect_obstack;
352 /* Forward declaration for prototypes. */
353 struct path_prefix;
354 struct prefix_list;
356 static void init_spec (void);
357 static void store_arg (const char *, int, int);
358 static void insert_wrapper (const char *);
359 static char *load_specs (const char *);
360 static void read_specs (const char *, bool, bool);
361 static void set_spec (const char *, const char *, bool);
362 static struct compiler *lookup_compiler (const char *, size_t, const char *);
363 static char *build_search_list (const struct path_prefix *, const char *,
364 bool, bool);
365 static void xputenv (const char *);
366 static void putenv_from_prefixes (const struct path_prefix *, const char *,
367 bool);
368 static int access_check (const char *, int);
369 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
370 static char *find_a_program (const char *);
371 static void add_prefix (struct path_prefix *, const char *, const char *,
372 int, int, int);
373 static void add_sysrooted_prefix (struct path_prefix *, const char *,
374 const char *, int, int, int);
375 static char *skip_whitespace (char *);
376 static void delete_if_ordinary (const char *);
377 static void delete_temp_files (void);
378 static void delete_failure_queue (void);
379 static void clear_failure_queue (void);
380 static int check_live_switch (int, int);
381 static const char *handle_braces (const char *);
382 static inline bool input_suffix_matches (const char *, const char *);
383 static inline bool switch_matches (const char *, const char *, int);
384 static inline void mark_matching_switches (const char *, const char *, int);
385 static inline void process_marked_switches (void);
386 static const char *process_brace_body (const char *, const char *, const char *, int, int);
387 static const struct spec_function *lookup_spec_function (const char *);
388 static const char *eval_spec_function (const char *, const char *, const char *);
389 static const char *handle_spec_function (const char *, bool *, const char *);
390 static char *save_string (const char *, int);
391 static void set_collect_gcc_options (void);
392 static int do_spec_1 (const char *, int, const char *);
393 static int do_spec_2 (const char *, const char *);
394 static void do_option_spec (const char *, const char *);
395 static void do_self_spec (const char *);
396 static const char *find_file (const char *);
397 static int is_directory (const char *, bool);
398 static const char *validate_switches (const char *, bool, bool);
399 static void validate_all_switches (void);
400 static inline void validate_switches_from_spec (const char *, bool);
401 static void give_switch (int, int);
402 static int default_arg (const char *, int);
403 static void set_multilib_dir (void);
404 static void print_multilib_info (void);
405 static void display_help (void);
406 static void add_preprocessor_option (const char *, int);
407 static void add_assembler_option (const char *, int);
408 static void add_linker_option (const char *, int);
409 static void process_command (unsigned int, struct cl_decoded_option *);
410 static int execute (void);
411 static void alloc_args (void);
412 static void clear_args (void);
413 static void fatal_signal (int);
414 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
415 static void init_gcc_specs (struct obstack *, const char *, const char *,
416 const char *);
417 #endif
418 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
419 static const char *convert_filename (const char *, int, int);
420 #endif
422 static void try_generate_repro (const char **argv);
423 static const char *getenv_spec_function (int, const char **);
424 static const char *if_exists_spec_function (int, const char **);
425 static const char *if_exists_else_spec_function (int, const char **);
426 static const char *if_exists_then_else_spec_function (int, const char **);
427 static const char *sanitize_spec_function (int, const char **);
428 static const char *replace_outfile_spec_function (int, const char **);
429 static const char *remove_outfile_spec_function (int, const char **);
430 static const char *version_compare_spec_function (int, const char **);
431 static const char *include_spec_function (int, const char **);
432 static const char *find_file_spec_function (int, const char **);
433 static const char *find_plugindir_spec_function (int, const char **);
434 static const char *print_asm_header_spec_function (int, const char **);
435 static const char *compare_debug_dump_opt_spec_function (int, const char **);
436 static const char *compare_debug_self_opt_spec_function (int, const char **);
437 static const char *pass_through_libs_spec_func (int, const char **);
438 static const char *dumps_spec_func (int, const char **);
439 static const char *greater_than_spec_func (int, const char **);
440 static const char *debug_level_greater_than_spec_func (int, const char **);
441 static const char *dwarf_version_greater_than_spec_func (int, const char **);
442 static const char *find_fortran_preinclude_file (int, const char **);
443 static char *convert_white_space (char *);
444 static char *quote_spec (char *);
445 static char *quote_spec_arg (char *);
446 static bool not_actual_file_p (const char *);
449 /* The Specs Language
451 Specs are strings containing lines, each of which (if not blank)
452 is made up of a program name, and arguments separated by spaces.
453 The program name must be exact and start from root, since no path
454 is searched and it is unreliable to depend on the current working directory.
455 Redirection of input or output is not supported; the subprograms must
456 accept filenames saying what files to read and write.
458 In addition, the specs can contain %-sequences to substitute variable text
459 or for conditional text. Here is a table of all defined %-sequences.
460 Note that spaces are not generated automatically around the results of
461 expanding these sequences; therefore, you can concatenate them together
462 or with constant text in a single argument.
464 %% substitute one % into the program name or argument.
465 %" substitute an empty argument.
466 %i substitute the name of the input file being processed.
467 %b substitute the basename for outputs related with the input file
468 being processed. This is often a substring of the input file name,
469 up to (and not including) the last period but, unless %w is active,
470 it is affected by the directory selected by -save-temps=*, by
471 -dumpdir, and, in case of multiple compilations, even by -dumpbase
472 and -dumpbase-ext and, in case of linking, by the linker output
473 name. When %w is active, it derives the main output name only from
474 the input file base name; when it is not, it names aux/dump output
475 file.
476 %B same as %b, but include the input file suffix (text after the last
477 period).
478 %gSUFFIX
479 substitute a file name that has suffix SUFFIX and is chosen
480 once per compilation, and mark the argument a la %d. To reduce
481 exposure to denial-of-service attacks, the file name is now
482 chosen in a way that is hard to predict even when previously
483 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
484 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
485 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
486 had been pre-processed. Previously, %g was simply substituted
487 with a file name chosen once per compilation, without regard
488 to any appended suffix (which was therefore treated just like
489 ordinary text), making such attacks more likely to succeed.
490 %|SUFFIX
491 like %g, but if -pipe is in effect, expands simply to "-".
492 %mSUFFIX
493 like %g, but if -pipe is in effect, expands to nothing. (We have both
494 %| and %m to accommodate differences between system assemblers; see
495 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
496 %uSUFFIX
497 like %g, but generates a new temporary file name even if %uSUFFIX
498 was already seen.
499 %USUFFIX
500 substitutes the last file name generated with %uSUFFIX, generating a
501 new one if there is no such last file name. In the absence of any
502 %uSUFFIX, this is just like %gSUFFIX, except they don't share
503 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
504 would involve the generation of two distinct file names, one
505 for each `%g.s' and another for each `%U.s'. Previously, %U was
506 simply substituted with a file name chosen for the previous %u,
507 without regard to any appended suffix.
508 %jSUFFIX
509 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
510 writable, and if save-temps is off; otherwise, substitute the name
511 of a temporary file, just like %u. This temporary file is not
512 meant for communication between processes, but rather as a junk
513 disposal mechanism.
514 %.SUFFIX
515 substitutes .SUFFIX for the suffixes of a matched switch's args when
516 it is subsequently output with %*. SUFFIX is terminated by the next
517 space or %.
518 %d marks the argument containing or following the %d as a
519 temporary file name, so that file will be deleted if GCC exits
520 successfully. Unlike %g, this contributes no text to the argument.
521 %w marks the argument containing or following the %w as the
522 "output file" of this compilation. This puts the argument
523 into the sequence of arguments that %o will substitute later.
524 %V indicates that this compilation produces no "output file".
525 %W{...}
526 like %{...} but marks the last argument supplied within as a file
527 to be deleted on failure.
528 %@{...}
529 like %{...} but puts the result into a FILE and substitutes @FILE
530 if an @file argument has been supplied.
531 %o substitutes the names of all the output files, with spaces
532 automatically placed around them. You should write spaces
533 around the %o as well or the results are undefined.
534 %o is for use in the specs for running the linker.
535 Input files whose names have no recognized suffix are not compiled
536 at all, but they are included among the output files, so they will
537 be linked.
538 %O substitutes the suffix for object files. Note that this is
539 handled specially when it immediately follows %g, %u, or %U
540 (with or without a suffix argument) because of the need for
541 those to form complete file names. The handling is such that
542 %O is treated exactly as if it had already been substituted,
543 except that %g, %u, and %U do not currently support additional
544 SUFFIX characters following %O as they would following, for
545 example, `.o'.
546 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
547 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
548 and -B options) and -imultilib as necessary.
549 %s current argument is the name of a library or startup file of some sort.
550 Search for that file in a standard list of directories
551 and substitute the full name found.
552 %T current argument is the name of a linker script.
553 Search for that file in the current list of directories to scan for
554 libraries. If the file is located, insert a --script option into the
555 command line followed by the full path name found. If the file is
556 not found then generate an error message.
557 Note: the current working directory is not searched.
558 %eSTR Print STR as an error message. STR is terminated by a newline.
559 Use this when inconsistent options are detected.
560 %nSTR Print STR as a notice. STR is terminated by a newline.
561 %x{OPTION} Accumulate an option for %X.
562 %X Output the accumulated linker options specified by compilations.
563 %Y Output the accumulated assembler options specified by compilations.
564 %Z Output the accumulated preprocessor options specified by compilations.
565 %a process ASM_SPEC as a spec.
566 This allows config.h to specify part of the spec for running as.
567 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
568 used here. This can be used to run a post-processor after the
569 assembler has done its job.
570 %D Dump out a -L option for each directory in startfile_prefixes.
571 If multilib_dir is set, extra entries are generated with it affixed.
572 %l process LINK_SPEC as a spec.
573 %L process LIB_SPEC as a spec.
574 %M Output multilib_os_dir.
575 %G process LIBGCC_SPEC as a spec.
576 %R Output the concatenation of target_system_root and
577 target_sysroot_suffix.
578 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
579 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
580 %C process CPP_SPEC as a spec.
581 %1 process CC1_SPEC as a spec.
582 %2 process CC1PLUS_SPEC as a spec.
583 %* substitute the variable part of a matched option. (See below.)
584 Note that each comma in the substituted string is replaced by
585 a single space. A space is appended after the last substition
586 unless there is more text in current sequence.
587 %<S remove all occurrences of -S from the command line.
588 Note - this command is position dependent. % commands in the
589 spec string before this one will see -S, % commands in the
590 spec string after this one will not.
591 %>S Similar to "%<S", but keep it in the GCC command line.
592 %<S* remove all occurrences of all switches beginning with -S from the
593 command line.
594 %:function(args)
595 Call the named function FUNCTION, passing it ARGS. ARGS is
596 first processed as a nested spec string, then split into an
597 argument vector in the usual fashion. The function returns
598 a string which is processed as if it had appeared literally
599 as part of the current spec.
600 %{S} substitutes the -S switch, if that switch was given to GCC.
601 If that switch was not specified, this substitutes nothing.
602 Here S is a metasyntactic variable.
603 %{S*} substitutes all the switches specified to GCC whose names start
604 with -S. This is used for -o, -I, etc; switches that take
605 arguments. GCC considers `-o foo' as being one switch whose
606 name starts with `o'. %{o*} would substitute this text,
607 including the space; thus, two arguments would be generated.
608 %{S*&T*} likewise, but preserve order of S and T options (the order
609 of S and T in the spec is not significant). Can be any number
610 of ampersand-separated variables; for each the wild card is
611 optional. Useful for CPP as %{D*&U*&A*}.
613 %{S:X} substitutes X, if the -S switch was given to GCC.
614 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
615 %{S*:X} substitutes X if one or more switches whose names start
616 with -S was given to GCC. Normally X is substituted only
617 once, no matter how many such switches appeared. However,
618 if %* appears somewhere in X, then X will be substituted
619 once for each matching switch, with the %* replaced by the
620 part of that switch that matched the '*'. A space will be
621 appended after the last substition unless there is more
622 text in current sequence.
623 %{.S:X} substitutes X, if processing a file with suffix S.
624 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
625 %{,S:X} substitutes X, if processing a file which will use spec S.
626 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
628 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
629 combined with '!', '.', ',', and '*' as above binding stronger
630 than the OR.
631 If %* appears in X, all of the alternatives must be starred, and
632 only the first matching alternative is substituted.
633 %{%:function(args):X}
634 Call function named FUNCTION with args ARGS. If the function
635 returns non-NULL, then X is substituted, if it returns
636 NULL, it isn't substituted.
637 %{S:X; if S was given to GCC, substitutes X;
638 T:Y; else if T was given to GCC, substitutes Y;
639 :D} else substitutes D. There can be as many clauses as you need.
640 This may be combined with '.', '!', ',', '|', and '*' as above.
642 %(Spec) processes a specification defined in a specs file as *Spec:
644 The switch matching text S in a %{S}, %{S:X}, or similar construct can use
645 a backslash to ignore the special meaning of the character following it,
646 thus allowing literal matching of a character that is otherwise specially
647 treated. For example, %{std=iso9899\:1999:X} substitutes X if the
648 -std=iso9899:1999 option is given.
650 The conditional text X in a %{S:X} or similar construct may contain
651 other nested % constructs or spaces, or even newlines. They are
652 processed as usual, as described above. Trailing white space in X is
653 ignored. White space may also appear anywhere on the left side of the
654 colon in these constructs, except between . or * and the corresponding
655 word.
657 The -O, -f, -g, -m, and -W switches are handled specifically in these
658 constructs. If another value of -O or the negated form of a -f, -m, or
659 -W switch is found later in the command line, the earlier switch
660 value is ignored, except with {S*} where S is just one letter; this
661 passes all matching options.
663 The character | at the beginning of the predicate text is used to indicate
664 that a command should be piped to the following command, but only if -pipe
665 is specified.
667 Note that it is built into GCC which switches take arguments and which
668 do not. You might think it would be useful to generalize this to
669 allow each compiler's spec to say which switches take arguments. But
670 this cannot be done in a consistent fashion. GCC cannot even decide
671 which input files have been specified without knowing which switches
672 take arguments, and it must know which input files to compile in order
673 to tell which compilers to run.
675 GCC also knows implicitly that arguments starting in `-l' are to be
676 treated as compiler output files, and passed to the linker in their
677 proper position among the other output files. */
679 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
681 /* config.h can define ASM_SPEC to provide extra args to the assembler
682 or extra switch-translations. */
683 #ifndef ASM_SPEC
684 #define ASM_SPEC ""
685 #endif
687 /* config.h can define ASM_FINAL_SPEC to run a post processor after
688 the assembler has run. */
689 #ifndef ASM_FINAL_SPEC
690 #define ASM_FINAL_SPEC \
691 "%{gsplit-dwarf: \n\
692 objcopy --extract-dwo \
693 %{c:%{o*:%*}%{!o*:%w%b%O}}%{!c:%U%O} \
694 %b.dwo \n\
695 objcopy --strip-dwo \
696 %{c:%{o*:%*}%{!o*:%w%b%O}}%{!c:%U%O} \
698 #endif
700 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
701 or extra switch-translations. */
702 #ifndef CPP_SPEC
703 #define CPP_SPEC ""
704 #endif
706 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
707 or extra switch-translations. */
708 #ifndef CC1_SPEC
709 #define CC1_SPEC ""
710 #endif
712 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
713 or extra switch-translations. */
714 #ifndef CC1PLUS_SPEC
715 #define CC1PLUS_SPEC ""
716 #endif
718 /* config.h can define LINK_SPEC to provide extra args to the linker
719 or extra switch-translations. */
720 #ifndef LINK_SPEC
721 #define LINK_SPEC ""
722 #endif
724 /* config.h can define LIB_SPEC to override the default libraries. */
725 #ifndef LIB_SPEC
726 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
727 #endif
729 /* When using -fsplit-stack we need to wrap pthread_create, in order
730 to initialize the stack guard. We always use wrapping, rather than
731 shared library ordering, and we keep the wrapper function in
732 libgcc. This is not yet a real spec, though it could become one;
733 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
734 only works with GNU ld and gold. */
735 #ifdef HAVE_GOLD_NON_DEFAULT_SPLIT_STACK
736 #define STACK_SPLIT_SPEC " %{fsplit-stack: -fuse-ld=gold --wrap=pthread_create}"
737 #else
738 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
739 #endif
741 #ifndef LIBASAN_SPEC
742 #define STATIC_LIBASAN_LIBS \
743 " %{static-libasan|static:%:include(libsanitizer.spec)%(link_libasan)}"
744 #ifdef LIBASAN_EARLY_SPEC
745 #define LIBASAN_SPEC STATIC_LIBASAN_LIBS
746 #elif defined(HAVE_LD_STATIC_DYNAMIC)
747 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
748 "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
749 STATIC_LIBASAN_LIBS
750 #else
751 #define LIBASAN_SPEC "-lasan" STATIC_LIBASAN_LIBS
752 #endif
753 #endif
755 #ifndef LIBASAN_EARLY_SPEC
756 #define LIBASAN_EARLY_SPEC ""
757 #endif
759 #ifndef LIBHWASAN_SPEC
760 #define STATIC_LIBHWASAN_LIBS \
761 " %{static-libhwasan|static:%:include(libsanitizer.spec)%(link_libhwasan)}"
762 #ifdef LIBHWASAN_EARLY_SPEC
763 #define LIBHWASAN_SPEC STATIC_LIBHWASAN_LIBS
764 #elif defined(HAVE_LD_STATIC_DYNAMIC)
765 #define LIBHWASAN_SPEC "%{static-libhwasan:" LD_STATIC_OPTION \
766 "} -lhwasan %{static-libhwasan:" LD_DYNAMIC_OPTION "}" \
767 STATIC_LIBHWASAN_LIBS
768 #else
769 #define LIBHWASAN_SPEC "-lhwasan" STATIC_LIBHWASAN_LIBS
770 #endif
771 #endif
773 #ifndef LIBHWASAN_EARLY_SPEC
774 #define LIBHWASAN_EARLY_SPEC ""
775 #endif
777 #ifndef LIBTSAN_SPEC
778 #define STATIC_LIBTSAN_LIBS \
779 " %{static-libtsan|static:%:include(libsanitizer.spec)%(link_libtsan)}"
780 #ifdef LIBTSAN_EARLY_SPEC
781 #define LIBTSAN_SPEC STATIC_LIBTSAN_LIBS
782 #elif defined(HAVE_LD_STATIC_DYNAMIC)
783 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
784 "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}" \
785 STATIC_LIBTSAN_LIBS
786 #else
787 #define LIBTSAN_SPEC "-ltsan" STATIC_LIBTSAN_LIBS
788 #endif
789 #endif
791 #ifndef LIBTSAN_EARLY_SPEC
792 #define LIBTSAN_EARLY_SPEC ""
793 #endif
795 #ifndef LIBLSAN_SPEC
796 #define STATIC_LIBLSAN_LIBS \
797 " %{static-liblsan|static:%:include(libsanitizer.spec)%(link_liblsan)}"
798 #ifdef LIBLSAN_EARLY_SPEC
799 #define LIBLSAN_SPEC STATIC_LIBLSAN_LIBS
800 #elif defined(HAVE_LD_STATIC_DYNAMIC)
801 #define LIBLSAN_SPEC "%{static-liblsan:" LD_STATIC_OPTION \
802 "} -llsan %{static-liblsan:" LD_DYNAMIC_OPTION "}" \
803 STATIC_LIBLSAN_LIBS
804 #else
805 #define LIBLSAN_SPEC "-llsan" STATIC_LIBLSAN_LIBS
806 #endif
807 #endif
809 #ifndef LIBLSAN_EARLY_SPEC
810 #define LIBLSAN_EARLY_SPEC ""
811 #endif
813 #ifndef LIBUBSAN_SPEC
814 #define STATIC_LIBUBSAN_LIBS \
815 " %{static-libubsan|static:%:include(libsanitizer.spec)%(link_libubsan)}"
816 #ifdef HAVE_LD_STATIC_DYNAMIC
817 #define LIBUBSAN_SPEC "%{static-libubsan:" LD_STATIC_OPTION \
818 "} -lubsan %{static-libubsan:" LD_DYNAMIC_OPTION "}" \
819 STATIC_LIBUBSAN_LIBS
820 #else
821 #define LIBUBSAN_SPEC "-lubsan" STATIC_LIBUBSAN_LIBS
822 #endif
823 #endif
825 /* Linker options for compressed debug sections. */
826 #if HAVE_LD_COMPRESS_DEBUG == 0
827 /* No linker support. */
828 #define LINK_COMPRESS_DEBUG_SPEC \
829 " %{gz*:%e-gz is not supported in this configuration} "
830 #elif HAVE_LD_COMPRESS_DEBUG == 1
831 /* GNU style on input, GNU ld options. Reject, not useful. */
832 #define LINK_COMPRESS_DEBUG_SPEC \
833 " %{gz*:%e-gz is not supported in this configuration} "
834 #elif HAVE_LD_COMPRESS_DEBUG == 2
835 /* GNU style, GNU gold options. */
836 #define LINK_COMPRESS_DEBUG_SPEC \
837 " %{gz|gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
838 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
839 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
840 #elif HAVE_LD_COMPRESS_DEBUG == 3
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=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
846 #else
847 #error Unknown value for HAVE_LD_COMPRESS_DEBUG.
848 #endif
850 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
851 included. */
852 #ifndef LIBGCC_SPEC
853 #if defined(REAL_LIBGCC_SPEC)
854 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
855 #elif defined(LINK_LIBGCC_SPECIAL_1)
856 /* Have gcc do the search for libgcc.a. */
857 #define LIBGCC_SPEC "libgcc.a%s"
858 #else
859 #define LIBGCC_SPEC "-lgcc"
860 #endif
861 #endif
863 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
864 #ifndef STARTFILE_SPEC
865 #define STARTFILE_SPEC \
866 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
867 #endif
869 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
870 #ifndef ENDFILE_SPEC
871 #define ENDFILE_SPEC ""
872 #endif
874 #ifndef LINKER_NAME
875 #define LINKER_NAME "collect2"
876 #endif
878 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
879 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
880 #else
881 #define ASM_MAP ""
882 #endif
884 /* Assembler options for compressed debug sections. */
885 #if HAVE_LD_COMPRESS_DEBUG < 2
886 /* Reject if the linker cannot write compressed debug sections. */
887 #define ASM_COMPRESS_DEBUG_SPEC \
888 " %{gz*:%e-gz is not supported in this configuration} "
889 #else /* HAVE_LD_COMPRESS_DEBUG >= 2 */
890 #if HAVE_AS_COMPRESS_DEBUG == 0
891 /* No assembler support. Ignore silently. */
892 #define ASM_COMPRESS_DEBUG_SPEC \
893 " %{gz*:} "
894 #elif HAVE_AS_COMPRESS_DEBUG == 1
895 /* GNU style, GNU as options. */
896 #define ASM_COMPRESS_DEBUG_SPEC \
897 " %{gz|gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "}" \
898 " %{gz=none:" AS_NO_COMPRESS_DEBUG_OPTION "}" \
899 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
900 #elif HAVE_AS_COMPRESS_DEBUG == 2
901 /* ELF gABI style. */
902 #define ASM_COMPRESS_DEBUG_SPEC \
903 " %{gz|gz=zlib:" AS_COMPRESS_DEBUG_OPTION "=zlib}" \
904 " %{gz=none:" AS_COMPRESS_DEBUG_OPTION "=none}" \
905 " %{gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
906 #else
907 #error Unknown value for HAVE_AS_COMPRESS_DEBUG.
908 #endif
909 #endif /* HAVE_LD_COMPRESS_DEBUG >= 2 */
911 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
912 to the assembler, when compiling assembly sources only. */
913 #ifndef ASM_DEBUG_SPEC
914 # if defined(HAVE_AS_GDWARF_5_DEBUG_FLAG) && defined(HAVE_AS_WORKING_DWARF_N_FLAG)
915 /* If --gdwarf-N is supported and as can handle even compiler generated
916 .debug_line with it, supply --gdwarf-N in ASM_DEBUG_OPTION_SPEC rather
917 than in ASM_DEBUG_SPEC, so that it applies to both .s and .c etc.
918 compilations. */
919 # define ASM_DEBUG_DWARF_OPTION ""
920 # elif defined(HAVE_AS_GDWARF_5_DEBUG_FLAG) && !defined(HAVE_LD_BROKEN_PE_DWARF5)
921 # define ASM_DEBUG_DWARF_OPTION "%{%:dwarf-version-gt(4):--gdwarf-5;" \
922 "%:dwarf-version-gt(3):--gdwarf-4;" \
923 "%:dwarf-version-gt(2):--gdwarf-3;" \
924 ":--gdwarf2}"
925 # else
926 # define ASM_DEBUG_DWARF_OPTION "--gdwarf2"
927 # endif
928 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
929 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
930 # define ASM_DEBUG_SPEC \
931 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
932 ? "%{%:debug-level-gt(0):" \
933 "%{gdwarf*:" ASM_DEBUG_DWARF_OPTION "};" \
934 ":%{g*:--gstabs}}" ASM_MAP \
935 : "%{%:debug-level-gt(0):" \
936 "%{gstabs*:--gstabs;" \
937 ":%{g*:" ASM_DEBUG_DWARF_OPTION "}}}" ASM_MAP)
938 # else
939 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
940 # define ASM_DEBUG_SPEC "%{g*:%{%:debug-level-gt(0):--gstabs}}" ASM_MAP
941 # endif
942 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
943 # define ASM_DEBUG_SPEC "%{g*:%{%:debug-level-gt(0):" \
944 ASM_DEBUG_DWARF_OPTION "}}" ASM_MAP
945 # endif
946 # endif
947 #endif
948 #ifndef ASM_DEBUG_SPEC
949 # define ASM_DEBUG_SPEC ""
950 #endif
952 /* Define ASM_DEBUG_OPTION_SPEC to be a spec suitable for translating '-g'
953 to the assembler when compiling all sources. */
954 #ifndef ASM_DEBUG_OPTION_SPEC
955 # if defined(HAVE_AS_GDWARF_5_DEBUG_FLAG) && defined(HAVE_AS_WORKING_DWARF_N_FLAG)
956 # define ASM_DEBUG_OPTION_DWARF_OPT \
957 "%{%:dwarf-version-gt(4):--gdwarf-5 ;" \
958 "%:dwarf-version-gt(3):--gdwarf-4 ;" \
959 "%:dwarf-version-gt(2):--gdwarf-3 ;" \
960 ":--gdwarf2 }"
961 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO)
962 # define ASM_DEBUG_OPTION_SPEC \
963 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
964 ? "%{%:debug-level-gt(0):" \
965 "%{gdwarf*:" ASM_DEBUG_OPTION_DWARF_OPT "}}" \
966 : "%{%:debug-level-gt(0):" \
967 "%{!gstabs*:%{g*:" ASM_DEBUG_OPTION_DWARF_OPT "}}}")
968 # elif defined(DWARF2_DEBUGGING_INFO)
969 # define ASM_DEBUG_OPTION_SPEC "%{g*:%{%:debug-level-gt(0):" \
970 ASM_DEBUG_OPTION_DWARF_OPT "}}"
971 # endif
972 # endif
973 #endif
974 #ifndef ASM_DEBUG_OPTION_SPEC
975 # define ASM_DEBUG_OPTION_SPEC ""
976 #endif
978 /* Here is the spec for running the linker, after compiling all files. */
980 /* This is overridable by the target in case they need to specify the
981 -lgcc and -lc order specially, yet not require them to override all
982 of LINK_COMMAND_SPEC. */
983 #ifndef LINK_GCC_C_SEQUENCE_SPEC
984 #define LINK_GCC_C_SEQUENCE_SPEC "%G %{!nolibc:%L %G}"
985 #endif
987 #ifndef LINK_SSP_SPEC
988 #ifdef TARGET_LIBC_PROVIDES_SSP
989 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
990 "|fstack-protector-strong|fstack-protector-explicit:}"
991 #else
992 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
993 "|fstack-protector-strong|fstack-protector-explicit" \
994 ":-lssp_nonshared -lssp}"
995 #endif
996 #endif
998 #ifdef ENABLE_DEFAULT_PIE
999 #define PIE_SPEC "!no-pie"
1000 #define NO_FPIE1_SPEC "fno-pie"
1001 #define FPIE1_SPEC NO_FPIE1_SPEC ":;"
1002 #define NO_FPIE2_SPEC "fno-PIE"
1003 #define FPIE2_SPEC NO_FPIE2_SPEC ":;"
1004 #define NO_FPIE_SPEC NO_FPIE1_SPEC "|" NO_FPIE2_SPEC
1005 #define FPIE_SPEC NO_FPIE_SPEC ":;"
1006 #define NO_FPIC1_SPEC "fno-pic"
1007 #define FPIC1_SPEC NO_FPIC1_SPEC ":;"
1008 #define NO_FPIC2_SPEC "fno-PIC"
1009 #define FPIC2_SPEC NO_FPIC2_SPEC ":;"
1010 #define NO_FPIC_SPEC NO_FPIC1_SPEC "|" NO_FPIC2_SPEC
1011 #define FPIC_SPEC NO_FPIC_SPEC ":;"
1012 #define NO_FPIE1_AND_FPIC1_SPEC NO_FPIE1_SPEC "|" NO_FPIC1_SPEC
1013 #define FPIE1_OR_FPIC1_SPEC NO_FPIE1_AND_FPIC1_SPEC ":;"
1014 #define NO_FPIE2_AND_FPIC2_SPEC NO_FPIE2_SPEC "|" NO_FPIC2_SPEC
1015 #define FPIE2_OR_FPIC2_SPEC NO_FPIE2_AND_FPIC2_SPEC ":;"
1016 #define NO_FPIE_AND_FPIC_SPEC NO_FPIE_SPEC "|" NO_FPIC_SPEC
1017 #define FPIE_OR_FPIC_SPEC NO_FPIE_AND_FPIC_SPEC ":;"
1018 #else
1019 #define PIE_SPEC "pie"
1020 #define FPIE1_SPEC "fpie"
1021 #define NO_FPIE1_SPEC FPIE1_SPEC ":;"
1022 #define FPIE2_SPEC "fPIE"
1023 #define NO_FPIE2_SPEC FPIE2_SPEC ":;"
1024 #define FPIE_SPEC FPIE1_SPEC "|" FPIE2_SPEC
1025 #define NO_FPIE_SPEC FPIE_SPEC ":;"
1026 #define FPIC1_SPEC "fpic"
1027 #define NO_FPIC1_SPEC FPIC1_SPEC ":;"
1028 #define FPIC2_SPEC "fPIC"
1029 #define NO_FPIC2_SPEC FPIC2_SPEC ":;"
1030 #define FPIC_SPEC FPIC1_SPEC "|" FPIC2_SPEC
1031 #define NO_FPIC_SPEC FPIC_SPEC ":;"
1032 #define FPIE1_OR_FPIC1_SPEC FPIE1_SPEC "|" FPIC1_SPEC
1033 #define NO_FPIE1_AND_FPIC1_SPEC FPIE1_OR_FPIC1_SPEC ":;"
1034 #define FPIE2_OR_FPIC2_SPEC FPIE2_SPEC "|" FPIC2_SPEC
1035 #define NO_FPIE2_AND_FPIC2_SPEC FPIE1_OR_FPIC2_SPEC ":;"
1036 #define FPIE_OR_FPIC_SPEC FPIE_SPEC "|" FPIC_SPEC
1037 #define NO_FPIE_AND_FPIC_SPEC FPIE_OR_FPIC_SPEC ":;"
1038 #endif
1040 #ifndef LINK_PIE_SPEC
1041 #ifdef HAVE_LD_PIE
1042 #ifndef LD_PIE_SPEC
1043 #define LD_PIE_SPEC "-pie"
1044 #endif
1045 #else
1046 #define LD_PIE_SPEC ""
1047 #endif
1048 #define LINK_PIE_SPEC "%{static|shared|r:;" PIE_SPEC ":" LD_PIE_SPEC "} "
1049 #endif
1051 #ifndef LINK_BUILDID_SPEC
1052 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
1053 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
1054 # endif
1055 #endif
1057 #ifndef LTO_PLUGIN_SPEC
1058 #define LTO_PLUGIN_SPEC ""
1059 #endif
1061 /* Conditional to test whether the LTO plugin is used or not.
1062 FIXME: For slim LTO we will need to enable plugin unconditionally. This
1063 still cause problems with PLUGIN_LD != LD and when plugin is built but
1064 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
1065 plugin only when LTO is enabled. We still honor explicit
1066 -fuse-linker-plugin if the linker used understands -plugin. */
1068 /* The linker has some plugin support. */
1069 #if HAVE_LTO_PLUGIN > 0
1070 /* The linker used has full plugin support, use LTO plugin by default. */
1071 #if HAVE_LTO_PLUGIN == 2
1072 #define PLUGIN_COND "!fno-use-linker-plugin:%{!fno-lto"
1073 #define PLUGIN_COND_CLOSE "}"
1074 #else
1075 /* The linker used has limited plugin support, use LTO plugin with explicit
1076 -fuse-linker-plugin. */
1077 #define PLUGIN_COND "fuse-linker-plugin"
1078 #define PLUGIN_COND_CLOSE ""
1079 #endif
1080 #define LINK_PLUGIN_SPEC \
1081 "%{" PLUGIN_COND": \
1082 -plugin %(linker_plugin_file) \
1083 -plugin-opt=%(lto_wrapper) \
1084 -plugin-opt=-fresolution=%u.res \
1085 " LTO_PLUGIN_SPEC "\
1086 %{flinker-output=*:-plugin-opt=-linker-output-known} \
1087 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
1088 }" PLUGIN_COND_CLOSE
1089 #else
1090 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
1091 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
1092 %e-fuse-linker-plugin is not supported in this configuration}"
1093 #endif
1095 /* Linker command line options for -fsanitize= early on the command line. */
1096 #ifndef SANITIZER_EARLY_SPEC
1097 #define SANITIZER_EARLY_SPEC "\
1098 %{!nostdlib:%{!r:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_EARLY_SPEC "} \
1099 %{%:sanitize(hwaddress):" LIBHWASAN_EARLY_SPEC "} \
1100 %{%:sanitize(thread):" LIBTSAN_EARLY_SPEC "} \
1101 %{%:sanitize(leak):" LIBLSAN_EARLY_SPEC "}}}}"
1102 #endif
1104 /* Linker command line options for -fsanitize= late on the command line. */
1105 #ifndef SANITIZER_SPEC
1106 #define SANITIZER_SPEC "\
1107 %{!nostdlib:%{!r:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_SPEC "\
1108 %{static:%ecannot specify -static with -fsanitize=address}}\
1109 %{%:sanitize(hwaddress):" LIBHWASAN_SPEC "\
1110 %{static:%ecannot specify -static with -fsanitize=hwaddress}}\
1111 %{%:sanitize(thread):" LIBTSAN_SPEC "\
1112 %{static:%ecannot specify -static with -fsanitize=thread}}\
1113 %{%:sanitize(undefined):" LIBUBSAN_SPEC "}\
1114 %{%:sanitize(leak):" LIBLSAN_SPEC "}}}}"
1115 #endif
1117 #ifndef POST_LINK_SPEC
1118 #define POST_LINK_SPEC ""
1119 #endif
1121 /* This is the spec to use, once the code for creating the vtable
1122 verification runtime library, libvtv.so, has been created. Currently
1123 the vtable verification runtime functions are in libstdc++, so we use
1124 the spec just below this one. */
1125 #ifndef VTABLE_VERIFICATION_SPEC
1126 #if ENABLE_VTABLE_VERIFY
1127 #define VTABLE_VERIFICATION_SPEC "\
1128 %{!nostdlib:%{!r:%{fvtable-verify=std: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}\
1129 %{fvtable-verify=preinit: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}}}"
1130 #else
1131 #define VTABLE_VERIFICATION_SPEC "\
1132 %{fvtable-verify=none:} \
1133 %{fvtable-verify=std: \
1134 %e-fvtable-verify=std is not supported in this configuration} \
1135 %{fvtable-verify=preinit: \
1136 %e-fvtable-verify=preinit is not supported in this configuration}"
1137 #endif
1138 #endif
1140 /* -u* was put back because both BSD and SysV seem to support it. */
1141 /* %{static|no-pie|static-pie:} simply prevents an error message:
1142 1. If the target machine doesn't handle -static.
1143 2. If PIE isn't enabled by default.
1144 3. If the target machine doesn't handle -static-pie.
1146 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
1147 scripts which exist in user specified directories, or in standard
1148 directories. */
1149 /* We pass any -flto flags on to the linker, which is expected
1150 to understand them. In practice, this means it had better be collect2. */
1151 /* %{e*} includes -export-dynamic; see comment in common.opt. */
1152 #ifndef LINK_COMMAND_SPEC
1153 #define LINK_COMMAND_SPEC "\
1154 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
1155 %(linker) " \
1156 LINK_PLUGIN_SPEC \
1157 "%{flto|flto=*:%<fcompare-debug*} \
1158 %{flto} %{fno-lto} %{flto=*} %l " LINK_PIE_SPEC \
1159 "%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
1160 "%X %{o*} %{e*} %{N} %{n} %{r}\
1161 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!r:%{!nostartfiles:%S}}} \
1162 %{static|no-pie|static-pie:} %@{L*} %(mfwrap) %(link_libgcc) " \
1163 VTABLE_VERIFICATION_SPEC " " SANITIZER_EARLY_SPEC " %o "" \
1164 %{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1):\
1165 %:include(libgomp.spec)%(link_gomp)}\
1166 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
1167 %(mflib) " STACK_SPLIT_SPEC "\
1168 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
1169 %{!nostdlib:%{!r:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}}\
1170 %{!nostdlib:%{!r:%{!nostartfiles:%E}}} %{T*} \n%(post_link) }}}}}}"
1171 #endif
1173 #ifndef LINK_LIBGCC_SPEC
1174 /* Generate -L options for startfile prefix list. */
1175 # define LINK_LIBGCC_SPEC "%D"
1176 #endif
1178 #ifndef STARTFILE_PREFIX_SPEC
1179 # define STARTFILE_PREFIX_SPEC ""
1180 #endif
1182 #ifndef SYSROOT_SPEC
1183 # define SYSROOT_SPEC "--sysroot=%R"
1184 #endif
1186 #ifndef SYSROOT_SUFFIX_SPEC
1187 # define SYSROOT_SUFFIX_SPEC ""
1188 #endif
1190 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
1191 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
1192 #endif
1194 static const char *asm_debug = ASM_DEBUG_SPEC;
1195 static const char *asm_debug_option = ASM_DEBUG_OPTION_SPEC;
1196 static const char *cpp_spec = CPP_SPEC;
1197 static const char *cc1_spec = CC1_SPEC;
1198 static const char *cc1plus_spec = CC1PLUS_SPEC;
1199 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
1200 static const char *link_ssp_spec = LINK_SSP_SPEC;
1201 static const char *asm_spec = ASM_SPEC;
1202 static const char *asm_final_spec = ASM_FINAL_SPEC;
1203 static const char *link_spec = LINK_SPEC;
1204 static const char *lib_spec = LIB_SPEC;
1205 static const char *link_gomp_spec = "";
1206 static const char *libgcc_spec = LIBGCC_SPEC;
1207 static const char *endfile_spec = ENDFILE_SPEC;
1208 static const char *startfile_spec = STARTFILE_SPEC;
1209 static const char *linker_name_spec = LINKER_NAME;
1210 static const char *linker_plugin_file_spec = "";
1211 static const char *lto_wrapper_spec = "";
1212 static const char *lto_gcc_spec = "";
1213 static const char *post_link_spec = POST_LINK_SPEC;
1214 static const char *link_command_spec = LINK_COMMAND_SPEC;
1215 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
1216 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
1217 static const char *sysroot_spec = SYSROOT_SPEC;
1218 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
1219 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
1220 static const char *self_spec = "";
1222 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
1223 There should be no need to override these in target dependent files,
1224 but we need to copy them to the specs file so that newer versions
1225 of the GCC driver can correctly drive older tool chains with the
1226 appropriate -B options. */
1228 /* When cpplib handles traditional preprocessing, get rid of this, and
1229 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
1230 that we default the front end language better. */
1231 static const char *trad_capable_cpp =
1232 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
1234 /* We don't wrap .d files in %W{} since a missing .d file, and
1235 therefore no dependency entry, confuses make into thinking a .o
1236 file that happens to exist is up-to-date. */
1237 static const char *cpp_unique_options =
1238 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %@{I*&F*} %{P} %I\
1239 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
1240 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
1241 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
1242 %{Mmodules} %{Mno-modules}\
1243 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
1244 %{remap} %{%:debug-level-gt(2):-dD}\
1245 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1246 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
1247 %{E|M|MM:%W{o*}}";
1249 /* This contains cpp options which are common with cc1_options and are passed
1250 only when preprocessing only to avoid duplication. We pass the cc1 spec
1251 options to the preprocessor so that it the cc1 spec may manipulate
1252 options used to set target flags. Those special target flags settings may
1253 in turn cause preprocessor symbols to be defined specially. */
1254 static const char *cpp_options =
1255 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
1256 %{f*} %{g*:%{%:debug-level-gt(0):%{g*}\
1257 %{!fno-working-directory:-fworking-directory}}} %{O*}\
1258 %{undef} %{save-temps*:-fpch-preprocess}";
1260 /* Pass -d* flags, possibly modifying -dumpdir, -dumpbase et al.
1262 Make it easy for a language to override the argument for the
1263 %:dumps specs function call. */
1264 #define DUMPS_OPTIONS(EXTS) \
1265 "%<dumpdir %<dumpbase %<dumpbase-ext %{d*} %:dumps(" EXTS ")"
1267 /* This contains cpp options which are not passed when the preprocessor
1268 output will be used by another program. */
1269 static const char *cpp_debug_options = DUMPS_OPTIONS ("");
1271 /* NB: This is shared amongst all front-ends, except for Ada. */
1272 static const char *cc1_options =
1273 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
1274 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1275 %1 %{!Q:-quiet} %(cpp_debug_options) %{m*} %{aux-info*}\
1276 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
1277 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
1278 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
1279 %{-target-help:--target-help}\
1280 %{-version:--version}\
1281 %{-help=*:--help=%*}\
1282 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %w%b.s}}}\
1283 %{fsyntax-only:-o %j} %{-param*}\
1284 %{coverage:-fprofile-arcs -ftest-coverage}\
1285 %{fprofile-arcs|fprofile-generate*|coverage:\
1286 %{!fprofile-update=single:\
1287 %{pthread:-fprofile-update=prefer-atomic}}}";
1289 static const char *asm_options =
1290 "%{-target-help:%:print-asm-header()} "
1291 #if HAVE_GNU_AS
1292 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
1293 to the assembler equivalents. */
1294 "%{v} %{w:-W} %{I*} "
1295 #endif
1296 "%(asm_debug_option)"
1297 ASM_COMPRESS_DEBUG_SPEC
1298 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
1300 static const char *invoke_as =
1301 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1302 "%{!fwpa*:\
1303 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1304 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
1306 #else
1307 "%{!fwpa*:\
1308 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1309 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
1311 #endif
1313 /* Some compilers have limits on line lengths, and the multilib_select
1314 and/or multilib_matches strings can be very long, so we build them at
1315 run time. */
1316 static struct obstack multilib_obstack;
1317 static const char *multilib_select;
1318 static const char *multilib_matches;
1319 static const char *multilib_defaults;
1320 static const char *multilib_exclusions;
1321 static const char *multilib_reuse;
1323 /* Check whether a particular argument is a default argument. */
1325 #ifndef MULTILIB_DEFAULTS
1326 #define MULTILIB_DEFAULTS { "" }
1327 #endif
1329 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
1331 #ifndef DRIVER_SELF_SPECS
1332 #define DRIVER_SELF_SPECS ""
1333 #endif
1335 /* Linking to libgomp implies pthreads. This is particularly important
1336 for targets that use different start files and suchlike. */
1337 #ifndef GOMP_SELF_SPECS
1338 #define GOMP_SELF_SPECS \
1339 "%{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1): " \
1340 "-pthread}"
1341 #endif
1343 /* Likewise for -fgnu-tm. */
1344 #ifndef GTM_SELF_SPECS
1345 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
1346 #endif
1348 static const char *const driver_self_specs[] = {
1349 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
1350 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS
1353 #ifndef OPTION_DEFAULT_SPECS
1354 #define OPTION_DEFAULT_SPECS { "", "" }
1355 #endif
1357 struct default_spec
1359 const char *name;
1360 const char *spec;
1363 static const struct default_spec
1364 option_default_specs[] = { OPTION_DEFAULT_SPECS };
1366 struct user_specs
1368 struct user_specs *next;
1369 const char *filename;
1372 static struct user_specs *user_specs_head, *user_specs_tail;
1375 /* Record the mapping from file suffixes for compilation specs. */
1377 struct compiler
1379 const char *suffix; /* Use this compiler for input files
1380 whose names end in this suffix. */
1382 const char *spec; /* To use this compiler, run this spec. */
1384 const char *cpp_spec; /* If non-NULL, substitute this spec
1385 for `%C', rather than the usual
1386 cpp_spec. */
1387 int combinable; /* If nonzero, compiler can deal with
1388 multiple source files at once (IMA). */
1389 int needs_preprocessing; /* If nonzero, source files need to
1390 be run through a preprocessor. */
1393 /* Pointer to a vector of `struct compiler' that gives the spec for
1394 compiling a file, based on its suffix.
1395 A file that does not end in any of these suffixes will be passed
1396 unchanged to the loader and nothing else will be done to it.
1398 An entry containing two 0s is used to terminate the vector.
1400 If multiple entries match a file, the last matching one is used. */
1402 static struct compiler *compilers;
1404 /* Number of entries in `compilers', not counting the null terminator. */
1406 static int n_compilers;
1408 /* The default list of file name suffixes and their compilation specs. */
1410 static const struct compiler default_compilers[] =
1412 /* Add lists of suffixes of known languages here. If those languages
1413 were not present when we built the driver, we will hit these copies
1414 and be given a more meaningful error than "file not used since
1415 linking is not done". */
1416 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
1417 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
1418 {".mii", "#Objective-C++", 0, 0, 0},
1419 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
1420 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
1421 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
1422 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
1423 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
1424 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
1425 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
1426 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
1427 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
1428 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
1429 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
1430 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1431 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1432 {".r", "#Ratfor", 0, 0, 0},
1433 {".go", "#Go", 0, 1, 0},
1434 {".d", "#D", 0, 1, 0}, {".dd", "#D", 0, 1, 0}, {".di", "#D", 0, 1, 0},
1435 /* Next come the entries for C. */
1436 {".c", "@c", 0, 0, 1},
1437 {"@c",
1438 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1439 external preprocessor if -save-temps is given. */
1440 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1441 %{!E:%{!M:%{!MM:\
1442 %{traditional:\
1443 %eGNU C no longer supports -traditional without -E}\
1444 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1445 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1446 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1447 %(cc1_options)}\
1448 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1449 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1450 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1451 {"-",
1452 "%{!E:%e-E or -x required when input is from standard input}\
1453 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1454 {".h", "@c-header", 0, 0, 0},
1455 {"@c-header",
1456 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1457 external preprocessor if -save-temps is given. */
1458 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1459 %{!E:%{!M:%{!MM:\
1460 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1461 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1462 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1463 %(cc1_options)\
1464 %{!fsyntax-only:%{!S:-o %g.s} \
1465 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1466 %W{o*:--output-pch=%*}}%V}}\
1467 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1468 cc1 %(cpp_unique_options) %(cc1_options)\
1469 %{!fsyntax-only:%{!S:-o %g.s} \
1470 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1471 %W{o*:--output-pch=%*}}%V}}}}}}}", 0, 0, 0},
1472 {".i", "@cpp-output", 0, 0, 0},
1473 {"@cpp-output",
1474 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1475 {".s", "@assembler", 0, 0, 0},
1476 {"@assembler",
1477 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1478 {".sx", "@assembler-with-cpp", 0, 0, 0},
1479 {".S", "@assembler-with-cpp", 0, 0, 0},
1480 {"@assembler-with-cpp",
1481 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1482 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1483 %{E|M|MM:%(cpp_debug_options)}\
1484 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1485 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1486 #else
1487 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1488 %{E|M|MM:%(cpp_debug_options)}\
1489 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1490 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1491 #endif
1492 , 0, 0, 0},
1494 #include "specs.h"
1495 /* Mark end of table. */
1496 {0, 0, 0, 0, 0}
1499 /* Number of elements in default_compilers, not counting the terminator. */
1501 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1503 typedef char *char_p; /* For DEF_VEC_P. */
1505 /* A vector of options to give to the linker.
1506 These options are accumulated by %x,
1507 and substituted into the linker command with %X. */
1508 static vec<char_p> linker_options;
1510 /* A vector of options to give to the assembler.
1511 These options are accumulated by -Wa,
1512 and substituted into the assembler command with %Y. */
1513 static vec<char_p> assembler_options;
1515 /* A vector of options to give to the preprocessor.
1516 These options are accumulated by -Wp,
1517 and substituted into the preprocessor command with %Z. */
1518 static vec<char_p> preprocessor_options;
1520 static char *
1521 skip_whitespace (char *p)
1523 while (1)
1525 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1526 be considered whitespace. */
1527 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1528 return p + 1;
1529 else if (*p == '\n' || *p == ' ' || *p == '\t')
1530 p++;
1531 else if (*p == '#')
1533 while (*p != '\n')
1534 p++;
1535 p++;
1537 else
1538 break;
1541 return p;
1543 /* Structures to keep track of prefixes to try when looking for files. */
1545 struct prefix_list
1547 const char *prefix; /* String to prepend to the path. */
1548 struct prefix_list *next; /* Next in linked list. */
1549 int require_machine_suffix; /* Don't use without machine_suffix. */
1550 /* 2 means try both machine_suffix and just_machine_suffix. */
1551 int priority; /* Sort key - priority within list. */
1552 int os_multilib; /* 1 if OS multilib scheme should be used,
1553 0 for GCC multilib scheme. */
1556 struct path_prefix
1558 struct prefix_list *plist; /* List of prefixes to try */
1559 int max_len; /* Max length of a prefix in PLIST */
1560 const char *name; /* Name of this list (used in config stuff) */
1563 /* List of prefixes to try when looking for executables. */
1565 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1567 /* List of prefixes to try when looking for startup (crt0) files. */
1569 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1571 /* List of prefixes to try when looking for include files. */
1573 static struct path_prefix include_prefixes = { 0, 0, "include" };
1575 /* Suffix to attach to directories searched for commands.
1576 This looks like `MACHINE/VERSION/'. */
1578 static const char *machine_suffix = 0;
1580 /* Suffix to attach to directories searched for commands.
1581 This is just `MACHINE/'. */
1583 static const char *just_machine_suffix = 0;
1585 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1587 static const char *gcc_exec_prefix;
1589 /* Adjusted value of standard_libexec_prefix. */
1591 static const char *gcc_libexec_prefix;
1593 /* Default prefixes to attach to command names. */
1595 #ifndef STANDARD_STARTFILE_PREFIX_1
1596 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1597 #endif
1598 #ifndef STANDARD_STARTFILE_PREFIX_2
1599 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1600 #endif
1602 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1603 #undef MD_EXEC_PREFIX
1604 #undef MD_STARTFILE_PREFIX
1605 #undef MD_STARTFILE_PREFIX_1
1606 #endif
1608 /* If no prefixes defined, use the null string, which will disable them. */
1609 #ifndef MD_EXEC_PREFIX
1610 #define MD_EXEC_PREFIX ""
1611 #endif
1612 #ifndef MD_STARTFILE_PREFIX
1613 #define MD_STARTFILE_PREFIX ""
1614 #endif
1615 #ifndef MD_STARTFILE_PREFIX_1
1616 #define MD_STARTFILE_PREFIX_1 ""
1617 #endif
1619 /* These directories are locations set at configure-time based on the
1620 --prefix option provided to configure. Their initializers are
1621 defined in Makefile.in. These paths are not *directly* used when
1622 gcc_exec_prefix is set because, in that case, we know where the
1623 compiler has been installed, and use paths relative to that
1624 location instead. */
1625 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1626 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1627 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1628 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1630 /* For native compilers, these are well-known paths containing
1631 components that may be provided by the system. For cross
1632 compilers, these paths are not used. */
1633 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1634 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1635 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1636 static const char *const standard_startfile_prefix_1
1637 = STANDARD_STARTFILE_PREFIX_1;
1638 static const char *const standard_startfile_prefix_2
1639 = STANDARD_STARTFILE_PREFIX_2;
1641 /* A relative path to be used in finding the location of tools
1642 relative to the driver. */
1643 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1645 /* A prefix to be used when this is an accelerator compiler. */
1646 static const char *const accel_dir_suffix = ACCEL_DIR_SUFFIX;
1648 /* Subdirectory to use for locating libraries. Set by
1649 set_multilib_dir based on the compilation options. */
1651 static const char *multilib_dir;
1653 /* Subdirectory to use for locating libraries in OS conventions. Set by
1654 set_multilib_dir based on the compilation options. */
1656 static const char *multilib_os_dir;
1658 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1659 set_multilib_dir based on the compilation options. */
1661 static const char *multiarch_dir;
1663 /* Structure to keep track of the specs that have been defined so far.
1664 These are accessed using %(specname) in a compiler or link
1665 spec. */
1667 struct spec_list
1669 /* The following 2 fields must be first */
1670 /* to allow EXTRA_SPECS to be initialized */
1671 const char *name; /* name of the spec. */
1672 const char *ptr; /* available ptr if no static pointer */
1674 /* The following fields are not initialized */
1675 /* by EXTRA_SPECS */
1676 const char **ptr_spec; /* pointer to the spec itself. */
1677 struct spec_list *next; /* Next spec in linked list. */
1678 int name_len; /* length of the name */
1679 bool user_p; /* whether string come from file spec. */
1680 bool alloc_p; /* whether string was allocated */
1681 const char *default_ptr; /* The default value of *ptr_spec. */
1684 #define INIT_STATIC_SPEC(NAME,PTR) \
1685 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false, \
1686 *PTR }
1688 /* List of statically defined specs. */
1689 static struct spec_list static_specs[] =
1691 INIT_STATIC_SPEC ("asm", &asm_spec),
1692 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1693 INIT_STATIC_SPEC ("asm_debug_option", &asm_debug_option),
1694 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1695 INIT_STATIC_SPEC ("asm_options", &asm_options),
1696 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1697 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1698 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1699 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1700 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1701 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1702 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1703 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1704 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1705 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1706 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1707 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1708 INIT_STATIC_SPEC ("link", &link_spec),
1709 INIT_STATIC_SPEC ("lib", &lib_spec),
1710 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1711 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1712 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1713 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1714 INIT_STATIC_SPEC ("version", &compiler_version),
1715 INIT_STATIC_SPEC ("multilib", &multilib_select),
1716 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1717 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1718 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1719 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1720 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1721 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1722 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1723 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1724 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1725 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1726 INIT_STATIC_SPEC ("post_link", &post_link_spec),
1727 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1728 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1729 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1730 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1731 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1732 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1733 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1734 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1735 INIT_STATIC_SPEC ("self_spec", &self_spec),
1738 #ifdef EXTRA_SPECS /* additional specs needed */
1739 /* Structure to keep track of just the first two args of a spec_list.
1740 That is all that the EXTRA_SPECS macro gives us. */
1741 struct spec_list_1
1743 const char *const name;
1744 const char *const ptr;
1747 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1748 static struct spec_list *extra_specs = (struct spec_list *) 0;
1749 #endif
1751 /* List of dynamically allocates specs that have been defined so far. */
1753 static struct spec_list *specs = (struct spec_list *) 0;
1755 /* List of static spec functions. */
1757 static const struct spec_function static_spec_functions[] =
1759 { "getenv", getenv_spec_function },
1760 { "if-exists", if_exists_spec_function },
1761 { "if-exists-else", if_exists_else_spec_function },
1762 { "if-exists-then-else", if_exists_then_else_spec_function },
1763 { "sanitize", sanitize_spec_function },
1764 { "replace-outfile", replace_outfile_spec_function },
1765 { "remove-outfile", remove_outfile_spec_function },
1766 { "version-compare", version_compare_spec_function },
1767 { "include", include_spec_function },
1768 { "find-file", find_file_spec_function },
1769 { "find-plugindir", find_plugindir_spec_function },
1770 { "print-asm-header", print_asm_header_spec_function },
1771 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1772 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1773 { "pass-through-libs", pass_through_libs_spec_func },
1774 { "dumps", dumps_spec_func },
1775 { "gt", greater_than_spec_func },
1776 { "debug-level-gt", debug_level_greater_than_spec_func },
1777 { "dwarf-version-gt", dwarf_version_greater_than_spec_func },
1778 { "fortran-preinclude-file", find_fortran_preinclude_file},
1779 #ifdef EXTRA_SPEC_FUNCTIONS
1780 EXTRA_SPEC_FUNCTIONS
1781 #endif
1782 { 0, 0 }
1785 static int processing_spec_function;
1787 /* Add appropriate libgcc specs to OBSTACK, taking into account
1788 various permutations of -shared-libgcc, -shared, and such. */
1790 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1792 #ifndef USE_LD_AS_NEEDED
1793 #define USE_LD_AS_NEEDED 0
1794 #endif
1796 static void
1797 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1798 const char *static_name, const char *eh_name)
1800 char *buf;
1802 #if USE_LD_AS_NEEDED
1803 buf = concat ("%{static|static-libgcc|static-pie:", static_name, " ", eh_name, "}"
1804 "%{!static:%{!static-libgcc:%{!static-pie:"
1805 "%{!shared-libgcc:",
1806 static_name, " " LD_AS_NEEDED_OPTION " ",
1807 shared_name, " " LD_NO_AS_NEEDED_OPTION
1809 "%{shared-libgcc:",
1810 shared_name, "%{!shared: ", static_name, "}"
1811 "}}"
1812 #else
1813 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1814 "%{!static:%{!static-libgcc:"
1815 "%{!shared:"
1816 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1817 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1819 #ifdef LINK_EH_SPEC
1820 "%{shared:"
1821 "%{shared-libgcc:", shared_name, "}"
1822 "%{!shared-libgcc:", static_name, "}"
1824 #else
1825 "%{shared:", shared_name, "}"
1826 #endif
1827 #endif
1828 "}}", NULL);
1830 obstack_grow (obstack, buf, strlen (buf));
1831 free (buf);
1833 #endif /* ENABLE_SHARED_LIBGCC */
1835 /* Initialize the specs lookup routines. */
1837 static void
1838 init_spec (void)
1840 struct spec_list *next = (struct spec_list *) 0;
1841 struct spec_list *sl = (struct spec_list *) 0;
1842 int i;
1844 if (specs)
1845 return; /* Already initialized. */
1847 if (verbose_flag)
1848 fnotice (stderr, "Using built-in specs.\n");
1850 #ifdef EXTRA_SPECS
1851 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1853 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1855 sl = &extra_specs[i];
1856 sl->name = extra_specs_1[i].name;
1857 sl->ptr = extra_specs_1[i].ptr;
1858 sl->next = next;
1859 sl->name_len = strlen (sl->name);
1860 sl->ptr_spec = &sl->ptr;
1861 gcc_assert (sl->ptr_spec != NULL);
1862 sl->default_ptr = sl->ptr;
1863 next = sl;
1865 #endif
1867 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1869 sl = &static_specs[i];
1870 sl->next = next;
1871 next = sl;
1874 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1875 /* ??? If neither -shared-libgcc nor --static-libgcc was
1876 seen, then we should be making an educated guess. Some proposed
1877 heuristics for ELF include:
1879 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1880 program will be doing dynamic loading, which will likely
1881 need the shared libgcc.
1883 (2) If "-ldl", then it's also a fair bet that we're doing
1884 dynamic loading.
1886 (3) For each ET_DYN we're linking against (either through -lfoo
1887 or /some/path/foo.so), check to see whether it or one of
1888 its dependencies depends on a shared libgcc.
1890 (4) If "-shared"
1892 If the runtime is fixed to look for program headers instead
1893 of calling __register_frame_info at all, for each object,
1894 use the shared libgcc if any EH symbol referenced.
1896 If crtstuff is fixed to not invoke __register_frame_info
1897 automatically, for each object, use the shared libgcc if
1898 any non-empty unwind section found.
1900 Doing any of this probably requires invoking an external program to
1901 do the actual object file scanning. */
1903 const char *p = libgcc_spec;
1904 int in_sep = 1;
1906 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1907 when given the proper command line arguments. */
1908 while (*p)
1910 if (in_sep && *p == '-' && startswith (p, "-lgcc"))
1912 init_gcc_specs (&obstack,
1913 "-lgcc_s"
1914 #ifdef USE_LIBUNWIND_EXCEPTIONS
1915 " -lunwind"
1916 #endif
1918 "-lgcc",
1919 "-lgcc_eh"
1920 #ifdef USE_LIBUNWIND_EXCEPTIONS
1921 # ifdef HAVE_LD_STATIC_DYNAMIC
1922 " %{!static:%{!static-pie:" LD_STATIC_OPTION "}} -lunwind"
1923 " %{!static:%{!static-pie:" LD_DYNAMIC_OPTION "}}"
1924 # else
1925 " -lunwind"
1926 # endif
1927 #endif
1930 p += 5;
1931 in_sep = 0;
1933 else if (in_sep && *p == 'l' && startswith (p, "libgcc.a%s"))
1935 /* Ug. We don't know shared library extensions. Hope that
1936 systems that use this form don't do shared libraries. */
1937 init_gcc_specs (&obstack,
1938 "-lgcc_s",
1939 "libgcc.a%s",
1940 "libgcc_eh.a%s"
1941 #ifdef USE_LIBUNWIND_EXCEPTIONS
1942 " -lunwind"
1943 #endif
1945 p += 10;
1946 in_sep = 0;
1948 else
1950 obstack_1grow (&obstack, *p);
1951 in_sep = (*p == ' ');
1952 p += 1;
1956 obstack_1grow (&obstack, '\0');
1957 libgcc_spec = XOBFINISH (&obstack, const char *);
1959 #endif
1960 #ifdef USE_AS_TRADITIONAL_FORMAT
1961 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1963 static const char tf[] = "--traditional-format ";
1964 obstack_grow (&obstack, tf, sizeof (tf) - 1);
1965 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1966 asm_spec = XOBFINISH (&obstack, const char *);
1968 #endif
1970 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1971 defined LINKER_HASH_STYLE
1972 # ifdef LINK_BUILDID_SPEC
1973 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1974 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof (LINK_BUILDID_SPEC) - 1);
1975 # endif
1976 # ifdef LINK_EH_SPEC
1977 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1978 obstack_grow (&obstack, LINK_EH_SPEC, sizeof (LINK_EH_SPEC) - 1);
1979 # endif
1980 # ifdef LINKER_HASH_STYLE
1981 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1982 before. */
1984 static const char hash_style[] = "--hash-style=";
1985 obstack_grow (&obstack, hash_style, sizeof (hash_style) - 1);
1986 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof (LINKER_HASH_STYLE) - 1);
1987 obstack_1grow (&obstack, ' ');
1989 # endif
1990 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1991 link_spec = XOBFINISH (&obstack, const char *);
1992 #endif
1994 specs = sl;
1997 /* Update the entry for SPEC in the static_specs table to point to VALUE,
1998 ensuring that we free the previous value if necessary. Set alloc_p for the
1999 entry to ALLOC_P: this determines whether we take ownership of VALUE (i.e.
2000 whether we need to free it later on). */
2001 static void
2002 set_static_spec (const char **spec, const char *value, bool alloc_p)
2004 struct spec_list *sl = NULL;
2006 for (unsigned i = 0; i < ARRAY_SIZE (static_specs); i++)
2008 if (static_specs[i].ptr_spec == spec)
2010 sl = static_specs + i;
2011 break;
2015 gcc_assert (sl);
2017 if (sl->alloc_p)
2019 const char *old = *spec;
2020 free (const_cast <char *> (old));
2023 *spec = value;
2024 sl->alloc_p = alloc_p;
2027 /* Update a static spec to a new string, taking ownership of that
2028 string's memory. */
2029 static void set_static_spec_owned (const char **spec, const char *val)
2031 return set_static_spec (spec, val, true);
2034 /* Update a static spec to point to a new value, but don't take
2035 ownership of (i.e. don't free) that string. */
2036 static void set_static_spec_shared (const char **spec, const char *val)
2038 return set_static_spec (spec, val, false);
2042 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
2043 removed; If the spec starts with a + then SPEC is added to the end of the
2044 current spec. */
2046 static void
2047 set_spec (const char *name, const char *spec, bool user_p)
2049 struct spec_list *sl;
2050 const char *old_spec;
2051 int name_len = strlen (name);
2052 int i;
2054 /* If this is the first call, initialize the statically allocated specs. */
2055 if (!specs)
2057 struct spec_list *next = (struct spec_list *) 0;
2058 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
2060 sl = &static_specs[i];
2061 sl->next = next;
2062 next = sl;
2064 specs = sl;
2067 /* See if the spec already exists. */
2068 for (sl = specs; sl; sl = sl->next)
2069 if (name_len == sl->name_len && !strcmp (sl->name, name))
2070 break;
2072 if (!sl)
2074 /* Not found - make it. */
2075 sl = XNEW (struct spec_list);
2076 sl->name = xstrdup (name);
2077 sl->name_len = name_len;
2078 sl->ptr_spec = &sl->ptr;
2079 sl->alloc_p = 0;
2080 *(sl->ptr_spec) = "";
2081 sl->next = specs;
2082 sl->default_ptr = NULL;
2083 specs = sl;
2086 old_spec = *(sl->ptr_spec);
2087 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
2088 ? concat (old_spec, spec + 1, NULL)
2089 : xstrdup (spec));
2091 #ifdef DEBUG_SPECS
2092 if (verbose_flag)
2093 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
2094 #endif
2096 /* Free the old spec. */
2097 if (old_spec && sl->alloc_p)
2098 free (CONST_CAST (char *, old_spec));
2100 sl->user_p = user_p;
2101 sl->alloc_p = true;
2104 /* Accumulate a command (program name and args), and run it. */
2106 typedef const char *const_char_p; /* For DEF_VEC_P. */
2108 /* Vector of pointers to arguments in the current line of specifications. */
2109 static vec<const_char_p> argbuf;
2111 /* Likewise, but for the current @file. */
2112 static vec<const_char_p> at_file_argbuf;
2114 /* Whether an @file is currently open. */
2115 static bool in_at_file = false;
2117 /* Were the options -c, -S or -E passed. */
2118 static int have_c = 0;
2120 /* Was the option -o passed. */
2121 static int have_o = 0;
2123 /* Was the option -E passed. */
2124 static int have_E = 0;
2126 /* Pointer to output file name passed in with -o. */
2127 static const char *output_file = 0;
2129 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
2130 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
2131 it here. */
2133 static struct temp_name {
2134 const char *suffix; /* suffix associated with the code. */
2135 int length; /* strlen (suffix). */
2136 int unique; /* Indicates whether %g or %u/%U was used. */
2137 const char *filename; /* associated filename. */
2138 int filename_length; /* strlen (filename). */
2139 struct temp_name *next;
2140 } *temp_names;
2142 /* Number of commands executed so far. */
2144 static int execution_count;
2146 /* Number of commands that exited with a signal. */
2148 static int signal_count;
2150 /* Allocate the argument vector. */
2152 static void
2153 alloc_args (void)
2155 argbuf.create (10);
2156 at_file_argbuf.create (10);
2159 /* Clear out the vector of arguments (after a command is executed). */
2161 static void
2162 clear_args (void)
2164 argbuf.truncate (0);
2165 at_file_argbuf.truncate (0);
2168 /* Add one argument to the vector at the end.
2169 This is done when a space is seen or at the end of the line.
2170 If DELETE_ALWAYS is nonzero, the arg is a filename
2171 and the file should be deleted eventually.
2172 If DELETE_FAILURE is nonzero, the arg is a filename
2173 and the file should be deleted if this compilation fails. */
2175 static void
2176 store_arg (const char *arg, int delete_always, int delete_failure)
2178 if (in_at_file)
2179 at_file_argbuf.safe_push (arg);
2180 else
2181 argbuf.safe_push (arg);
2183 if (delete_always || delete_failure)
2185 const char *p;
2186 /* If the temporary file we should delete is specified as
2187 part of a joined argument extract the filename. */
2188 if (arg[0] == '-'
2189 && (p = strrchr (arg, '=')))
2190 arg = p + 1;
2191 record_temp_file (arg, delete_always, delete_failure);
2195 /* Open a temporary @file into which subsequent arguments will be stored. */
2197 static void
2198 open_at_file (void)
2200 if (in_at_file)
2201 fatal_error (input_location, "cannot open nested response file");
2202 else
2203 in_at_file = true;
2206 /* Create a temporary @file name. */
2208 static char *make_at_file (void)
2210 static int fileno = 0;
2211 char filename[20];
2212 const char *base, *ext;
2214 if (!save_temps_flag)
2215 return make_temp_file ("");
2217 base = dumpbase;
2218 if (!(base && *base))
2219 base = dumpdir;
2220 if (!(base && *base))
2221 base = "a";
2223 sprintf (filename, ".args.%d", fileno++);
2224 ext = filename;
2226 if (base == dumpdir && dumpdir_trailing_dash_added)
2227 ext++;
2229 return concat (base, ext, NULL);
2232 /* Close the temporary @file and add @file to the argument list. */
2234 static void
2235 close_at_file (void)
2237 if (!in_at_file)
2238 fatal_error (input_location, "cannot close nonexistent response file");
2240 in_at_file = false;
2242 const unsigned int n_args = at_file_argbuf.length ();
2243 if (n_args == 0)
2244 return;
2246 char **argv = XALLOCAVEC (char *, n_args + 1);
2247 char *temp_file = make_at_file ();
2248 char *at_argument = concat ("@", temp_file, NULL);
2249 FILE *f = fopen (temp_file, "w");
2250 int status;
2251 unsigned int i;
2253 /* Copy the strings over. */
2254 for (i = 0; i < n_args; i++)
2255 argv[i] = CONST_CAST (char *, at_file_argbuf[i]);
2256 argv[i] = NULL;
2258 at_file_argbuf.truncate (0);
2260 if (f == NULL)
2261 fatal_error (input_location, "could not open temporary response file %s",
2262 temp_file);
2264 status = writeargv (argv, f);
2266 if (status)
2267 fatal_error (input_location,
2268 "could not write to temporary response file %s",
2269 temp_file);
2271 status = fclose (f);
2273 if (status == EOF)
2274 fatal_error (input_location, "could not close temporary response file %s",
2275 temp_file);
2277 store_arg (at_argument, 0, 0);
2279 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
2282 /* Load specs from a file name named FILENAME, replacing occurrences of
2283 various different types of line-endings, \r\n, \n\r and just \r, with
2284 a single \n. */
2286 static char *
2287 load_specs (const char *filename)
2289 int desc;
2290 int readlen;
2291 struct stat statbuf;
2292 char *buffer;
2293 char *buffer_p;
2294 char *specs;
2295 char *specs_p;
2297 if (verbose_flag)
2298 fnotice (stderr, "Reading specs from %s\n", filename);
2300 /* Open and stat the file. */
2301 desc = open (filename, O_RDONLY, 0);
2302 if (desc < 0)
2304 failed:
2305 /* This leaves DESC open, but the OS will save us. */
2306 fatal_error (input_location, "cannot read spec file %qs: %m", filename);
2309 if (stat (filename, &statbuf) < 0)
2310 goto failed;
2312 /* Read contents of file into BUFFER. */
2313 buffer = XNEWVEC (char, statbuf.st_size + 1);
2314 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
2315 if (readlen < 0)
2316 goto failed;
2317 buffer[readlen] = 0;
2318 close (desc);
2320 specs = XNEWVEC (char, readlen + 1);
2321 specs_p = specs;
2322 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
2324 int skip = 0;
2325 char c = *buffer_p;
2326 if (c == '\r')
2328 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
2329 skip = 1;
2330 else if (*(buffer_p + 1) == '\n') /* \r\n */
2331 skip = 1;
2332 else /* \r */
2333 c = '\n';
2335 if (! skip)
2336 *specs_p++ = c;
2338 *specs_p = '\0';
2340 free (buffer);
2341 return (specs);
2344 /* Read compilation specs from a file named FILENAME,
2345 replacing the default ones.
2347 A suffix which starts with `*' is a definition for
2348 one of the machine-specific sub-specs. The "suffix" should be
2349 *asm, *cc1, *cpp, *link, *startfile, etc.
2350 The corresponding spec is stored in asm_spec, etc.,
2351 rather than in the `compilers' vector.
2353 Anything invalid in the file is a fatal error. */
2355 static void
2356 read_specs (const char *filename, bool main_p, bool user_p)
2358 char *buffer;
2359 char *p;
2361 buffer = load_specs (filename);
2363 /* Scan BUFFER for specs, putting them in the vector. */
2364 p = buffer;
2365 while (1)
2367 char *suffix;
2368 char *spec;
2369 char *in, *out, *p1, *p2, *p3;
2371 /* Advance P in BUFFER to the next nonblank nocomment line. */
2372 p = skip_whitespace (p);
2373 if (*p == 0)
2374 break;
2376 /* Is this a special command that starts with '%'? */
2377 /* Don't allow this for the main specs file, since it would
2378 encourage people to overwrite it. */
2379 if (*p == '%' && !main_p)
2381 p1 = p;
2382 while (*p && *p != '\n')
2383 p++;
2385 /* Skip '\n'. */
2386 p++;
2388 if (startswith (p1, "%include")
2389 && (p1[sizeof "%include" - 1] == ' '
2390 || p1[sizeof "%include" - 1] == '\t'))
2392 char *new_filename;
2394 p1 += sizeof ("%include");
2395 while (*p1 == ' ' || *p1 == '\t')
2396 p1++;
2398 if (*p1++ != '<' || p[-2] != '>')
2399 fatal_error (input_location,
2400 "specs %%include syntax malformed after "
2401 "%ld characters",
2402 (long) (p1 - buffer + 1));
2404 p[-2] = '\0';
2405 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2406 read_specs (new_filename ? new_filename : p1, false, user_p);
2407 continue;
2409 else if (startswith (p1, "%include_noerr")
2410 && (p1[sizeof "%include_noerr" - 1] == ' '
2411 || p1[sizeof "%include_noerr" - 1] == '\t'))
2413 char *new_filename;
2415 p1 += sizeof "%include_noerr";
2416 while (*p1 == ' ' || *p1 == '\t')
2417 p1++;
2419 if (*p1++ != '<' || p[-2] != '>')
2420 fatal_error (input_location,
2421 "specs %%include syntax malformed after "
2422 "%ld characters",
2423 (long) (p1 - buffer + 1));
2425 p[-2] = '\0';
2426 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2427 if (new_filename)
2428 read_specs (new_filename, false, user_p);
2429 else if (verbose_flag)
2430 fnotice (stderr, "could not find specs file %s\n", p1);
2431 continue;
2433 else if (startswith (p1, "%rename")
2434 && (p1[sizeof "%rename" - 1] == ' '
2435 || p1[sizeof "%rename" - 1] == '\t'))
2437 int name_len;
2438 struct spec_list *sl;
2439 struct spec_list *newsl;
2441 /* Get original name. */
2442 p1 += sizeof "%rename";
2443 while (*p1 == ' ' || *p1 == '\t')
2444 p1++;
2446 if (! ISALPHA ((unsigned char) *p1))
2447 fatal_error (input_location,
2448 "specs %%rename syntax malformed after "
2449 "%ld characters",
2450 (long) (p1 - buffer));
2452 p2 = p1;
2453 while (*p2 && !ISSPACE ((unsigned char) *p2))
2454 p2++;
2456 if (*p2 != ' ' && *p2 != '\t')
2457 fatal_error (input_location,
2458 "specs %%rename syntax malformed after "
2459 "%ld characters",
2460 (long) (p2 - buffer));
2462 name_len = p2 - p1;
2463 *p2++ = '\0';
2464 while (*p2 == ' ' || *p2 == '\t')
2465 p2++;
2467 if (! ISALPHA ((unsigned char) *p2))
2468 fatal_error (input_location,
2469 "specs %%rename syntax malformed after "
2470 "%ld characters",
2471 (long) (p2 - buffer));
2473 /* Get new spec name. */
2474 p3 = p2;
2475 while (*p3 && !ISSPACE ((unsigned char) *p3))
2476 p3++;
2478 if (p3 != p - 1)
2479 fatal_error (input_location,
2480 "specs %%rename syntax malformed after "
2481 "%ld characters",
2482 (long) (p3 - buffer));
2483 *p3 = '\0';
2485 for (sl = specs; sl; sl = sl->next)
2486 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2487 break;
2489 if (!sl)
2490 fatal_error (input_location,
2491 "specs %s spec was not found to be renamed", p1);
2493 if (strcmp (p1, p2) == 0)
2494 continue;
2496 for (newsl = specs; newsl; newsl = newsl->next)
2497 if (strcmp (newsl->name, p2) == 0)
2498 fatal_error (input_location,
2499 "%s: attempt to rename spec %qs to "
2500 "already defined spec %qs",
2501 filename, p1, p2);
2503 if (verbose_flag)
2505 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
2506 #ifdef DEBUG_SPECS
2507 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
2508 #endif
2511 set_spec (p2, *(sl->ptr_spec), user_p);
2512 if (sl->alloc_p)
2513 free (CONST_CAST (char *, *(sl->ptr_spec)));
2515 *(sl->ptr_spec) = "";
2516 sl->alloc_p = 0;
2517 continue;
2519 else
2520 fatal_error (input_location,
2521 "specs unknown %% command after %ld characters",
2522 (long) (p1 - buffer));
2525 /* Find the colon that should end the suffix. */
2526 p1 = p;
2527 while (*p1 && *p1 != ':' && *p1 != '\n')
2528 p1++;
2530 /* The colon shouldn't be missing. */
2531 if (*p1 != ':')
2532 fatal_error (input_location,
2533 "specs file malformed after %ld characters",
2534 (long) (p1 - buffer));
2536 /* Skip back over trailing whitespace. */
2537 p2 = p1;
2538 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2539 p2--;
2541 /* Copy the suffix to a string. */
2542 suffix = save_string (p, p2 - p);
2543 /* Find the next line. */
2544 p = skip_whitespace (p1 + 1);
2545 if (p[1] == 0)
2546 fatal_error (input_location,
2547 "specs file malformed after %ld characters",
2548 (long) (p - buffer));
2550 p1 = p;
2551 /* Find next blank line or end of string. */
2552 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2553 p1++;
2555 /* Specs end at the blank line and do not include the newline. */
2556 spec = save_string (p, p1 - p);
2557 p = p1;
2559 /* Delete backslash-newline sequences from the spec. */
2560 in = spec;
2561 out = spec;
2562 while (*in != 0)
2564 if (in[0] == '\\' && in[1] == '\n')
2565 in += 2;
2566 else if (in[0] == '#')
2567 while (*in && *in != '\n')
2568 in++;
2570 else
2571 *out++ = *in++;
2573 *out = 0;
2575 if (suffix[0] == '*')
2577 if (! strcmp (suffix, "*link_command"))
2578 link_command_spec = spec;
2579 else
2581 set_spec (suffix + 1, spec, user_p);
2582 free (spec);
2585 else
2587 /* Add this pair to the vector. */
2588 compilers
2589 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
2591 compilers[n_compilers].suffix = suffix;
2592 compilers[n_compilers].spec = spec;
2593 n_compilers++;
2594 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2597 if (*suffix == 0)
2598 link_command_spec = spec;
2601 if (link_command_spec == 0)
2602 fatal_error (input_location, "spec file has no spec for linking");
2604 XDELETEVEC (buffer);
2607 /* Record the names of temporary files we tell compilers to write,
2608 and delete them at the end of the run. */
2610 /* This is the common prefix we use to make temp file names.
2611 It is chosen once for each run of this program.
2612 It is substituted into a spec by %g or %j.
2613 Thus, all temp file names contain this prefix.
2614 In practice, all temp file names start with this prefix.
2616 This prefix comes from the envvar TMPDIR if it is defined;
2617 otherwise, from the P_tmpdir macro if that is defined;
2618 otherwise, in /usr/tmp or /tmp;
2619 or finally the current directory if all else fails. */
2621 static const char *temp_filename;
2623 /* Length of the prefix. */
2625 static int temp_filename_length;
2627 /* Define the list of temporary files to delete. */
2629 struct temp_file
2631 const char *name;
2632 struct temp_file *next;
2635 /* Queue of files to delete on success or failure of compilation. */
2636 static struct temp_file *always_delete_queue;
2637 /* Queue of files to delete on failure of compilation. */
2638 static struct temp_file *failure_delete_queue;
2640 /* Record FILENAME as a file to be deleted automatically.
2641 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2642 otherwise delete it in any case.
2643 FAIL_DELETE nonzero means delete it if a compilation step fails;
2644 otherwise delete it in any case. */
2646 void
2647 record_temp_file (const char *filename, int always_delete, int fail_delete)
2649 char *const name = xstrdup (filename);
2651 if (always_delete)
2653 struct temp_file *temp;
2654 for (temp = always_delete_queue; temp; temp = temp->next)
2655 if (! filename_cmp (name, temp->name))
2657 free (name);
2658 goto already1;
2661 temp = XNEW (struct temp_file);
2662 temp->next = always_delete_queue;
2663 temp->name = name;
2664 always_delete_queue = temp;
2666 already1:;
2669 if (fail_delete)
2671 struct temp_file *temp;
2672 for (temp = failure_delete_queue; temp; temp = temp->next)
2673 if (! filename_cmp (name, temp->name))
2675 free (name);
2676 goto already2;
2679 temp = XNEW (struct temp_file);
2680 temp->next = failure_delete_queue;
2681 temp->name = name;
2682 failure_delete_queue = temp;
2684 already2:;
2688 /* Delete all the temporary files whose names we previously recorded. */
2690 #ifndef DELETE_IF_ORDINARY
2691 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2692 do \
2694 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2695 if (unlink (NAME) < 0) \
2696 if (VERBOSE_FLAG) \
2697 error ("%s: %m", (NAME)); \
2698 } while (0)
2699 #endif
2701 static void
2702 delete_if_ordinary (const char *name)
2704 struct stat st;
2705 #ifdef DEBUG
2706 int i, c;
2708 printf ("Delete %s? (y or n) ", name);
2709 fflush (stdout);
2710 i = getchar ();
2711 if (i != '\n')
2712 while ((c = getchar ()) != '\n' && c != EOF)
2715 if (i == 'y' || i == 'Y')
2716 #endif /* DEBUG */
2717 DELETE_IF_ORDINARY (name, st, verbose_flag);
2720 static void
2721 delete_temp_files (void)
2723 struct temp_file *temp;
2725 for (temp = always_delete_queue; temp; temp = temp->next)
2726 delete_if_ordinary (temp->name);
2727 always_delete_queue = 0;
2730 /* Delete all the files to be deleted on error. */
2732 static void
2733 delete_failure_queue (void)
2735 struct temp_file *temp;
2737 for (temp = failure_delete_queue; temp; temp = temp->next)
2738 delete_if_ordinary (temp->name);
2741 static void
2742 clear_failure_queue (void)
2744 failure_delete_queue = 0;
2747 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2748 returns non-NULL.
2749 If DO_MULTI is true iterate over the paths twice, first with multilib
2750 suffix then without, otherwise iterate over the paths once without
2751 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2752 to avoid visiting the same path twice, but we could do better. For
2753 instance, /usr/lib/../lib is considered different from /usr/lib.
2754 At least EXTRA_SPACE chars past the end of the path passed to
2755 CALLBACK are available for use by the callback.
2756 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2758 Returns the value returned by CALLBACK. */
2760 static void *
2761 for_each_path (const struct path_prefix *paths,
2762 bool do_multi,
2763 size_t extra_space,
2764 void *(*callback) (char *, void *),
2765 void *callback_info)
2767 struct prefix_list *pl;
2768 const char *multi_dir = NULL;
2769 const char *multi_os_dir = NULL;
2770 const char *multiarch_suffix = NULL;
2771 const char *multi_suffix;
2772 const char *just_multi_suffix;
2773 char *path = NULL;
2774 void *ret = NULL;
2775 bool skip_multi_dir = false;
2776 bool skip_multi_os_dir = false;
2778 multi_suffix = machine_suffix;
2779 just_multi_suffix = just_machine_suffix;
2780 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2782 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2783 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2784 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2786 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2787 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2788 if (multiarch_dir)
2789 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2791 while (1)
2793 size_t multi_dir_len = 0;
2794 size_t multi_os_dir_len = 0;
2795 size_t multiarch_len = 0;
2796 size_t suffix_len;
2797 size_t just_suffix_len;
2798 size_t len;
2800 if (multi_dir)
2801 multi_dir_len = strlen (multi_dir);
2802 if (multi_os_dir)
2803 multi_os_dir_len = strlen (multi_os_dir);
2804 if (multiarch_suffix)
2805 multiarch_len = strlen (multiarch_suffix);
2806 suffix_len = strlen (multi_suffix);
2807 just_suffix_len = strlen (just_multi_suffix);
2809 if (path == NULL)
2811 len = paths->max_len + extra_space + 1;
2812 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2813 path = XNEWVEC (char, len);
2816 for (pl = paths->plist; pl != 0; pl = pl->next)
2818 len = strlen (pl->prefix);
2819 memcpy (path, pl->prefix, len);
2821 /* Look first in MACHINE/VERSION subdirectory. */
2822 if (!skip_multi_dir)
2824 memcpy (path + len, multi_suffix, suffix_len + 1);
2825 ret = callback (path, callback_info);
2826 if (ret)
2827 break;
2830 /* Some paths are tried with just the machine (ie. target)
2831 subdir. This is used for finding as, ld, etc. */
2832 if (!skip_multi_dir
2833 && pl->require_machine_suffix == 2)
2835 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2836 ret = callback (path, callback_info);
2837 if (ret)
2838 break;
2841 /* Now try the multiarch path. */
2842 if (!skip_multi_dir
2843 && !pl->require_machine_suffix && multiarch_dir)
2845 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2846 ret = callback (path, callback_info);
2847 if (ret)
2848 break;
2851 /* Now try the base path. */
2852 if (!pl->require_machine_suffix
2853 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2855 const char *this_multi;
2856 size_t this_multi_len;
2858 if (pl->os_multilib)
2860 this_multi = multi_os_dir;
2861 this_multi_len = multi_os_dir_len;
2863 else
2865 this_multi = multi_dir;
2866 this_multi_len = multi_dir_len;
2869 if (this_multi_len)
2870 memcpy (path + len, this_multi, this_multi_len + 1);
2871 else
2872 path[len] = '\0';
2874 ret = callback (path, callback_info);
2875 if (ret)
2876 break;
2879 if (pl)
2880 break;
2882 if (multi_dir == NULL && multi_os_dir == NULL)
2883 break;
2885 /* Run through the paths again, this time without multilibs.
2886 Don't repeat any we have already seen. */
2887 if (multi_dir)
2889 free (CONST_CAST (char *, multi_dir));
2890 multi_dir = NULL;
2891 free (CONST_CAST (char *, multi_suffix));
2892 multi_suffix = machine_suffix;
2893 free (CONST_CAST (char *, just_multi_suffix));
2894 just_multi_suffix = just_machine_suffix;
2896 else
2897 skip_multi_dir = true;
2898 if (multi_os_dir)
2900 free (CONST_CAST (char *, multi_os_dir));
2901 multi_os_dir = NULL;
2903 else
2904 skip_multi_os_dir = true;
2907 if (multi_dir)
2909 free (CONST_CAST (char *, multi_dir));
2910 free (CONST_CAST (char *, multi_suffix));
2911 free (CONST_CAST (char *, just_multi_suffix));
2913 if (multi_os_dir)
2914 free (CONST_CAST (char *, multi_os_dir));
2915 if (ret != path)
2916 free (path);
2917 return ret;
2920 /* Callback for build_search_list. Adds path to obstack being built. */
2922 struct add_to_obstack_info {
2923 struct obstack *ob;
2924 bool check_dir;
2925 bool first_time;
2928 static void *
2929 add_to_obstack (char *path, void *data)
2931 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2933 if (info->check_dir && !is_directory (path, false))
2934 return NULL;
2936 if (!info->first_time)
2937 obstack_1grow (info->ob, PATH_SEPARATOR);
2939 obstack_grow (info->ob, path, strlen (path));
2941 info->first_time = false;
2942 return NULL;
2945 /* Add or change the value of an environment variable, outputting the
2946 change to standard error if in verbose mode. */
2947 static void
2948 xputenv (const char *string)
2950 env.xput (string);
2953 /* Build a list of search directories from PATHS.
2954 PREFIX is a string to prepend to the list.
2955 If CHECK_DIR_P is true we ensure the directory exists.
2956 If DO_MULTI is true, multilib paths are output first, then
2957 non-multilib paths.
2958 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2959 It is also used by the --print-search-dirs flag. */
2961 static char *
2962 build_search_list (const struct path_prefix *paths, const char *prefix,
2963 bool check_dir, bool do_multi)
2965 struct add_to_obstack_info info;
2967 info.ob = &collect_obstack;
2968 info.check_dir = check_dir;
2969 info.first_time = true;
2971 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2972 obstack_1grow (&collect_obstack, '=');
2974 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2976 obstack_1grow (&collect_obstack, '\0');
2977 return XOBFINISH (&collect_obstack, char *);
2980 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2981 for collect. */
2983 static void
2984 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2985 bool do_multi)
2987 xputenv (build_search_list (paths, env_var, true, do_multi));
2990 /* Check whether NAME can be accessed in MODE. This is like access,
2991 except that it never considers directories to be executable. */
2993 static int
2994 access_check (const char *name, int mode)
2996 if (mode == X_OK)
2998 struct stat st;
3000 if (stat (name, &st) < 0
3001 || S_ISDIR (st.st_mode))
3002 return -1;
3005 return access (name, mode);
3008 /* Callback for find_a_file. Appends the file name to the directory
3009 path. If the resulting file exists in the right mode, return the
3010 full pathname to the file. */
3012 struct file_at_path_info {
3013 const char *name;
3014 const char *suffix;
3015 int name_len;
3016 int suffix_len;
3017 int mode;
3020 static void *
3021 file_at_path (char *path, void *data)
3023 struct file_at_path_info *info = (struct file_at_path_info *) data;
3024 size_t len = strlen (path);
3026 memcpy (path + len, info->name, info->name_len);
3027 len += info->name_len;
3029 /* Some systems have a suffix for executable files.
3030 So try appending that first. */
3031 if (info->suffix_len)
3033 memcpy (path + len, info->suffix, info->suffix_len + 1);
3034 if (access_check (path, info->mode) == 0)
3035 return path;
3038 path[len] = '\0';
3039 if (access_check (path, info->mode) == 0)
3040 return path;
3042 return NULL;
3045 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
3046 access to check permissions. If DO_MULTI is true, search multilib
3047 paths then non-multilib paths, otherwise do not search multilib paths.
3048 Return 0 if not found, otherwise return its name, allocated with malloc. */
3050 static char *
3051 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
3052 bool do_multi)
3054 struct file_at_path_info info;
3056 /* Find the filename in question (special case for absolute paths). */
3058 if (IS_ABSOLUTE_PATH (name))
3060 if (access (name, mode) == 0)
3061 return xstrdup (name);
3063 return NULL;
3066 info.name = name;
3067 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
3068 info.name_len = strlen (info.name);
3069 info.suffix_len = strlen (info.suffix);
3070 info.mode = mode;
3072 return (char*) for_each_path (pprefix, do_multi,
3073 info.name_len + info.suffix_len,
3074 file_at_path, &info);
3077 /* Specialization of find_a_file for programs that also takes into account
3078 configure-specified default programs. */
3080 static char*
3081 find_a_program (const char *name)
3083 /* Do not search if default matches query. */
3085 #ifdef DEFAULT_ASSEMBLER
3086 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, X_OK) == 0)
3087 return xstrdup (DEFAULT_ASSEMBLER);
3088 #endif
3090 #ifdef DEFAULT_LINKER
3091 if (! strcmp (name, "ld") && access (DEFAULT_LINKER, X_OK) == 0)
3092 return xstrdup (DEFAULT_LINKER);
3093 #endif
3095 #ifdef DEFAULT_DSYMUTIL
3096 if (! strcmp (name, "dsymutil") && access (DEFAULT_DSYMUTIL, X_OK) == 0)
3097 return xstrdup (DEFAULT_DSYMUTIL);
3098 #endif
3100 return find_a_file (&exec_prefixes, name, X_OK, false);
3103 /* Ranking of prefixes in the sort list. -B prefixes are put before
3104 all others. */
3106 enum path_prefix_priority
3108 PREFIX_PRIORITY_B_OPT,
3109 PREFIX_PRIORITY_LAST
3112 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
3113 order according to PRIORITY. Within each PRIORITY, new entries are
3114 appended.
3116 If WARN is nonzero, we will warn if no file is found
3117 through this prefix. WARN should point to an int
3118 which will be set to 1 if this entry is used.
3120 COMPONENT is the value to be passed to update_path.
3122 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
3123 the complete value of machine_suffix.
3124 2 means try both machine_suffix and just_machine_suffix. */
3126 static void
3127 add_prefix (struct path_prefix *pprefix, const char *prefix,
3128 const char *component, /* enum prefix_priority */ int priority,
3129 int require_machine_suffix, int os_multilib)
3131 struct prefix_list *pl, **prev;
3132 int len;
3134 for (prev = &pprefix->plist;
3135 (*prev) != NULL && (*prev)->priority <= priority;
3136 prev = &(*prev)->next)
3139 /* Keep track of the longest prefix. */
3141 prefix = update_path (prefix, component);
3142 len = strlen (prefix);
3143 if (len > pprefix->max_len)
3144 pprefix->max_len = len;
3146 pl = XNEW (struct prefix_list);
3147 pl->prefix = prefix;
3148 pl->require_machine_suffix = require_machine_suffix;
3149 pl->priority = priority;
3150 pl->os_multilib = os_multilib;
3152 /* Insert after PREV. */
3153 pl->next = (*prev);
3154 (*prev) = pl;
3157 /* Same as add_prefix, but prepending target_system_root to prefix. */
3158 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
3159 static void
3160 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
3161 const char *component,
3162 /* enum prefix_priority */ int priority,
3163 int require_machine_suffix, int os_multilib)
3165 if (!IS_ABSOLUTE_PATH (prefix))
3166 fatal_error (input_location, "system path %qs is not absolute", prefix);
3168 if (target_system_root)
3170 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
3171 size_t sysroot_len = strlen (target_system_root);
3173 if (sysroot_len > 0
3174 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
3175 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
3177 if (target_sysroot_suffix)
3178 prefix = concat (sysroot_no_trailing_dir_separator,
3179 target_sysroot_suffix, prefix, NULL);
3180 else
3181 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
3183 free (sysroot_no_trailing_dir_separator);
3185 /* We have to override this because GCC's notion of sysroot
3186 moves along with GCC. */
3187 component = "GCC";
3190 add_prefix (pprefix, prefix, component, priority,
3191 require_machine_suffix, os_multilib);
3194 /* Same as add_prefix, but prepending target_sysroot_hdrs_suffix to prefix. */
3196 static void
3197 add_sysrooted_hdrs_prefix (struct path_prefix *pprefix, const char *prefix,
3198 const char *component,
3199 /* enum prefix_priority */ int priority,
3200 int require_machine_suffix, int os_multilib)
3202 if (!IS_ABSOLUTE_PATH (prefix))
3203 fatal_error (input_location, "system path %qs is not absolute", prefix);
3205 if (target_system_root)
3207 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
3208 size_t sysroot_len = strlen (target_system_root);
3210 if (sysroot_len > 0
3211 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
3212 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
3214 if (target_sysroot_hdrs_suffix)
3215 prefix = concat (sysroot_no_trailing_dir_separator,
3216 target_sysroot_hdrs_suffix, prefix, NULL);
3217 else
3218 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
3220 free (sysroot_no_trailing_dir_separator);
3222 /* We have to override this because GCC's notion of sysroot
3223 moves along with GCC. */
3224 component = "GCC";
3227 add_prefix (pprefix, prefix, component, priority,
3228 require_machine_suffix, os_multilib);
3232 /* Execute the command specified by the arguments on the current line of spec.
3233 When using pipes, this includes several piped-together commands
3234 with `|' between them.
3236 Return 0 if successful, -1 if failed. */
3238 static int
3239 execute (void)
3241 int i;
3242 int n_commands; /* # of command. */
3243 char *string;
3244 struct pex_obj *pex;
3245 struct command
3247 const char *prog; /* program name. */
3248 const char **argv; /* vector of args. */
3250 const char *arg;
3252 struct command *commands; /* each command buffer with above info. */
3254 gcc_assert (!processing_spec_function);
3256 if (wrapper_string)
3258 string = find_a_program (argbuf[0]);
3259 if (string)
3260 argbuf[0] = string;
3261 insert_wrapper (wrapper_string);
3264 /* Count # of piped commands. */
3265 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
3266 if (strcmp (arg, "|") == 0)
3267 n_commands++;
3269 /* Get storage for each command. */
3270 commands = XALLOCAVEC (struct command, n_commands);
3272 /* Split argbuf into its separate piped processes,
3273 and record info about each one.
3274 Also search for the programs that are to be run. */
3276 argbuf.safe_push (0);
3278 commands[0].prog = argbuf[0]; /* first command. */
3279 commands[0].argv = argbuf.address ();
3281 if (!wrapper_string)
3283 string = find_a_program(commands[0].prog);
3284 if (string)
3285 commands[0].argv[0] = string;
3288 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
3289 if (arg && strcmp (arg, "|") == 0)
3290 { /* each command. */
3291 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
3292 fatal_error (input_location, "%<-pipe%> not supported");
3293 #endif
3294 argbuf[i] = 0; /* Termination of command args. */
3295 commands[n_commands].prog = argbuf[i + 1];
3296 commands[n_commands].argv
3297 = &(argbuf.address ())[i + 1];
3298 string = find_a_program(commands[n_commands].prog);
3299 if (string)
3300 commands[n_commands].argv[0] = string;
3301 n_commands++;
3304 /* If -v, print what we are about to do, and maybe query. */
3306 if (verbose_flag)
3308 /* For help listings, put a blank line between sub-processes. */
3309 if (print_help_list)
3310 fputc ('\n', stderr);
3312 /* Print each piped command as a separate line. */
3313 for (i = 0; i < n_commands; i++)
3315 const char *const *j;
3317 if (verbose_only_flag)
3319 for (j = commands[i].argv; *j; j++)
3321 const char *p;
3322 for (p = *j; *p; ++p)
3323 if (!ISALNUM ((unsigned char) *p)
3324 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
3325 break;
3326 if (*p || !*j)
3328 fprintf (stderr, " \"");
3329 for (p = *j; *p; ++p)
3331 if (*p == '"' || *p == '\\' || *p == '$')
3332 fputc ('\\', stderr);
3333 fputc (*p, stderr);
3335 fputc ('"', stderr);
3337 /* If it's empty, print "". */
3338 else if (!**j)
3339 fprintf (stderr, " \"\"");
3340 else
3341 fprintf (stderr, " %s", *j);
3344 else
3345 for (j = commands[i].argv; *j; j++)
3346 /* If it's empty, print "". */
3347 if (!**j)
3348 fprintf (stderr, " \"\"");
3349 else
3350 fprintf (stderr, " %s", *j);
3352 /* Print a pipe symbol after all but the last command. */
3353 if (i + 1 != n_commands)
3354 fprintf (stderr, " |");
3355 fprintf (stderr, "\n");
3357 fflush (stderr);
3358 if (verbose_only_flag != 0)
3360 /* verbose_only_flag should act as if the spec was
3361 executed, so increment execution_count before
3362 returning. This prevents spurious warnings about
3363 unused linker input files, etc. */
3364 execution_count++;
3365 return 0;
3367 #ifdef DEBUG
3368 fnotice (stderr, "\nGo ahead? (y or n) ");
3369 fflush (stderr);
3370 i = getchar ();
3371 if (i != '\n')
3372 while (getchar () != '\n')
3375 if (i != 'y' && i != 'Y')
3376 return 0;
3377 #endif /* DEBUG */
3380 #ifdef ENABLE_VALGRIND_CHECKING
3381 /* Run the each command through valgrind. To simplify prepending the
3382 path to valgrind and the option "-q" (for quiet operation unless
3383 something triggers), we allocate a separate argv array. */
3385 for (i = 0; i < n_commands; i++)
3387 const char **argv;
3388 int argc;
3389 int j;
3391 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
3394 argv = XALLOCAVEC (const char *, argc + 3);
3396 argv[0] = VALGRIND_PATH;
3397 argv[1] = "-q";
3398 for (j = 2; j < argc + 2; j++)
3399 argv[j] = commands[i].argv[j - 2];
3400 argv[j] = NULL;
3402 commands[i].argv = argv;
3403 commands[i].prog = argv[0];
3405 #endif
3407 /* Run each piped subprocess. */
3409 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
3410 ? PEX_RECORD_TIMES : 0),
3411 progname, temp_filename);
3412 if (pex == NULL)
3413 fatal_error (input_location, "%<pex_init%> failed: %m");
3415 for (i = 0; i < n_commands; i++)
3417 const char *errmsg;
3418 int err;
3419 const char *string = commands[i].argv[0];
3421 errmsg = pex_run (pex,
3422 ((i + 1 == n_commands ? PEX_LAST : 0)
3423 | (string == commands[i].prog ? PEX_SEARCH : 0)),
3424 string, CONST_CAST (char **, commands[i].argv),
3425 NULL, NULL, &err);
3426 if (errmsg != NULL)
3428 errno = err;
3429 fatal_error (input_location,
3430 err ? G_("cannot execute %qs: %s: %m")
3431 : G_("cannot execute %qs: %s"),
3432 string, errmsg);
3435 if (i && string != commands[i].prog)
3436 free (CONST_CAST (char *, string));
3439 execution_count++;
3441 /* Wait for all the subprocesses to finish. */
3444 int *statuses;
3445 struct pex_time *times = NULL;
3446 int ret_code = 0;
3448 statuses = XALLOCAVEC (int, n_commands);
3449 if (!pex_get_status (pex, n_commands, statuses))
3450 fatal_error (input_location, "failed to get exit status: %m");
3452 if (report_times || report_times_to_file)
3454 times = XALLOCAVEC (struct pex_time, n_commands);
3455 if (!pex_get_times (pex, n_commands, times))
3456 fatal_error (input_location, "failed to get process times: %m");
3459 pex_free (pex);
3461 for (i = 0; i < n_commands; ++i)
3463 int status = statuses[i];
3465 if (WIFSIGNALED (status))
3466 switch (WTERMSIG (status))
3468 case SIGINT:
3469 case SIGTERM:
3470 /* SIGQUIT and SIGKILL are not available on MinGW. */
3471 #ifdef SIGQUIT
3472 case SIGQUIT:
3473 #endif
3474 #ifdef SIGKILL
3475 case SIGKILL:
3476 #endif
3477 /* The user (or environment) did something to the
3478 inferior. Making this an ICE confuses the user into
3479 thinking there's a compiler bug. Much more likely is
3480 the user or OOM killer nuked it. */
3481 fatal_error (input_location,
3482 "%s signal terminated program %s",
3483 strsignal (WTERMSIG (status)),
3484 commands[i].prog);
3485 break;
3487 #ifdef SIGPIPE
3488 case SIGPIPE:
3489 /* SIGPIPE is a special case. It happens in -pipe mode
3490 when the compiler dies before the preprocessor is
3491 done, or the assembler dies before the compiler is
3492 done. There's generally been an error already, and
3493 this is just fallout. So don't generate another
3494 error unless we would otherwise have succeeded. */
3495 if (signal_count || greatest_status >= MIN_FATAL_STATUS)
3497 signal_count++;
3498 ret_code = -1;
3499 break;
3501 #endif
3502 /* FALLTHROUGH */
3504 default:
3505 /* The inferior failed to catch the signal. */
3506 internal_error_no_backtrace ("%s signal terminated program %s",
3507 strsignal (WTERMSIG (status)),
3508 commands[i].prog);
3510 else if (WIFEXITED (status)
3511 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
3513 /* For ICEs in cc1, cc1obj, cc1plus see if it is
3514 reproducible or not. */
3515 const char *p;
3516 if (flag_report_bug
3517 && WEXITSTATUS (status) == ICE_EXIT_CODE
3518 && i == 0
3519 && (p = strrchr (commands[0].argv[0], DIR_SEPARATOR))
3520 && startswith (p + 1, "cc1"))
3521 try_generate_repro (commands[0].argv);
3522 if (WEXITSTATUS (status) > greatest_status)
3523 greatest_status = WEXITSTATUS (status);
3524 ret_code = -1;
3527 if (report_times || report_times_to_file)
3529 struct pex_time *pt = &times[i];
3530 double ut, st;
3532 ut = ((double) pt->user_seconds
3533 + (double) pt->user_microseconds / 1.0e6);
3534 st = ((double) pt->system_seconds
3535 + (double) pt->system_microseconds / 1.0e6);
3537 if (ut + st != 0)
3539 if (report_times)
3540 fnotice (stderr, "# %s %.2f %.2f\n",
3541 commands[i].prog, ut, st);
3543 if (report_times_to_file)
3545 int c = 0;
3546 const char *const *j;
3548 fprintf (report_times_to_file, "%g %g", ut, st);
3550 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
3552 const char *p;
3553 for (p = *j; *p; ++p)
3554 if (*p == '"' || *p == '\\' || *p == '$'
3555 || ISSPACE (*p))
3556 break;
3558 if (*p)
3560 fprintf (report_times_to_file, " \"");
3561 for (p = *j; *p; ++p)
3563 if (*p == '"' || *p == '\\' || *p == '$')
3564 fputc ('\\', report_times_to_file);
3565 fputc (*p, report_times_to_file);
3567 fputc ('"', report_times_to_file);
3569 else
3570 fprintf (report_times_to_file, " %s", *j);
3573 fputc ('\n', report_times_to_file);
3579 if (commands[0].argv[0] != commands[0].prog)
3580 free (CONST_CAST (char *, commands[0].argv[0]));
3582 return ret_code;
3586 /* Find all the switches given to us
3587 and make a vector describing them.
3588 The elements of the vector are strings, one per switch given.
3589 If a switch uses following arguments, then the `part1' field
3590 is the switch itself and the `args' field
3591 is a null-terminated vector containing the following arguments.
3592 Bits in the `live_cond' field are:
3593 SWITCH_LIVE to indicate this switch is true in a conditional spec.
3594 SWITCH_FALSE to indicate this switch is overridden by a later switch.
3595 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
3596 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored.
3597 SWITCH_KEEP_FOR_GCC to indicate that this switch, otherwise ignored,
3598 should be included in COLLECT_GCC_OPTIONS.
3599 in all do_spec calls afterwards. Used for %<S from self specs.
3600 The `known' field describes whether this is an internal switch.
3601 The `validated' field describes whether any spec has looked at this switch;
3602 if it remains false at the end of the run, the switch must be meaningless.
3603 The `ordering' field is used to temporarily mark switches that have to be
3604 kept in a specific order. */
3606 #define SWITCH_LIVE (1 << 0)
3607 #define SWITCH_FALSE (1 << 1)
3608 #define SWITCH_IGNORE (1 << 2)
3609 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
3610 #define SWITCH_KEEP_FOR_GCC (1 << 4)
3612 struct switchstr
3614 const char *part1;
3615 const char **args;
3616 unsigned int live_cond;
3617 bool known;
3618 bool validated;
3619 bool ordering;
3622 static struct switchstr *switches;
3624 static int n_switches;
3626 static int n_switches_alloc;
3628 /* Set to zero if -fcompare-debug is disabled, positive if it's
3629 enabled and we're running the first compilation, negative if it's
3630 enabled and we're running the second compilation. For most of the
3631 time, it's in the range -1..1, but it can be temporarily set to 2
3632 or 3 to indicate that the -fcompare-debug flags didn't come from
3633 the command-line, but rather from the GCC_COMPARE_DEBUG environment
3634 variable, until a synthesized -fcompare-debug flag is added to the
3635 command line. */
3636 int compare_debug;
3638 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
3639 int compare_debug_second;
3641 /* Set to the flags that should be passed to the second compilation in
3642 a -fcompare-debug compilation. */
3643 const char *compare_debug_opt;
3645 static struct switchstr *switches_debug_check[2];
3647 static int n_switches_debug_check[2];
3649 static int n_switches_alloc_debug_check[2];
3651 static char *debug_check_temp_file[2];
3653 /* Language is one of three things:
3655 1) The name of a real programming language.
3656 2) NULL, indicating that no one has figured out
3657 what it is yet.
3658 3) '*', indicating that the file should be passed
3659 to the linker. */
3660 struct infile
3662 const char *name;
3663 const char *language;
3664 struct compiler *incompiler;
3665 bool compiled;
3666 bool preprocessed;
3669 /* Also a vector of input files specified. */
3671 static struct infile *infiles;
3673 int n_infiles;
3675 static int n_infiles_alloc;
3677 /* True if undefined environment variables encountered during spec processing
3678 are ok to ignore, typically when we're running for --help or --version. */
3680 static bool spec_undefvar_allowed;
3682 /* True if multiple input files are being compiled to a single
3683 assembly file. */
3685 static bool combine_inputs;
3687 /* This counts the number of libraries added by lang_specific_driver, so that
3688 we can tell if there were any user supplied any files or libraries. */
3690 static int added_libraries;
3692 /* And a vector of corresponding output files is made up later. */
3694 const char **outfiles;
3696 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3698 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3699 is true if we should look for an executable suffix. DO_OBJ
3700 is true if we should look for an object suffix. */
3702 static const char *
3703 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3704 int do_obj ATTRIBUTE_UNUSED)
3706 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3707 int i;
3708 #endif
3709 int len;
3711 if (name == NULL)
3712 return NULL;
3714 len = strlen (name);
3716 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3717 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3718 if (do_obj && len > 2
3719 && name[len - 2] == '.'
3720 && name[len - 1] == 'o')
3722 obstack_grow (&obstack, name, len - 2);
3723 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3724 name = XOBFINISH (&obstack, const char *);
3726 #endif
3728 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3729 /* If there is no filetype, make it the executable suffix (which includes
3730 the "."). But don't get confused if we have just "-o". */
3731 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || not_actual_file_p (name))
3732 return name;
3734 for (i = len - 1; i >= 0; i--)
3735 if (IS_DIR_SEPARATOR (name[i]))
3736 break;
3738 for (i++; i < len; i++)
3739 if (name[i] == '.')
3740 return name;
3742 obstack_grow (&obstack, name, len);
3743 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3744 strlen (TARGET_EXECUTABLE_SUFFIX));
3745 name = XOBFINISH (&obstack, const char *);
3746 #endif
3748 return name;
3750 #endif
3752 /* Display the command line switches accepted by gcc. */
3753 static void
3754 display_help (void)
3756 printf (_("Usage: %s [options] file...\n"), progname);
3757 fputs (_("Options:\n"), stdout);
3759 fputs (_(" -pass-exit-codes Exit with highest error code from a phase.\n"), stdout);
3760 fputs (_(" --help Display this information.\n"), stdout);
3761 fputs (_(" --target-help Display target specific command line options.\n"), stdout);
3762 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...].\n"), stdout);
3763 fputs (_(" Display specific types of command line options.\n"), stdout);
3764 if (! verbose_flag)
3765 fputs (_(" (Use '-v --help' to display command line options of sub-processes).\n"), stdout);
3766 fputs (_(" --version Display compiler version information.\n"), stdout);
3767 fputs (_(" -dumpspecs Display all of the built in spec strings.\n"), stdout);
3768 fputs (_(" -dumpversion Display the version of the compiler.\n"), stdout);
3769 fputs (_(" -dumpmachine Display the compiler's target processor.\n"), stdout);
3770 fputs (_(" -foffload=<targets> Specify offloading targets.\n"), stdout);
3771 fputs (_(" -print-search-dirs Display the directories in the compiler's search path.\n"), stdout);
3772 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library.\n"), stdout);
3773 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>.\n"), stdout);
3774 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>.\n"), stdout);
3775 fputs (_("\
3776 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3777 a component in the library path.\n"), stdout);
3778 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc.\n"), stdout);
3779 fputs (_("\
3780 -print-multi-lib Display the mapping between command line options and\n\
3781 multiple library search directories.\n"), stdout);
3782 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries.\n"), stdout);
3783 fputs (_(" -print-sysroot Display the target libraries directory.\n"), stdout);
3784 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers.\n"), stdout);
3785 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler.\n"), stdout);
3786 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor.\n"), stdout);
3787 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker.\n"), stdout);
3788 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler.\n"), stdout);
3789 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor.\n"), stdout);
3790 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker.\n"), stdout);
3791 fputs (_(" -save-temps Do not delete intermediate files.\n"), stdout);
3792 fputs (_(" -save-temps=<arg> Do not delete intermediate files.\n"), stdout);
3793 fputs (_("\
3794 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3795 prefixes to other gcc components.\n"), stdout);
3796 fputs (_(" -pipe Use pipes rather than intermediate files.\n"), stdout);
3797 fputs (_(" -time Time the execution of each subprocess.\n"), stdout);
3798 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>.\n"), stdout);
3799 fputs (_(" -std=<standard> Assume that the input sources are for <standard>.\n"), stdout);
3800 fputs (_("\
3801 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3802 and libraries.\n"), stdout);
3803 fputs (_(" -B <directory> Add <directory> to the compiler's search paths.\n"), stdout);
3804 fputs (_(" -v Display the programs invoked by the compiler.\n"), stdout);
3805 fputs (_(" -### Like -v but options quoted and commands not executed.\n"), stdout);
3806 fputs (_(" -E Preprocess only; do not compile, assemble or link.\n"), stdout);
3807 fputs (_(" -S Compile only; do not assemble or link.\n"), stdout);
3808 fputs (_(" -c Compile and assemble, but do not link.\n"), stdout);
3809 fputs (_(" -o <file> Place the output into <file>.\n"), stdout);
3810 fputs (_(" -pie Create a dynamically linked position independent\n\
3811 executable.\n"), stdout);
3812 fputs (_(" -shared Create a shared library.\n"), stdout);
3813 fputs (_("\
3814 -x <language> Specify the language of the following input files.\n\
3815 Permissible languages include: c c++ assembler none\n\
3816 'none' means revert to the default behavior of\n\
3817 guessing the language based on the file's extension.\n\
3818 "), stdout);
3820 printf (_("\
3821 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3822 passed on to the various sub-processes invoked by %s. In order to pass\n\
3823 other options on to these processes the -W<letter> options must be used.\n\
3824 "), progname);
3826 /* The rest of the options are displayed by invocations of the various
3827 sub-processes. */
3830 static void
3831 add_preprocessor_option (const char *option, int len)
3833 preprocessor_options.safe_push (save_string (option, len));
3836 static void
3837 add_assembler_option (const char *option, int len)
3839 assembler_options.safe_push (save_string (option, len));
3842 static void
3843 add_linker_option (const char *option, int len)
3845 linker_options.safe_push (save_string (option, len));
3848 /* Allocate space for an input file in infiles. */
3850 static void
3851 alloc_infile (void)
3853 if (n_infiles_alloc == 0)
3855 n_infiles_alloc = 16;
3856 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3858 else if (n_infiles_alloc == n_infiles)
3860 n_infiles_alloc *= 2;
3861 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3865 /* Store an input file with the given NAME and LANGUAGE in
3866 infiles. */
3868 static void
3869 add_infile (const char *name, const char *language)
3871 alloc_infile ();
3872 infiles[n_infiles].name = name;
3873 infiles[n_infiles++].language = language;
3876 /* Allocate space for a switch in switches. */
3878 static void
3879 alloc_switch (void)
3881 if (n_switches_alloc == 0)
3883 n_switches_alloc = 16;
3884 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3886 else if (n_switches_alloc == n_switches)
3888 n_switches_alloc *= 2;
3889 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3893 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3894 as validated if VALIDATED and KNOWN if it is an internal switch. */
3896 static void
3897 save_switch (const char *opt, size_t n_args, const char *const *args,
3898 bool validated, bool known)
3900 alloc_switch ();
3901 switches[n_switches].part1 = opt + 1;
3902 if (n_args == 0)
3903 switches[n_switches].args = 0;
3904 else
3906 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3907 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3908 switches[n_switches].args[n_args] = NULL;
3911 switches[n_switches].live_cond = 0;
3912 switches[n_switches].validated = validated;
3913 switches[n_switches].known = known;
3914 switches[n_switches].ordering = 0;
3915 n_switches++;
3918 /* Set the SOURCE_DATE_EPOCH environment variable to the current time if it is
3919 not set already. */
3921 static void
3922 set_source_date_epoch_envvar ()
3924 /* Array size is 21 = ceil(log_10(2^64)) + 1 to hold string representations
3925 of 64 bit integers. */
3926 char source_date_epoch[21];
3927 time_t tt;
3929 errno = 0;
3930 tt = time (NULL);
3931 if (tt < (time_t) 0 || errno != 0)
3932 tt = (time_t) 0;
3934 snprintf (source_date_epoch, 21, "%llu", (unsigned long long) tt);
3935 /* Using setenv instead of xputenv because we want the variable to remain
3936 after finalizing so that it's still set in the second run when using
3937 -fcompare-debug. */
3938 setenv ("SOURCE_DATE_EPOCH", source_date_epoch, 0);
3941 /* Handle an option DECODED that is unknown to the option-processing
3942 machinery. */
3944 static bool
3945 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3947 const char *opt = decoded->arg;
3948 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3949 && !(decoded->errors & CL_ERR_NEGATIVE))
3951 /* Leave unknown -Wno-* options for the compiler proper, to be
3952 diagnosed only if there are warnings. */
3953 save_switch (decoded->canonical_option[0],
3954 decoded->canonical_option_num_elements - 1,
3955 &decoded->canonical_option[1], false, true);
3956 return false;
3958 if (decoded->opt_index == OPT_SPECIAL_unknown)
3960 /* Give it a chance to define it a spec file. */
3961 save_switch (decoded->canonical_option[0],
3962 decoded->canonical_option_num_elements - 1,
3963 &decoded->canonical_option[1], false, false);
3964 return false;
3966 else
3967 return true;
3970 /* Handle an option DECODED that is not marked as CL_DRIVER.
3971 LANG_MASK will always be CL_DRIVER. */
3973 static void
3974 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3975 unsigned int lang_mask ATTRIBUTE_UNUSED)
3977 /* At this point, non-driver options are accepted (and expected to
3978 be passed down by specs) unless marked to be rejected by the
3979 driver. Options to be rejected by the driver but accepted by the
3980 compilers proper are treated just like completely unknown
3981 options. */
3982 const struct cl_option *option = &cl_options[decoded->opt_index];
3984 if (option->cl_reject_driver)
3985 error ("unrecognized command-line option %qs",
3986 decoded->orig_option_with_args_text);
3987 else
3988 save_switch (decoded->canonical_option[0],
3989 decoded->canonical_option_num_elements - 1,
3990 &decoded->canonical_option[1], false, true);
3993 static const char *spec_lang = 0;
3994 static int last_language_n_infiles;
3997 /* Check that GCC is configured to support the offload target. */
3999 static bool
4000 check_offload_target_name (const char *target, ptrdiff_t len)
4002 const char *n, *c = OFFLOAD_TARGETS;
4003 while (c)
4005 n = strchr (c, ',');
4006 if (n == NULL)
4007 n = strchr (c, '\0');
4008 if (len == n - c && strncmp (target, c, n - c) == 0)
4009 break;
4010 c = *n ? n + 1 : NULL;
4012 if (!c)
4014 auto_vec<const char*> candidates;
4015 size_t olen = strlen (OFFLOAD_TARGETS) + 1;
4016 char *cand = XALLOCAVEC (char, olen);
4017 memcpy (cand, OFFLOAD_TARGETS, olen);
4018 for (c = strtok (cand, ","); c; c = strtok (NULL, ","))
4019 candidates.safe_push (c);
4020 candidates.safe_push ("default");
4021 candidates.safe_push ("disable");
4023 char *target2 = XALLOCAVEC (char, len + 1);
4024 memcpy (target2, target, len);
4025 target2[len] = '\0';
4027 error ("GCC is not configured to support %qs as %<-foffload=%> argument",
4028 target2);
4030 char *s;
4031 const char *hint = candidates_list_and_hint (target2, s, candidates);
4032 if (hint)
4033 inform (UNKNOWN_LOCATION,
4034 "valid %<-foffload=%> arguments are: %s; "
4035 "did you mean %qs?", s, hint);
4036 else
4037 inform (UNKNOWN_LOCATION, "valid %<-foffload=%> arguments are: %s", s);
4038 XDELETEVEC (s);
4039 return false;
4041 return true;
4044 /* Sanity check for -foffload-options. */
4046 static void
4047 check_foffload_target_names (const char *arg)
4049 const char *cur, *next, *end;
4050 /* If option argument starts with '-' then no target is specified and we
4051 do not need to parse it. */
4052 if (arg[0] == '-')
4053 return;
4054 end = strchr (arg, '=');
4055 if (end == NULL)
4057 error ("%<=%>options missing after %<-foffload-options=%>target");
4058 return;
4061 cur = arg;
4062 while (cur < end)
4064 next = strchr (cur, ',');
4065 if (next == NULL)
4066 next = end;
4067 next = (next > end) ? end : next;
4069 /* Retain non-supported targets after printing an error as those will not
4070 be processed; each enabled target only processes its triplet. */
4071 check_offload_target_name (cur, next - cur);
4072 cur = next + 1;
4076 /* Parse -foffload option argument. */
4078 static void
4079 handle_foffload_option (const char *arg)
4081 const char *c, *cur, *n, *next, *end;
4082 char *target;
4084 /* If option argument starts with '-' then no target is specified and we
4085 do not need to parse it. */
4086 if (arg[0] == '-')
4087 return;
4089 end = strchr (arg, '=');
4090 if (end == NULL)
4091 end = strchr (arg, '\0');
4092 cur = arg;
4094 while (cur < end)
4096 next = strchr (cur, ',');
4097 if (next == NULL)
4098 next = end;
4099 next = (next > end) ? end : next;
4101 target = XNEWVEC (char, next - cur + 1);
4102 memcpy (target, cur, next - cur);
4103 target[next - cur] = '\0';
4105 /* Reset offloading list and continue. */
4106 if (strcmp (target, "default") == 0)
4108 free (offload_targets);
4109 offload_targets = NULL;
4110 goto next_item;
4113 /* If 'disable' is passed to the option, clean the list of
4114 offload targets and return, even if more targets follow.
4115 Likewise if GCC is not configured to support that offload target. */
4116 if (strcmp (target, "disable") == 0
4117 || !check_offload_target_name (target, next - cur))
4119 free (offload_targets);
4120 offload_targets = xstrdup ("");
4121 return;
4124 if (!offload_targets)
4126 offload_targets = target;
4127 target = NULL;
4129 else
4131 /* Check that the target hasn't already presented in the list. */
4132 c = offload_targets;
4135 n = strchr (c, ':');
4136 if (n == NULL)
4137 n = strchr (c, '\0');
4139 if (next - cur == n - c && strncmp (c, target, n - c) == 0)
4140 break;
4142 c = n + 1;
4144 while (*n);
4146 /* If duplicate is not found, append the target to the list. */
4147 if (c > n)
4149 size_t offload_targets_len = strlen (offload_targets);
4150 offload_targets
4151 = XRESIZEVEC (char, offload_targets,
4152 offload_targets_len + 1 + next - cur + 1);
4153 offload_targets[offload_targets_len++] = ':';
4154 memcpy (offload_targets + offload_targets_len, target, next - cur + 1);
4157 next_item:
4158 cur = next + 1;
4159 XDELETEVEC (target);
4163 /* Handle a driver option; arguments and return value as for
4164 handle_option. */
4166 static bool
4167 driver_handle_option (struct gcc_options *opts,
4168 struct gcc_options *opts_set,
4169 const struct cl_decoded_option *decoded,
4170 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
4171 location_t loc,
4172 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
4173 diagnostic_context *dc,
4174 void (*) (void))
4176 size_t opt_index = decoded->opt_index;
4177 const char *arg = decoded->arg;
4178 const char *compare_debug_replacement_opt;
4179 int value = decoded->value;
4180 bool validated = false;
4181 bool do_save = true;
4183 gcc_assert (opts == &global_options);
4184 gcc_assert (opts_set == &global_options_set);
4185 gcc_assert (kind == DK_UNSPECIFIED);
4186 gcc_assert (loc == UNKNOWN_LOCATION);
4187 gcc_assert (dc == global_dc);
4189 switch (opt_index)
4191 case OPT_dumpspecs:
4193 struct spec_list *sl;
4194 init_spec ();
4195 for (sl = specs; sl; sl = sl->next)
4196 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
4197 if (link_command_spec)
4198 printf ("*link_command:\n%s\n\n", link_command_spec);
4199 exit (0);
4202 case OPT_dumpversion:
4203 printf ("%s\n", spec_version);
4204 exit (0);
4206 case OPT_dumpmachine:
4207 printf ("%s\n", spec_machine);
4208 exit (0);
4210 case OPT_dumpfullversion:
4211 printf ("%s\n", BASEVER);
4212 exit (0);
4214 case OPT__version:
4215 print_version = 1;
4217 /* CPP driver cannot obtain switch from cc1_options. */
4218 if (is_cpp_driver)
4219 add_preprocessor_option ("--version", strlen ("--version"));
4220 add_assembler_option ("--version", strlen ("--version"));
4221 add_linker_option ("--version", strlen ("--version"));
4222 break;
4224 case OPT__completion_:
4225 validated = true;
4226 completion = decoded->arg;
4227 break;
4229 case OPT__help:
4230 print_help_list = 1;
4232 /* CPP driver cannot obtain switch from cc1_options. */
4233 if (is_cpp_driver)
4234 add_preprocessor_option ("--help", 6);
4235 add_assembler_option ("--help", 6);
4236 add_linker_option ("--help", 6);
4237 break;
4239 case OPT__help_:
4240 print_subprocess_help = 2;
4241 break;
4243 case OPT__target_help:
4244 print_subprocess_help = 1;
4246 /* CPP driver cannot obtain switch from cc1_options. */
4247 if (is_cpp_driver)
4248 add_preprocessor_option ("--target-help", 13);
4249 add_assembler_option ("--target-help", 13);
4250 add_linker_option ("--target-help", 13);
4251 break;
4253 case OPT__no_sysroot_suffix:
4254 case OPT_pass_exit_codes:
4255 case OPT_print_search_dirs:
4256 case OPT_print_file_name_:
4257 case OPT_print_prog_name_:
4258 case OPT_print_multi_lib:
4259 case OPT_print_multi_directory:
4260 case OPT_print_sysroot:
4261 case OPT_print_multi_os_directory:
4262 case OPT_print_multiarch:
4263 case OPT_print_sysroot_headers_suffix:
4264 case OPT_time:
4265 case OPT_wrapper:
4266 /* These options set the variables specified in common.opt
4267 automatically, and do not need to be saved for spec
4268 processing. */
4269 do_save = false;
4270 break;
4272 case OPT_print_libgcc_file_name:
4273 print_file_name = "libgcc.a";
4274 do_save = false;
4275 break;
4277 case OPT_fuse_ld_bfd:
4278 use_ld = ".bfd";
4279 break;
4281 case OPT_fuse_ld_gold:
4282 use_ld = ".gold";
4283 break;
4285 case OPT_fuse_ld_mold:
4286 use_ld = ".mold";
4287 break;
4289 case OPT_fcompare_debug_second:
4290 compare_debug_second = 1;
4291 break;
4293 case OPT_fcompare_debug:
4294 switch (value)
4296 case 0:
4297 compare_debug_replacement_opt = "-fcompare-debug=";
4298 arg = "";
4299 goto compare_debug_with_arg;
4301 case 1:
4302 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
4303 arg = "-gtoggle";
4304 goto compare_debug_with_arg;
4306 default:
4307 gcc_unreachable ();
4309 break;
4311 case OPT_fcompare_debug_:
4312 compare_debug_replacement_opt = decoded->canonical_option[0];
4313 compare_debug_with_arg:
4314 gcc_assert (decoded->canonical_option_num_elements == 1);
4315 gcc_assert (arg != NULL);
4316 if (*arg)
4317 compare_debug = 1;
4318 else
4319 compare_debug = -1;
4320 if (compare_debug < 0)
4321 compare_debug_opt = NULL;
4322 else
4323 compare_debug_opt = arg;
4324 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
4325 set_source_date_epoch_envvar ();
4326 return true;
4328 case OPT_fdiagnostics_color_:
4329 diagnostic_color_init (dc, value);
4330 break;
4332 case OPT_fdiagnostics_urls_:
4333 diagnostic_urls_init (dc, value);
4334 break;
4336 case OPT_fdiagnostics_format_:
4337 diagnostic_output_format_init (dc,
4338 (enum diagnostics_output_format)value);
4339 break;
4341 case OPT_Wa_:
4343 int prev, j;
4344 /* Pass the rest of this option to the assembler. */
4346 /* Split the argument at commas. */
4347 prev = 0;
4348 for (j = 0; arg[j]; j++)
4349 if (arg[j] == ',')
4351 add_assembler_option (arg + prev, j - prev);
4352 prev = j + 1;
4355 /* Record the part after the last comma. */
4356 add_assembler_option (arg + prev, j - prev);
4358 do_save = false;
4359 break;
4361 case OPT_Wp_:
4363 int prev, j;
4364 /* Pass the rest of this option to the preprocessor. */
4366 /* Split the argument at commas. */
4367 prev = 0;
4368 for (j = 0; arg[j]; j++)
4369 if (arg[j] == ',')
4371 add_preprocessor_option (arg + prev, j - prev);
4372 prev = j + 1;
4375 /* Record the part after the last comma. */
4376 add_preprocessor_option (arg + prev, j - prev);
4378 do_save = false;
4379 break;
4381 case OPT_Wl_:
4383 int prev, j;
4384 /* Split the argument at commas. */
4385 prev = 0;
4386 for (j = 0; arg[j]; j++)
4387 if (arg[j] == ',')
4389 add_infile (save_string (arg + prev, j - prev), "*");
4390 prev = j + 1;
4392 /* Record the part after the last comma. */
4393 add_infile (arg + prev, "*");
4395 do_save = false;
4396 break;
4398 case OPT_Xlinker:
4399 add_infile (arg, "*");
4400 do_save = false;
4401 break;
4403 case OPT_Xpreprocessor:
4404 add_preprocessor_option (arg, strlen (arg));
4405 do_save = false;
4406 break;
4408 case OPT_Xassembler:
4409 add_assembler_option (arg, strlen (arg));
4410 do_save = false;
4411 break;
4413 case OPT_l:
4414 /* POSIX allows separation of -l and the lib arg; canonicalize
4415 by concatenating -l with its arg */
4416 add_infile (concat ("-l", arg, NULL), "*");
4417 do_save = false;
4418 break;
4420 case OPT_L:
4421 /* Similarly, canonicalize -L for linkers that may not accept
4422 separate arguments. */
4423 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
4424 return true;
4426 case OPT_F:
4427 /* Likewise -F. */
4428 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
4429 return true;
4431 case OPT_save_temps:
4432 if (!save_temps_flag)
4433 save_temps_flag = SAVE_TEMPS_DUMP;
4434 validated = true;
4435 break;
4437 case OPT_save_temps_:
4438 if (strcmp (arg, "cwd") == 0)
4439 save_temps_flag = SAVE_TEMPS_CWD;
4440 else if (strcmp (arg, "obj") == 0
4441 || strcmp (arg, "object") == 0)
4442 save_temps_flag = SAVE_TEMPS_OBJ;
4443 else
4444 fatal_error (input_location, "%qs is an unknown %<-save-temps%> option",
4445 decoded->orig_option_with_args_text);
4446 save_temps_overrides_dumpdir = true;
4447 break;
4449 case OPT_dumpdir:
4450 free (dumpdir);
4451 dumpdir = xstrdup (arg);
4452 save_temps_overrides_dumpdir = false;
4453 break;
4455 case OPT_dumpbase:
4456 free (dumpbase);
4457 dumpbase = xstrdup (arg);
4458 break;
4460 case OPT_dumpbase_ext:
4461 free (dumpbase_ext);
4462 dumpbase_ext = xstrdup (arg);
4463 break;
4465 case OPT_no_canonical_prefixes:
4466 /* Already handled as a special case, so ignored here. */
4467 do_save = false;
4468 break;
4470 case OPT_pipe:
4471 validated = true;
4472 /* These options set the variables specified in common.opt
4473 automatically, but do need to be saved for spec
4474 processing. */
4475 break;
4477 case OPT_specs_:
4479 struct user_specs *user = XNEW (struct user_specs);
4481 user->next = (struct user_specs *) 0;
4482 user->filename = arg;
4483 if (user_specs_tail)
4484 user_specs_tail->next = user;
4485 else
4486 user_specs_head = user;
4487 user_specs_tail = user;
4489 validated = true;
4490 break;
4492 case OPT__sysroot_:
4493 target_system_root = arg;
4494 target_system_root_changed = 1;
4495 /* Saving this option is useful to let self-specs decide to
4496 provide a default one. */
4497 do_save = true;
4498 validated = true;
4499 break;
4501 case OPT_time_:
4502 if (report_times_to_file)
4503 fclose (report_times_to_file);
4504 report_times_to_file = fopen (arg, "a");
4505 do_save = false;
4506 break;
4508 case OPT____:
4509 /* "-###"
4510 This is similar to -v except that there is no execution
4511 of the commands and the echoed arguments are quoted. It
4512 is intended for use in shell scripts to capture the
4513 driver-generated command line. */
4514 verbose_only_flag++;
4515 verbose_flag = 1;
4516 do_save = false;
4517 break;
4519 case OPT_B:
4521 size_t len = strlen (arg);
4523 /* Catch the case where the user has forgotten to append a
4524 directory separator to the path. Note, they may be using
4525 -B to add an executable name prefix, eg "i386-elf-", in
4526 order to distinguish between multiple installations of
4527 GCC in the same directory. Hence we must check to see
4528 if appending a directory separator actually makes a
4529 valid directory name. */
4530 if (!IS_DIR_SEPARATOR (arg[len - 1])
4531 && is_directory (arg, false))
4533 char *tmp = XNEWVEC (char, len + 2);
4534 strcpy (tmp, arg);
4535 tmp[len] = DIR_SEPARATOR;
4536 tmp[++len] = 0;
4537 arg = tmp;
4540 add_prefix (&exec_prefixes, arg, NULL,
4541 PREFIX_PRIORITY_B_OPT, 0, 0);
4542 add_prefix (&startfile_prefixes, arg, NULL,
4543 PREFIX_PRIORITY_B_OPT, 0, 0);
4544 add_prefix (&include_prefixes, arg, NULL,
4545 PREFIX_PRIORITY_B_OPT, 0, 0);
4547 validated = true;
4548 break;
4550 case OPT_E:
4551 have_E = true;
4552 break;
4554 case OPT_x:
4555 spec_lang = arg;
4556 if (!strcmp (spec_lang, "none"))
4557 /* Suppress the warning if -xnone comes after the last input
4558 file, because alternate command interfaces like g++ might
4559 find it useful to place -xnone after each input file. */
4560 spec_lang = 0;
4561 else
4562 last_language_n_infiles = n_infiles;
4563 do_save = false;
4564 break;
4566 case OPT_o:
4567 have_o = 1;
4568 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
4569 arg = convert_filename (arg, ! have_c, 0);
4570 #endif
4571 output_file = arg;
4572 /* On some systems, ld cannot handle "-o" without a space. So
4573 split the option from its argument. */
4574 save_switch ("-o", 1, &arg, validated, true);
4575 return true;
4577 #ifdef ENABLE_DEFAULT_PIE
4578 case OPT_pie:
4579 /* -pie is turned on by default. */
4580 #endif
4582 case OPT_static_libgcc:
4583 case OPT_shared_libgcc:
4584 case OPT_static_libgfortran:
4585 case OPT_static_libphobos:
4586 case OPT_static_libstdc__:
4587 /* These are always valid, since gcc.cc itself understands the
4588 first two, gfortranspec.cc understands -static-libgfortran,
4589 d-spec.cc understands -static-libphobos, and g++spec.cc
4590 understands -static-libstdc++ */
4591 validated = true;
4592 break;
4594 case OPT_fwpa:
4595 flag_wpa = "";
4596 break;
4598 case OPT_foffload_options_:
4599 check_foffload_target_names (arg);
4600 break;
4602 case OPT_foffload_:
4603 handle_foffload_option (arg);
4604 if (arg[0] == '-' || NULL != strchr (arg, '='))
4605 save_switch (concat ("-foffload-options=", arg, NULL),
4606 0, NULL, validated, true);
4607 do_save = false;
4608 break;
4610 default:
4611 /* Various driver options need no special processing at this
4612 point, having been handled in a prescan above or being
4613 handled by specs. */
4614 break;
4617 if (do_save)
4618 save_switch (decoded->canonical_option[0],
4619 decoded->canonical_option_num_elements - 1,
4620 &decoded->canonical_option[1], validated, true);
4621 return true;
4624 /* Return true if F2 is F1 followed by a single suffix, i.e., by a
4625 period and additional characters other than a period. */
4627 static inline bool
4628 adds_single_suffix_p (const char *f2, const char *f1)
4630 size_t len = strlen (f1);
4632 return (strncmp (f1, f2, len) == 0
4633 && f2[len] == '.'
4634 && strchr (f2 + len + 1, '.') == NULL);
4637 /* Put the driver's standard set of option handlers in *HANDLERS. */
4639 static void
4640 set_option_handlers (struct cl_option_handlers *handlers)
4642 handlers->unknown_option_callback = driver_unknown_option_callback;
4643 handlers->wrong_lang_callback = driver_wrong_lang_callback;
4644 handlers->num_handlers = 3;
4645 handlers->handlers[0].handler = driver_handle_option;
4646 handlers->handlers[0].mask = CL_DRIVER;
4647 handlers->handlers[1].handler = common_handle_option;
4648 handlers->handlers[1].mask = CL_COMMON;
4649 handlers->handlers[2].handler = target_handle_option;
4650 handlers->handlers[2].mask = CL_TARGET;
4654 /* Return the index into infiles for the single non-library
4655 non-lto-wpa input file, -1 if there isn't any, or -2 if there is
4656 more than one. */
4657 static inline int
4658 single_input_file_index ()
4660 int ret = -1;
4662 for (int i = 0; i < n_infiles; i++)
4664 if (infiles[i].language
4665 && (infiles[i].language[0] == '*'
4666 || (flag_wpa
4667 && strcmp (infiles[i].language, "lto") == 0)))
4668 continue;
4670 if (ret != -1)
4671 return -2;
4673 ret = i;
4676 return ret;
4679 /* Create the vector `switches' and its contents.
4680 Store its length in `n_switches'. */
4682 static void
4683 process_command (unsigned int decoded_options_count,
4684 struct cl_decoded_option *decoded_options)
4686 const char *temp;
4687 char *temp1;
4688 char *tooldir_prefix, *tooldir_prefix2;
4689 char *(*get_relative_prefix) (const char *, const char *,
4690 const char *) = NULL;
4691 struct cl_option_handlers handlers;
4692 unsigned int j;
4694 gcc_exec_prefix = env.get ("GCC_EXEC_PREFIX");
4696 n_switches = 0;
4697 n_infiles = 0;
4698 added_libraries = 0;
4700 /* Figure compiler version from version string. */
4702 compiler_version = temp1 = xstrdup (version_string);
4704 for (; *temp1; ++temp1)
4706 if (*temp1 == ' ')
4708 *temp1 = '\0';
4709 break;
4713 /* Handle any -no-canonical-prefixes flag early, to assign the function
4714 that builds relative prefixes. This function creates default search
4715 paths that are needed later in normal option handling. */
4717 for (j = 1; j < decoded_options_count; j++)
4719 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
4721 get_relative_prefix = make_relative_prefix_ignore_links;
4722 break;
4725 if (! get_relative_prefix)
4726 get_relative_prefix = make_relative_prefix;
4728 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
4729 see if we can create it from the pathname specified in
4730 decoded_options[0].arg. */
4732 gcc_libexec_prefix = standard_libexec_prefix;
4733 #ifndef VMS
4734 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
4735 if (!gcc_exec_prefix)
4737 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
4738 standard_bindir_prefix,
4739 standard_exec_prefix);
4740 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
4741 standard_bindir_prefix,
4742 standard_libexec_prefix);
4743 if (gcc_exec_prefix)
4744 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
4746 else
4748 /* make_relative_prefix requires a program name, but
4749 GCC_EXEC_PREFIX is typically a directory name with a trailing
4750 / (which is ignored by make_relative_prefix), so append a
4751 program name. */
4752 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
4753 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
4754 standard_exec_prefix,
4755 standard_libexec_prefix);
4757 /* The path is unrelocated, so fallback to the original setting. */
4758 if (!gcc_libexec_prefix)
4759 gcc_libexec_prefix = standard_libexec_prefix;
4761 free (tmp_prefix);
4763 #else
4764 #endif
4765 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
4766 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
4767 or an automatically created GCC_EXEC_PREFIX from
4768 decoded_options[0].arg. */
4770 /* Do language-specific adjustment/addition of flags. */
4771 lang_specific_driver (&decoded_options, &decoded_options_count,
4772 &added_libraries);
4774 if (gcc_exec_prefix)
4776 int len = strlen (gcc_exec_prefix);
4778 if (len > (int) sizeof ("/lib/gcc/") - 1
4779 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
4781 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
4782 if (IS_DIR_SEPARATOR (*temp)
4783 && filename_ncmp (temp + 1, "lib", 3) == 0
4784 && IS_DIR_SEPARATOR (temp[4])
4785 && filename_ncmp (temp + 5, "gcc", 3) == 0)
4786 len -= sizeof ("/lib/gcc/") - 1;
4789 set_std_prefix (gcc_exec_prefix, len);
4790 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
4791 PREFIX_PRIORITY_LAST, 0, 0);
4792 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
4793 PREFIX_PRIORITY_LAST, 0, 0);
4796 /* COMPILER_PATH and LIBRARY_PATH have values
4797 that are lists of directory names with colons. */
4799 temp = env.get ("COMPILER_PATH");
4800 if (temp)
4802 const char *startp, *endp;
4803 char *nstore = (char *) alloca (strlen (temp) + 3);
4805 startp = endp = temp;
4806 while (1)
4808 if (*endp == PATH_SEPARATOR || *endp == 0)
4810 strncpy (nstore, startp, endp - startp);
4811 if (endp == startp)
4812 strcpy (nstore, concat (".", dir_separator_str, NULL));
4813 else if (!IS_DIR_SEPARATOR (endp[-1]))
4815 nstore[endp - startp] = DIR_SEPARATOR;
4816 nstore[endp - startp + 1] = 0;
4818 else
4819 nstore[endp - startp] = 0;
4820 add_prefix (&exec_prefixes, nstore, 0,
4821 PREFIX_PRIORITY_LAST, 0, 0);
4822 add_prefix (&include_prefixes, nstore, 0,
4823 PREFIX_PRIORITY_LAST, 0, 0);
4824 if (*endp == 0)
4825 break;
4826 endp = startp = endp + 1;
4828 else
4829 endp++;
4833 temp = env.get (LIBRARY_PATH_ENV);
4834 if (temp && *cross_compile == '0')
4836 const char *startp, *endp;
4837 char *nstore = (char *) alloca (strlen (temp) + 3);
4839 startp = endp = temp;
4840 while (1)
4842 if (*endp == PATH_SEPARATOR || *endp == 0)
4844 strncpy (nstore, startp, endp - startp);
4845 if (endp == startp)
4846 strcpy (nstore, concat (".", dir_separator_str, NULL));
4847 else if (!IS_DIR_SEPARATOR (endp[-1]))
4849 nstore[endp - startp] = DIR_SEPARATOR;
4850 nstore[endp - startp + 1] = 0;
4852 else
4853 nstore[endp - startp] = 0;
4854 add_prefix (&startfile_prefixes, nstore, NULL,
4855 PREFIX_PRIORITY_LAST, 0, 1);
4856 if (*endp == 0)
4857 break;
4858 endp = startp = endp + 1;
4860 else
4861 endp++;
4865 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
4866 temp = env.get ("LPATH");
4867 if (temp && *cross_compile == '0')
4869 const char *startp, *endp;
4870 char *nstore = (char *) alloca (strlen (temp) + 3);
4872 startp = endp = temp;
4873 while (1)
4875 if (*endp == PATH_SEPARATOR || *endp == 0)
4877 strncpy (nstore, startp, endp - startp);
4878 if (endp == startp)
4879 strcpy (nstore, concat (".", dir_separator_str, NULL));
4880 else if (!IS_DIR_SEPARATOR (endp[-1]))
4882 nstore[endp - startp] = DIR_SEPARATOR;
4883 nstore[endp - startp + 1] = 0;
4885 else
4886 nstore[endp - startp] = 0;
4887 add_prefix (&startfile_prefixes, nstore, NULL,
4888 PREFIX_PRIORITY_LAST, 0, 1);
4889 if (*endp == 0)
4890 break;
4891 endp = startp = endp + 1;
4893 else
4894 endp++;
4898 /* Process the options and store input files and switches in their
4899 vectors. */
4901 last_language_n_infiles = -1;
4903 set_option_handlers (&handlers);
4905 for (j = 1; j < decoded_options_count; j++)
4907 switch (decoded_options[j].opt_index)
4909 case OPT_S:
4910 case OPT_c:
4911 case OPT_E:
4912 have_c = 1;
4913 break;
4915 if (have_c)
4916 break;
4919 for (j = 1; j < decoded_options_count; j++)
4921 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
4923 const char *arg = decoded_options[j].arg;
4925 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4926 arg = convert_filename (arg, 0, access (arg, F_OK));
4927 #endif
4928 add_infile (arg, spec_lang);
4930 continue;
4933 read_cmdline_option (&global_options, &global_options_set,
4934 decoded_options + j, UNKNOWN_LOCATION,
4935 CL_DRIVER, &handlers, global_dc);
4938 /* If the user didn't specify any, default to all configured offload
4939 targets. */
4940 if (ENABLE_OFFLOADING && offload_targets == NULL)
4942 handle_foffload_option (OFFLOAD_TARGETS);
4943 #if OFFLOAD_DEFAULTED
4944 offload_targets_default = true;
4945 #endif
4948 /* Handle -gtoggle as it would later in toplev.cc:process_options to
4949 make the debug-level-gt spec function work as expected. */
4950 if (flag_gtoggle)
4952 if (debug_info_level == DINFO_LEVEL_NONE)
4953 debug_info_level = DINFO_LEVEL_NORMAL;
4954 else
4955 debug_info_level = DINFO_LEVEL_NONE;
4958 if (output_file
4959 && strcmp (output_file, "-") != 0
4960 && strcmp (output_file, HOST_BIT_BUCKET) != 0)
4962 int i;
4963 for (i = 0; i < n_infiles; i++)
4964 if ((!infiles[i].language || infiles[i].language[0] != '*')
4965 && canonical_filename_eq (infiles[i].name, output_file))
4966 fatal_error (input_location,
4967 "input file %qs is the same as output file",
4968 output_file);
4971 if (output_file != NULL && output_file[0] == '\0')
4972 fatal_error (input_location, "output filename may not be empty");
4974 /* -dumpdir and -save-temps=* both specify the location of aux/dump
4975 outputs; the one that appears last prevails. When compiling
4976 multiple sources, an explicit dumpbase (minus -ext) may be
4977 combined with an explicit or implicit dumpdir, whereas when
4978 linking, a specified or implied link output name (minus
4979 extension) may be combined with a prevailing -save-temps=* or an
4980 otherwise implied dumpdir, but not override a prevailing
4981 -dumpdir. Primary outputs (e.g., linker output when linking
4982 without -o, or .i, .s or .o outputs when processing multiple
4983 inputs with -E, -S or -c, respectively) are NOT affected by these
4984 -save-temps=/-dump* options, always landing in the current
4985 directory and with the same basename as the input when an output
4986 name is not given, but when they're intermediate outputs, they
4987 are named like other aux outputs, so the options affect their
4988 location and name.
4990 Here are some examples. There are several more in the
4991 documentation of -o and -dump*, and some quite exhaustive tests
4992 in gcc.misc-tests/outputs.exp.
4994 When compiling any number of sources, no -dump* nor
4995 -save-temps=*, all outputs in cwd without prefix:
4997 # gcc -c b.c -gsplit-dwarf
4998 -> cc1 [-dumpdir ./] -dumpbase b.c -dumpbase-ext .c # b.o b.dwo
5000 # gcc -c b.c d.c -gsplit-dwarf
5001 -> cc1 [-dumpdir ./] -dumpbase b.c -dumpbase-ext .c # b.o b.dwo
5002 && cc1 [-dumpdir ./] -dumpbase d.c -dumpbase-ext .c # d.o d.dwo
5004 When compiling and linking, no -dump* nor -save-temps=*, .o
5005 outputs are temporary, aux outputs land in the dir of the output,
5006 prefixed with the basename of the linker output:
5008 # gcc b.c d.c -o ab -gsplit-dwarf
5009 -> cc1 -dumpdir ab- -dumpbase b.c -dumpbase-ext .c # ab-b.dwo
5010 && cc1 -dumpdir ab- -dumpbase d.c -dumpbase-ext .c # ab-d.dwo
5011 && link ... -o ab
5013 # gcc b.c d.c [-o a.out] -gsplit-dwarf
5014 -> cc1 -dumpdir a- -dumpbase b.c -dumpbase-ext .c # a-b.dwo
5015 && cc1 -dumpdir a- -dumpbase d.c -dumpbase-ext .c # a-d.dwo
5016 && link ... [-o a.out]
5018 When compiling and linking, a prevailing -dumpdir fully overrides
5019 the prefix of aux outputs given by the output name:
5021 # gcc -dumpdir f b.c d.c -gsplit-dwarf [-o [dir/]whatever]
5022 -> cc1 -dumpdir f -dumpbase b.c -dumpbase-ext .c # fb.dwo
5023 && cc1 -dumpdir f -dumpbase d.c -dumpbase-ext .c # fd.dwo
5024 && link ... [-o whatever]
5026 When compiling multiple inputs, an explicit -dumpbase is combined
5027 with -dumpdir, affecting aux outputs, but not the .o outputs:
5029 # gcc -dumpdir f -dumpbase g- b.c d.c -gsplit-dwarf -c
5030 -> cc1 -dumpdir fg- -dumpbase b.c -dumpbase-ext .c # b.o fg-b.dwo
5031 && cc1 -dumpdir fg- -dumpbase d.c -dumpbase-ext .c # d.o fg-d.dwo
5033 When compiling and linking with -save-temps, the .o outputs that
5034 would have been temporary become aux outputs, so they get
5035 affected by -dump* flags:
5037 # gcc -dumpdir f -dumpbase g- -save-temps b.c d.c
5038 -> cc1 -dumpdir fg- -dumpbase b.c -dumpbase-ext .c # fg-b.o
5039 && cc1 -dumpdir fg- -dumpbase d.c -dumpbase-ext .c # fg-d.o
5040 && link
5042 If -save-temps=* prevails over -dumpdir, however, the explicit
5043 -dumpdir is discarded, as if it wasn't there. The basename of
5044 the implicit linker output, a.out or a.exe, becomes a- as the aux
5045 output prefix for all compilations:
5047 # gcc [-dumpdir f] -save-temps=cwd b.c d.c
5048 -> cc1 -dumpdir a- -dumpbase b.c -dumpbase-ext .c # a-b.o
5049 && cc1 -dumpdir a- -dumpbase d.c -dumpbase-ext .c # a-d.o
5050 && link
5052 A single -dumpbase, applying to multiple inputs, overrides the
5053 linker output name, implied or explicit, as the aux output prefix:
5055 # gcc [-dumpdir f] -dumpbase g- -save-temps=cwd b.c d.c
5056 -> cc1 -dumpdir g- -dumpbase b.c -dumpbase-ext .c # g-b.o
5057 && cc1 -dumpdir g- -dumpbase d.c -dumpbase-ext .c # g-d.o
5058 && link
5060 # gcc [-dumpdir f] -dumpbase g- -save-temps=cwd b.c d.c -o dir/h.out
5061 -> cc1 -dumpdir g- -dumpbase b.c -dumpbase-ext .c # g-b.o
5062 && cc1 -dumpdir g- -dumpbase d.c -dumpbase-ext .c # g-d.o
5063 && link -o dir/h.out
5065 Now, if the linker output is NOT overridden as a prefix, but
5066 -save-temps=* overrides implicit or explicit -dumpdir, the
5067 effective dump dir combines the dir selected by the -save-temps=*
5068 option with the basename of the specified or implied link output:
5070 # gcc [-dumpdir f] -save-temps=cwd b.c d.c -o dir/h.out
5071 -> cc1 -dumpdir h- -dumpbase b.c -dumpbase-ext .c # h-b.o
5072 && cc1 -dumpdir h- -dumpbase d.c -dumpbase-ext .c # h-d.o
5073 && link -o dir/h.out
5075 # gcc [-dumpdir f] -save-temps=obj b.c d.c -o dir/h.out
5076 -> cc1 -dumpdir dir/h- -dumpbase b.c -dumpbase-ext .c # dir/h-b.o
5077 && cc1 -dumpdir dir/h- -dumpbase d.c -dumpbase-ext .c # dir/h-d.o
5078 && link -o dir/h.out
5080 But then again, a single -dumpbase applying to multiple inputs
5081 gets used instead of the linker output basename in the combined
5082 dumpdir:
5084 # gcc [-dumpdir f] -dumpbase g- -save-temps=obj b.c d.c -o dir/h.out
5085 -> cc1 -dumpdir dir/g- -dumpbase b.c -dumpbase-ext .c # dir/g-b.o
5086 && cc1 -dumpdir dir/g- -dumpbase d.c -dumpbase-ext .c # dir/g-d.o
5087 && link -o dir/h.out
5089 With a single input being compiled, the output basename does NOT
5090 affect the dumpdir prefix.
5092 # gcc -save-temps=obj b.c -gsplit-dwarf -c -o dir/b.o
5093 -> cc1 -dumpdir dir/ -dumpbase b.c -dumpbase-ext .c # dir/b.o dir/b.dwo
5095 but when compiling and linking even a single file, it does:
5097 # gcc -save-temps=obj b.c -o dir/h.out
5098 -> cc1 -dumpdir dir/h- -dumpbase b.c -dumpbase-ext .c # dir/h-b.o
5100 unless an explicit -dumpdir prevails:
5102 # gcc -save-temps[=obj] -dumpdir g- b.c -o dir/h.out
5103 -> cc1 -dumpdir g- -dumpbase b.c -dumpbase-ext .c # g-b.o
5107 bool explicit_dumpdir = dumpdir;
5109 if ((!save_temps_overrides_dumpdir && explicit_dumpdir)
5110 || (output_file && not_actual_file_p (output_file)))
5112 /* Do nothing. */
5115 /* If -save-temps=obj and -o name, create the prefix to use for %b.
5116 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
5117 else if (save_temps_flag != SAVE_TEMPS_CWD && output_file != NULL)
5119 free (dumpdir);
5120 dumpdir = NULL;
5121 temp = lbasename (output_file);
5122 if (temp != output_file)
5123 dumpdir = xstrndup (output_file,
5124 strlen (output_file) - strlen (temp));
5126 else if (dumpdir)
5128 free (dumpdir);
5129 dumpdir = NULL;
5132 if (save_temps_flag)
5133 save_temps_flag = SAVE_TEMPS_DUMP;
5135 /* If there is any pathname component in an explicit -dumpbase, it
5136 overrides dumpdir entirely, so discard it right away. Although
5137 the presence of an explicit -dumpdir matters for the driver, it
5138 shouldn't matter for other processes, that get all that's needed
5139 from the -dumpdir and -dumpbase always passed to them. */
5140 if (dumpdir && dumpbase && lbasename (dumpbase) != dumpbase)
5142 free (dumpdir);
5143 dumpdir = NULL;
5146 /* Check that dumpbase_ext matches the end of dumpbase, drop it
5147 otherwise. */
5148 if (dumpbase_ext && dumpbase && *dumpbase)
5150 int lendb = strlen (dumpbase);
5151 int lendbx = strlen (dumpbase_ext);
5153 /* -dumpbase-ext must be a suffix proper; discard it if it
5154 matches all of -dumpbase, as that would make for an empty
5155 basename. */
5156 if (lendbx >= lendb
5157 || strcmp (dumpbase + lendb - lendbx, dumpbase_ext) != 0)
5159 free (dumpbase_ext);
5160 dumpbase_ext = NULL;
5164 /* -dumpbase with multiple sources goes into dumpdir. With a single
5165 source, it does only if linking and if dumpdir was not explicitly
5166 specified. */
5167 if (dumpbase && *dumpbase
5168 && (single_input_file_index () == -2
5169 || (!have_c && !explicit_dumpdir)))
5171 char *prefix;
5173 if (dumpbase_ext)
5174 /* We checked that they match above. */
5175 dumpbase[strlen (dumpbase) - strlen (dumpbase_ext)] = '\0';
5177 if (dumpdir)
5178 prefix = concat (dumpdir, dumpbase, "-", NULL);
5179 else
5180 prefix = concat (dumpbase, "-", NULL);
5182 free (dumpdir);
5183 free (dumpbase);
5184 free (dumpbase_ext);
5185 dumpbase = dumpbase_ext = NULL;
5186 dumpdir = prefix;
5187 dumpdir_trailing_dash_added = true;
5190 /* If dumpbase was not brought into dumpdir but we're linking, bring
5191 output_file into dumpdir unless dumpdir was explicitly specified.
5192 The test for !explicit_dumpdir is further below, because we want
5193 to use the obase computation for a ghost outbase, passed to
5194 GCC_COLLECT_OPTIONS. */
5195 else if (!have_c && (!explicit_dumpdir || (dumpbase && !*dumpbase)))
5197 /* If we get here, we know dumpbase was not specified, or it was
5198 specified as an empty string. If it was anything else, it
5199 would have combined with dumpdir above, because the condition
5200 for dumpbase to be used when present is broader than the
5201 condition that gets us here. */
5202 gcc_assert (!dumpbase || !*dumpbase);
5204 const char *obase;
5205 char *tofree = NULL;
5206 if (!output_file || not_actual_file_p (output_file))
5207 obase = "a";
5208 else
5210 obase = lbasename (output_file);
5211 size_t blen = strlen (obase), xlen;
5212 /* Drop the suffix if it's dumpbase_ext, if given,
5213 otherwise .exe or the target executable suffix, or if the
5214 output was explicitly named a.out, but not otherwise. */
5215 if (dumpbase_ext
5216 ? (blen > (xlen = strlen (dumpbase_ext))
5217 && strcmp ((temp = (obase + blen - xlen)),
5218 dumpbase_ext) == 0)
5219 : ((temp = strrchr (obase + 1, '.'))
5220 && (xlen = strlen (temp))
5221 && (strcmp (temp, ".exe") == 0
5222 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
5223 || strcmp (temp, TARGET_EXECUTABLE_SUFFIX) == 0
5224 #endif
5225 || strcmp (obase, "a.out") == 0)))
5227 tofree = xstrndup (obase, blen - xlen);
5228 obase = tofree;
5232 /* We wish to save this basename to the -dumpdir passed through
5233 GCC_COLLECT_OPTIONS within maybe_run_linker, for e.g. LTO,
5234 but we do NOT wish to add it to e.g. %b, so we keep
5235 outbase_length as zero. */
5236 gcc_assert (!outbase);
5237 outbase_length = 0;
5239 /* If we're building [dir1/]foo[.exe] out of a single input
5240 [dir2/]foo.c that shares the same basename, dump to
5241 [dir2/]foo.c.* rather than duplicating the basename into
5242 [dir2/]foo-foo.c.*. */
5243 int idxin;
5244 if (dumpbase
5245 || ((idxin = single_input_file_index ()) >= 0
5246 && adds_single_suffix_p (lbasename (infiles[idxin].name),
5247 obase)))
5249 if (obase == tofree)
5250 outbase = tofree;
5251 else
5253 outbase = xstrdup (obase);
5254 free (tofree);
5256 obase = tofree = NULL;
5258 else
5260 if (dumpdir)
5262 char *p = concat (dumpdir, obase, "-", NULL);
5263 free (dumpdir);
5264 dumpdir = p;
5266 else
5267 dumpdir = concat (obase, "-", NULL);
5269 dumpdir_trailing_dash_added = true;
5271 free (tofree);
5272 obase = tofree = NULL;
5275 if (!explicit_dumpdir || dumpbase)
5277 /* Absent -dumpbase and present -dumpbase-ext have been applied
5278 to the linker output name, so compute fresh defaults for each
5279 compilation. */
5280 free (dumpbase_ext);
5281 dumpbase_ext = NULL;
5285 /* Now, if we're compiling, or if we haven't used the dumpbase
5286 above, then outbase (%B) is derived from dumpbase, if given, or
5287 from the output name, given or implied. We can't precompute
5288 implied output names, but that's ok, since they're derived from
5289 input names. Just make sure we skip this if dumpbase is the
5290 empty string: we want to use input names then, so don't set
5291 outbase. */
5292 if ((dumpbase || have_c)
5293 && !(dumpbase && !*dumpbase))
5295 gcc_assert (!outbase);
5297 if (dumpbase)
5299 gcc_assert (single_input_file_index () != -2);
5300 /* We do not want lbasename here; dumpbase with dirnames
5301 overrides dumpdir entirely, even if dumpdir is
5302 specified. */
5303 if (dumpbase_ext)
5304 /* We've already checked above that the suffix matches. */
5305 outbase = xstrndup (dumpbase,
5306 strlen (dumpbase) - strlen (dumpbase_ext));
5307 else
5308 outbase = xstrdup (dumpbase);
5310 else if (output_file && !not_actual_file_p (output_file))
5312 outbase = xstrdup (lbasename (output_file));
5313 char *p = strrchr (outbase + 1, '.');
5314 if (p)
5315 *p = '\0';
5318 if (outbase)
5319 outbase_length = strlen (outbase);
5322 /* If there is any pathname component in an explicit -dumpbase, do
5323 not use dumpdir, but retain it to pass it on to the compiler. */
5324 if (dumpdir)
5325 dumpdir_length = strlen (dumpdir);
5326 else
5327 dumpdir_length = 0;
5329 /* Check that dumpbase_ext, if still present, still matches the end
5330 of dumpbase, if present, and drop it otherwise. We only retained
5331 it above when dumpbase was absent to maybe use it to drop the
5332 extension from output_name before combining it with dumpdir. We
5333 won't deal with -dumpbase-ext when -dumpbase is not explicitly
5334 given, even if just to activate backward-compatible dumpbase:
5335 dropping it on the floor is correct, expected and documented
5336 behavior. Attempting to deal with a -dumpbase-ext that might
5337 match the end of some input filename, or of the combination of
5338 the output basename with the suffix of the input filename,
5339 possible with an intermediate .gk extension for -fcompare-debug,
5340 is just calling for trouble. */
5341 if (dumpbase_ext)
5343 if (!dumpbase || !*dumpbase)
5345 free (dumpbase_ext);
5346 dumpbase_ext = NULL;
5348 else
5349 gcc_assert (strcmp (dumpbase + strlen (dumpbase)
5350 - strlen (dumpbase_ext), dumpbase_ext) == 0);
5353 if (save_temps_flag && use_pipes)
5355 /* -save-temps overrides -pipe, so that temp files are produced */
5356 if (save_temps_flag)
5357 warning (0, "%<-pipe%> ignored because %<-save-temps%> specified");
5358 use_pipes = 0;
5361 if (!compare_debug)
5363 const char *gcd = env.get ("GCC_COMPARE_DEBUG");
5365 if (gcd && gcd[0] == '-')
5367 compare_debug = 2;
5368 compare_debug_opt = gcd;
5370 else if (gcd && *gcd && strcmp (gcd, "0"))
5372 compare_debug = 3;
5373 compare_debug_opt = "-gtoggle";
5376 else if (compare_debug < 0)
5378 compare_debug = 0;
5379 gcc_assert (!compare_debug_opt);
5382 /* Set up the search paths. We add directories that we expect to
5383 contain GNU Toolchain components before directories specified by
5384 the machine description so that we will find GNU components (like
5385 the GNU assembler) before those of the host system. */
5387 /* If we don't know where the toolchain has been installed, use the
5388 configured-in locations. */
5389 if (!gcc_exec_prefix)
5391 #ifndef OS2
5392 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
5393 PREFIX_PRIORITY_LAST, 1, 0);
5394 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
5395 PREFIX_PRIORITY_LAST, 2, 0);
5396 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
5397 PREFIX_PRIORITY_LAST, 2, 0);
5398 #endif
5399 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
5400 PREFIX_PRIORITY_LAST, 1, 0);
5403 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
5404 tooldir_prefix2 = concat (tooldir_base_prefix, spec_machine,
5405 dir_separator_str, NULL);
5407 /* Look for tools relative to the location from which the driver is
5408 running, or, if that is not available, the configured prefix. */
5409 tooldir_prefix
5410 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
5411 spec_host_machine, dir_separator_str, spec_version,
5412 accel_dir_suffix, dir_separator_str, tooldir_prefix2, NULL);
5413 free (tooldir_prefix2);
5415 add_prefix (&exec_prefixes,
5416 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
5417 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
5418 add_prefix (&startfile_prefixes,
5419 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
5420 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
5421 free (tooldir_prefix);
5423 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
5424 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
5425 then consider it to relocate with the rest of the GCC installation
5426 if GCC_EXEC_PREFIX is set.
5427 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
5428 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
5430 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
5431 standard_bindir_prefix,
5432 target_system_root);
5433 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
5435 target_system_root = tmp_prefix;
5436 target_system_root_changed = 1;
5439 #endif
5441 /* More prefixes are enabled in main, after we read the specs file
5442 and determine whether this is cross-compilation or not. */
5444 if (n_infiles != 0 && n_infiles == last_language_n_infiles && spec_lang != 0)
5445 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
5447 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
5448 environment variable. */
5449 if (compare_debug == 2 || compare_debug == 3)
5451 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
5452 save_switch (opt, 0, NULL, false, true);
5453 compare_debug = 1;
5456 /* Ensure we only invoke each subprocess once. */
5457 if (n_infiles == 0
5458 && (print_subprocess_help || print_help_list || print_version))
5460 /* Create a dummy input file, so that we can pass
5461 the help option on to the various sub-processes. */
5462 add_infile ("help-dummy", "c");
5465 /* Decide if undefined variable references are allowed in specs. */
5467 /* -v alone is safe. --version and --help alone or together are safe. Note
5468 that -v would make them unsafe, as they'd then be run for subprocesses as
5469 well, the location of which might depend on variables possibly coming
5470 from self-specs. Note also that the command name is counted in
5471 decoded_options_count. */
5473 unsigned help_version_count = 0;
5475 if (print_version)
5476 help_version_count++;
5478 if (print_help_list)
5479 help_version_count++;
5481 spec_undefvar_allowed =
5482 ((verbose_flag && decoded_options_count == 2)
5483 || help_version_count == decoded_options_count - 1);
5485 alloc_switch ();
5486 switches[n_switches].part1 = 0;
5487 alloc_infile ();
5488 infiles[n_infiles].name = 0;
5491 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
5492 and place that in the environment. */
5494 static void
5495 set_collect_gcc_options (void)
5497 int i;
5498 int first_time;
5500 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
5501 the compiler. */
5502 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
5503 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
5505 first_time = TRUE;
5506 for (i = 0; (int) i < n_switches; i++)
5508 const char *const *args;
5509 const char *p, *q;
5510 if (!first_time)
5511 obstack_grow (&collect_obstack, " ", 1);
5513 first_time = FALSE;
5515 /* Ignore elided switches. */
5516 if ((switches[i].live_cond
5517 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
5518 == SWITCH_IGNORE)
5519 continue;
5521 obstack_grow (&collect_obstack, "'-", 2);
5522 q = switches[i].part1;
5523 while ((p = strchr (q, '\'')))
5525 obstack_grow (&collect_obstack, q, p - q);
5526 obstack_grow (&collect_obstack, "'\\''", 4);
5527 q = ++p;
5529 obstack_grow (&collect_obstack, q, strlen (q));
5530 obstack_grow (&collect_obstack, "'", 1);
5532 for (args = switches[i].args; args && *args; args++)
5534 obstack_grow (&collect_obstack, " '", 2);
5535 q = *args;
5536 while ((p = strchr (q, '\'')))
5538 obstack_grow (&collect_obstack, q, p - q);
5539 obstack_grow (&collect_obstack, "'\\''", 4);
5540 q = ++p;
5542 obstack_grow (&collect_obstack, q, strlen (q));
5543 obstack_grow (&collect_obstack, "'", 1);
5547 if (dumpdir)
5549 if (!first_time)
5550 obstack_grow (&collect_obstack, " ", 1);
5551 first_time = FALSE;
5553 obstack_grow (&collect_obstack, "'-dumpdir' '", 12);
5554 const char *p, *q;
5556 q = dumpdir;
5557 while ((p = strchr (q, '\'')))
5559 obstack_grow (&collect_obstack, q, p - q);
5560 obstack_grow (&collect_obstack, "'\\''", 4);
5561 q = ++p;
5563 obstack_grow (&collect_obstack, q, strlen (q));
5565 obstack_grow (&collect_obstack, "'", 1);
5568 obstack_grow (&collect_obstack, "\0", 1);
5569 xputenv (XOBFINISH (&collect_obstack, char *));
5572 /* Process a spec string, accumulating and running commands. */
5574 /* These variables describe the input file name.
5575 input_file_number is the index on outfiles of this file,
5576 so that the output file name can be stored for later use by %o.
5577 input_basename is the start of the part of the input file
5578 sans all directory names, and basename_length is the number
5579 of characters starting there excluding the suffix .c or whatever. */
5581 static const char *gcc_input_filename;
5582 static int input_file_number;
5583 size_t input_filename_length;
5584 static int basename_length;
5585 static int suffixed_basename_length;
5586 static const char *input_basename;
5587 static const char *input_suffix;
5588 #ifndef HOST_LACKS_INODE_NUMBERS
5589 static struct stat input_stat;
5590 #endif
5591 static int input_stat_set;
5593 /* The compiler used to process the current input file. */
5594 static struct compiler *input_file_compiler;
5596 /* These are variables used within do_spec and do_spec_1. */
5598 /* Nonzero if an arg has been started and not yet terminated
5599 (with space, tab or newline). */
5600 static int arg_going;
5602 /* Nonzero means %d or %g has been seen; the next arg to be terminated
5603 is a temporary file name. */
5604 static int delete_this_arg;
5606 /* Nonzero means %w has been seen; the next arg to be terminated
5607 is the output file name of this compilation. */
5608 static int this_is_output_file;
5610 /* Nonzero means %s has been seen; the next arg to be terminated
5611 is the name of a library file and we should try the standard
5612 search dirs for it. */
5613 static int this_is_library_file;
5615 /* Nonzero means %T has been seen; the next arg to be terminated
5616 is the name of a linker script and we should try all of the
5617 standard search dirs for it. If it is found insert a --script
5618 command line switch and then substitute the full path in place,
5619 otherwise generate an error message. */
5620 static int this_is_linker_script;
5622 /* Nonzero means that the input of this command is coming from a pipe. */
5623 static int input_from_pipe;
5625 /* Nonnull means substitute this for any suffix when outputting a switches
5626 arguments. */
5627 static const char *suffix_subst;
5629 /* If there is an argument being accumulated, terminate it and store it. */
5631 static void
5632 end_going_arg (void)
5634 if (arg_going)
5636 const char *string;
5638 obstack_1grow (&obstack, 0);
5639 string = XOBFINISH (&obstack, const char *);
5640 if (this_is_library_file)
5641 string = find_file (string);
5642 if (this_is_linker_script)
5644 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
5646 if (full_script_path == NULL)
5648 error ("unable to locate default linker script %qs in the library search paths", string);
5649 /* Script was not found on search path. */
5650 return;
5652 store_arg ("--script", false, false);
5653 string = full_script_path;
5655 store_arg (string, delete_this_arg, this_is_output_file);
5656 if (this_is_output_file)
5657 outfiles[input_file_number] = string;
5658 arg_going = 0;
5663 /* Parse the WRAPPER string which is a comma separated list of the command line
5664 and insert them into the beginning of argbuf. */
5666 static void
5667 insert_wrapper (const char *wrapper)
5669 int n = 0;
5670 int i;
5671 char *buf = xstrdup (wrapper);
5672 char *p = buf;
5673 unsigned int old_length = argbuf.length ();
5677 n++;
5678 while (*p == ',')
5679 p++;
5681 while ((p = strchr (p, ',')) != NULL);
5683 argbuf.safe_grow (old_length + n, true);
5684 memmove (argbuf.address () + n,
5685 argbuf.address (),
5686 old_length * sizeof (const_char_p));
5688 i = 0;
5689 p = buf;
5692 while (*p == ',')
5694 *p = 0;
5695 p++;
5697 argbuf[i] = p;
5698 i++;
5700 while ((p = strchr (p, ',')) != NULL);
5701 gcc_assert (i == n);
5704 /* Process the spec SPEC and run the commands specified therein.
5705 Returns 0 if the spec is successfully processed; -1 if failed. */
5708 do_spec (const char *spec)
5710 int value;
5712 value = do_spec_2 (spec, NULL);
5714 /* Force out any unfinished command.
5715 If -pipe, this forces out the last command if it ended in `|'. */
5716 if (value == 0)
5718 if (argbuf.length () > 0
5719 && !strcmp (argbuf.last (), "|"))
5720 argbuf.pop ();
5722 set_collect_gcc_options ();
5724 if (argbuf.length () > 0)
5725 value = execute ();
5728 return value;
5731 /* Process the spec SPEC, with SOFT_MATCHED_PART designating the current value
5732 of a matched * pattern which may be re-injected by way of %*. */
5734 static int
5735 do_spec_2 (const char *spec, const char *soft_matched_part)
5737 int result;
5739 clear_args ();
5740 arg_going = 0;
5741 delete_this_arg = 0;
5742 this_is_output_file = 0;
5743 this_is_library_file = 0;
5744 this_is_linker_script = 0;
5745 input_from_pipe = 0;
5746 suffix_subst = NULL;
5748 result = do_spec_1 (spec, 0, soft_matched_part);
5750 end_going_arg ();
5752 return result;
5755 /* Process the given spec string and add any new options to the end
5756 of the switches/n_switches array. */
5758 static void
5759 do_option_spec (const char *name, const char *spec)
5761 unsigned int i, value_count, value_len;
5762 const char *p, *q, *value;
5763 char *tmp_spec, *tmp_spec_p;
5765 if (configure_default_options[0].name == NULL)
5766 return;
5768 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
5769 if (strcmp (configure_default_options[i].name, name) == 0)
5770 break;
5771 if (i == ARRAY_SIZE (configure_default_options))
5772 return;
5774 value = configure_default_options[i].value;
5775 value_len = strlen (value);
5777 /* Compute the size of the final spec. */
5778 value_count = 0;
5779 p = spec;
5780 while ((p = strstr (p, "%(VALUE)")) != NULL)
5782 p ++;
5783 value_count ++;
5786 /* Replace each %(VALUE) by the specified value. */
5787 tmp_spec = (char *) alloca (strlen (spec) + 1
5788 + value_count * (value_len - strlen ("%(VALUE)")));
5789 tmp_spec_p = tmp_spec;
5790 q = spec;
5791 while ((p = strstr (q, "%(VALUE)")) != NULL)
5793 memcpy (tmp_spec_p, q, p - q);
5794 tmp_spec_p = tmp_spec_p + (p - q);
5795 memcpy (tmp_spec_p, value, value_len);
5796 tmp_spec_p += value_len;
5797 q = p + strlen ("%(VALUE)");
5799 strcpy (tmp_spec_p, q);
5801 do_self_spec (tmp_spec);
5804 /* Process the given spec string and add any new options to the end
5805 of the switches/n_switches array. */
5807 static void
5808 do_self_spec (const char *spec)
5810 int i;
5812 do_spec_2 (spec, NULL);
5813 do_spec_1 (" ", 0, NULL);
5815 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
5816 do_self_specs adds the replacements to switches array, so it shouldn't
5817 be processed afterwards. */
5818 for (i = 0; i < n_switches; i++)
5819 if ((switches[i].live_cond & SWITCH_IGNORE))
5820 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
5822 if (argbuf.length () > 0)
5824 const char **argbuf_copy;
5825 struct cl_decoded_option *decoded_options;
5826 struct cl_option_handlers handlers;
5827 unsigned int decoded_options_count;
5828 unsigned int j;
5830 /* Create a copy of argbuf with a dummy argv[0] entry for
5831 decode_cmdline_options_to_array. */
5832 argbuf_copy = XNEWVEC (const char *,
5833 argbuf.length () + 1);
5834 argbuf_copy[0] = "";
5835 memcpy (argbuf_copy + 1, argbuf.address (),
5836 argbuf.length () * sizeof (const char *));
5838 decode_cmdline_options_to_array (argbuf.length () + 1,
5839 argbuf_copy,
5840 CL_DRIVER, &decoded_options,
5841 &decoded_options_count);
5842 free (argbuf_copy);
5844 set_option_handlers (&handlers);
5846 for (j = 1; j < decoded_options_count; j++)
5848 switch (decoded_options[j].opt_index)
5850 case OPT_SPECIAL_input_file:
5851 /* Specs should only generate options, not input
5852 files. */
5853 if (strcmp (decoded_options[j].arg, "-") != 0)
5854 fatal_error (input_location,
5855 "switch %qs does not start with %<-%>",
5856 decoded_options[j].arg);
5857 else
5858 fatal_error (input_location,
5859 "spec-generated switch is just %<-%>");
5860 break;
5862 case OPT_fcompare_debug_second:
5863 case OPT_fcompare_debug:
5864 case OPT_fcompare_debug_:
5865 case OPT_o:
5866 /* Avoid duplicate processing of some options from
5867 compare-debug specs; just save them here. */
5868 save_switch (decoded_options[j].canonical_option[0],
5869 (decoded_options[j].canonical_option_num_elements
5870 - 1),
5871 &decoded_options[j].canonical_option[1], false, true);
5872 break;
5874 default:
5875 read_cmdline_option (&global_options, &global_options_set,
5876 decoded_options + j, UNKNOWN_LOCATION,
5877 CL_DRIVER, &handlers, global_dc);
5878 break;
5882 free (decoded_options);
5884 alloc_switch ();
5885 switches[n_switches].part1 = 0;
5889 /* Callback for processing %D and %I specs. */
5891 struct spec_path_info {
5892 const char *option;
5893 const char *append;
5894 size_t append_len;
5895 bool omit_relative;
5896 bool separate_options;
5899 static void *
5900 spec_path (char *path, void *data)
5902 struct spec_path_info *info = (struct spec_path_info *) data;
5903 size_t len = 0;
5904 char save = 0;
5906 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
5907 return NULL;
5909 if (info->append_len != 0)
5911 len = strlen (path);
5912 memcpy (path + len, info->append, info->append_len + 1);
5915 if (!is_directory (path, true))
5916 return NULL;
5918 do_spec_1 (info->option, 1, NULL);
5919 if (info->separate_options)
5920 do_spec_1 (" ", 0, NULL);
5922 if (info->append_len == 0)
5924 len = strlen (path);
5925 save = path[len - 1];
5926 if (IS_DIR_SEPARATOR (path[len - 1]))
5927 path[len - 1] = '\0';
5930 do_spec_1 (path, 1, NULL);
5931 do_spec_1 (" ", 0, NULL);
5933 /* Must not damage the original path. */
5934 if (info->append_len == 0)
5935 path[len - 1] = save;
5937 return NULL;
5940 /* True if we should compile INFILE. */
5942 static bool
5943 compile_input_file_p (struct infile *infile)
5945 if ((!infile->language) || (infile->language[0] != '*'))
5946 if (infile->incompiler == input_file_compiler)
5947 return true;
5948 return false;
5951 /* Process each member of VEC as a spec. */
5953 static void
5954 do_specs_vec (vec<char_p> vec)
5956 for (char *opt : vec)
5958 do_spec_1 (opt, 1, NULL);
5959 /* Make each accumulated option a separate argument. */
5960 do_spec_1 (" ", 0, NULL);
5964 /* Add options passed via -Xassembler or -Wa to COLLECT_AS_OPTIONS. */
5966 static void
5967 putenv_COLLECT_AS_OPTIONS (vec<char_p> vec)
5969 if (vec.is_empty ())
5970 return;
5972 obstack_init (&collect_obstack);
5973 obstack_grow (&collect_obstack, "COLLECT_AS_OPTIONS=",
5974 strlen ("COLLECT_AS_OPTIONS="));
5976 char *opt;
5977 unsigned ix;
5979 FOR_EACH_VEC_ELT (vec, ix, opt)
5981 obstack_1grow (&collect_obstack, '\'');
5982 obstack_grow (&collect_obstack, opt, strlen (opt));
5983 obstack_1grow (&collect_obstack, '\'');
5984 if (ix < vec.length () - 1)
5985 obstack_1grow(&collect_obstack, ' ');
5988 obstack_1grow (&collect_obstack, '\0');
5989 xputenv (XOBFINISH (&collect_obstack, char *));
5992 /* Process the sub-spec SPEC as a portion of a larger spec.
5993 This is like processing a whole spec except that we do
5994 not initialize at the beginning and we do not supply a
5995 newline by default at the end.
5996 INSWITCH nonzero means don't process %-sequences in SPEC;
5997 in this case, % is treated as an ordinary character.
5998 This is used while substituting switches.
5999 INSWITCH nonzero also causes SPC not to terminate an argument.
6001 Value is zero unless a line was finished
6002 and the command on that line reported an error. */
6004 static int
6005 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
6007 const char *p = spec;
6008 int c;
6009 int i;
6010 int value;
6012 /* If it's an empty string argument to a switch, keep it as is. */
6013 if (inswitch && !*p)
6014 arg_going = 1;
6016 while ((c = *p++))
6017 /* If substituting a switch, treat all chars like letters.
6018 Otherwise, NL, SPC, TAB and % are special. */
6019 switch (inswitch ? 'a' : c)
6021 case '\n':
6022 end_going_arg ();
6024 if (argbuf.length () > 0
6025 && !strcmp (argbuf.last (), "|"))
6027 /* A `|' before the newline means use a pipe here,
6028 but only if -pipe was specified.
6029 Otherwise, execute now and don't pass the `|' as an arg. */
6030 if (use_pipes)
6032 input_from_pipe = 1;
6033 break;
6035 else
6036 argbuf.pop ();
6039 set_collect_gcc_options ();
6041 if (argbuf.length () > 0)
6043 value = execute ();
6044 if (value)
6045 return value;
6047 /* Reinitialize for a new command, and for a new argument. */
6048 clear_args ();
6049 arg_going = 0;
6050 delete_this_arg = 0;
6051 this_is_output_file = 0;
6052 this_is_library_file = 0;
6053 this_is_linker_script = 0;
6054 input_from_pipe = 0;
6055 break;
6057 case '|':
6058 end_going_arg ();
6060 /* Use pipe */
6061 obstack_1grow (&obstack, c);
6062 arg_going = 1;
6063 break;
6065 case '\t':
6066 case ' ':
6067 end_going_arg ();
6069 /* Reinitialize for a new argument. */
6070 delete_this_arg = 0;
6071 this_is_output_file = 0;
6072 this_is_library_file = 0;
6073 this_is_linker_script = 0;
6074 break;
6076 case '%':
6077 switch (c = *p++)
6079 case 0:
6080 fatal_error (input_location, "spec %qs invalid", spec);
6082 case 'b':
6083 /* Don't use %b in the linker command. */
6084 gcc_assert (suffixed_basename_length);
6085 if (!this_is_output_file && dumpdir_length)
6086 obstack_grow (&obstack, dumpdir, dumpdir_length);
6087 if (this_is_output_file || !outbase_length)
6088 obstack_grow (&obstack, input_basename, basename_length);
6089 else
6090 obstack_grow (&obstack, outbase, outbase_length);
6091 if (compare_debug < 0)
6092 obstack_grow (&obstack, ".gk", 3);
6093 arg_going = 1;
6094 break;
6096 case 'B':
6097 /* Don't use %B in the linker command. */
6098 gcc_assert (suffixed_basename_length);
6099 if (!this_is_output_file && dumpdir_length)
6100 obstack_grow (&obstack, dumpdir, dumpdir_length);
6101 if (this_is_output_file || !outbase_length)
6102 obstack_grow (&obstack, input_basename, basename_length);
6103 else
6104 obstack_grow (&obstack, outbase, outbase_length);
6105 if (compare_debug < 0)
6106 obstack_grow (&obstack, ".gk", 3);
6107 obstack_grow (&obstack, input_basename + basename_length,
6108 suffixed_basename_length - basename_length);
6110 arg_going = 1;
6111 break;
6113 case 'd':
6114 delete_this_arg = 2;
6115 break;
6117 /* Dump out the directories specified with LIBRARY_PATH,
6118 followed by the absolute directories
6119 that we search for startfiles. */
6120 case 'D':
6122 struct spec_path_info info;
6124 info.option = "-L";
6125 info.append_len = 0;
6126 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
6127 /* Used on systems which record the specified -L dirs
6128 and use them to search for dynamic linking.
6129 Relative directories always come from -B,
6130 and it is better not to use them for searching
6131 at run time. In particular, stage1 loses. */
6132 info.omit_relative = true;
6133 #else
6134 info.omit_relative = false;
6135 #endif
6136 info.separate_options = false;
6138 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
6140 break;
6142 case 'e':
6143 /* %efoo means report an error with `foo' as error message
6144 and don't execute any more commands for this file. */
6146 const char *q = p;
6147 char *buf;
6148 while (*p != 0 && *p != '\n')
6149 p++;
6150 buf = (char *) alloca (p - q + 1);
6151 strncpy (buf, q, p - q);
6152 buf[p - q] = 0;
6153 error ("%s", _(buf));
6154 return -1;
6156 break;
6157 case 'n':
6158 /* %nfoo means report a notice with `foo' on stderr. */
6160 const char *q = p;
6161 char *buf;
6162 while (*p != 0 && *p != '\n')
6163 p++;
6164 buf = (char *) alloca (p - q + 1);
6165 strncpy (buf, q, p - q);
6166 buf[p - q] = 0;
6167 inform (UNKNOWN_LOCATION, "%s", _(buf));
6168 if (*p)
6169 p++;
6171 break;
6173 case 'j':
6175 struct stat st;
6177 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
6178 defined, and it is not a directory, and it is
6179 writable, use it. Otherwise, treat this like any
6180 other temporary file. */
6182 if ((!save_temps_flag)
6183 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
6184 && (access (HOST_BIT_BUCKET, W_OK) == 0))
6186 obstack_grow (&obstack, HOST_BIT_BUCKET,
6187 strlen (HOST_BIT_BUCKET));
6188 delete_this_arg = 0;
6189 arg_going = 1;
6190 break;
6193 goto create_temp_file;
6194 case '|':
6195 if (use_pipes)
6197 obstack_1grow (&obstack, '-');
6198 delete_this_arg = 0;
6199 arg_going = 1;
6201 /* consume suffix */
6202 while (*p == '.' || ISALNUM ((unsigned char) *p))
6203 p++;
6204 if (p[0] == '%' && p[1] == 'O')
6205 p += 2;
6207 break;
6209 goto create_temp_file;
6210 case 'm':
6211 if (use_pipes)
6213 /* consume suffix */
6214 while (*p == '.' || ISALNUM ((unsigned char) *p))
6215 p++;
6216 if (p[0] == '%' && p[1] == 'O')
6217 p += 2;
6219 break;
6221 goto create_temp_file;
6222 case 'g':
6223 case 'u':
6224 case 'U':
6225 create_temp_file:
6227 struct temp_name *t;
6228 int suffix_length;
6229 const char *suffix = p;
6230 char *saved_suffix = NULL;
6232 while (*p == '.' || ISALNUM ((unsigned char) *p))
6233 p++;
6234 suffix_length = p - suffix;
6235 if (p[0] == '%' && p[1] == 'O')
6237 p += 2;
6238 /* We don't support extra suffix characters after %O. */
6239 if (*p == '.' || ISALNUM ((unsigned char) *p))
6240 fatal_error (input_location,
6241 "spec %qs has invalid %<%%0%c%>", spec, *p);
6242 if (suffix_length == 0)
6243 suffix = TARGET_OBJECT_SUFFIX;
6244 else
6246 saved_suffix
6247 = XNEWVEC (char, suffix_length
6248 + strlen (TARGET_OBJECT_SUFFIX) + 1);
6249 strncpy (saved_suffix, suffix, suffix_length);
6250 strcpy (saved_suffix + suffix_length,
6251 TARGET_OBJECT_SUFFIX);
6253 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
6256 if (compare_debug < 0)
6258 suffix = concat (".gk", suffix, NULL);
6259 suffix_length += 3;
6262 /* If -save-temps was specified, use that for the
6263 temp file. */
6264 if (save_temps_flag)
6266 char *tmp;
6267 bool adjusted_suffix = false;
6268 if (suffix_length
6269 && !outbase_length && !basename_length
6270 && !dumpdir_trailing_dash_added)
6272 adjusted_suffix = true;
6273 suffix++;
6274 suffix_length--;
6276 temp_filename_length
6277 = dumpdir_length + suffix_length + 1;
6278 if (outbase_length)
6279 temp_filename_length += outbase_length;
6280 else
6281 temp_filename_length += basename_length;
6282 tmp = (char *) alloca (temp_filename_length);
6283 if (dumpdir_length)
6284 memcpy (tmp, dumpdir, dumpdir_length);
6285 if (outbase_length)
6286 memcpy (tmp + dumpdir_length, outbase,
6287 outbase_length);
6288 else if (basename_length)
6289 memcpy (tmp + dumpdir_length, input_basename,
6290 basename_length);
6291 memcpy (tmp + temp_filename_length - suffix_length - 1,
6292 suffix, suffix_length);
6293 if (adjusted_suffix)
6295 adjusted_suffix = false;
6296 suffix--;
6297 suffix_length++;
6299 tmp[temp_filename_length - 1] = '\0';
6300 temp_filename = tmp;
6302 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
6304 #ifndef HOST_LACKS_INODE_NUMBERS
6305 struct stat st_temp;
6307 /* Note, set_input() resets input_stat_set to 0. */
6308 if (input_stat_set == 0)
6310 input_stat_set = stat (gcc_input_filename,
6311 &input_stat);
6312 if (input_stat_set >= 0)
6313 input_stat_set = 1;
6316 /* If we have the stat for the gcc_input_filename
6317 and we can do the stat for the temp_filename
6318 then the they could still refer to the same
6319 file if st_dev/st_ino's are the same. */
6320 if (input_stat_set != 1
6321 || stat (temp_filename, &st_temp) < 0
6322 || input_stat.st_dev != st_temp.st_dev
6323 || input_stat.st_ino != st_temp.st_ino)
6324 #else
6325 /* Just compare canonical pathnames. */
6326 char* input_realname = lrealpath (gcc_input_filename);
6327 char* temp_realname = lrealpath (temp_filename);
6328 bool files_differ = filename_cmp (input_realname, temp_realname);
6329 free (input_realname);
6330 free (temp_realname);
6331 if (files_differ)
6332 #endif
6334 temp_filename
6335 = save_string (temp_filename,
6336 temp_filename_length - 1);
6337 obstack_grow (&obstack, temp_filename,
6338 temp_filename_length);
6339 arg_going = 1;
6340 delete_this_arg = 0;
6341 break;
6346 /* See if we already have an association of %g/%u/%U and
6347 suffix. */
6348 for (t = temp_names; t; t = t->next)
6349 if (t->length == suffix_length
6350 && strncmp (t->suffix, suffix, suffix_length) == 0
6351 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
6352 break;
6354 /* Make a new association if needed. %u and %j
6355 require one. */
6356 if (t == 0 || c == 'u' || c == 'j')
6358 if (t == 0)
6360 t = XNEW (struct temp_name);
6361 t->next = temp_names;
6362 temp_names = t;
6364 t->length = suffix_length;
6365 if (saved_suffix)
6367 t->suffix = saved_suffix;
6368 saved_suffix = NULL;
6370 else
6371 t->suffix = save_string (suffix, suffix_length);
6372 t->unique = (c == 'u' || c == 'U' || c == 'j');
6373 temp_filename = make_temp_file (t->suffix);
6374 temp_filename_length = strlen (temp_filename);
6375 t->filename = temp_filename;
6376 t->filename_length = temp_filename_length;
6379 free (saved_suffix);
6381 obstack_grow (&obstack, t->filename, t->filename_length);
6382 delete_this_arg = 1;
6384 arg_going = 1;
6385 break;
6387 case 'i':
6388 if (combine_inputs)
6390 /* We are going to expand `%i' into `@FILE', where FILE
6391 is a newly-created temporary filename. The filenames
6392 that would usually be expanded in place of %o will be
6393 written to the temporary file. */
6394 if (at_file_supplied)
6395 open_at_file ();
6397 for (i = 0; (int) i < n_infiles; i++)
6398 if (compile_input_file_p (&infiles[i]))
6400 store_arg (infiles[i].name, 0, 0);
6401 infiles[i].compiled = true;
6404 if (at_file_supplied)
6405 close_at_file ();
6407 else
6409 obstack_grow (&obstack, gcc_input_filename,
6410 input_filename_length);
6411 arg_going = 1;
6413 break;
6415 case 'I':
6417 struct spec_path_info info;
6419 if (multilib_dir)
6421 do_spec_1 ("-imultilib", 1, NULL);
6422 /* Make this a separate argument. */
6423 do_spec_1 (" ", 0, NULL);
6424 do_spec_1 (multilib_dir, 1, NULL);
6425 do_spec_1 (" ", 0, NULL);
6428 if (multiarch_dir)
6430 do_spec_1 ("-imultiarch", 1, NULL);
6431 /* Make this a separate argument. */
6432 do_spec_1 (" ", 0, NULL);
6433 do_spec_1 (multiarch_dir, 1, NULL);
6434 do_spec_1 (" ", 0, NULL);
6437 if (gcc_exec_prefix)
6439 do_spec_1 ("-iprefix", 1, NULL);
6440 /* Make this a separate argument. */
6441 do_spec_1 (" ", 0, NULL);
6442 do_spec_1 (gcc_exec_prefix, 1, NULL);
6443 do_spec_1 (" ", 0, NULL);
6446 if (target_system_root_changed ||
6447 (target_system_root && target_sysroot_hdrs_suffix))
6449 do_spec_1 ("-isysroot", 1, NULL);
6450 /* Make this a separate argument. */
6451 do_spec_1 (" ", 0, NULL);
6452 do_spec_1 (target_system_root, 1, NULL);
6453 if (target_sysroot_hdrs_suffix)
6454 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
6455 do_spec_1 (" ", 0, NULL);
6458 info.option = "-isystem";
6459 info.append = "include";
6460 info.append_len = strlen (info.append);
6461 info.omit_relative = false;
6462 info.separate_options = true;
6464 for_each_path (&include_prefixes, false, info.append_len,
6465 spec_path, &info);
6467 info.append = "include-fixed";
6468 if (*sysroot_hdrs_suffix_spec)
6469 info.append = concat (info.append, dir_separator_str,
6470 multilib_dir, NULL);
6471 info.append_len = strlen (info.append);
6472 for_each_path (&include_prefixes, false, info.append_len,
6473 spec_path, &info);
6475 break;
6477 case 'o':
6478 /* We are going to expand `%o' into `@FILE', where FILE
6479 is a newly-created temporary filename. The filenames
6480 that would usually be expanded in place of %o will be
6481 written to the temporary file. */
6482 if (at_file_supplied)
6483 open_at_file ();
6485 for (i = 0; i < n_infiles + lang_specific_extra_outfiles; i++)
6486 if (outfiles[i])
6487 store_arg (outfiles[i], 0, 0);
6489 if (at_file_supplied)
6490 close_at_file ();
6491 break;
6493 case 'O':
6494 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
6495 arg_going = 1;
6496 break;
6498 case 's':
6499 this_is_library_file = 1;
6500 break;
6502 case 'T':
6503 this_is_linker_script = 1;
6504 break;
6506 case 'V':
6507 outfiles[input_file_number] = NULL;
6508 break;
6510 case 'w':
6511 this_is_output_file = 1;
6512 break;
6514 case 'W':
6516 unsigned int cur_index = argbuf.length ();
6517 /* Handle the {...} following the %W. */
6518 if (*p != '{')
6519 fatal_error (input_location,
6520 "spec %qs has invalid %<%%W%c%>", spec, *p);
6521 p = handle_braces (p + 1);
6522 if (p == 0)
6523 return -1;
6524 end_going_arg ();
6525 /* If any args were output, mark the last one for deletion
6526 on failure. */
6527 if (argbuf.length () != cur_index)
6528 record_temp_file (argbuf.last (), 0, 1);
6529 break;
6532 case '@':
6533 /* Handle the {...} following the %@. */
6534 if (*p != '{')
6535 fatal_error (input_location,
6536 "spec %qs has invalid %<%%@%c%>", spec, *p);
6537 if (at_file_supplied)
6538 open_at_file ();
6539 p = handle_braces (p + 1);
6540 if (at_file_supplied)
6541 close_at_file ();
6542 if (p == 0)
6543 return -1;
6544 break;
6546 /* %x{OPTION} records OPTION for %X to output. */
6547 case 'x':
6549 const char *p1 = p;
6550 char *string;
6552 /* Skip past the option value and make a copy. */
6553 if (*p != '{')
6554 fatal_error (input_location,
6555 "spec %qs has invalid %<%%x%c%>", spec, *p);
6556 while (*p++ != '}')
6558 string = save_string (p1 + 1, p - p1 - 2);
6560 /* See if we already recorded this option. */
6561 for (const char *opt : linker_options)
6562 if (! strcmp (string, opt))
6564 free (string);
6565 return 0;
6568 /* This option is new; add it. */
6569 add_linker_option (string, strlen (string));
6570 free (string);
6572 break;
6574 /* Dump out the options accumulated previously using %x. */
6575 case 'X':
6576 do_specs_vec (linker_options);
6577 break;
6579 /* Dump out the options accumulated previously using -Wa,. */
6580 case 'Y':
6581 do_specs_vec (assembler_options);
6582 break;
6584 /* Dump out the options accumulated previously using -Wp,. */
6585 case 'Z':
6586 do_specs_vec (preprocessor_options);
6587 break;
6589 /* Here are digits and numbers that just process
6590 a certain constant string as a spec. */
6592 case '1':
6593 value = do_spec_1 (cc1_spec, 0, NULL);
6594 if (value != 0)
6595 return value;
6596 break;
6598 case '2':
6599 value = do_spec_1 (cc1plus_spec, 0, NULL);
6600 if (value != 0)
6601 return value;
6602 break;
6604 case 'a':
6605 value = do_spec_1 (asm_spec, 0, NULL);
6606 if (value != 0)
6607 return value;
6608 break;
6610 case 'A':
6611 value = do_spec_1 (asm_final_spec, 0, NULL);
6612 if (value != 0)
6613 return value;
6614 break;
6616 case 'C':
6618 const char *const spec
6619 = (input_file_compiler->cpp_spec
6620 ? input_file_compiler->cpp_spec
6621 : cpp_spec);
6622 value = do_spec_1 (spec, 0, NULL);
6623 if (value != 0)
6624 return value;
6626 break;
6628 case 'E':
6629 value = do_spec_1 (endfile_spec, 0, NULL);
6630 if (value != 0)
6631 return value;
6632 break;
6634 case 'l':
6635 value = do_spec_1 (link_spec, 0, NULL);
6636 if (value != 0)
6637 return value;
6638 break;
6640 case 'L':
6641 value = do_spec_1 (lib_spec, 0, NULL);
6642 if (value != 0)
6643 return value;
6644 break;
6646 case 'M':
6647 if (multilib_os_dir == NULL)
6648 obstack_1grow (&obstack, '.');
6649 else
6650 obstack_grow (&obstack, multilib_os_dir,
6651 strlen (multilib_os_dir));
6652 break;
6654 case 'G':
6655 value = do_spec_1 (libgcc_spec, 0, NULL);
6656 if (value != 0)
6657 return value;
6658 break;
6660 case 'R':
6661 /* We assume there is a directory
6662 separator at the end of this string. */
6663 if (target_system_root)
6665 obstack_grow (&obstack, target_system_root,
6666 strlen (target_system_root));
6667 if (target_sysroot_suffix)
6668 obstack_grow (&obstack, target_sysroot_suffix,
6669 strlen (target_sysroot_suffix));
6671 break;
6673 case 'S':
6674 value = do_spec_1 (startfile_spec, 0, NULL);
6675 if (value != 0)
6676 return value;
6677 break;
6679 /* Here we define characters other than letters and digits. */
6681 case '{':
6682 p = handle_braces (p);
6683 if (p == 0)
6684 return -1;
6685 break;
6687 case ':':
6688 p = handle_spec_function (p, NULL, soft_matched_part);
6689 if (p == 0)
6690 return -1;
6691 break;
6693 case '%':
6694 obstack_1grow (&obstack, '%');
6695 break;
6697 case '.':
6699 unsigned len = 0;
6701 while (p[len] && p[len] != ' ' && p[len] != '%')
6702 len++;
6703 suffix_subst = save_string (p - 1, len + 1);
6704 p += len;
6706 break;
6708 /* Henceforth ignore the option(s) matching the pattern
6709 after the %<. */
6710 case '<':
6711 case '>':
6713 unsigned len = 0;
6714 int have_wildcard = 0;
6715 int i;
6716 int switch_option;
6718 if (c == '>')
6719 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
6720 else
6721 switch_option = SWITCH_IGNORE;
6723 while (p[len] && p[len] != ' ' && p[len] != '\t')
6724 len++;
6726 if (p[len-1] == '*')
6727 have_wildcard = 1;
6729 for (i = 0; i < n_switches; i++)
6730 if (!strncmp (switches[i].part1, p, len - have_wildcard)
6731 && (have_wildcard || switches[i].part1[len] == '\0'))
6733 switches[i].live_cond |= switch_option;
6734 /* User switch be validated from validate_all_switches.
6735 when the definition is seen from the spec file.
6736 If not defined anywhere, will be rejected. */
6737 if (switches[i].known)
6738 switches[i].validated = true;
6741 p += len;
6743 break;
6745 case '*':
6746 if (soft_matched_part)
6748 if (soft_matched_part[0])
6749 do_spec_1 (soft_matched_part, 1, NULL);
6750 /* Only insert a space after the substitution if it is at the
6751 end of the current sequence. So if:
6753 "%{foo=*:bar%*}%{foo=*:one%*two}"
6755 matches -foo=hello then it will produce:
6757 barhello onehellotwo
6759 if (*p == 0 || *p == '}')
6760 do_spec_1 (" ", 0, NULL);
6762 else
6763 /* Catch the case where a spec string contains something like
6764 '%{foo:%*}'. i.e. there is no * in the pattern on the left
6765 hand side of the :. */
6766 error ("spec failure: %<%%*%> has not been initialized by pattern match");
6767 break;
6769 /* Process a string found as the value of a spec given by name.
6770 This feature allows individual machine descriptions
6771 to add and use their own specs. */
6772 case '(':
6774 const char *name = p;
6775 struct spec_list *sl;
6776 int len;
6778 /* The string after the S/P is the name of a spec that is to be
6779 processed. */
6780 while (*p && *p != ')')
6781 p++;
6783 /* See if it's in the list. */
6784 for (len = p - name, sl = specs; sl; sl = sl->next)
6785 if (sl->name_len == len && !strncmp (sl->name, name, len))
6787 name = *(sl->ptr_spec);
6788 #ifdef DEBUG_SPECS
6789 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
6790 sl->name, name);
6791 #endif
6792 break;
6795 if (sl)
6797 value = do_spec_1 (name, 0, NULL);
6798 if (value != 0)
6799 return value;
6802 /* Discard the closing paren. */
6803 if (*p)
6804 p++;
6806 break;
6808 case '"':
6809 /* End a previous argument, if there is one, then issue an
6810 empty argument. */
6811 end_going_arg ();
6812 arg_going = 1;
6813 end_going_arg ();
6814 break;
6816 default:
6817 error ("spec failure: unrecognized spec option %qc", c);
6818 break;
6820 break;
6822 case '\\':
6823 /* Backslash: treat next character as ordinary. */
6824 c = *p++;
6826 /* When adding more cases that previously matched default, make
6827 sure to adjust quote_spec_char_p as well. */
6829 /* Fall through. */
6830 default:
6831 /* Ordinary character: put it into the current argument. */
6832 obstack_1grow (&obstack, c);
6833 arg_going = 1;
6836 /* End of string. If we are processing a spec function, we need to
6837 end any pending argument. */
6838 if (processing_spec_function)
6839 end_going_arg ();
6841 return 0;
6844 /* Look up a spec function. */
6846 static const struct spec_function *
6847 lookup_spec_function (const char *name)
6849 const struct spec_function *sf;
6851 for (sf = static_spec_functions; sf->name != NULL; sf++)
6852 if (strcmp (sf->name, name) == 0)
6853 return sf;
6855 return NULL;
6858 /* Evaluate a spec function. */
6860 static const char *
6861 eval_spec_function (const char *func, const char *args,
6862 const char *soft_matched_part)
6864 const struct spec_function *sf;
6865 const char *funcval;
6867 /* Saved spec processing context. */
6868 vec<const_char_p> save_argbuf;
6870 int save_arg_going;
6871 int save_delete_this_arg;
6872 int save_this_is_output_file;
6873 int save_this_is_library_file;
6874 int save_input_from_pipe;
6875 int save_this_is_linker_script;
6876 const char *save_suffix_subst;
6878 int save_growing_size;
6879 void *save_growing_value = NULL;
6881 sf = lookup_spec_function (func);
6882 if (sf == NULL)
6883 fatal_error (input_location, "unknown spec function %qs", func);
6885 /* Push the spec processing context. */
6886 save_argbuf = argbuf;
6888 save_arg_going = arg_going;
6889 save_delete_this_arg = delete_this_arg;
6890 save_this_is_output_file = this_is_output_file;
6891 save_this_is_library_file = this_is_library_file;
6892 save_this_is_linker_script = this_is_linker_script;
6893 save_input_from_pipe = input_from_pipe;
6894 save_suffix_subst = suffix_subst;
6896 /* If we have some object growing now, finalize it so the args and function
6897 eval proceed from a cleared context. This is needed to prevent the first
6898 constructed arg from mistakenly including the growing value. We'll push
6899 this value back on the obstack once the function evaluation is done, to
6900 restore a consistent processing context for our caller. This is fine as
6901 the address of growing objects isn't guaranteed to remain stable until
6902 they are finalized, and we expect this situation to be rare enough for
6903 the extra copy not to be an issue. */
6904 save_growing_size = obstack_object_size (&obstack);
6905 if (save_growing_size > 0)
6906 save_growing_value = obstack_finish (&obstack);
6908 /* Create a new spec processing context, and build the function
6909 arguments. */
6911 alloc_args ();
6912 if (do_spec_2 (args, soft_matched_part) < 0)
6913 fatal_error (input_location, "error in arguments to spec function %qs",
6914 func);
6916 /* argbuf_index is an index for the next argument to be inserted, and
6917 so contains the count of the args already inserted. */
6919 funcval = (*sf->func) (argbuf.length (),
6920 argbuf.address ());
6922 /* Pop the spec processing context. */
6923 argbuf.release ();
6924 argbuf = save_argbuf;
6926 arg_going = save_arg_going;
6927 delete_this_arg = save_delete_this_arg;
6928 this_is_output_file = save_this_is_output_file;
6929 this_is_library_file = save_this_is_library_file;
6930 this_is_linker_script = save_this_is_linker_script;
6931 input_from_pipe = save_input_from_pipe;
6932 suffix_subst = save_suffix_subst;
6934 if (save_growing_size > 0)
6935 obstack_grow (&obstack, save_growing_value, save_growing_size);
6937 return funcval;
6940 /* Handle a spec function call of the form:
6942 %:function(args)
6944 ARGS is processed as a spec in a separate context and split into an
6945 argument vector in the normal fashion. The function returns a string
6946 containing a spec which we then process in the caller's context, or
6947 NULL if no processing is required.
6949 If RETVAL_NONNULL is not NULL, then store a bool whether function
6950 returned non-NULL.
6952 SOFT_MATCHED_PART holds the current value of a matched * pattern, which
6953 may be re-expanded with a %* as part of the function arguments. */
6955 static const char *
6956 handle_spec_function (const char *p, bool *retval_nonnull,
6957 const char *soft_matched_part)
6959 char *func, *args;
6960 const char *endp, *funcval;
6961 int count;
6963 processing_spec_function++;
6965 /* Get the function name. */
6966 for (endp = p; *endp != '\0'; endp++)
6968 if (*endp == '(') /* ) */
6969 break;
6970 /* Only allow [A-Za-z0-9], -, and _ in function names. */
6971 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
6972 fatal_error (input_location, "malformed spec function name");
6974 if (*endp != '(') /* ) */
6975 fatal_error (input_location, "no arguments for spec function");
6976 func = save_string (p, endp - p);
6977 p = ++endp;
6979 /* Get the arguments. */
6980 for (count = 0; *endp != '\0'; endp++)
6982 /* ( */
6983 if (*endp == ')')
6985 if (count == 0)
6986 break;
6987 count--;
6989 else if (*endp == '(') /* ) */
6990 count++;
6992 /* ( */
6993 if (*endp != ')')
6994 fatal_error (input_location, "malformed spec function arguments");
6995 args = save_string (p, endp - p);
6996 p = ++endp;
6998 /* p now points to just past the end of the spec function expression. */
7000 funcval = eval_spec_function (func, args, soft_matched_part);
7001 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
7002 p = NULL;
7003 if (retval_nonnull)
7004 *retval_nonnull = funcval != NULL;
7006 free (func);
7007 free (args);
7009 processing_spec_function--;
7011 return p;
7014 /* Inline subroutine of handle_braces. Returns true if the current
7015 input suffix matches the atom bracketed by ATOM and END_ATOM. */
7016 static inline bool
7017 input_suffix_matches (const char *atom, const char *end_atom)
7019 return (input_suffix
7020 && !strncmp (input_suffix, atom, end_atom - atom)
7021 && input_suffix[end_atom - atom] == '\0');
7024 /* Subroutine of handle_braces. Returns true if the current
7025 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
7026 static bool
7027 input_spec_matches (const char *atom, const char *end_atom)
7029 return (input_file_compiler
7030 && input_file_compiler->suffix
7031 && input_file_compiler->suffix[0] != '\0'
7032 && !strncmp (input_file_compiler->suffix + 1, atom,
7033 end_atom - atom)
7034 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
7037 /* Subroutine of handle_braces. Returns true if a switch
7038 matching the atom bracketed by ATOM and END_ATOM appeared on the
7039 command line. */
7040 static bool
7041 switch_matches (const char *atom, const char *end_atom, int starred)
7043 int i;
7044 int len = end_atom - atom;
7045 int plen = starred ? len : -1;
7047 for (i = 0; i < n_switches; i++)
7048 if (!strncmp (switches[i].part1, atom, len)
7049 && (starred || switches[i].part1[len] == '\0')
7050 && check_live_switch (i, plen))
7051 return true;
7053 /* Check if a switch with separated form matching the atom.
7054 We check -D and -U switches. */
7055 else if (switches[i].args != 0)
7057 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
7058 && *switches[i].part1 == atom[0])
7060 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
7061 && (starred || (switches[i].part1[1] == '\0'
7062 && switches[i].args[0][len - 1] == '\0'))
7063 && check_live_switch (i, (starred ? 1 : -1)))
7064 return true;
7068 return false;
7071 /* Inline subroutine of handle_braces. Mark all of the switches which
7072 match ATOM (extends to END_ATOM; STARRED indicates whether there
7073 was a star after the atom) for later processing. */
7074 static inline void
7075 mark_matching_switches (const char *atom, const char *end_atom, int starred)
7077 int i;
7078 int len = end_atom - atom;
7079 int plen = starred ? len : -1;
7081 for (i = 0; i < n_switches; i++)
7082 if (!strncmp (switches[i].part1, atom, len)
7083 && (starred || switches[i].part1[len] == '\0')
7084 && check_live_switch (i, plen))
7085 switches[i].ordering = 1;
7088 /* Inline subroutine of handle_braces. Process all the currently
7089 marked switches through give_switch, and clear the marks. */
7090 static inline void
7091 process_marked_switches (void)
7093 int i;
7095 for (i = 0; i < n_switches; i++)
7096 if (switches[i].ordering == 1)
7098 switches[i].ordering = 0;
7099 give_switch (i, 0);
7103 /* Handle a %{ ... } construct. P points just inside the leading {.
7104 Returns a pointer one past the end of the brace block, or 0
7105 if we call do_spec_1 and that returns -1. */
7107 static const char *
7108 handle_braces (const char *p)
7110 const char *atom, *end_atom;
7111 const char *d_atom = NULL, *d_end_atom = NULL;
7112 char *esc_buf = NULL, *d_esc_buf = NULL;
7113 int esc;
7114 const char *orig = p;
7116 bool a_is_suffix;
7117 bool a_is_spectype;
7118 bool a_is_starred;
7119 bool a_is_negated;
7120 bool a_matched;
7122 bool a_must_be_last = false;
7123 bool ordered_set = false;
7124 bool disjunct_set = false;
7125 bool disj_matched = false;
7126 bool disj_starred = true;
7127 bool n_way_choice = false;
7128 bool n_way_matched = false;
7130 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
7134 if (a_must_be_last)
7135 goto invalid;
7137 /* Scan one "atom" (S in the description above of %{}, possibly
7138 with '!', '.', '@', ',', or '*' modifiers). */
7139 a_matched = false;
7140 a_is_suffix = false;
7141 a_is_starred = false;
7142 a_is_negated = false;
7143 a_is_spectype = false;
7145 SKIP_WHITE ();
7146 if (*p == '!')
7147 p++, a_is_negated = true;
7149 SKIP_WHITE ();
7150 if (*p == '%' && p[1] == ':')
7152 atom = NULL;
7153 end_atom = NULL;
7154 p = handle_spec_function (p + 2, &a_matched, NULL);
7156 else
7158 if (*p == '.')
7159 p++, a_is_suffix = true;
7160 else if (*p == ',')
7161 p++, a_is_spectype = true;
7163 atom = p;
7164 esc = 0;
7165 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
7166 || *p == ',' || *p == '.' || *p == '@' || *p == '\\')
7168 if (*p == '\\')
7170 p++;
7171 if (!*p)
7172 fatal_error (input_location,
7173 "braced spec %qs ends in escape", orig);
7174 esc++;
7176 p++;
7178 end_atom = p;
7180 if (esc)
7182 const char *ap;
7183 char *ep;
7185 if (esc_buf && esc_buf != d_esc_buf)
7186 free (esc_buf);
7187 esc_buf = NULL;
7188 ep = esc_buf = (char *) xmalloc (end_atom - atom - esc + 1);
7189 for (ap = atom; ap != end_atom; ap++, ep++)
7191 if (*ap == '\\')
7192 ap++;
7193 *ep = *ap;
7195 *ep = '\0';
7196 atom = esc_buf;
7197 end_atom = ep;
7200 if (*p == '*')
7201 p++, a_is_starred = 1;
7204 SKIP_WHITE ();
7205 switch (*p)
7207 case '&': case '}':
7208 /* Substitute the switch(es) indicated by the current atom. */
7209 ordered_set = true;
7210 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
7211 || a_is_spectype || atom == end_atom)
7212 goto invalid;
7214 mark_matching_switches (atom, end_atom, a_is_starred);
7216 if (*p == '}')
7217 process_marked_switches ();
7218 break;
7220 case '|': case ':':
7221 /* Substitute some text if the current atom appears as a switch
7222 or suffix. */
7223 disjunct_set = true;
7224 if (ordered_set)
7225 goto invalid;
7227 if (atom && atom == end_atom)
7229 if (!n_way_choice || disj_matched || *p == '|'
7230 || a_is_negated || a_is_suffix || a_is_spectype
7231 || a_is_starred)
7232 goto invalid;
7234 /* An empty term may appear as the last choice of an
7235 N-way choice set; it means "otherwise". */
7236 a_must_be_last = true;
7237 disj_matched = !n_way_matched;
7238 disj_starred = false;
7240 else
7242 if ((a_is_suffix || a_is_spectype) && a_is_starred)
7243 goto invalid;
7245 if (!a_is_starred)
7246 disj_starred = false;
7248 /* Don't bother testing this atom if we already have a
7249 match. */
7250 if (!disj_matched && !n_way_matched)
7252 if (atom == NULL)
7253 /* a_matched is already set by handle_spec_function. */;
7254 else if (a_is_suffix)
7255 a_matched = input_suffix_matches (atom, end_atom);
7256 else if (a_is_spectype)
7257 a_matched = input_spec_matches (atom, end_atom);
7258 else
7259 a_matched = switch_matches (atom, end_atom, a_is_starred);
7261 if (a_matched != a_is_negated)
7263 disj_matched = true;
7264 d_atom = atom;
7265 d_end_atom = end_atom;
7266 d_esc_buf = esc_buf;
7271 if (*p == ':')
7273 /* Found the body, that is, the text to substitute if the
7274 current disjunction matches. */
7275 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
7276 disj_matched && !n_way_matched);
7277 if (p == 0)
7278 goto done;
7280 /* If we have an N-way choice, reset state for the next
7281 disjunction. */
7282 if (*p == ';')
7284 n_way_choice = true;
7285 n_way_matched |= disj_matched;
7286 disj_matched = false;
7287 disj_starred = true;
7288 d_atom = d_end_atom = NULL;
7291 break;
7293 default:
7294 goto invalid;
7297 while (*p++ != '}');
7299 done:
7300 if (d_esc_buf && d_esc_buf != esc_buf)
7301 free (d_esc_buf);
7302 if (esc_buf)
7303 free (esc_buf);
7305 return p;
7307 invalid:
7308 fatal_error (input_location, "braced spec %qs is invalid at %qc", orig, *p);
7310 #undef SKIP_WHITE
7313 /* Subroutine of handle_braces. Scan and process a brace substitution body
7314 (X in the description of %{} syntax). P points one past the colon;
7315 ATOM and END_ATOM bracket the first atom which was found to be true
7316 (present) in the current disjunction; STARRED indicates whether all
7317 the atoms in the current disjunction were starred (for syntax validation);
7318 MATCHED indicates whether the disjunction matched or not, and therefore
7319 whether or not the body is to be processed through do_spec_1 or just
7320 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
7321 returns -1. */
7323 static const char *
7324 process_brace_body (const char *p, const char *atom, const char *end_atom,
7325 int starred, int matched)
7327 const char *body, *end_body;
7328 unsigned int nesting_level;
7329 bool have_subst = false;
7331 /* Locate the closing } or ;, honoring nested braces.
7332 Trim trailing whitespace. */
7333 body = p;
7334 nesting_level = 1;
7335 for (;;)
7337 if (*p == '{')
7338 nesting_level++;
7339 else if (*p == '}')
7341 if (!--nesting_level)
7342 break;
7344 else if (*p == ';' && nesting_level == 1)
7345 break;
7346 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
7347 have_subst = true;
7348 else if (*p == '\0')
7349 goto invalid;
7350 p++;
7353 end_body = p;
7354 while (end_body[-1] == ' ' || end_body[-1] == '\t')
7355 end_body--;
7357 if (have_subst && !starred)
7358 goto invalid;
7360 if (matched)
7362 /* Copy the substitution body to permanent storage and execute it.
7363 If have_subst is false, this is a simple matter of running the
7364 body through do_spec_1... */
7365 char *string = save_string (body, end_body - body);
7366 if (!have_subst)
7368 if (do_spec_1 (string, 0, NULL) < 0)
7370 free (string);
7371 return 0;
7374 else
7376 /* ... but if have_subst is true, we have to process the
7377 body once for each matching switch, with %* set to the
7378 variant part of the switch. */
7379 unsigned int hard_match_len = end_atom - atom;
7380 int i;
7382 for (i = 0; i < n_switches; i++)
7383 if (!strncmp (switches[i].part1, atom, hard_match_len)
7384 && check_live_switch (i, hard_match_len))
7386 if (do_spec_1 (string, 0,
7387 &switches[i].part1[hard_match_len]) < 0)
7389 free (string);
7390 return 0;
7392 /* Pass any arguments this switch has. */
7393 give_switch (i, 1);
7394 suffix_subst = NULL;
7397 free (string);
7400 return p;
7402 invalid:
7403 fatal_error (input_location, "braced spec body %qs is invalid", body);
7406 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
7407 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
7408 spec, or -1 if either exact match or %* is used.
7410 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
7411 whose value does not begin with "no-" is obsoleted by the same value
7412 with the "no-", similarly for a switch with the "no-" prefix. */
7414 static int
7415 check_live_switch (int switchnum, int prefix_length)
7417 const char *name = switches[switchnum].part1;
7418 int i;
7420 /* If we already processed this switch and determined if it was
7421 live or not, return our past determination. */
7422 if (switches[switchnum].live_cond != 0)
7423 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
7424 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
7425 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
7426 == 0);
7428 /* In the common case of {<at-most-one-letter>*}, a negating
7429 switch would always match, so ignore that case. We will just
7430 send the conflicting switches to the compiler phase. */
7431 if (prefix_length >= 0 && prefix_length <= 1)
7432 return 1;
7434 /* Now search for duplicate in a manner that depends on the name. */
7435 switch (*name)
7437 case 'O':
7438 for (i = switchnum + 1; i < n_switches; i++)
7439 if (switches[i].part1[0] == 'O')
7441 switches[switchnum].validated = true;
7442 switches[switchnum].live_cond = SWITCH_FALSE;
7443 return 0;
7445 break;
7447 case 'W': case 'f': case 'm': case 'g':
7448 if (startswith (name + 1, "no-"))
7450 /* We have Xno-YYY, search for XYYY. */
7451 for (i = switchnum + 1; i < n_switches; i++)
7452 if (switches[i].part1[0] == name[0]
7453 && ! strcmp (&switches[i].part1[1], &name[4]))
7455 /* --specs are validated with the validate_switches mechanism. */
7456 if (switches[switchnum].known)
7457 switches[switchnum].validated = true;
7458 switches[switchnum].live_cond = SWITCH_FALSE;
7459 return 0;
7462 else
7464 /* We have XYYY, search for Xno-YYY. */
7465 for (i = switchnum + 1; i < n_switches; i++)
7466 if (switches[i].part1[0] == name[0]
7467 && switches[i].part1[1] == 'n'
7468 && switches[i].part1[2] == 'o'
7469 && switches[i].part1[3] == '-'
7470 && !strcmp (&switches[i].part1[4], &name[1]))
7472 /* --specs are validated with the validate_switches mechanism. */
7473 if (switches[switchnum].known)
7474 switches[switchnum].validated = true;
7475 switches[switchnum].live_cond = SWITCH_FALSE;
7476 return 0;
7479 break;
7482 /* Otherwise the switch is live. */
7483 switches[switchnum].live_cond |= SWITCH_LIVE;
7484 return 1;
7487 /* Pass a switch to the current accumulating command
7488 in the same form that we received it.
7489 SWITCHNUM identifies the switch; it is an index into
7490 the vector of switches gcc received, which is `switches'.
7491 This cannot fail since it never finishes a command line.
7493 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
7495 static void
7496 give_switch (int switchnum, int omit_first_word)
7498 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
7499 return;
7501 if (!omit_first_word)
7503 do_spec_1 ("-", 0, NULL);
7504 do_spec_1 (switches[switchnum].part1, 1, NULL);
7507 if (switches[switchnum].args != 0)
7509 const char **p;
7510 for (p = switches[switchnum].args; *p; p++)
7512 const char *arg = *p;
7514 do_spec_1 (" ", 0, NULL);
7515 if (suffix_subst)
7517 unsigned length = strlen (arg);
7518 int dot = 0;
7520 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
7521 if (arg[length] == '.')
7523 (CONST_CAST (char *, arg))[length] = 0;
7524 dot = 1;
7525 break;
7527 do_spec_1 (arg, 1, NULL);
7528 if (dot)
7529 (CONST_CAST (char *, arg))[length] = '.';
7530 do_spec_1 (suffix_subst, 1, NULL);
7532 else
7533 do_spec_1 (arg, 1, NULL);
7537 do_spec_1 (" ", 0, NULL);
7538 switches[switchnum].validated = true;
7541 /* Print GCC configuration (e.g. version, thread model, target,
7542 configuration_arguments) to a given FILE. */
7544 static void
7545 print_configuration (FILE *file)
7547 int n;
7548 const char *thrmod;
7550 fnotice (file, "Target: %s\n", spec_machine);
7551 fnotice (file, "Configured with: %s\n", configuration_arguments);
7553 #ifdef THREAD_MODEL_SPEC
7554 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
7555 but there's no point in doing all this processing just to get
7556 thread_model back. */
7557 obstack_init (&obstack);
7558 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
7559 obstack_1grow (&obstack, '\0');
7560 thrmod = XOBFINISH (&obstack, const char *);
7561 #else
7562 thrmod = thread_model;
7563 #endif
7565 fnotice (file, "Thread model: %s\n", thrmod);
7566 fnotice (file, "Supported LTO compression algorithms: zlib");
7567 #ifdef HAVE_ZSTD_H
7568 fnotice (file, " zstd");
7569 #endif
7570 fnotice (file, "\n");
7572 /* compiler_version is truncated at the first space when initialized
7573 from version string, so truncate version_string at the first space
7574 before comparing. */
7575 for (n = 0; version_string[n]; n++)
7576 if (version_string[n] == ' ')
7577 break;
7579 if (! strncmp (version_string, compiler_version, n)
7580 && compiler_version[n] == 0)
7581 fnotice (file, "gcc version %s %s\n", version_string,
7582 pkgversion_string);
7583 else
7584 fnotice (file, "gcc driver version %s %sexecuting gcc version %s\n",
7585 version_string, pkgversion_string, compiler_version);
7589 #define RETRY_ICE_ATTEMPTS 3
7591 /* Returns true if FILE1 and FILE2 contain equivalent data, 0 otherwise. */
7593 static bool
7594 files_equal_p (char *file1, char *file2)
7596 struct stat st1, st2;
7597 off_t n, len;
7598 int fd1, fd2;
7599 const int bufsize = 8192;
7600 char *buf = XNEWVEC (char, bufsize);
7602 fd1 = open (file1, O_RDONLY);
7603 fd2 = open (file2, O_RDONLY);
7605 if (fd1 < 0 || fd2 < 0)
7606 goto error;
7608 if (fstat (fd1, &st1) < 0 || fstat (fd2, &st2) < 0)
7609 goto error;
7611 if (st1.st_size != st2.st_size)
7612 goto error;
7614 for (n = st1.st_size; n; n -= len)
7616 len = n;
7617 if ((int) len > bufsize / 2)
7618 len = bufsize / 2;
7620 if (read (fd1, buf, len) != (int) len
7621 || read (fd2, buf + bufsize / 2, len) != (int) len)
7623 goto error;
7626 if (memcmp (buf, buf + bufsize / 2, len) != 0)
7627 goto error;
7630 free (buf);
7631 close (fd1);
7632 close (fd2);
7634 return 1;
7636 error:
7637 free (buf);
7638 close (fd1);
7639 close (fd2);
7640 return 0;
7643 /* Check that compiler's output doesn't differ across runs.
7644 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are arrays of files, containing
7645 stdout and stderr for each compiler run. Return true if all of
7646 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are equivalent. */
7648 static bool
7649 check_repro (char **temp_stdout_files, char **temp_stderr_files)
7651 int i;
7652 for (i = 0; i < RETRY_ICE_ATTEMPTS - 2; ++i)
7654 if (!files_equal_p (temp_stdout_files[i], temp_stdout_files[i + 1])
7655 || !files_equal_p (temp_stderr_files[i], temp_stderr_files[i + 1]))
7657 fnotice (stderr, "The bug is not reproducible, so it is"
7658 " likely a hardware or OS problem.\n");
7659 break;
7662 return i == RETRY_ICE_ATTEMPTS - 2;
7665 enum attempt_status {
7666 ATTEMPT_STATUS_FAIL_TO_RUN,
7667 ATTEMPT_STATUS_SUCCESS,
7668 ATTEMPT_STATUS_ICE
7672 /* Run compiler with arguments NEW_ARGV to reproduce the ICE, storing stdout
7673 to OUT_TEMP and stderr to ERR_TEMP. If APPEND is TRUE, append to OUT_TEMP
7674 and ERR_TEMP instead of truncating. If EMIT_SYSTEM_INFO is TRUE, also write
7675 GCC configuration into to ERR_TEMP. Return ATTEMPT_STATUS_FAIL_TO_RUN if
7676 compiler failed to run, ATTEMPT_STATUS_ICE if compiled ICE-ed and
7677 ATTEMPT_STATUS_SUCCESS otherwise. */
7679 static enum attempt_status
7680 run_attempt (const char **new_argv, const char *out_temp,
7681 const char *err_temp, int emit_system_info, int append)
7684 if (emit_system_info)
7686 FILE *file_out = fopen (err_temp, "a");
7687 print_configuration (file_out);
7688 fputs ("\n", file_out);
7689 fclose (file_out);
7692 int exit_status;
7693 const char *errmsg;
7694 struct pex_obj *pex;
7695 int err;
7696 int pex_flags = PEX_USE_PIPES | PEX_LAST;
7697 enum attempt_status status = ATTEMPT_STATUS_FAIL_TO_RUN;
7699 if (append)
7700 pex_flags |= PEX_STDOUT_APPEND | PEX_STDERR_APPEND;
7702 pex = pex_init (PEX_USE_PIPES, new_argv[0], NULL);
7703 if (!pex)
7704 fatal_error (input_location, "%<pex_init%> failed: %m");
7706 errmsg = pex_run (pex, pex_flags, new_argv[0],
7707 CONST_CAST2 (char *const *, const char **, &new_argv[1]),
7708 out_temp, err_temp, &err);
7709 if (errmsg != NULL)
7711 errno = err;
7712 fatal_error (input_location,
7713 err ? G_ ("cannot execute %qs: %s: %m")
7714 : G_ ("cannot execute %qs: %s"),
7715 new_argv[0], errmsg);
7718 if (!pex_get_status (pex, 1, &exit_status))
7719 goto out;
7721 switch (WEXITSTATUS (exit_status))
7723 case ICE_EXIT_CODE:
7724 status = ATTEMPT_STATUS_ICE;
7725 break;
7727 case SUCCESS_EXIT_CODE:
7728 status = ATTEMPT_STATUS_SUCCESS;
7729 break;
7731 default:
7735 out:
7736 pex_free (pex);
7737 return status;
7740 /* This routine reads lines from IN file, adds C++ style comments
7741 at the begining of each line and writes result into OUT. */
7743 static void
7744 insert_comments (const char *file_in, const char *file_out)
7746 FILE *in = fopen (file_in, "rb");
7747 FILE *out = fopen (file_out, "wb");
7748 char line[256];
7750 bool add_comment = true;
7751 while (fgets (line, sizeof (line), in))
7753 if (add_comment)
7754 fputs ("// ", out);
7755 fputs (line, out);
7756 add_comment = strchr (line, '\n') != NULL;
7759 fclose (in);
7760 fclose (out);
7763 /* This routine adds preprocessed source code into the given ERR_FILE.
7764 To do this, it adds "-E" to NEW_ARGV and execute RUN_ATTEMPT routine to
7765 add information in report file. RUN_ATTEMPT should return
7766 ATTEMPT_STATUS_SUCCESS, in other case we cannot generate the report. */
7768 static void
7769 do_report_bug (const char **new_argv, const int nargs,
7770 char **out_file, char **err_file)
7772 int i, status;
7773 int fd = open (*out_file, O_RDWR | O_APPEND);
7774 if (fd < 0)
7775 return;
7776 write (fd, "\n//", 3);
7777 for (i = 0; i < nargs; i++)
7779 write (fd, " ", 1);
7780 write (fd, new_argv[i], strlen (new_argv[i]));
7782 write (fd, "\n\n", 2);
7783 close (fd);
7784 new_argv[nargs] = "-E";
7785 new_argv[nargs + 1] = NULL;
7787 status = run_attempt (new_argv, *out_file, *err_file, 0, 1);
7789 if (status == ATTEMPT_STATUS_SUCCESS)
7791 fnotice (stderr, "Preprocessed source stored into %s file,"
7792 " please attach this to your bugreport.\n", *out_file);
7793 /* Make sure it is not deleted. */
7794 free (*out_file);
7795 *out_file = NULL;
7799 /* Try to reproduce ICE. If bug is reproducible, generate report .err file
7800 containing GCC configuration, backtrace, compiler's command line options
7801 and preprocessed source code. */
7803 static void
7804 try_generate_repro (const char **argv)
7806 int i, nargs, out_arg = -1, quiet = 0, attempt;
7807 const char **new_argv;
7808 char *temp_files[RETRY_ICE_ATTEMPTS * 2];
7809 char **temp_stdout_files = &temp_files[0];
7810 char **temp_stderr_files = &temp_files[RETRY_ICE_ATTEMPTS];
7812 if (gcc_input_filename == NULL || ! strcmp (gcc_input_filename, "-"))
7813 return;
7815 for (nargs = 0; argv[nargs] != NULL; ++nargs)
7816 /* Only retry compiler ICEs, not preprocessor ones. */
7817 if (! strcmp (argv[nargs], "-E"))
7818 return;
7819 else if (argv[nargs][0] == '-' && argv[nargs][1] == 'o')
7821 if (out_arg == -1)
7822 out_arg = nargs;
7823 else
7824 return;
7826 /* If the compiler is going to output any time information,
7827 it might varry between invocations. */
7828 else if (! strcmp (argv[nargs], "-quiet"))
7829 quiet = 1;
7830 else if (! strcmp (argv[nargs], "-ftime-report"))
7831 return;
7833 if (out_arg == -1 || !quiet)
7834 return;
7836 memset (temp_files, '\0', sizeof (temp_files));
7837 new_argv = XALLOCAVEC (const char *, nargs + 4);
7838 memcpy (new_argv, argv, (nargs + 1) * sizeof (const char *));
7839 new_argv[nargs++] = "-frandom-seed=0";
7840 new_argv[nargs++] = "-fdump-noaddr";
7841 new_argv[nargs] = NULL;
7842 if (new_argv[out_arg][2] == '\0')
7843 new_argv[out_arg + 1] = "-";
7844 else
7845 new_argv[out_arg] = "-o-";
7847 int status;
7848 for (attempt = 0; attempt < RETRY_ICE_ATTEMPTS; ++attempt)
7850 int emit_system_info = 0;
7851 int append = 0;
7852 temp_stdout_files[attempt] = make_temp_file (".out");
7853 temp_stderr_files[attempt] = make_temp_file (".err");
7855 if (attempt == RETRY_ICE_ATTEMPTS - 1)
7857 append = 1;
7858 emit_system_info = 1;
7861 status = run_attempt (new_argv, temp_stdout_files[attempt],
7862 temp_stderr_files[attempt], emit_system_info,
7863 append);
7865 if (status != ATTEMPT_STATUS_ICE)
7867 fnotice (stderr, "The bug is not reproducible, so it is"
7868 " likely a hardware or OS problem.\n");
7869 goto out;
7873 if (!check_repro (temp_stdout_files, temp_stderr_files))
7874 goto out;
7877 /* Insert commented out backtrace into report file. */
7878 char **stderr_commented = &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1];
7879 insert_comments (temp_stderr_files[RETRY_ICE_ATTEMPTS - 1],
7880 *stderr_commented);
7882 /* In final attempt we append compiler options and preprocesssed code to last
7883 generated .out file with configuration and backtrace. */
7884 char **err = &temp_stderr_files[RETRY_ICE_ATTEMPTS - 1];
7885 do_report_bug (new_argv, nargs, stderr_commented, err);
7888 out:
7889 for (i = 0; i < RETRY_ICE_ATTEMPTS * 2; i++)
7890 if (temp_files[i])
7892 unlink (temp_stdout_files[i]);
7893 free (temp_stdout_files[i]);
7897 /* Search for a file named NAME trying various prefixes including the
7898 user's -B prefix and some standard ones.
7899 Return the absolute file name found. If nothing is found, return NAME. */
7901 static const char *
7902 find_file (const char *name)
7904 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
7905 return newname ? newname : name;
7908 /* Determine whether a directory exists. If LINKER, return 0 for
7909 certain fixed names not needed by the linker. */
7911 static int
7912 is_directory (const char *path1, bool linker)
7914 int len1;
7915 char *path;
7916 char *cp;
7917 struct stat st;
7919 /* Ensure the string ends with "/.". The resulting path will be a
7920 directory even if the given path is a symbolic link. */
7921 len1 = strlen (path1);
7922 path = (char *) alloca (3 + len1);
7923 memcpy (path, path1, len1);
7924 cp = path + len1;
7925 if (!IS_DIR_SEPARATOR (cp[-1]))
7926 *cp++ = DIR_SEPARATOR;
7927 *cp++ = '.';
7928 *cp = '\0';
7930 /* Exclude directories that the linker is known to search. */
7931 if (linker
7932 && IS_DIR_SEPARATOR (path[0])
7933 && ((cp - path == 6
7934 && filename_ncmp (path + 1, "lib", 3) == 0)
7935 || (cp - path == 10
7936 && filename_ncmp (path + 1, "usr", 3) == 0
7937 && IS_DIR_SEPARATOR (path[4])
7938 && filename_ncmp (path + 5, "lib", 3) == 0)))
7939 return 0;
7941 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
7944 /* Set up the various global variables to indicate that we're processing
7945 the input file named FILENAME. */
7947 void
7948 set_input (const char *filename)
7950 const char *p;
7952 gcc_input_filename = filename;
7953 input_filename_length = strlen (gcc_input_filename);
7954 input_basename = lbasename (gcc_input_filename);
7956 /* Find a suffix starting with the last period,
7957 and set basename_length to exclude that suffix. */
7958 basename_length = strlen (input_basename);
7959 suffixed_basename_length = basename_length;
7960 p = input_basename + basename_length;
7961 while (p != input_basename && *p != '.')
7962 --p;
7963 if (*p == '.' && p != input_basename)
7965 basename_length = p - input_basename;
7966 input_suffix = p + 1;
7968 else
7969 input_suffix = "";
7971 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
7972 we will need to do a stat on the gcc_input_filename. The
7973 INPUT_STAT_SET signals that the stat is needed. */
7974 input_stat_set = 0;
7977 /* On fatal signals, delete all the temporary files. */
7979 static void
7980 fatal_signal (int signum)
7982 signal (signum, SIG_DFL);
7983 delete_failure_queue ();
7984 delete_temp_files ();
7985 /* Get the same signal again, this time not handled,
7986 so its normal effect occurs. */
7987 kill (getpid (), signum);
7990 /* Compare the contents of the two files named CMPFILE[0] and
7991 CMPFILE[1]. Return zero if they're identical, nonzero
7992 otherwise. */
7994 static int
7995 compare_files (char *cmpfile[])
7997 int ret = 0;
7998 FILE *temp[2] = { NULL, NULL };
7999 int i;
8001 #if HAVE_MMAP_FILE
8003 size_t length[2];
8004 void *map[2] = { NULL, NULL };
8006 for (i = 0; i < 2; i++)
8008 struct stat st;
8010 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
8012 error ("%s: could not determine length of compare-debug file %s",
8013 gcc_input_filename, cmpfile[i]);
8014 ret = 1;
8015 break;
8018 length[i] = st.st_size;
8021 if (!ret && length[0] != length[1])
8023 error ("%s: %<-fcompare-debug%> failure (length)", gcc_input_filename);
8024 ret = 1;
8027 if (!ret)
8028 for (i = 0; i < 2; i++)
8030 int fd = open (cmpfile[i], O_RDONLY);
8031 if (fd < 0)
8033 error ("%s: could not open compare-debug file %s",
8034 gcc_input_filename, cmpfile[i]);
8035 ret = 1;
8036 break;
8039 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
8040 close (fd);
8042 if (map[i] == (void *) MAP_FAILED)
8044 ret = -1;
8045 break;
8049 if (!ret)
8051 if (memcmp (map[0], map[1], length[0]) != 0)
8053 error ("%s: %<-fcompare-debug%> failure", gcc_input_filename);
8054 ret = 1;
8058 for (i = 0; i < 2; i++)
8059 if (map[i])
8060 munmap ((caddr_t) map[i], length[i]);
8062 if (ret >= 0)
8063 return ret;
8065 ret = 0;
8067 #endif
8069 for (i = 0; i < 2; i++)
8071 temp[i] = fopen (cmpfile[i], "r");
8072 if (!temp[i])
8074 error ("%s: could not open compare-debug file %s",
8075 gcc_input_filename, cmpfile[i]);
8076 ret = 1;
8077 break;
8081 if (!ret && temp[0] && temp[1])
8082 for (;;)
8084 int c0, c1;
8085 c0 = fgetc (temp[0]);
8086 c1 = fgetc (temp[1]);
8088 if (c0 != c1)
8090 error ("%s: %<-fcompare-debug%> failure",
8091 gcc_input_filename);
8092 ret = 1;
8093 break;
8096 if (c0 == EOF)
8097 break;
8100 for (i = 1; i >= 0; i--)
8102 if (temp[i])
8103 fclose (temp[i]);
8106 return ret;
8109 driver::driver (bool can_finalize, bool debug) :
8110 explicit_link_files (NULL),
8111 decoded_options (NULL)
8113 env.init (can_finalize, debug);
8116 driver::~driver ()
8118 XDELETEVEC (explicit_link_files);
8119 XDELETEVEC (decoded_options);
8122 /* driver::main is implemented as a series of driver:: method calls. */
8125 driver::main (int argc, char **argv)
8127 bool early_exit;
8129 set_progname (argv[0]);
8130 expand_at_files (&argc, &argv);
8131 decode_argv (argc, const_cast <const char **> (argv));
8132 global_initializations ();
8133 build_multilib_strings ();
8134 set_up_specs ();
8135 putenv_COLLECT_AS_OPTIONS (assembler_options);
8136 putenv_COLLECT_GCC (argv[0]);
8137 maybe_putenv_COLLECT_LTO_WRAPPER ();
8138 maybe_putenv_OFFLOAD_TARGETS ();
8139 handle_unrecognized_options ();
8141 if (completion)
8143 m_option_proposer.suggest_completion (completion);
8144 return 0;
8147 if (!maybe_print_and_exit ())
8148 return 0;
8150 early_exit = prepare_infiles ();
8151 if (early_exit)
8152 return get_exit_code ();
8154 do_spec_on_infiles ();
8155 maybe_run_linker (argv[0]);
8156 final_actions ();
8157 return get_exit_code ();
8160 /* Locate the final component of argv[0] after any leading path, and set
8161 the program name accordingly. */
8163 void
8164 driver::set_progname (const char *argv0) const
8166 const char *p = argv0 + strlen (argv0);
8167 while (p != argv0 && !IS_DIR_SEPARATOR (p[-1]))
8168 --p;
8169 progname = p;
8171 xmalloc_set_program_name (progname);
8174 /* Expand any @ files within the command-line args,
8175 setting at_file_supplied if any were expanded. */
8177 void
8178 driver::expand_at_files (int *argc, char ***argv) const
8180 char **old_argv = *argv;
8182 expandargv (argc, argv);
8184 /* Determine if any expansions were made. */
8185 if (*argv != old_argv)
8186 at_file_supplied = true;
8189 /* Decode the command-line arguments from argc/argv into the
8190 decoded_options array. */
8192 void
8193 driver::decode_argv (int argc, const char **argv)
8195 init_opts_obstack ();
8196 init_options_struct (&global_options, &global_options_set);
8198 decode_cmdline_options_to_array (argc, argv,
8199 CL_DRIVER,
8200 &decoded_options, &decoded_options_count);
8203 /* Perform various initializations and setup. */
8205 void
8206 driver::global_initializations ()
8208 /* Unlock the stdio streams. */
8209 unlock_std_streams ();
8211 gcc_init_libintl ();
8213 diagnostic_initialize (global_dc, 0);
8214 diagnostic_color_init (global_dc);
8215 diagnostic_urls_init (global_dc);
8217 #ifdef GCC_DRIVER_HOST_INITIALIZATION
8218 /* Perform host dependent initialization when needed. */
8219 GCC_DRIVER_HOST_INITIALIZATION;
8220 #endif
8222 if (atexit (delete_temp_files) != 0)
8223 fatal_error (input_location, "atexit failed");
8225 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
8226 signal (SIGINT, fatal_signal);
8227 #ifdef SIGHUP
8228 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
8229 signal (SIGHUP, fatal_signal);
8230 #endif
8231 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
8232 signal (SIGTERM, fatal_signal);
8233 #ifdef SIGPIPE
8234 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
8235 signal (SIGPIPE, fatal_signal);
8236 #endif
8237 #ifdef SIGCHLD
8238 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
8239 receive the signal. A different setting is inheritable */
8240 signal (SIGCHLD, SIG_DFL);
8241 #endif
8243 /* Parsing and gimplification sometimes need quite large stack.
8244 Increase stack size limits if possible. */
8245 stack_limit_increase (64 * 1024 * 1024);
8247 /* Allocate the argument vector. */
8248 alloc_args ();
8250 obstack_init (&obstack);
8253 /* Build multilib_select, et. al from the separate lines that make up each
8254 multilib selection. */
8256 void
8257 driver::build_multilib_strings () const
8260 const char *p;
8261 const char *const *q = multilib_raw;
8262 int need_space;
8264 obstack_init (&multilib_obstack);
8265 while ((p = *q++) != (char *) 0)
8266 obstack_grow (&multilib_obstack, p, strlen (p));
8268 obstack_1grow (&multilib_obstack, 0);
8269 multilib_select = XOBFINISH (&multilib_obstack, const char *);
8271 q = multilib_matches_raw;
8272 while ((p = *q++) != (char *) 0)
8273 obstack_grow (&multilib_obstack, p, strlen (p));
8275 obstack_1grow (&multilib_obstack, 0);
8276 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
8278 q = multilib_exclusions_raw;
8279 while ((p = *q++) != (char *) 0)
8280 obstack_grow (&multilib_obstack, p, strlen (p));
8282 obstack_1grow (&multilib_obstack, 0);
8283 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
8285 q = multilib_reuse_raw;
8286 while ((p = *q++) != (char *) 0)
8287 obstack_grow (&multilib_obstack, p, strlen (p));
8289 obstack_1grow (&multilib_obstack, 0);
8290 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
8292 need_space = FALSE;
8293 for (size_t i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
8295 if (need_space)
8296 obstack_1grow (&multilib_obstack, ' ');
8297 obstack_grow (&multilib_obstack,
8298 multilib_defaults_raw[i],
8299 strlen (multilib_defaults_raw[i]));
8300 need_space = TRUE;
8303 obstack_1grow (&multilib_obstack, 0);
8304 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
8308 /* Set up the spec-handling machinery. */
8310 void
8311 driver::set_up_specs () const
8313 const char *spec_machine_suffix;
8314 char *specs_file;
8315 size_t i;
8317 #ifdef INIT_ENVIRONMENT
8318 /* Set up any other necessary machine specific environment variables. */
8319 xputenv (INIT_ENVIRONMENT);
8320 #endif
8322 /* Make a table of what switches there are (switches, n_switches).
8323 Make a table of specified input files (infiles, n_infiles).
8324 Decode switches that are handled locally. */
8326 process_command (decoded_options_count, decoded_options);
8328 /* Initialize the vector of specs to just the default.
8329 This means one element containing 0s, as a terminator. */
8331 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
8332 memcpy (compilers, default_compilers, sizeof default_compilers);
8333 n_compilers = n_default_compilers;
8335 /* Read specs from a file if there is one. */
8337 machine_suffix = concat (spec_host_machine, dir_separator_str, spec_version,
8338 accel_dir_suffix, dir_separator_str, NULL);
8339 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
8341 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
8342 /* Read the specs file unless it is a default one. */
8343 if (specs_file != 0 && strcmp (specs_file, "specs"))
8344 read_specs (specs_file, true, false);
8345 else
8346 init_spec ();
8348 #ifdef ACCEL_COMPILER
8349 spec_machine_suffix = machine_suffix;
8350 #else
8351 spec_machine_suffix = just_machine_suffix;
8352 #endif
8354 /* We need to check standard_exec_prefix/spec_machine_suffix/specs
8355 for any override of as, ld and libraries. */
8356 specs_file = (char *) alloca (strlen (standard_exec_prefix)
8357 + strlen (spec_machine_suffix) + sizeof ("specs"));
8358 strcpy (specs_file, standard_exec_prefix);
8359 strcat (specs_file, spec_machine_suffix);
8360 strcat (specs_file, "specs");
8361 if (access (specs_file, R_OK) == 0)
8362 read_specs (specs_file, true, false);
8364 /* Process any configure-time defaults specified for the command line
8365 options, via OPTION_DEFAULT_SPECS. */
8366 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
8367 do_option_spec (option_default_specs[i].name,
8368 option_default_specs[i].spec);
8370 /* Process DRIVER_SELF_SPECS, adding any new options to the end
8371 of the command line. */
8373 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
8374 do_self_spec (driver_self_specs[i]);
8376 /* If not cross-compiling, look for executables in the standard
8377 places. */
8378 if (*cross_compile == '0')
8380 if (*md_exec_prefix)
8382 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
8383 PREFIX_PRIORITY_LAST, 0, 0);
8387 /* Process sysroot_suffix_spec. */
8388 if (*sysroot_suffix_spec != 0
8389 && !no_sysroot_suffix
8390 && do_spec_2 (sysroot_suffix_spec, NULL) == 0)
8392 if (argbuf.length () > 1)
8393 error ("spec failure: more than one argument to "
8394 "%<SYSROOT_SUFFIX_SPEC%>");
8395 else if (argbuf.length () == 1)
8396 target_sysroot_suffix = xstrdup (argbuf.last ());
8399 #ifdef HAVE_LD_SYSROOT
8400 /* Pass the --sysroot option to the linker, if it supports that. If
8401 there is a sysroot_suffix_spec, it has already been processed by
8402 this point, so target_system_root really is the system root we
8403 should be using. */
8404 if (target_system_root)
8406 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
8407 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
8408 set_spec ("link", XOBFINISH (&obstack, const char *), false);
8410 #endif
8412 /* Process sysroot_hdrs_suffix_spec. */
8413 if (*sysroot_hdrs_suffix_spec != 0
8414 && !no_sysroot_suffix
8415 && do_spec_2 (sysroot_hdrs_suffix_spec, NULL) == 0)
8417 if (argbuf.length () > 1)
8418 error ("spec failure: more than one argument "
8419 "to %<SYSROOT_HEADERS_SUFFIX_SPEC%>");
8420 else if (argbuf.length () == 1)
8421 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
8424 /* Look for startfiles in the standard places. */
8425 if (*startfile_prefix_spec != 0
8426 && do_spec_2 (startfile_prefix_spec, NULL) == 0
8427 && do_spec_1 (" ", 0, NULL) == 0)
8429 for (const char *arg : argbuf)
8430 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
8431 PREFIX_PRIORITY_LAST, 0, 1);
8433 /* We should eventually get rid of all these and stick to
8434 startfile_prefix_spec exclusively. */
8435 else if (*cross_compile == '0' || target_system_root)
8437 if (*md_startfile_prefix)
8438 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
8439 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
8441 if (*md_startfile_prefix_1)
8442 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
8443 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
8445 /* If standard_startfile_prefix is relative, base it on
8446 standard_exec_prefix. This lets us move the installed tree
8447 as a unit. If GCC_EXEC_PREFIX is defined, base
8448 standard_startfile_prefix on that as well.
8450 If the prefix is relative, only search it for native compilers;
8451 otherwise we will search a directory containing host libraries. */
8452 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
8453 add_sysrooted_prefix (&startfile_prefixes,
8454 standard_startfile_prefix, "BINUTILS",
8455 PREFIX_PRIORITY_LAST, 0, 1);
8456 else if (*cross_compile == '0')
8458 add_prefix (&startfile_prefixes,
8459 concat (gcc_exec_prefix
8460 ? gcc_exec_prefix : standard_exec_prefix,
8461 machine_suffix,
8462 standard_startfile_prefix, NULL),
8463 NULL, PREFIX_PRIORITY_LAST, 0, 1);
8466 /* Sysrooted prefixes are relocated because target_system_root is
8467 also relocated by gcc_exec_prefix. */
8468 if (*standard_startfile_prefix_1)
8469 add_sysrooted_prefix (&startfile_prefixes,
8470 standard_startfile_prefix_1, "BINUTILS",
8471 PREFIX_PRIORITY_LAST, 0, 1);
8472 if (*standard_startfile_prefix_2)
8473 add_sysrooted_prefix (&startfile_prefixes,
8474 standard_startfile_prefix_2, "BINUTILS",
8475 PREFIX_PRIORITY_LAST, 0, 1);
8478 /* Process any user specified specs in the order given on the command
8479 line. */
8480 for (struct user_specs *uptr = user_specs_head; uptr; uptr = uptr->next)
8482 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
8483 R_OK, true);
8484 read_specs (filename ? filename : uptr->filename, false, true);
8487 /* Process any user self specs. */
8489 struct spec_list *sl;
8490 for (sl = specs; sl; sl = sl->next)
8491 if (sl->name_len == sizeof "self_spec" - 1
8492 && !strcmp (sl->name, "self_spec"))
8493 do_self_spec (*sl->ptr_spec);
8496 if (compare_debug)
8498 enum save_temps save;
8500 if (!compare_debug_second)
8502 n_switches_debug_check[1] = n_switches;
8503 n_switches_alloc_debug_check[1] = n_switches_alloc;
8504 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
8505 n_switches_alloc);
8507 do_self_spec ("%:compare-debug-self-opt()");
8508 n_switches_debug_check[0] = n_switches;
8509 n_switches_alloc_debug_check[0] = n_switches_alloc;
8510 switches_debug_check[0] = switches;
8512 n_switches = n_switches_debug_check[1];
8513 n_switches_alloc = n_switches_alloc_debug_check[1];
8514 switches = switches_debug_check[1];
8517 /* Avoid crash when computing %j in this early. */
8518 save = save_temps_flag;
8519 save_temps_flag = SAVE_TEMPS_NONE;
8521 compare_debug = -compare_debug;
8522 do_self_spec ("%:compare-debug-self-opt()");
8524 save_temps_flag = save;
8526 if (!compare_debug_second)
8528 n_switches_debug_check[1] = n_switches;
8529 n_switches_alloc_debug_check[1] = n_switches_alloc;
8530 switches_debug_check[1] = switches;
8531 compare_debug = -compare_debug;
8532 n_switches = n_switches_debug_check[0];
8533 n_switches_alloc = n_switches_debug_check[0];
8534 switches = switches_debug_check[0];
8539 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
8540 if (gcc_exec_prefix)
8541 gcc_exec_prefix = concat (gcc_exec_prefix, spec_host_machine,
8542 dir_separator_str, spec_version,
8543 accel_dir_suffix, dir_separator_str, NULL);
8545 /* Now we have the specs.
8546 Set the `valid' bits for switches that match anything in any spec. */
8548 validate_all_switches ();
8550 /* Now that we have the switches and the specs, set
8551 the subdirectory based on the options. */
8552 set_multilib_dir ();
8555 /* Set up to remember the pathname of gcc and any options
8556 needed for collect. We use argv[0] instead of progname because
8557 we need the complete pathname. */
8559 void
8560 driver::putenv_COLLECT_GCC (const char *argv0) const
8562 obstack_init (&collect_obstack);
8563 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
8564 obstack_grow (&collect_obstack, argv0, strlen (argv0) + 1);
8565 xputenv (XOBFINISH (&collect_obstack, char *));
8568 /* Set up to remember the pathname of the lto wrapper. */
8570 void
8571 driver::maybe_putenv_COLLECT_LTO_WRAPPER () const
8573 char *lto_wrapper_file;
8575 if (have_c)
8576 lto_wrapper_file = NULL;
8577 else
8578 lto_wrapper_file = find_a_program ("lto-wrapper");
8579 if (lto_wrapper_file)
8581 lto_wrapper_file = convert_white_space (lto_wrapper_file);
8582 set_static_spec_owned (&lto_wrapper_spec, lto_wrapper_file);
8583 obstack_init (&collect_obstack);
8584 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
8585 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
8586 obstack_grow (&collect_obstack, lto_wrapper_spec,
8587 strlen (lto_wrapper_spec) + 1);
8588 xputenv (XOBFINISH (&collect_obstack, char *));
8593 /* Set up to remember the names of offload targets. */
8595 void
8596 driver::maybe_putenv_OFFLOAD_TARGETS () const
8598 if (offload_targets && offload_targets[0] != '\0')
8600 obstack_grow (&collect_obstack, "OFFLOAD_TARGET_NAMES=",
8601 sizeof ("OFFLOAD_TARGET_NAMES=") - 1);
8602 obstack_grow (&collect_obstack, offload_targets,
8603 strlen (offload_targets) + 1);
8604 xputenv (XOBFINISH (&collect_obstack, char *));
8605 #if OFFLOAD_DEFAULTED
8606 if (offload_targets_default)
8607 xputenv ("OFFLOAD_TARGET_DEFAULT=1");
8608 #endif
8611 free (offload_targets);
8612 offload_targets = NULL;
8615 /* Reject switches that no pass was interested in. */
8617 void
8618 driver::handle_unrecognized_options ()
8620 for (size_t i = 0; (int) i < n_switches; i++)
8621 if (! switches[i].validated)
8623 const char *hint = m_option_proposer.suggest_option (switches[i].part1);
8624 if (hint)
8625 error ("unrecognized command-line option %<-%s%>;"
8626 " did you mean %<-%s%>?",
8627 switches[i].part1, hint);
8628 else
8629 error ("unrecognized command-line option %<-%s%>",
8630 switches[i].part1);
8634 /* Handle the various -print-* options, returning 0 if the driver
8635 should exit, or nonzero if the driver should continue. */
8638 driver::maybe_print_and_exit () const
8640 if (print_search_dirs)
8642 printf (_("install: %s%s\n"),
8643 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
8644 gcc_exec_prefix ? "" : machine_suffix);
8645 printf (_("programs: %s\n"),
8646 build_search_list (&exec_prefixes, "", false, false));
8647 printf (_("libraries: %s\n"),
8648 build_search_list (&startfile_prefixes, "", false, true));
8649 return (0);
8652 if (print_file_name)
8654 printf ("%s\n", find_file (print_file_name));
8655 return (0);
8658 if (print_prog_name)
8660 if (use_ld != NULL && ! strcmp (print_prog_name, "ld"))
8662 /* Append USE_LD to the default linker. */
8663 #ifdef DEFAULT_LINKER
8664 char *ld;
8665 # ifdef HAVE_HOST_EXECUTABLE_SUFFIX
8666 int len = (sizeof (DEFAULT_LINKER)
8667 - sizeof (HOST_EXECUTABLE_SUFFIX));
8668 ld = NULL;
8669 if (len > 0)
8671 char *default_linker = xstrdup (DEFAULT_LINKER);
8672 /* Strip HOST_EXECUTABLE_SUFFIX if DEFAULT_LINKER contains
8673 HOST_EXECUTABLE_SUFFIX. */
8674 if (! strcmp (&default_linker[len], HOST_EXECUTABLE_SUFFIX))
8676 default_linker[len] = '\0';
8677 ld = concat (default_linker, use_ld,
8678 HOST_EXECUTABLE_SUFFIX, NULL);
8681 if (ld == NULL)
8682 # endif
8683 ld = concat (DEFAULT_LINKER, use_ld, NULL);
8684 if (access (ld, X_OK) == 0)
8686 printf ("%s\n", ld);
8687 return (0);
8689 #endif
8690 print_prog_name = concat (print_prog_name, use_ld, NULL);
8692 char *newname = find_a_program (print_prog_name);
8693 printf ("%s\n", (newname ? newname : print_prog_name));
8694 return (0);
8697 if (print_multi_lib)
8699 print_multilib_info ();
8700 return (0);
8703 if (print_multi_directory)
8705 if (multilib_dir == NULL)
8706 printf (".\n");
8707 else
8708 printf ("%s\n", multilib_dir);
8709 return (0);
8712 if (print_multiarch)
8714 if (multiarch_dir == NULL)
8715 printf ("\n");
8716 else
8717 printf ("%s\n", multiarch_dir);
8718 return (0);
8721 if (print_sysroot)
8723 if (target_system_root)
8725 if (target_sysroot_suffix)
8726 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
8727 else
8728 printf ("%s\n", target_system_root);
8730 return (0);
8733 if (print_multi_os_directory)
8735 if (multilib_os_dir == NULL)
8736 printf (".\n");
8737 else
8738 printf ("%s\n", multilib_os_dir);
8739 return (0);
8742 if (print_sysroot_headers_suffix)
8744 if (*sysroot_hdrs_suffix_spec)
8746 printf("%s\n", (target_sysroot_hdrs_suffix
8747 ? target_sysroot_hdrs_suffix
8748 : ""));
8749 return (0);
8751 else
8752 /* The error status indicates that only one set of fixed
8753 headers should be built. */
8754 fatal_error (input_location,
8755 "not configured with sysroot headers suffix");
8758 if (print_help_list)
8760 display_help ();
8762 if (! verbose_flag)
8764 printf (_("\nFor bug reporting instructions, please see:\n"));
8765 printf ("%s.\n", bug_report_url);
8767 return (0);
8770 /* We do not exit here. Instead we have created a fake input file
8771 called 'help-dummy' which needs to be compiled, and we pass this
8772 on the various sub-processes, along with the --help switch.
8773 Ensure their output appears after ours. */
8774 fputc ('\n', stdout);
8775 fflush (stdout);
8778 if (print_version)
8780 printf (_("%s %s%s\n"), progname, pkgversion_string,
8781 version_string);
8782 printf ("Copyright %s 2022 Free Software Foundation, Inc.\n",
8783 _("(C)"));
8784 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
8785 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
8786 stdout);
8787 if (! verbose_flag)
8788 return 0;
8790 /* We do not exit here. We use the same mechanism of --help to print
8791 the version of the sub-processes. */
8792 fputc ('\n', stdout);
8793 fflush (stdout);
8796 if (verbose_flag)
8798 print_configuration (stderr);
8799 if (n_infiles == 0)
8800 return (0);
8803 return 1;
8806 /* Figure out what to do with each input file.
8807 Return true if we need to exit early from "main", false otherwise. */
8809 bool
8810 driver::prepare_infiles ()
8812 size_t i;
8813 int lang_n_infiles = 0;
8815 if (n_infiles == added_libraries)
8816 fatal_error (input_location, "no input files");
8818 if (seen_error ())
8819 /* Early exit needed from main. */
8820 return true;
8822 /* Make a place to record the compiler output file names
8823 that correspond to the input files. */
8825 i = n_infiles;
8826 i += lang_specific_extra_outfiles;
8827 outfiles = XCNEWVEC (const char *, i);
8829 /* Record which files were specified explicitly as link input. */
8831 explicit_link_files = XCNEWVEC (char, n_infiles);
8833 combine_inputs = have_o || flag_wpa;
8835 for (i = 0; (int) i < n_infiles; i++)
8837 const char *name = infiles[i].name;
8838 struct compiler *compiler = lookup_compiler (name,
8839 strlen (name),
8840 infiles[i].language);
8842 if (compiler && !(compiler->combinable))
8843 combine_inputs = false;
8845 if (lang_n_infiles > 0 && compiler != input_file_compiler
8846 && infiles[i].language && infiles[i].language[0] != '*')
8847 infiles[i].incompiler = compiler;
8848 else if (compiler)
8850 lang_n_infiles++;
8851 input_file_compiler = compiler;
8852 infiles[i].incompiler = compiler;
8854 else
8856 /* Since there is no compiler for this input file, assume it is a
8857 linker file. */
8858 explicit_link_files[i] = 1;
8859 infiles[i].incompiler = NULL;
8861 infiles[i].compiled = false;
8862 infiles[i].preprocessed = false;
8865 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
8866 fatal_error (input_location,
8867 "cannot specify %<-o%> with %<-c%>, %<-S%> or %<-E%> "
8868 "with multiple files");
8870 /* No early exit needed from main; we can continue. */
8871 return false;
8874 /* Run the spec machinery on each input file. */
8876 void
8877 driver::do_spec_on_infiles () const
8879 size_t i;
8881 for (i = 0; (int) i < n_infiles; i++)
8883 int this_file_error = 0;
8885 /* Tell do_spec what to substitute for %i. */
8887 input_file_number = i;
8888 set_input (infiles[i].name);
8890 if (infiles[i].compiled)
8891 continue;
8893 /* Use the same thing in %o, unless cp->spec says otherwise. */
8895 outfiles[i] = gcc_input_filename;
8897 /* Figure out which compiler from the file's suffix. */
8899 input_file_compiler
8900 = lookup_compiler (infiles[i].name, input_filename_length,
8901 infiles[i].language);
8903 if (input_file_compiler)
8905 /* Ok, we found an applicable compiler. Run its spec. */
8907 if (input_file_compiler->spec[0] == '#')
8909 error ("%s: %s compiler not installed on this system",
8910 gcc_input_filename, &input_file_compiler->spec[1]);
8911 this_file_error = 1;
8913 else
8915 int value;
8917 if (compare_debug)
8919 free (debug_check_temp_file[0]);
8920 debug_check_temp_file[0] = NULL;
8922 free (debug_check_temp_file[1]);
8923 debug_check_temp_file[1] = NULL;
8926 value = do_spec (input_file_compiler->spec);
8927 infiles[i].compiled = true;
8928 if (value < 0)
8929 this_file_error = 1;
8930 else if (compare_debug && debug_check_temp_file[0])
8932 if (verbose_flag)
8933 inform (UNKNOWN_LOCATION,
8934 "recompiling with %<-fcompare-debug%>");
8936 compare_debug = -compare_debug;
8937 n_switches = n_switches_debug_check[1];
8938 n_switches_alloc = n_switches_alloc_debug_check[1];
8939 switches = switches_debug_check[1];
8941 value = do_spec (input_file_compiler->spec);
8943 compare_debug = -compare_debug;
8944 n_switches = n_switches_debug_check[0];
8945 n_switches_alloc = n_switches_alloc_debug_check[0];
8946 switches = switches_debug_check[0];
8948 if (value < 0)
8950 error ("during %<-fcompare-debug%> recompilation");
8951 this_file_error = 1;
8954 gcc_assert (debug_check_temp_file[1]
8955 && filename_cmp (debug_check_temp_file[0],
8956 debug_check_temp_file[1]));
8958 if (verbose_flag)
8959 inform (UNKNOWN_LOCATION, "comparing final insns dumps");
8961 if (compare_files (debug_check_temp_file))
8962 this_file_error = 1;
8965 if (compare_debug)
8967 free (debug_check_temp_file[0]);
8968 debug_check_temp_file[0] = NULL;
8970 free (debug_check_temp_file[1]);
8971 debug_check_temp_file[1] = NULL;
8976 /* If this file's name does not contain a recognized suffix,
8977 record it as explicit linker input. */
8979 else
8980 explicit_link_files[i] = 1;
8982 /* Clear the delete-on-failure queue, deleting the files in it
8983 if this compilation failed. */
8985 if (this_file_error)
8987 delete_failure_queue ();
8988 errorcount++;
8990 /* If this compilation succeeded, don't delete those files later. */
8991 clear_failure_queue ();
8994 /* Reset the input file name to the first compile/object file name, for use
8995 with %b in LINK_SPEC. We use the first input file that we can find
8996 a compiler to compile it instead of using infiles.language since for
8997 languages other than C we use aliases that we then lookup later. */
8998 if (n_infiles > 0)
9000 int i;
9002 for (i = 0; i < n_infiles ; i++)
9003 if (infiles[i].incompiler
9004 || (infiles[i].language && infiles[i].language[0] != '*'))
9006 set_input (infiles[i].name);
9007 break;
9011 if (!seen_error ())
9013 /* Make sure INPUT_FILE_NUMBER points to first available open
9014 slot. */
9015 input_file_number = n_infiles;
9016 if (lang_specific_pre_link ())
9017 errorcount++;
9021 /* If we have to run the linker, do it now. */
9023 void
9024 driver::maybe_run_linker (const char *argv0) const
9026 size_t i;
9027 int linker_was_run = 0;
9028 int num_linker_inputs;
9030 /* Determine if there are any linker input files. */
9031 num_linker_inputs = 0;
9032 for (i = 0; (int) i < n_infiles; i++)
9033 if (explicit_link_files[i] || outfiles[i] != NULL)
9034 num_linker_inputs++;
9036 /* Arrange for temporary file names created during linking to take
9037 on names related with the linker output rather than with the
9038 inputs when appropriate. */
9039 if (outbase && *outbase)
9041 if (dumpdir)
9043 char *tofree = dumpdir;
9044 gcc_checking_assert (strlen (dumpdir) == dumpdir_length);
9045 dumpdir = concat (dumpdir, outbase, ".", NULL);
9046 free (tofree);
9048 else
9049 dumpdir = concat (outbase, ".", NULL);
9050 dumpdir_length += strlen (outbase) + 1;
9051 dumpdir_trailing_dash_added = true;
9053 else if (dumpdir_trailing_dash_added)
9055 gcc_assert (dumpdir[dumpdir_length - 1] == '-');
9056 dumpdir[dumpdir_length - 1] = '.';
9059 if (dumpdir_trailing_dash_added)
9061 gcc_assert (dumpdir_length > 0);
9062 gcc_assert (dumpdir[dumpdir_length - 1] == '.');
9063 dumpdir_length--;
9066 free (outbase);
9067 input_basename = outbase = NULL;
9068 outbase_length = suffixed_basename_length = basename_length = 0;
9070 /* Run ld to link all the compiler output files. */
9072 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
9074 int tmp = execution_count;
9076 detect_jobserver ();
9078 if (! have_c)
9080 #if HAVE_LTO_PLUGIN > 0
9081 #if HAVE_LTO_PLUGIN == 2
9082 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
9083 #else
9084 const char *fuse_linker_plugin = "fuse-linker-plugin";
9085 #endif
9086 #endif
9088 /* We'll use ld if we can't find collect2. */
9089 if (! strcmp (linker_name_spec, "collect2"))
9091 char *s = find_a_program ("collect2");
9092 if (s == NULL)
9093 set_static_spec_shared (&linker_name_spec, "ld");
9096 #if HAVE_LTO_PLUGIN > 0
9097 #if HAVE_LTO_PLUGIN == 2
9098 if (!switch_matches (fno_use_linker_plugin,
9099 fno_use_linker_plugin
9100 + strlen (fno_use_linker_plugin), 0))
9101 #else
9102 if (switch_matches (fuse_linker_plugin,
9103 fuse_linker_plugin
9104 + strlen (fuse_linker_plugin), 0))
9105 #endif
9107 char *temp_spec = find_a_file (&exec_prefixes,
9108 LTOPLUGINSONAME, R_OK,
9109 false);
9110 if (!temp_spec)
9111 fatal_error (input_location,
9112 "%<-fuse-linker-plugin%>, but %s not found",
9113 LTOPLUGINSONAME);
9114 linker_plugin_file_spec = convert_white_space (temp_spec);
9116 #endif
9117 set_static_spec_shared (&lto_gcc_spec, argv0);
9120 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
9121 for collect. */
9122 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
9123 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
9125 if (print_subprocess_help == 1)
9127 printf (_("\nLinker options\n==============\n\n"));
9128 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
9129 " to the linker.\n\n"));
9130 fflush (stdout);
9132 int value = do_spec (link_command_spec);
9133 if (value < 0)
9134 errorcount = 1;
9135 linker_was_run = (tmp != execution_count);
9138 /* If options said don't run linker,
9139 complain about input files to be given to the linker. */
9141 if (! linker_was_run && !seen_error ())
9142 for (i = 0; (int) i < n_infiles; i++)
9143 if (explicit_link_files[i]
9144 && !(infiles[i].language && infiles[i].language[0] == '*'))
9146 warning (0, "%s: linker input file unused because linking not done",
9147 outfiles[i]);
9148 if (access (outfiles[i], F_OK) < 0)
9149 /* This is can be an indication the user specifed an errorneous
9150 separated option value, (or used the wrong prefix for an
9151 option). */
9152 error ("%s: linker input file not found: %m", outfiles[i]);
9156 /* The end of "main". */
9158 void
9159 driver::final_actions () const
9161 /* Delete some or all of the temporary files we made. */
9163 if (seen_error ())
9164 delete_failure_queue ();
9165 delete_temp_files ();
9167 if (print_help_list)
9169 printf (("\nFor bug reporting instructions, please see:\n"));
9170 printf ("%s\n", bug_report_url);
9174 /* Detect whether jobserver is active and working. If not drop
9175 --jobserver-auth from MAKEFLAGS. */
9177 void
9178 driver::detect_jobserver () const
9180 /* Detect jobserver and drop it if it's not working. */
9181 const char *makeflags = env.get ("MAKEFLAGS");
9182 if (makeflags != NULL)
9184 const char *needle = "--jobserver-auth=";
9185 const char *n = strstr (makeflags, needle);
9186 if (n != NULL)
9188 int rfd = -1;
9189 int wfd = -1;
9191 bool jobserver
9192 = (sscanf (n + strlen (needle), "%d,%d", &rfd, &wfd) == 2
9193 && rfd > 0
9194 && wfd > 0
9195 && is_valid_fd (rfd)
9196 && is_valid_fd (wfd));
9198 /* Drop the jobserver if it's not working now. */
9199 if (!jobserver)
9201 unsigned offset = n - makeflags;
9202 char *dup = xstrdup (makeflags);
9203 dup[offset] = '\0';
9205 const char *space = strchr (makeflags + offset, ' ');
9206 if (space != NULL)
9207 strcpy (dup + offset, space);
9208 xputenv (concat ("MAKEFLAGS=", dup, NULL));
9214 /* Determine what the exit code of the driver should be. */
9217 driver::get_exit_code () const
9219 return (signal_count != 0 ? 2
9220 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
9221 : 0);
9224 /* Find the proper compilation spec for the file name NAME,
9225 whose length is LENGTH. LANGUAGE is the specified language,
9226 or 0 if this file is to be passed to the linker. */
9228 static struct compiler *
9229 lookup_compiler (const char *name, size_t length, const char *language)
9231 struct compiler *cp;
9233 /* If this was specified by the user to be a linker input, indicate that. */
9234 if (language != 0 && language[0] == '*')
9235 return 0;
9237 /* Otherwise, look for the language, if one is spec'd. */
9238 if (language != 0)
9240 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
9241 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
9243 if (name != NULL && strcmp (name, "-") == 0
9244 && (strcmp (cp->suffix, "@c-header") == 0
9245 || strcmp (cp->suffix, "@c++-header") == 0)
9246 && !have_E)
9247 fatal_error (input_location,
9248 "cannot use %<-%> as input filename for a "
9249 "precompiled header");
9251 return cp;
9254 error ("language %s not recognized", language);
9255 return 0;
9258 /* Look for a suffix. */
9259 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
9261 if (/* The suffix `-' matches only the file name `-'. */
9262 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
9263 || (strlen (cp->suffix) < length
9264 /* See if the suffix matches the end of NAME. */
9265 && !strcmp (cp->suffix,
9266 name + length - strlen (cp->suffix))
9268 break;
9271 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
9272 /* Look again, but case-insensitively this time. */
9273 if (cp < compilers)
9274 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
9276 if (/* The suffix `-' matches only the file name `-'. */
9277 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
9278 || (strlen (cp->suffix) < length
9279 /* See if the suffix matches the end of NAME. */
9280 && ((!strcmp (cp->suffix,
9281 name + length - strlen (cp->suffix))
9282 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
9283 && !strcasecmp (cp->suffix,
9284 name + length - strlen (cp->suffix)))
9286 break;
9288 #endif
9290 if (cp >= compilers)
9292 if (cp->spec[0] != '@')
9293 /* A non-alias entry: return it. */
9294 return cp;
9296 /* An alias entry maps a suffix to a language.
9297 Search for the language; pass 0 for NAME and LENGTH
9298 to avoid infinite recursion if language not found. */
9299 return lookup_compiler (NULL, 0, cp->spec + 1);
9301 return 0;
9304 static char *
9305 save_string (const char *s, int len)
9307 char *result = XNEWVEC (char, len + 1);
9309 gcc_checking_assert (strlen (s) >= (unsigned int) len);
9310 memcpy (result, s, len);
9311 result[len] = 0;
9312 return result;
9316 static inline void
9317 validate_switches_from_spec (const char *spec, bool user)
9319 const char *p = spec;
9320 char c;
9321 while ((c = *p++))
9322 if (c == '%'
9323 && (*p == '{'
9324 || *p == '<'
9325 || (*p == 'W' && *++p == '{')
9326 || (*p == '@' && *++p == '{')))
9327 /* We have a switch spec. */
9328 p = validate_switches (p + 1, user, *p == '{');
9331 static void
9332 validate_all_switches (void)
9334 struct compiler *comp;
9335 struct spec_list *spec;
9337 for (comp = compilers; comp->spec; comp++)
9338 validate_switches_from_spec (comp->spec, false);
9340 /* Look through the linked list of specs read from the specs file. */
9341 for (spec = specs; spec; spec = spec->next)
9342 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
9344 validate_switches_from_spec (link_command_spec, false);
9347 /* Look at the switch-name that comes after START and mark as valid
9348 all supplied switches that match it. If BRACED, handle other
9349 switches after '|' and '&', and specs after ':' until ';' or '}',
9350 going back for more switches after ';'. Without BRACED, handle
9351 only one atom. Return a pointer to whatever follows the handled
9352 items, after the closing brace if BRACED. */
9354 static const char *
9355 validate_switches (const char *start, bool user_spec, bool braced)
9357 const char *p = start;
9358 const char *atom;
9359 size_t len;
9360 int i;
9361 bool suffix = false;
9362 bool starred = false;
9364 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
9366 next_member:
9367 SKIP_WHITE ();
9369 if (*p == '!')
9370 p++;
9372 SKIP_WHITE ();
9373 if (*p == '.' || *p == ',')
9374 suffix = true, p++;
9376 atom = p;
9377 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
9378 || *p == ',' || *p == '.' || *p == '@')
9379 p++;
9380 len = p - atom;
9382 if (*p == '*')
9383 starred = true, p++;
9385 SKIP_WHITE ();
9387 if (!suffix)
9389 /* Mark all matching switches as valid. */
9390 for (i = 0; i < n_switches; i++)
9391 if (!strncmp (switches[i].part1, atom, len)
9392 && (starred || switches[i].part1[len] == '\0')
9393 && (switches[i].known || user_spec))
9394 switches[i].validated = true;
9397 if (!braced)
9398 return p;
9400 if (*p) p++;
9401 if (*p && (p[-1] == '|' || p[-1] == '&'))
9402 goto next_member;
9404 if (*p && p[-1] == ':')
9406 while (*p && *p != ';' && *p != '}')
9408 if (*p == '%')
9410 p++;
9411 if (*p == '{' || *p == '<')
9412 p = validate_switches (p+1, user_spec, *p == '{');
9413 else if (p[0] == 'W' && p[1] == '{')
9414 p = validate_switches (p+2, user_spec, true);
9415 else if (p[0] == '@' && p[1] == '{')
9416 p = validate_switches (p+2, user_spec, true);
9418 else
9419 p++;
9422 if (*p) p++;
9423 if (*p && p[-1] == ';')
9424 goto next_member;
9427 return p;
9428 #undef SKIP_WHITE
9431 struct mdswitchstr
9433 const char *str;
9434 int len;
9437 static struct mdswitchstr *mdswitches;
9438 static int n_mdswitches;
9440 /* Check whether a particular argument was used. The first time we
9441 canonicalize the switches to keep only the ones we care about. */
9443 struct used_arg_t
9445 public:
9446 int operator () (const char *p, int len);
9447 void finalize ();
9449 private:
9450 struct mswitchstr
9452 const char *str;
9453 const char *replace;
9454 int len;
9455 int rep_len;
9458 mswitchstr *mswitches;
9459 int n_mswitches;
9463 used_arg_t used_arg;
9466 used_arg_t::operator () (const char *p, int len)
9468 int i, j;
9470 if (!mswitches)
9472 struct mswitchstr *matches;
9473 const char *q;
9474 int cnt = 0;
9476 /* Break multilib_matches into the component strings of string
9477 and replacement string. */
9478 for (q = multilib_matches; *q != '\0'; q++)
9479 if (*q == ';')
9480 cnt++;
9482 matches
9483 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
9484 i = 0;
9485 q = multilib_matches;
9486 while (*q != '\0')
9488 matches[i].str = q;
9489 while (*q != ' ')
9491 if (*q == '\0')
9493 invalid_matches:
9494 fatal_error (input_location, "multilib spec %qs is invalid",
9495 multilib_matches);
9497 q++;
9499 matches[i].len = q - matches[i].str;
9501 matches[i].replace = ++q;
9502 while (*q != ';' && *q != '\0')
9504 if (*q == ' ')
9505 goto invalid_matches;
9506 q++;
9508 matches[i].rep_len = q - matches[i].replace;
9509 i++;
9510 if (*q == ';')
9511 q++;
9514 /* Now build a list of the replacement string for switches that we care
9515 about. Make sure we allocate at least one entry. This prevents
9516 xmalloc from calling fatal, and prevents us from re-executing this
9517 block of code. */
9518 mswitches
9519 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
9520 for (i = 0; i < n_switches; i++)
9521 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
9523 int xlen = strlen (switches[i].part1);
9524 for (j = 0; j < cnt; j++)
9525 if (xlen == matches[j].len
9526 && ! strncmp (switches[i].part1, matches[j].str, xlen))
9528 mswitches[n_mswitches].str = matches[j].replace;
9529 mswitches[n_mswitches].len = matches[j].rep_len;
9530 mswitches[n_mswitches].replace = (char *) 0;
9531 mswitches[n_mswitches].rep_len = 0;
9532 n_mswitches++;
9533 break;
9537 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
9538 on the command line nor any options mutually incompatible with
9539 them. */
9540 for (i = 0; i < n_mdswitches; i++)
9542 const char *r;
9544 for (q = multilib_options; *q != '\0'; *q && q++)
9546 while (*q == ' ')
9547 q++;
9549 r = q;
9550 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
9551 || strchr (" /", q[mdswitches[i].len]) == NULL)
9553 while (*q != ' ' && *q != '/' && *q != '\0')
9554 q++;
9555 if (*q != '/')
9556 break;
9557 q++;
9560 if (*q != ' ' && *q != '\0')
9562 while (*r != ' ' && *r != '\0')
9564 q = r;
9565 while (*q != ' ' && *q != '/' && *q != '\0')
9566 q++;
9568 if (used_arg (r, q - r))
9569 break;
9571 if (*q != '/')
9573 mswitches[n_mswitches].str = mdswitches[i].str;
9574 mswitches[n_mswitches].len = mdswitches[i].len;
9575 mswitches[n_mswitches].replace = (char *) 0;
9576 mswitches[n_mswitches].rep_len = 0;
9577 n_mswitches++;
9578 break;
9581 r = q + 1;
9583 break;
9589 for (i = 0; i < n_mswitches; i++)
9590 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
9591 return 1;
9593 return 0;
9596 void used_arg_t::finalize ()
9598 XDELETEVEC (mswitches);
9599 mswitches = NULL;
9600 n_mswitches = 0;
9604 static int
9605 default_arg (const char *p, int len)
9607 int i;
9609 for (i = 0; i < n_mdswitches; i++)
9610 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
9611 return 1;
9613 return 0;
9616 /* Work out the subdirectory to use based on the options. The format of
9617 multilib_select is a list of elements. Each element is a subdirectory
9618 name followed by a list of options followed by a semicolon. The format
9619 of multilib_exclusions is the same, but without the preceding
9620 directory. First gcc will check the exclusions, if none of the options
9621 beginning with an exclamation point are present, and all of the other
9622 options are present, then we will ignore this completely. Passing
9623 that, gcc will consider each multilib_select in turn using the same
9624 rules for matching the options. If a match is found, that subdirectory
9625 will be used.
9626 A subdirectory name is optionally followed by a colon and the corresponding
9627 multiarch name. */
9629 static void
9630 set_multilib_dir (void)
9632 const char *p;
9633 unsigned int this_path_len;
9634 const char *this_path, *this_arg;
9635 const char *start, *end;
9636 int not_arg;
9637 int ok, ndfltok, first;
9639 n_mdswitches = 0;
9640 start = multilib_defaults;
9641 while (*start == ' ' || *start == '\t')
9642 start++;
9643 while (*start != '\0')
9645 n_mdswitches++;
9646 while (*start != ' ' && *start != '\t' && *start != '\0')
9647 start++;
9648 while (*start == ' ' || *start == '\t')
9649 start++;
9652 if (n_mdswitches)
9654 int i = 0;
9656 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
9657 for (start = multilib_defaults; *start != '\0'; start = end + 1)
9659 while (*start == ' ' || *start == '\t')
9660 start++;
9662 if (*start == '\0')
9663 break;
9665 for (end = start + 1;
9666 *end != ' ' && *end != '\t' && *end != '\0'; end++)
9669 obstack_grow (&multilib_obstack, start, end - start);
9670 obstack_1grow (&multilib_obstack, 0);
9671 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
9672 mdswitches[i++].len = end - start;
9674 if (*end == '\0')
9675 break;
9679 p = multilib_exclusions;
9680 while (*p != '\0')
9682 /* Ignore newlines. */
9683 if (*p == '\n')
9685 ++p;
9686 continue;
9689 /* Check the arguments. */
9690 ok = 1;
9691 while (*p != ';')
9693 if (*p == '\0')
9695 invalid_exclusions:
9696 fatal_error (input_location, "multilib exclusions %qs is invalid",
9697 multilib_exclusions);
9700 if (! ok)
9702 ++p;
9703 continue;
9706 this_arg = p;
9707 while (*p != ' ' && *p != ';')
9709 if (*p == '\0')
9710 goto invalid_exclusions;
9711 ++p;
9714 if (*this_arg != '!')
9715 not_arg = 0;
9716 else
9718 not_arg = 1;
9719 ++this_arg;
9722 ok = used_arg (this_arg, p - this_arg);
9723 if (not_arg)
9724 ok = ! ok;
9726 if (*p == ' ')
9727 ++p;
9730 if (ok)
9731 return;
9733 ++p;
9736 first = 1;
9737 p = multilib_select;
9739 /* Append multilib reuse rules if any. With those rules, we can reuse
9740 one multilib for certain different options sets. */
9741 if (strlen (multilib_reuse) > 0)
9742 p = concat (p, multilib_reuse, NULL);
9744 while (*p != '\0')
9746 /* Ignore newlines. */
9747 if (*p == '\n')
9749 ++p;
9750 continue;
9753 /* Get the initial path. */
9754 this_path = p;
9755 while (*p != ' ')
9757 if (*p == '\0')
9759 invalid_select:
9760 fatal_error (input_location, "multilib select %qs %qs is invalid",
9761 multilib_select, multilib_reuse);
9763 ++p;
9765 this_path_len = p - this_path;
9767 /* Check the arguments. */
9768 ok = 1;
9769 ndfltok = 1;
9770 ++p;
9771 while (*p != ';')
9773 if (*p == '\0')
9774 goto invalid_select;
9776 if (! ok)
9778 ++p;
9779 continue;
9782 this_arg = p;
9783 while (*p != ' ' && *p != ';')
9785 if (*p == '\0')
9786 goto invalid_select;
9787 ++p;
9790 if (*this_arg != '!')
9791 not_arg = 0;
9792 else
9794 not_arg = 1;
9795 ++this_arg;
9798 /* If this is a default argument, we can just ignore it.
9799 This is true even if this_arg begins with '!'. Beginning
9800 with '!' does not mean that this argument is necessarily
9801 inappropriate for this library: it merely means that
9802 there is a more specific library which uses this
9803 argument. If this argument is a default, we need not
9804 consider that more specific library. */
9805 ok = used_arg (this_arg, p - this_arg);
9806 if (not_arg)
9807 ok = ! ok;
9809 if (! ok)
9810 ndfltok = 0;
9812 if (default_arg (this_arg, p - this_arg))
9813 ok = 1;
9815 if (*p == ' ')
9816 ++p;
9819 if (ok && first)
9821 if (this_path_len != 1
9822 || this_path[0] != '.')
9824 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
9825 char *q;
9827 strncpy (new_multilib_dir, this_path, this_path_len);
9828 new_multilib_dir[this_path_len] = '\0';
9829 q = strchr (new_multilib_dir, ':');
9830 if (q != NULL)
9831 *q = '\0';
9832 multilib_dir = new_multilib_dir;
9834 first = 0;
9837 if (ndfltok)
9839 const char *q = this_path, *end = this_path + this_path_len;
9841 while (q < end && *q != ':')
9842 q++;
9843 if (q < end)
9845 const char *q2 = q + 1, *ml_end = end;
9846 char *new_multilib_os_dir;
9848 while (q2 < end && *q2 != ':')
9849 q2++;
9850 if (*q2 == ':')
9851 ml_end = q2;
9852 if (ml_end - q == 1)
9853 multilib_os_dir = xstrdup (".");
9854 else
9856 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
9857 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
9858 new_multilib_os_dir[ml_end - q - 1] = '\0';
9859 multilib_os_dir = new_multilib_os_dir;
9862 if (q2 < end && *q2 == ':')
9864 char *new_multiarch_dir = XNEWVEC (char, end - q2);
9865 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
9866 new_multiarch_dir[end - q2 - 1] = '\0';
9867 multiarch_dir = new_multiarch_dir;
9869 break;
9873 ++p;
9876 if (multilib_dir == NULL && multilib_os_dir != NULL
9877 && strcmp (multilib_os_dir, ".") == 0)
9879 free (CONST_CAST (char *, multilib_os_dir));
9880 multilib_os_dir = NULL;
9882 else if (multilib_dir != NULL && multilib_os_dir == NULL)
9883 multilib_os_dir = multilib_dir;
9886 /* Print out the multiple library subdirectory selection
9887 information. This prints out a series of lines. Each line looks
9888 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
9889 required. Only the desired options are printed out, the negative
9890 matches. The options are print without a leading dash. There are
9891 no spaces to make it easy to use the information in the shell.
9892 Each subdirectory is printed only once. This assumes the ordering
9893 generated by the genmultilib script. Also, we leave out ones that match
9894 the exclusions. */
9896 static void
9897 print_multilib_info (void)
9899 const char *p = multilib_select;
9900 const char *last_path = 0, *this_path;
9901 int skip;
9902 int not_arg;
9903 unsigned int last_path_len = 0;
9905 while (*p != '\0')
9907 skip = 0;
9908 /* Ignore newlines. */
9909 if (*p == '\n')
9911 ++p;
9912 continue;
9915 /* Get the initial path. */
9916 this_path = p;
9917 while (*p != ' ')
9919 if (*p == '\0')
9921 invalid_select:
9922 fatal_error (input_location,
9923 "multilib select %qs is invalid", multilib_select);
9926 ++p;
9929 /* When --disable-multilib was used but target defines
9930 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
9931 with .:: for multiarch configurations) are there just to find
9932 multilib_os_dir, so skip them from output. */
9933 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
9934 skip = 1;
9936 /* Check for matches with the multilib_exclusions. We don't bother
9937 with the '!' in either list. If any of the exclusion rules match
9938 all of its options with the select rule, we skip it. */
9940 const char *e = multilib_exclusions;
9941 const char *this_arg;
9943 while (*e != '\0')
9945 int m = 1;
9946 /* Ignore newlines. */
9947 if (*e == '\n')
9949 ++e;
9950 continue;
9953 /* Check the arguments. */
9954 while (*e != ';')
9956 const char *q;
9957 int mp = 0;
9959 if (*e == '\0')
9961 invalid_exclusion:
9962 fatal_error (input_location,
9963 "multilib exclusion %qs is invalid",
9964 multilib_exclusions);
9967 if (! m)
9969 ++e;
9970 continue;
9973 this_arg = e;
9975 while (*e != ' ' && *e != ';')
9977 if (*e == '\0')
9978 goto invalid_exclusion;
9979 ++e;
9982 q = p + 1;
9983 while (*q != ';')
9985 const char *arg;
9986 int len = e - this_arg;
9988 if (*q == '\0')
9989 goto invalid_select;
9991 arg = q;
9993 while (*q != ' ' && *q != ';')
9995 if (*q == '\0')
9996 goto invalid_select;
9997 ++q;
10000 if (! strncmp (arg, this_arg,
10001 (len < q - arg) ? q - arg : len)
10002 || default_arg (this_arg, e - this_arg))
10004 mp = 1;
10005 break;
10008 if (*q == ' ')
10009 ++q;
10012 if (! mp)
10013 m = 0;
10015 if (*e == ' ')
10016 ++e;
10019 if (m)
10021 skip = 1;
10022 break;
10025 if (*e != '\0')
10026 ++e;
10030 if (! skip)
10032 /* If this is a duplicate, skip it. */
10033 skip = (last_path != 0
10034 && (unsigned int) (p - this_path) == last_path_len
10035 && ! filename_ncmp (last_path, this_path, last_path_len));
10037 last_path = this_path;
10038 last_path_len = p - this_path;
10041 /* If all required arguments are default arguments, and no default
10042 arguments appear in the ! argument list, then we can skip it.
10043 We will already have printed a directory identical to this one
10044 which does not require that default argument. */
10045 if (! skip)
10047 const char *q;
10048 bool default_arg_ok = false;
10050 q = p + 1;
10051 while (*q != ';')
10053 const char *arg;
10055 if (*q == '\0')
10056 goto invalid_select;
10058 if (*q == '!')
10060 not_arg = 1;
10061 q++;
10063 else
10064 not_arg = 0;
10065 arg = q;
10067 while (*q != ' ' && *q != ';')
10069 if (*q == '\0')
10070 goto invalid_select;
10071 ++q;
10074 if (default_arg (arg, q - arg))
10076 /* Stop checking if any default arguments appeared in not
10077 list. */
10078 if (not_arg)
10080 default_arg_ok = false;
10081 break;
10084 default_arg_ok = true;
10086 else if (!not_arg)
10088 /* Stop checking if any required argument is not provided by
10089 default arguments. */
10090 default_arg_ok = false;
10091 break;
10094 if (*q == ' ')
10095 ++q;
10098 /* Make sure all default argument is OK for this multi-lib set. */
10099 if (default_arg_ok)
10100 skip = 1;
10101 else
10102 skip = 0;
10105 if (! skip)
10107 const char *p1;
10109 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
10110 putchar (*p1);
10111 putchar (';');
10114 ++p;
10115 while (*p != ';')
10117 int use_arg;
10119 if (*p == '\0')
10120 goto invalid_select;
10122 if (skip)
10124 ++p;
10125 continue;
10128 use_arg = *p != '!';
10130 if (use_arg)
10131 putchar ('@');
10133 while (*p != ' ' && *p != ';')
10135 if (*p == '\0')
10136 goto invalid_select;
10137 if (use_arg)
10138 putchar (*p);
10139 ++p;
10142 if (*p == ' ')
10143 ++p;
10146 if (! skip)
10148 /* If there are extra options, print them now. */
10149 if (multilib_extra && *multilib_extra)
10151 int print_at = TRUE;
10152 const char *q;
10154 for (q = multilib_extra; *q != '\0'; q++)
10156 if (*q == ' ')
10157 print_at = TRUE;
10158 else
10160 if (print_at)
10161 putchar ('@');
10162 putchar (*q);
10163 print_at = FALSE;
10168 putchar ('\n');
10171 ++p;
10175 /* getenv built-in spec function.
10177 Returns the value of the environment variable given by its first argument,
10178 concatenated with the second argument. If the variable is not defined, a
10179 fatal error is issued unless such undefs are internally allowed, in which
10180 case the variable name prefixed by a '/' is used as the variable value.
10182 The leading '/' allows using the result at a spot where a full path would
10183 normally be expected and when the actual value doesn't really matter since
10184 undef vars are allowed. */
10186 static const char *
10187 getenv_spec_function (int argc, const char **argv)
10189 const char *value;
10190 const char *varname;
10192 char *result;
10193 char *ptr;
10194 size_t len;
10196 if (argc != 2)
10197 return NULL;
10199 varname = argv[0];
10200 value = env.get (varname);
10202 /* If the variable isn't defined and this is allowed, craft our expected
10203 return value. Assume variable names used in specs strings don't contain
10204 any active spec character so don't need escaping. */
10205 if (!value && spec_undefvar_allowed)
10207 result = XNEWVAR (char, strlen(varname) + 2);
10208 sprintf (result, "/%s", varname);
10209 return result;
10212 if (!value)
10213 fatal_error (input_location,
10214 "environment variable %qs not defined", varname);
10216 /* We have to escape every character of the environment variable so
10217 they are not interpreted as active spec characters. A
10218 particularly painful case is when we are reading a variable
10219 holding a windows path complete with \ separators. */
10220 len = strlen (value) * 2 + strlen (argv[1]) + 1;
10221 result = XNEWVAR (char, len);
10222 for (ptr = result; *value; ptr += 2)
10224 ptr[0] = '\\';
10225 ptr[1] = *value++;
10228 strcpy (ptr, argv[1]);
10230 return result;
10233 /* if-exists built-in spec function.
10235 Checks to see if the file specified by the absolute pathname in
10236 ARGS exists. Returns that pathname if found.
10238 The usual use for this function is to check for a library file
10239 (whose name has been expanded with %s). */
10241 static const char *
10242 if_exists_spec_function (int argc, const char **argv)
10244 /* Must have only one argument. */
10245 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
10246 return argv[0];
10248 return NULL;
10251 /* if-exists-else built-in spec function.
10253 This is like if-exists, but takes an additional argument which
10254 is returned if the first argument does not exist. */
10256 static const char *
10257 if_exists_else_spec_function (int argc, const char **argv)
10259 /* Must have exactly two arguments. */
10260 if (argc != 2)
10261 return NULL;
10263 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
10264 return argv[0];
10266 return argv[1];
10269 /* if-exists-then-else built-in spec function.
10271 Checks to see if the file specified by the absolute pathname in
10272 the first arg exists. Returns the second arg if so, otherwise returns
10273 the third arg if it is present. */
10275 static const char *
10276 if_exists_then_else_spec_function (int argc, const char **argv)
10279 /* Must have two or three arguments. */
10280 if (argc != 2 && argc != 3)
10281 return NULL;
10283 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
10284 return argv[1];
10286 if (argc == 3)
10287 return argv[2];
10289 return NULL;
10292 /* sanitize built-in spec function.
10294 This returns non-NULL, if sanitizing address, thread or
10295 any of the undefined behavior sanitizers. */
10297 static const char *
10298 sanitize_spec_function (int argc, const char **argv)
10300 if (argc != 1)
10301 return NULL;
10303 if (strcmp (argv[0], "address") == 0)
10304 return (flag_sanitize & SANITIZE_USER_ADDRESS) ? "" : NULL;
10305 if (strcmp (argv[0], "hwaddress") == 0)
10306 return (flag_sanitize & SANITIZE_USER_HWADDRESS) ? "" : NULL;
10307 if (strcmp (argv[0], "kernel-address") == 0)
10308 return (flag_sanitize & SANITIZE_KERNEL_ADDRESS) ? "" : NULL;
10309 if (strcmp (argv[0], "kernel-hwaddress") == 0)
10310 return (flag_sanitize & SANITIZE_KERNEL_HWADDRESS) ? "" : NULL;
10311 if (strcmp (argv[0], "thread") == 0)
10312 return (flag_sanitize & SANITIZE_THREAD) ? "" : NULL;
10313 if (strcmp (argv[0], "undefined") == 0)
10314 return ((flag_sanitize
10315 & (SANITIZE_UNDEFINED | SANITIZE_UNDEFINED_NONDEFAULT))
10316 && !flag_sanitize_undefined_trap_on_error) ? "" : NULL;
10317 if (strcmp (argv[0], "leak") == 0)
10318 return ((flag_sanitize
10319 & (SANITIZE_ADDRESS | SANITIZE_LEAK | SANITIZE_THREAD))
10320 == SANITIZE_LEAK) ? "" : NULL;
10321 return NULL;
10324 /* replace-outfile built-in spec function.
10326 This looks for the first argument in the outfiles array's name and
10327 replaces it with the second argument. */
10329 static const char *
10330 replace_outfile_spec_function (int argc, const char **argv)
10332 int i;
10333 /* Must have exactly two arguments. */
10334 if (argc != 2)
10335 abort ();
10337 for (i = 0; i < n_infiles; i++)
10339 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
10340 outfiles[i] = xstrdup (argv[1]);
10342 return NULL;
10345 /* remove-outfile built-in spec function.
10347 * This looks for the first argument in the outfiles array's name and
10348 * removes it. */
10350 static const char *
10351 remove_outfile_spec_function (int argc, const char **argv)
10353 int i;
10354 /* Must have exactly one argument. */
10355 if (argc != 1)
10356 abort ();
10358 for (i = 0; i < n_infiles; i++)
10360 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
10361 outfiles[i] = NULL;
10363 return NULL;
10366 /* Given two version numbers, compares the two numbers.
10367 A version number must match the regular expression
10368 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
10370 static int
10371 compare_version_strings (const char *v1, const char *v2)
10373 int rresult;
10374 regex_t r;
10376 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
10377 REG_EXTENDED | REG_NOSUB) != 0)
10378 abort ();
10379 rresult = regexec (&r, v1, 0, NULL, 0);
10380 if (rresult == REG_NOMATCH)
10381 fatal_error (input_location, "invalid version number %qs", v1);
10382 else if (rresult != 0)
10383 abort ();
10384 rresult = regexec (&r, v2, 0, NULL, 0);
10385 if (rresult == REG_NOMATCH)
10386 fatal_error (input_location, "invalid version number %qs", v2);
10387 else if (rresult != 0)
10388 abort ();
10390 return strverscmp (v1, v2);
10394 /* version_compare built-in spec function.
10396 This takes an argument of the following form:
10398 <comparison-op> <arg1> [<arg2>] <switch> <result>
10400 and produces "result" if the comparison evaluates to true,
10401 and nothing if it doesn't.
10403 The supported <comparison-op> values are:
10405 >= true if switch is a later (or same) version than arg1
10406 !> opposite of >=
10407 < true if switch is an earlier version than arg1
10408 !< opposite of <
10409 >< true if switch is arg1 or later, and earlier than arg2
10410 <> true if switch is earlier than arg1 or is arg2 or later
10412 If the switch is not present, the condition is false unless
10413 the first character of the <comparison-op> is '!'.
10415 For example,
10416 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
10417 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
10419 static const char *
10420 version_compare_spec_function (int argc, const char **argv)
10422 int comp1, comp2;
10423 size_t switch_len;
10424 const char *switch_value = NULL;
10425 int nargs = 1, i;
10426 bool result;
10428 if (argc < 3)
10429 fatal_error (input_location, "too few arguments to %%:version-compare");
10430 if (argv[0][0] == '\0')
10431 abort ();
10432 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
10433 nargs = 2;
10434 if (argc != nargs + 3)
10435 fatal_error (input_location, "too many arguments to %%:version-compare");
10437 switch_len = strlen (argv[nargs + 1]);
10438 for (i = 0; i < n_switches; i++)
10439 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
10440 && check_live_switch (i, switch_len))
10441 switch_value = switches[i].part1 + switch_len;
10443 if (switch_value == NULL)
10444 comp1 = comp2 = -1;
10445 else
10447 comp1 = compare_version_strings (switch_value, argv[1]);
10448 if (nargs == 2)
10449 comp2 = compare_version_strings (switch_value, argv[2]);
10450 else
10451 comp2 = -1; /* This value unused. */
10454 switch (argv[0][0] << 8 | argv[0][1])
10456 case '>' << 8 | '=':
10457 result = comp1 >= 0;
10458 break;
10459 case '!' << 8 | '<':
10460 result = comp1 >= 0 || switch_value == NULL;
10461 break;
10462 case '<' << 8:
10463 result = comp1 < 0;
10464 break;
10465 case '!' << 8 | '>':
10466 result = comp1 < 0 || switch_value == NULL;
10467 break;
10468 case '>' << 8 | '<':
10469 result = comp1 >= 0 && comp2 < 0;
10470 break;
10471 case '<' << 8 | '>':
10472 result = comp1 < 0 || comp2 >= 0;
10473 break;
10475 default:
10476 fatal_error (input_location,
10477 "unknown operator %qs in %%:version-compare", argv[0]);
10479 if (! result)
10480 return NULL;
10482 return argv[nargs + 2];
10485 /* %:include builtin spec function. This differs from %include in that it
10486 can be nested inside a spec, and thus be conditionalized. It takes
10487 one argument, the filename, and looks for it in the startfile path.
10488 The result is always NULL, i.e. an empty expansion. */
10490 static const char *
10491 include_spec_function (int argc, const char **argv)
10493 char *file;
10495 if (argc != 1)
10496 abort ();
10498 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
10499 read_specs (file ? file : argv[0], false, false);
10501 return NULL;
10504 /* %:find-file spec function. This function replaces its argument by
10505 the file found through find_file, that is the -print-file-name gcc
10506 program option. */
10507 static const char *
10508 find_file_spec_function (int argc, const char **argv)
10510 const char *file;
10512 if (argc != 1)
10513 abort ();
10515 file = find_file (argv[0]);
10516 return file;
10520 /* %:find-plugindir spec function. This function replaces its argument
10521 by the -iplugindir=<dir> option. `dir' is found through find_file, that
10522 is the -print-file-name gcc program option. */
10523 static const char *
10524 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
10526 const char *option;
10528 if (argc != 0)
10529 abort ();
10531 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
10532 return option;
10536 /* %:print-asm-header spec function. Print a banner to say that the
10537 following output is from the assembler. */
10539 static const char *
10540 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
10541 const char **argv ATTRIBUTE_UNUSED)
10543 printf (_("Assembler options\n=================\n\n"));
10544 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
10545 fflush (stdout);
10546 return NULL;
10549 /* Get a random number for -frandom-seed */
10551 static unsigned HOST_WIDE_INT
10552 get_random_number (void)
10554 unsigned HOST_WIDE_INT ret = 0;
10555 int fd;
10557 fd = open ("/dev/urandom", O_RDONLY);
10558 if (fd >= 0)
10560 read (fd, &ret, sizeof (HOST_WIDE_INT));
10561 close (fd);
10562 if (ret)
10563 return ret;
10566 /* Get some more or less random data. */
10567 #ifdef HAVE_GETTIMEOFDAY
10569 struct timeval tv;
10571 gettimeofday (&tv, NULL);
10572 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
10574 #else
10576 time_t now = time (NULL);
10578 if (now != (time_t)-1)
10579 ret = (unsigned) now;
10581 #endif
10583 return ret ^ getpid ();
10586 /* %:compare-debug-dump-opt spec function. Save the last argument,
10587 expected to be the last -fdump-final-insns option, or generate a
10588 temporary. */
10590 static const char *
10591 compare_debug_dump_opt_spec_function (int arg,
10592 const char **argv ATTRIBUTE_UNUSED)
10594 char *ret;
10595 char *name;
10596 int which;
10597 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
10599 if (arg != 0)
10600 fatal_error (input_location,
10601 "too many arguments to %%:compare-debug-dump-opt");
10603 do_spec_2 ("%{fdump-final-insns=*:%*}", NULL);
10604 do_spec_1 (" ", 0, NULL);
10606 if (argbuf.length () > 0
10607 && strcmp (argv[argbuf.length () - 1], ".") != 0)
10609 if (!compare_debug)
10610 return NULL;
10612 name = xstrdup (argv[argbuf.length () - 1]);
10613 ret = NULL;
10615 else
10617 if (argbuf.length () > 0)
10618 do_spec_2 ("%B.gkd", NULL);
10619 else if (!compare_debug)
10620 return NULL;
10621 else
10622 do_spec_2 ("%{!save-temps*:%g.gkd}%{save-temps*:%B.gkd}", NULL);
10624 do_spec_1 (" ", 0, NULL);
10626 gcc_assert (argbuf.length () > 0);
10628 name = xstrdup (argbuf.last ());
10630 char *arg = quote_spec (xstrdup (name));
10631 ret = concat ("-fdump-final-insns=", arg, NULL);
10632 free (arg);
10635 which = compare_debug < 0;
10636 debug_check_temp_file[which] = name;
10638 if (!which)
10640 unsigned HOST_WIDE_INT value = get_random_number ();
10642 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
10645 if (*random_seed)
10647 char *tmp = ret;
10648 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
10649 ret, NULL);
10650 free (tmp);
10653 if (which)
10654 *random_seed = 0;
10656 return ret;
10659 /* %:compare-debug-self-opt spec function. Expands to the options
10660 that are to be passed in the second compilation of
10661 compare-debug. */
10663 static const char *
10664 compare_debug_self_opt_spec_function (int arg,
10665 const char **argv ATTRIBUTE_UNUSED)
10667 if (arg != 0)
10668 fatal_error (input_location,
10669 "too many arguments to %%:compare-debug-self-opt");
10671 if (compare_debug >= 0)
10672 return NULL;
10674 return concat ("\
10675 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
10676 %<fdump-final-insns=* -w -S -o %j \
10677 %{!fcompare-debug-second:-fcompare-debug-second} \
10678 ", compare_debug_opt, NULL);
10681 /* %:pass-through-libs spec function. Finds all -l options and input
10682 file names in the lib spec passed to it, and makes a list of them
10683 prepended with the plugin option to cause them to be passed through
10684 to the final link after all the new object files have been added. */
10686 const char *
10687 pass_through_libs_spec_func (int argc, const char **argv)
10689 char *prepended = xstrdup (" ");
10690 int n;
10691 /* Shlemiel the painter's algorithm. Innately horrible, but at least
10692 we know that there will never be more than a handful of strings to
10693 concat, and it's only once per run, so it's not worth optimising. */
10694 for (n = 0; n < argc; n++)
10696 char *old = prepended;
10697 /* Anything that isn't an option is a full path to an output
10698 file; pass it through if it ends in '.a'. Among options,
10699 pass only -l. */
10700 if (argv[n][0] == '-' && argv[n][1] == 'l')
10702 const char *lopt = argv[n] + 2;
10703 /* Handle both joined and non-joined -l options. If for any
10704 reason there's a trailing -l with no joined or following
10705 arg just discard it. */
10706 if (!*lopt && ++n >= argc)
10707 break;
10708 else if (!*lopt)
10709 lopt = argv[n];
10710 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
10711 lopt, " ", NULL);
10713 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
10715 prepended = concat (prepended, "-plugin-opt=-pass-through=",
10716 argv[n], " ", NULL);
10718 if (prepended != old)
10719 free (old);
10721 return prepended;
10724 static bool
10725 not_actual_file_p (const char *name)
10727 return (strcmp (name, "-") == 0
10728 || strcmp (name, HOST_BIT_BUCKET) == 0);
10731 /* %:dumps spec function. Take an optional argument that overrides
10732 the default extension for -dumpbase and -dumpbase-ext.
10733 Return -dumpdir, -dumpbase and -dumpbase-ext, if needed. */
10734 const char *
10735 dumps_spec_func (int argc, const char **argv ATTRIBUTE_UNUSED)
10737 const char *ext = dumpbase_ext;
10738 char *p;
10740 char *args[3] = { NULL, NULL, NULL };
10741 int nargs = 0;
10743 /* Do not compute a default for -dumpbase-ext when -dumpbase was
10744 given explicitly. */
10745 if (dumpbase && *dumpbase && !ext)
10746 ext = "";
10748 if (argc == 1)
10750 /* Do not override the explicitly-specified -dumpbase-ext with
10751 the specs-provided overrider. */
10752 if (!ext)
10753 ext = argv[0];
10755 else if (argc != 0)
10756 fatal_error (input_location, "too many arguments for %%:dumps");
10758 if (dumpdir)
10760 p = quote_spec_arg (xstrdup (dumpdir));
10761 args[nargs++] = concat (" -dumpdir ", p, NULL);
10762 free (p);
10765 if (!ext)
10766 ext = input_basename + basename_length;
10768 /* Use the precomputed outbase, or compute dumpbase from
10769 input_basename, just like %b would. */
10770 char *base;
10772 if (dumpbase && *dumpbase)
10774 base = xstrdup (dumpbase);
10775 p = base + outbase_length;
10776 gcc_checking_assert (strncmp (base, outbase, outbase_length) == 0);
10777 gcc_checking_assert (strcmp (p, ext) == 0);
10779 else if (outbase_length)
10781 base = xstrndup (outbase, outbase_length);
10782 p = NULL;
10784 else
10786 base = xstrndup (input_basename, suffixed_basename_length);
10787 p = base + basename_length;
10790 if (compare_debug < 0 || !p || strcmp (p, ext) != 0)
10792 if (p)
10793 *p = '\0';
10795 const char *gk;
10796 if (compare_debug < 0)
10797 gk = ".gk";
10798 else
10799 gk = "";
10801 p = concat (base, gk, ext, NULL);
10803 free (base);
10804 base = p;
10807 base = quote_spec_arg (base);
10808 args[nargs++] = concat (" -dumpbase ", base, NULL);
10809 free (base);
10811 if (*ext)
10813 p = quote_spec_arg (xstrdup (ext));
10814 args[nargs++] = concat (" -dumpbase-ext ", p, NULL);
10815 free (p);
10818 const char *ret = concat (args[0], args[1], args[2], NULL);
10819 while (nargs > 0)
10820 free (args[--nargs]);
10822 return ret;
10825 /* Returns "" if ARGV[ARGC - 2] is greater than ARGV[ARGC-1].
10826 Otherwise, return NULL. */
10828 static const char *
10829 greater_than_spec_func (int argc, const char **argv)
10831 char *converted;
10833 if (argc == 1)
10834 return NULL;
10836 gcc_assert (argc >= 2);
10838 long arg = strtol (argv[argc - 2], &converted, 10);
10839 gcc_assert (converted != argv[argc - 2]);
10841 long lim = strtol (argv[argc - 1], &converted, 10);
10842 gcc_assert (converted != argv[argc - 1]);
10844 if (arg > lim)
10845 return "";
10847 return NULL;
10850 /* Returns "" if debug_info_level is greater than ARGV[ARGC-1].
10851 Otherwise, return NULL. */
10853 static const char *
10854 debug_level_greater_than_spec_func (int argc, const char **argv)
10856 char *converted;
10858 if (argc != 1)
10859 fatal_error (input_location,
10860 "wrong number of arguments to %%:debug-level-gt");
10862 long arg = strtol (argv[0], &converted, 10);
10863 gcc_assert (converted != argv[0]);
10865 if (debug_info_level > arg)
10866 return "";
10868 return NULL;
10871 /* Returns "" if dwarf_version is greater than ARGV[ARGC-1].
10872 Otherwise, return NULL. */
10874 static const char *
10875 dwarf_version_greater_than_spec_func (int argc, const char **argv)
10877 char *converted;
10879 if (argc != 1)
10880 fatal_error (input_location,
10881 "wrong number of arguments to %%:dwarf-version-gt");
10883 long arg = strtol (argv[0], &converted, 10);
10884 gcc_assert (converted != argv[0]);
10886 if (dwarf_version > arg)
10887 return "";
10889 return NULL;
10892 static void
10893 path_prefix_reset (path_prefix *prefix)
10895 struct prefix_list *iter, *next;
10896 iter = prefix->plist;
10897 while (iter)
10899 next = iter->next;
10900 free (const_cast <char *> (iter->prefix));
10901 XDELETE (iter);
10902 iter = next;
10904 prefix->plist = 0;
10905 prefix->max_len = 0;
10908 /* The function takes 3 arguments: OPTION name, file name and location
10909 where we search for Fortran modules.
10910 When the FILE is found by find_file, return OPTION=path_to_file. */
10912 static const char *
10913 find_fortran_preinclude_file (int argc, const char **argv)
10915 char *result = NULL;
10916 if (argc != 3)
10917 return NULL;
10919 struct path_prefix prefixes = { 0, 0, "preinclude" };
10921 /* Search first for 'finclude' folder location for a header file
10922 installed by the compiler (similar to omp_lib.h). */
10923 add_prefix (&prefixes, argv[2], NULL, 0, 0, 0);
10924 #ifdef TOOL_INCLUDE_DIR
10925 /* Then search: <prefix>/<target>/<include>/finclude */
10926 add_prefix (&prefixes, TOOL_INCLUDE_DIR "/finclude/",
10927 NULL, 0, 0, 0);
10928 #endif
10929 #ifdef NATIVE_SYSTEM_HEADER_DIR
10930 /* Then search: <sysroot>/usr/include/finclude/<multilib> */
10931 add_sysrooted_hdrs_prefix (&prefixes, NATIVE_SYSTEM_HEADER_DIR "/finclude/",
10932 NULL, 0, 0, 0);
10933 #endif
10935 const char *path = find_a_file (&include_prefixes, argv[1], R_OK, false);
10936 if (path != NULL)
10937 result = concat (argv[0], path, NULL);
10938 else
10940 path = find_a_file (&prefixes, argv[1], R_OK, false);
10941 if (path != NULL)
10942 result = concat (argv[0], path, NULL);
10945 path_prefix_reset (&prefixes);
10946 return result;
10949 /* If any character in ORIG fits QUOTE_P (_, P), reallocate the string
10950 so as to precede every one of them with a backslash. Return the
10951 original string or the reallocated one. */
10953 static inline char *
10954 quote_string (char *orig, bool (*quote_p)(char, void *), void *p)
10956 int len, number_of_space = 0;
10958 for (len = 0; orig[len]; len++)
10959 if (quote_p (orig[len], p))
10960 number_of_space++;
10962 if (number_of_space)
10964 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
10965 int j, k;
10966 for (j = 0, k = 0; j <= len; j++, k++)
10968 if (quote_p (orig[j], p))
10969 new_spec[k++] = '\\';
10970 new_spec[k] = orig[j];
10972 free (orig);
10973 return new_spec;
10975 else
10976 return orig;
10979 /* Return true iff C is any of the characters convert_white_space
10980 should quote. */
10982 static inline bool
10983 whitespace_to_convert_p (char c, void *)
10985 return (c == ' ' || c == '\t');
10988 /* Insert backslash before spaces in ORIG (usually a file path), to
10989 avoid being broken by spec parser.
10991 This function is needed as do_spec_1 treats white space (' ' and '\t')
10992 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
10993 the file name should be treated as a single argument rather than being
10994 broken into multiple. Solution is to insert '\\' before the space in a
10995 file name.
10997 This function converts and only converts all occurrence of ' '
10998 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
10999 "a b" -> "a\\ b"
11000 "a b" -> "a\\ \\ b"
11001 "a\tb" -> "a\\\tb"
11002 "a\\ b" -> "a\\\\ b"
11004 orig: input null-terminating string that was allocated by xalloc. The
11005 memory it points to might be freed in this function. Behavior undefined
11006 if ORIG wasn't xalloced or was freed already at entry.
11008 Return: ORIG if no conversion needed. Otherwise a newly allocated string
11009 that was converted from ORIG. */
11011 static char *
11012 convert_white_space (char *orig)
11014 return quote_string (orig, whitespace_to_convert_p, NULL);
11017 /* Return true iff C matches any of the spec active characters. */
11018 static inline bool
11019 quote_spec_char_p (char c, void *)
11021 switch (c)
11023 case ' ':
11024 case '\t':
11025 case '\n':
11026 case '|':
11027 case '%':
11028 case '\\':
11029 return true;
11031 default:
11032 return false;
11036 /* Like convert_white_space, but deactivate all active spec chars by
11037 quoting them. */
11039 static inline char *
11040 quote_spec (char *orig)
11042 return quote_string (orig, quote_spec_char_p, NULL);
11045 /* Like quote_spec, but also turn an empty string into the spec for an
11046 empty argument. */
11048 static inline char *
11049 quote_spec_arg (char *orig)
11051 if (!*orig)
11053 free (orig);
11054 return xstrdup ("%\"");
11057 return quote_spec (orig);
11060 /* Restore all state within gcc.cc to the initial state, so that the driver
11061 code can be safely re-run in-process.
11063 Many const char * variables are referenced by static specs (see
11064 INIT_STATIC_SPEC above). These variables are restored to their default
11065 values by a simple loop over the static specs.
11067 For other variables, we directly restore them all to their initial
11068 values (often implicitly 0).
11070 Free the various obstacks in this file, along with "opts_obstack"
11071 from opts.cc.
11073 This function also restores any environment variables that were changed. */
11075 void
11076 driver::finalize ()
11078 env.restore ();
11079 diagnostic_finish (global_dc);
11081 is_cpp_driver = 0;
11082 at_file_supplied = 0;
11083 print_help_list = 0;
11084 print_version = 0;
11085 verbose_only_flag = 0;
11086 print_subprocess_help = 0;
11087 use_ld = NULL;
11088 report_times_to_file = NULL;
11089 target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
11090 target_system_root_changed = 0;
11091 target_sysroot_suffix = 0;
11092 target_sysroot_hdrs_suffix = 0;
11093 save_temps_flag = SAVE_TEMPS_NONE;
11094 save_temps_overrides_dumpdir = false;
11095 dumpdir_trailing_dash_added = false;
11096 free (dumpdir);
11097 free (dumpbase);
11098 free (dumpbase_ext);
11099 free (outbase);
11100 dumpdir = dumpbase = dumpbase_ext = outbase = NULL;
11101 dumpdir_length = outbase_length = 0;
11102 spec_machine = DEFAULT_TARGET_MACHINE;
11103 greatest_status = 1;
11105 obstack_free (&obstack, NULL);
11106 obstack_free (&opts_obstack, NULL); /* in opts.cc */
11107 obstack_free (&collect_obstack, NULL);
11109 link_command_spec = LINK_COMMAND_SPEC;
11111 obstack_free (&multilib_obstack, NULL);
11113 user_specs_head = NULL;
11114 user_specs_tail = NULL;
11116 /* Within the "compilers" vec, the fields "suffix" and "spec" were
11117 statically allocated for the default compilers, but dynamically
11118 allocated for additional compilers. Delete them for the latter. */
11119 for (int i = n_default_compilers; i < n_compilers; i++)
11121 free (const_cast <char *> (compilers[i].suffix));
11122 free (const_cast <char *> (compilers[i].spec));
11124 XDELETEVEC (compilers);
11125 compilers = NULL;
11126 n_compilers = 0;
11128 linker_options.truncate (0);
11129 assembler_options.truncate (0);
11130 preprocessor_options.truncate (0);
11132 path_prefix_reset (&exec_prefixes);
11133 path_prefix_reset (&startfile_prefixes);
11134 path_prefix_reset (&include_prefixes);
11136 machine_suffix = 0;
11137 just_machine_suffix = 0;
11138 gcc_exec_prefix = 0;
11139 gcc_libexec_prefix = 0;
11140 set_static_spec_shared (&md_exec_prefix, MD_EXEC_PREFIX);
11141 set_static_spec_shared (&md_startfile_prefix, MD_STARTFILE_PREFIX);
11142 set_static_spec_shared (&md_startfile_prefix_1, MD_STARTFILE_PREFIX_1);
11143 multilib_dir = 0;
11144 multilib_os_dir = 0;
11145 multiarch_dir = 0;
11147 /* Free any specs dynamically-allocated by set_spec.
11148 These will be at the head of the list, before the
11149 statically-allocated ones. */
11150 if (specs)
11152 while (specs != static_specs)
11154 spec_list *next = specs->next;
11155 free (const_cast <char *> (specs->name));
11156 XDELETE (specs);
11157 specs = next;
11159 specs = 0;
11161 for (unsigned i = 0; i < ARRAY_SIZE (static_specs); i++)
11163 spec_list *sl = &static_specs[i];
11164 if (sl->alloc_p)
11166 free (const_cast <char *> (*(sl->ptr_spec)));
11167 sl->alloc_p = false;
11169 *(sl->ptr_spec) = sl->default_ptr;
11171 #ifdef EXTRA_SPECS
11172 extra_specs = NULL;
11173 #endif
11175 processing_spec_function = 0;
11177 clear_args ();
11179 have_c = 0;
11180 have_o = 0;
11182 temp_names = NULL;
11183 execution_count = 0;
11184 signal_count = 0;
11186 temp_filename = NULL;
11187 temp_filename_length = 0;
11188 always_delete_queue = NULL;
11189 failure_delete_queue = NULL;
11191 XDELETEVEC (switches);
11192 switches = NULL;
11193 n_switches = 0;
11194 n_switches_alloc = 0;
11196 compare_debug = 0;
11197 compare_debug_second = 0;
11198 compare_debug_opt = NULL;
11199 for (int i = 0; i < 2; i++)
11201 switches_debug_check[i] = NULL;
11202 n_switches_debug_check[i] = 0;
11203 n_switches_alloc_debug_check[i] = 0;
11204 debug_check_temp_file[i] = NULL;
11207 XDELETEVEC (infiles);
11208 infiles = NULL;
11209 n_infiles = 0;
11210 n_infiles_alloc = 0;
11212 combine_inputs = false;
11213 added_libraries = 0;
11214 XDELETEVEC (outfiles);
11215 outfiles = NULL;
11216 spec_lang = 0;
11217 last_language_n_infiles = 0;
11218 gcc_input_filename = NULL;
11219 input_file_number = 0;
11220 input_filename_length = 0;
11221 basename_length = 0;
11222 suffixed_basename_length = 0;
11223 input_basename = NULL;
11224 input_suffix = NULL;
11225 /* We don't need to purge "input_stat", just to unset "input_stat_set". */
11226 input_stat_set = 0;
11227 input_file_compiler = NULL;
11228 arg_going = 0;
11229 delete_this_arg = 0;
11230 this_is_output_file = 0;
11231 this_is_library_file = 0;
11232 this_is_linker_script = 0;
11233 input_from_pipe = 0;
11234 suffix_subst = NULL;
11236 mdswitches = NULL;
11237 n_mdswitches = 0;
11239 used_arg.finalize ();
11242 /* PR jit/64810.
11243 Targets can provide configure-time default options in
11244 OPTION_DEFAULT_SPECS. The jit needs to access these, but
11245 they are expressed in the spec language.
11247 Run just enough of the driver to be able to expand these
11248 specs, and then call the callback CB on each
11249 such option. The options strings are *without* a leading
11250 '-' character e.g. ("march=x86-64"). Finally, clean up. */
11252 void
11253 driver_get_configure_time_options (void (*cb) (const char *option,
11254 void *user_data),
11255 void *user_data)
11257 size_t i;
11259 obstack_init (&obstack);
11260 init_opts_obstack ();
11261 n_switches = 0;
11263 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
11264 do_option_spec (option_default_specs[i].name,
11265 option_default_specs[i].spec);
11267 for (i = 0; (int) i < n_switches; i++)
11269 gcc_assert (switches[i].part1);
11270 (*cb) (switches[i].part1, user_data);
11273 obstack_free (&opts_obstack, NULL);
11274 obstack_free (&obstack, NULL);
11275 n_switches = 0;