2018-06-19 Tony Reix <tony.reix@atos.com>
[official-gcc.git] / gcc / gcc.c
blob405d2e38d446c79eeb928f8549d7c7e1a267c02a
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987-2018 Free Software Foundation, Inc.
4 This file is part of GCC.
6 GCC is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 3, or (at your option) any later
9 version.
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14 for more details.
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING3. If not see
18 <http://www.gnu.org/licenses/>. */
20 /* This program is the user interface to the C compiler and possibly to
21 other compilers. It is used because compilation is a complicated procedure
22 which involves running several programs and passing temporary files between
23 them, forwarding the users switches to those programs selectively,
24 and deleting the temporary files at the end.
26 CC recognizes how to compile each input file by suffixes in the file names.
27 Once it knows which kind of compilation to perform, the procedure for
28 compilation is specified by a string called a "spec". */
30 #include "config.h"
31 #include "system.h"
32 #include "coretypes.h"
33 #include "multilib.h" /* before tm.h */
34 #include "tm.h"
35 #include "xregex.h"
36 #include "obstack.h"
37 #include "intl.h"
38 #include "prefix.h"
39 #include "gcc.h"
40 #include "diagnostic.h"
41 #include "flags.h"
42 #include "opts.h"
43 #include "params.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 class 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.c 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 indicating whether we should ONLY print the command and
224 arguments (like verbose_flag) without executing the command.
225 Displayed arguments are quoted so that the generated command
226 line is suitable for execution. This is intended for use in
227 shell scripts to capture the driver-generated command line. */
228 static int verbose_only_flag;
230 /* Flag indicating how to print command line options of sub-processes. */
232 static int print_subprocess_help;
234 /* Linker suffix passed to -fuse-ld=... */
235 static const char *use_ld;
237 /* Whether we should report subprocess execution times to a file. */
239 FILE *report_times_to_file = NULL;
241 /* Nonzero means place this string before uses of /, so that include
242 and library files can be found in an alternate location. */
244 #ifdef TARGET_SYSTEM_ROOT
245 #define DEFAULT_TARGET_SYSTEM_ROOT (TARGET_SYSTEM_ROOT)
246 #else
247 #define DEFAULT_TARGET_SYSTEM_ROOT (0)
248 #endif
249 static const char *target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
251 /* Nonzero means pass the updated target_system_root to the compiler. */
253 static int target_system_root_changed;
255 /* Nonzero means append this string to target_system_root. */
257 static const char *target_sysroot_suffix = 0;
259 /* Nonzero means append this string to target_system_root for headers. */
261 static const char *target_sysroot_hdrs_suffix = 0;
263 /* Nonzero means write "temp" files in source directory
264 and use the source file's name in them, and don't delete them. */
266 static enum save_temps {
267 SAVE_TEMPS_NONE, /* no -save-temps */
268 SAVE_TEMPS_CWD, /* -save-temps in current directory */
269 SAVE_TEMPS_OBJ /* -save-temps in object directory */
270 } save_temps_flag;
272 /* Output file to use to get the object directory for -save-temps=obj */
273 static char *save_temps_prefix = 0;
274 static size_t save_temps_length = 0;
276 /* The compiler version. */
278 static const char *compiler_version;
280 /* The target version. */
282 static const char *const spec_version = DEFAULT_TARGET_VERSION;
284 /* The target machine. */
286 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
287 static const char *spec_host_machine = DEFAULT_REAL_TARGET_MACHINE;
289 /* List of offload targets. Separated by colon. Empty string for
290 -foffload=disable. */
292 static char *offload_targets = NULL;
294 /* Nonzero if cross-compiling.
295 When -b is used, the value comes from the `specs' file. */
297 #ifdef CROSS_DIRECTORY_STRUCTURE
298 static const char *cross_compile = "1";
299 #else
300 static const char *cross_compile = "0";
301 #endif
303 /* Greatest exit code of sub-processes that has been encountered up to
304 now. */
305 static int greatest_status = 1;
307 /* This is the obstack which we use to allocate many strings. */
309 static struct obstack obstack;
311 /* This is the obstack to build an environment variable to pass to
312 collect2 that describes all of the relevant switches of what to
313 pass the compiler in building the list of pointers to constructors
314 and destructors. */
316 static struct obstack collect_obstack;
318 /* Forward declaration for prototypes. */
319 struct path_prefix;
320 struct prefix_list;
322 static void init_spec (void);
323 static void store_arg (const char *, int, int);
324 static void insert_wrapper (const char *);
325 static char *load_specs (const char *);
326 static void read_specs (const char *, bool, bool);
327 static void set_spec (const char *, const char *, bool);
328 static struct compiler *lookup_compiler (const char *, size_t, const char *);
329 static char *build_search_list (const struct path_prefix *, const char *,
330 bool, bool);
331 static void xputenv (const char *);
332 static void putenv_from_prefixes (const struct path_prefix *, const char *,
333 bool);
334 static int access_check (const char *, int);
335 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
336 static void add_prefix (struct path_prefix *, const char *, const char *,
337 int, int, int);
338 static void add_sysrooted_prefix (struct path_prefix *, const char *,
339 const char *, int, int, int);
340 static char *skip_whitespace (char *);
341 static void delete_if_ordinary (const char *);
342 static void delete_temp_files (void);
343 static void delete_failure_queue (void);
344 static void clear_failure_queue (void);
345 static int check_live_switch (int, int);
346 static const char *handle_braces (const char *);
347 static inline bool input_suffix_matches (const char *, const char *);
348 static inline bool switch_matches (const char *, const char *, int);
349 static inline void mark_matching_switches (const char *, const char *, int);
350 static inline void process_marked_switches (void);
351 static const char *process_brace_body (const char *, const char *, const char *, int, int);
352 static const struct spec_function *lookup_spec_function (const char *);
353 static const char *eval_spec_function (const char *, const char *);
354 static const char *handle_spec_function (const char *, bool *);
355 static char *save_string (const char *, int);
356 static void set_collect_gcc_options (void);
357 static int do_spec_1 (const char *, int, const char *);
358 static int do_spec_2 (const char *);
359 static void do_option_spec (const char *, const char *);
360 static void do_self_spec (const char *);
361 static const char *find_file (const char *);
362 static int is_directory (const char *, bool);
363 static const char *validate_switches (const char *, bool);
364 static void validate_all_switches (void);
365 static inline void validate_switches_from_spec (const char *, bool);
366 static void give_switch (int, int);
367 static int default_arg (const char *, int);
368 static void set_multilib_dir (void);
369 static void print_multilib_info (void);
370 static void perror_with_name (const char *);
371 static void display_help (void);
372 static void add_preprocessor_option (const char *, int);
373 static void add_assembler_option (const char *, int);
374 static void add_linker_option (const char *, int);
375 static void process_command (unsigned int, struct cl_decoded_option *);
376 static int execute (void);
377 static void alloc_args (void);
378 static void clear_args (void);
379 static void fatal_signal (int);
380 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
381 static void init_gcc_specs (struct obstack *, const char *, const char *,
382 const char *);
383 #endif
384 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
385 static const char *convert_filename (const char *, int, int);
386 #endif
388 static void try_generate_repro (const char **argv);
389 static const char *getenv_spec_function (int, const char **);
390 static const char *if_exists_spec_function (int, const char **);
391 static const char *if_exists_else_spec_function (int, const char **);
392 static const char *sanitize_spec_function (int, const char **);
393 static const char *replace_outfile_spec_function (int, const char **);
394 static const char *remove_outfile_spec_function (int, const char **);
395 static const char *version_compare_spec_function (int, const char **);
396 static const char *include_spec_function (int, const char **);
397 static const char *find_file_spec_function (int, const char **);
398 static const char *find_plugindir_spec_function (int, const char **);
399 static const char *print_asm_header_spec_function (int, const char **);
400 static const char *compare_debug_dump_opt_spec_function (int, const char **);
401 static const char *compare_debug_self_opt_spec_function (int, const char **);
402 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
403 static const char *pass_through_libs_spec_func (int, const char **);
404 static const char *replace_extension_spec_func (int, const char **);
405 static const char *greater_than_spec_func (int, const char **);
406 static const char *debug_level_greater_than_spec_func (int, const char **);
407 static char *convert_white_space (char *);
409 /* The Specs Language
411 Specs are strings containing lines, each of which (if not blank)
412 is made up of a program name, and arguments separated by spaces.
413 The program name must be exact and start from root, since no path
414 is searched and it is unreliable to depend on the current working directory.
415 Redirection of input or output is not supported; the subprograms must
416 accept filenames saying what files to read and write.
418 In addition, the specs can contain %-sequences to substitute variable text
419 or for conditional text. Here is a table of all defined %-sequences.
420 Note that spaces are not generated automatically around the results of
421 expanding these sequences; therefore, you can concatenate them together
422 or with constant text in a single argument.
424 %% substitute one % into the program name or argument.
425 %i substitute the name of the input file being processed.
426 %b substitute the basename of the input file being processed.
427 This is the substring up to (and not including) the last period
428 and not including the directory unless -save-temps was specified
429 to put temporaries in a different location.
430 %B same as %b, but include the file suffix (text after the last period).
431 %gSUFFIX
432 substitute a file name that has suffix SUFFIX and is chosen
433 once per compilation, and mark the argument a la %d. To reduce
434 exposure to denial-of-service attacks, the file name is now
435 chosen in a way that is hard to predict even when previously
436 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
437 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
438 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
439 had been pre-processed. Previously, %g was simply substituted
440 with a file name chosen once per compilation, without regard
441 to any appended suffix (which was therefore treated just like
442 ordinary text), making such attacks more likely to succeed.
443 %|SUFFIX
444 like %g, but if -pipe is in effect, expands simply to "-".
445 %mSUFFIX
446 like %g, but if -pipe is in effect, expands to nothing. (We have both
447 %| and %m to accommodate differences between system assemblers; see
448 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
449 %uSUFFIX
450 like %g, but generates a new temporary file name even if %uSUFFIX
451 was already seen.
452 %USUFFIX
453 substitutes the last file name generated with %uSUFFIX, generating a
454 new one if there is no such last file name. In the absence of any
455 %uSUFFIX, this is just like %gSUFFIX, except they don't share
456 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
457 would involve the generation of two distinct file names, one
458 for each `%g.s' and another for each `%U.s'. Previously, %U was
459 simply substituted with a file name chosen for the previous %u,
460 without regard to any appended suffix.
461 %jSUFFIX
462 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
463 writable, and if save-temps is off; otherwise, substitute the name
464 of a temporary file, just like %u. This temporary file is not
465 meant for communication between processes, but rather as a junk
466 disposal mechanism.
467 %.SUFFIX
468 substitutes .SUFFIX for the suffixes of a matched switch's args when
469 it is subsequently output with %*. SUFFIX is terminated by the next
470 space or %.
471 %d marks the argument containing or following the %d as a
472 temporary file name, so that file will be deleted if GCC exits
473 successfully. Unlike %g, this contributes no text to the argument.
474 %w marks the argument containing or following the %w as the
475 "output file" of this compilation. This puts the argument
476 into the sequence of arguments that %o will substitute later.
477 %V indicates that this compilation produces no "output file".
478 %W{...}
479 like %{...} but marks the last argument supplied within as a file
480 to be deleted on failure.
481 %@{...}
482 like %{...} but puts the result into a FILE and substitutes @FILE
483 if an @file argument has been supplied.
484 %o substitutes the names of all the output files, with spaces
485 automatically placed around them. You should write spaces
486 around the %o as well or the results are undefined.
487 %o is for use in the specs for running the linker.
488 Input files whose names have no recognized suffix are not compiled
489 at all, but they are included among the output files, so they will
490 be linked.
491 %O substitutes the suffix for object files. Note that this is
492 handled specially when it immediately follows %g, %u, or %U
493 (with or without a suffix argument) because of the need for
494 those to form complete file names. The handling is such that
495 %O is treated exactly as if it had already been substituted,
496 except that %g, %u, and %U do not currently support additional
497 SUFFIX characters following %O as they would following, for
498 example, `.o'.
499 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
500 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
501 and -B options) and -imultilib as necessary.
502 %s current argument is the name of a library or startup file of some sort.
503 Search for that file in a standard list of directories
504 and substitute the full name found.
505 %eSTR Print STR as an error message. STR is terminated by a newline.
506 Use this when inconsistent options are detected.
507 %nSTR Print STR as a notice. STR is terminated by a newline.
508 %x{OPTION} Accumulate an option for %X.
509 %X Output the accumulated linker options specified by compilations.
510 %Y Output the accumulated assembler options specified by compilations.
511 %Z Output the accumulated preprocessor options specified by compilations.
512 %a process ASM_SPEC as a spec.
513 This allows config.h to specify part of the spec for running as.
514 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
515 used here. This can be used to run a post-processor after the
516 assembler has done its job.
517 %D Dump out a -L option for each directory in startfile_prefixes.
518 If multilib_dir is set, extra entries are generated with it affixed.
519 %l process LINK_SPEC as a spec.
520 %L process LIB_SPEC as a spec.
521 %M Output multilib_os_dir.
522 %G process LIBGCC_SPEC as a spec.
523 %R Output the concatenation of target_system_root and
524 target_sysroot_suffix.
525 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
526 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
527 %C process CPP_SPEC as a spec.
528 %1 process CC1_SPEC as a spec.
529 %2 process CC1PLUS_SPEC as a spec.
530 %* substitute the variable part of a matched option. (See below.)
531 Note that each comma in the substituted string is replaced by
532 a single space. A space is appended after the last substition
533 unless there is more text in current sequence.
534 %<S remove all occurrences of -S from the command line.
535 Note - this command is position dependent. % commands in the
536 spec string before this one will see -S, % commands in the
537 spec string after this one will not.
538 %>S Similar to "%<S", but keep it in the GCC command line.
539 %<S* remove all occurrences of all switches beginning with -S from the
540 command line.
541 %:function(args)
542 Call the named function FUNCTION, passing it ARGS. ARGS is
543 first processed as a nested spec string, then split into an
544 argument vector in the usual fashion. The function returns
545 a string which is processed as if it had appeared literally
546 as part of the current spec.
547 %{S} substitutes the -S switch, if that switch was given to GCC.
548 If that switch was not specified, this substitutes nothing.
549 Here S is a metasyntactic variable.
550 %{S*} substitutes all the switches specified to GCC whose names start
551 with -S. This is used for -o, -I, etc; switches that take
552 arguments. GCC considers `-o foo' as being one switch whose
553 name starts with `o'. %{o*} would substitute this text,
554 including the space; thus, two arguments would be generated.
555 %{S*&T*} likewise, but preserve order of S and T options (the order
556 of S and T in the spec is not significant). Can be any number
557 of ampersand-separated variables; for each the wild card is
558 optional. Useful for CPP as %{D*&U*&A*}.
560 %{S:X} substitutes X, if the -S switch was given to GCC.
561 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
562 %{S*:X} substitutes X if one or more switches whose names start
563 with -S was given to GCC. Normally X is substituted only
564 once, no matter how many such switches appeared. However,
565 if %* appears somewhere in X, then X will be substituted
566 once for each matching switch, with the %* replaced by the
567 part of that switch that matched the '*'. A space will be
568 appended after the last substition unless there is more
569 text in current sequence.
570 %{.S:X} substitutes X, if processing a file with suffix S.
571 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
572 %{,S:X} substitutes X, if processing a file which will use spec S.
573 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
575 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
576 combined with '!', '.', ',', and '*' as above binding stronger
577 than the OR.
578 If %* appears in X, all of the alternatives must be starred, and
579 only the first matching alternative is substituted.
580 %{%:function(args):X}
581 Call function named FUNCTION with args ARGS. If the function
582 returns non-NULL, then X is substituted, if it returns
583 NULL, it isn't substituted.
584 %{S:X; if S was given to GCC, substitutes X;
585 T:Y; else if T was given to GCC, substitutes Y;
586 :D} else substitutes D. There can be as many clauses as you need.
587 This may be combined with '.', '!', ',', '|', and '*' as above.
589 %(Spec) processes a specification defined in a specs file as *Spec:
591 The switch matching text S in a %{S}, %{S:X}, or similar construct can use
592 a backslash to ignore the special meaning of the character following it,
593 thus allowing literal matching of a character that is otherwise specially
594 treated. For example, %{std=iso9899\:1999:X} substitutes X if the
595 -std=iso9899:1999 option is given.
597 The conditional text X in a %{S:X} or similar construct may contain
598 other nested % constructs or spaces, or even newlines. They are
599 processed as usual, as described above. Trailing white space in X is
600 ignored. White space may also appear anywhere on the left side of the
601 colon in these constructs, except between . or * and the corresponding
602 word.
604 The -O, -f, -g, -m, and -W switches are handled specifically in these
605 constructs. If another value of -O or the negated form of a -f, -m, or
606 -W switch is found later in the command line, the earlier switch
607 value is ignored, except with {S*} where S is just one letter; this
608 passes all matching options.
610 The character | at the beginning of the predicate text is used to indicate
611 that a command should be piped to the following command, but only if -pipe
612 is specified.
614 Note that it is built into GCC which switches take arguments and which
615 do not. You might think it would be useful to generalize this to
616 allow each compiler's spec to say which switches take arguments. But
617 this cannot be done in a consistent fashion. GCC cannot even decide
618 which input files have been specified without knowing which switches
619 take arguments, and it must know which input files to compile in order
620 to tell which compilers to run.
622 GCC also knows implicitly that arguments starting in `-l' are to be
623 treated as compiler output files, and passed to the linker in their
624 proper position among the other output files. */
626 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
628 /* config.h can define ASM_SPEC to provide extra args to the assembler
629 or extra switch-translations. */
630 #ifndef ASM_SPEC
631 #define ASM_SPEC ""
632 #endif
634 /* config.h can define ASM_FINAL_SPEC to run a post processor after
635 the assembler has run. */
636 #ifndef ASM_FINAL_SPEC
637 #define ASM_FINAL_SPEC \
638 "%{gsplit-dwarf: \n\
639 objcopy --extract-dwo \
640 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
641 %{c:%{o*:%:replace-extension(%{o*:%*} .dwo)}%{!o*:%b.dwo}}%{!c:%b.dwo} \n\
642 objcopy --strip-dwo \
643 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
645 #endif
647 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
648 or extra switch-translations. */
649 #ifndef CPP_SPEC
650 #define CPP_SPEC ""
651 #endif
653 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
654 or extra switch-translations. */
655 #ifndef CC1_SPEC
656 #define CC1_SPEC ""
657 #endif
659 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
660 or extra switch-translations. */
661 #ifndef CC1PLUS_SPEC
662 #define CC1PLUS_SPEC ""
663 #endif
665 /* config.h can define LINK_SPEC to provide extra args to the linker
666 or extra switch-translations. */
667 #ifndef LINK_SPEC
668 #define LINK_SPEC ""
669 #endif
671 /* config.h can define LIB_SPEC to override the default libraries. */
672 #ifndef LIB_SPEC
673 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
674 #endif
676 /* When using -fsplit-stack we need to wrap pthread_create, in order
677 to initialize the stack guard. We always use wrapping, rather than
678 shared library ordering, and we keep the wrapper function in
679 libgcc. This is not yet a real spec, though it could become one;
680 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
681 only works with GNU ld and gold. */
682 #ifdef HAVE_GOLD_NON_DEFAULT_SPLIT_STACK
683 #define STACK_SPLIT_SPEC " %{fsplit-stack: -fuse-ld=gold --wrap=pthread_create}"
684 #else
685 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
686 #endif
688 #ifndef LIBASAN_SPEC
689 #define STATIC_LIBASAN_LIBS \
690 " %{static-libasan|static:%:include(libsanitizer.spec)%(link_libasan)}"
691 #ifdef LIBASAN_EARLY_SPEC
692 #define LIBASAN_SPEC STATIC_LIBASAN_LIBS
693 #elif defined(HAVE_LD_STATIC_DYNAMIC)
694 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
695 "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
696 STATIC_LIBASAN_LIBS
697 #else
698 #define LIBASAN_SPEC "-lasan" STATIC_LIBASAN_LIBS
699 #endif
700 #endif
702 #ifndef LIBASAN_EARLY_SPEC
703 #define LIBASAN_EARLY_SPEC ""
704 #endif
706 #ifndef LIBTSAN_SPEC
707 #define STATIC_LIBTSAN_LIBS \
708 " %{static-libtsan|static:%:include(libsanitizer.spec)%(link_libtsan)}"
709 #ifdef LIBTSAN_EARLY_SPEC
710 #define LIBTSAN_SPEC STATIC_LIBTSAN_LIBS
711 #elif defined(HAVE_LD_STATIC_DYNAMIC)
712 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
713 "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}" \
714 STATIC_LIBTSAN_LIBS
715 #else
716 #define LIBTSAN_SPEC "-ltsan" STATIC_LIBTSAN_LIBS
717 #endif
718 #endif
720 #ifndef LIBTSAN_EARLY_SPEC
721 #define LIBTSAN_EARLY_SPEC ""
722 #endif
724 #ifndef LIBLSAN_SPEC
725 #define STATIC_LIBLSAN_LIBS \
726 " %{static-liblsan|static:%:include(libsanitizer.spec)%(link_liblsan)}"
727 #ifdef LIBLSAN_EARLY_SPEC
728 #define LIBLSAN_SPEC STATIC_LIBLSAN_LIBS
729 #elif defined(HAVE_LD_STATIC_DYNAMIC)
730 #define LIBLSAN_SPEC "%{static-liblsan:" LD_STATIC_OPTION \
731 "} -llsan %{static-liblsan:" LD_DYNAMIC_OPTION "}" \
732 STATIC_LIBLSAN_LIBS
733 #else
734 #define LIBLSAN_SPEC "-llsan" STATIC_LIBLSAN_LIBS
735 #endif
736 #endif
738 #ifndef LIBLSAN_EARLY_SPEC
739 #define LIBLSAN_EARLY_SPEC ""
740 #endif
742 #ifndef LIBUBSAN_SPEC
743 #define STATIC_LIBUBSAN_LIBS \
744 " %{static-libubsan|static:%:include(libsanitizer.spec)%(link_libubsan)}"
745 #ifdef HAVE_LD_STATIC_DYNAMIC
746 #define LIBUBSAN_SPEC "%{static-libubsan:" LD_STATIC_OPTION \
747 "} -lubsan %{static-libubsan:" LD_DYNAMIC_OPTION "}" \
748 STATIC_LIBUBSAN_LIBS
749 #else
750 #define LIBUBSAN_SPEC "-lubsan" STATIC_LIBUBSAN_LIBS
751 #endif
752 #endif
754 /* Linker options for compressed debug sections. */
755 #if HAVE_LD_COMPRESS_DEBUG == 0
756 /* No linker support. */
757 #define LINK_COMPRESS_DEBUG_SPEC \
758 " %{gz*:%e-gz is not supported in this configuration} "
759 #elif HAVE_LD_COMPRESS_DEBUG == 1
760 /* GNU style on input, GNU ld options. Reject, not useful. */
761 #define LINK_COMPRESS_DEBUG_SPEC \
762 " %{gz*:%e-gz is not supported in this configuration} "
763 #elif HAVE_LD_COMPRESS_DEBUG == 2
764 /* GNU style, GNU gold options. */
765 #define LINK_COMPRESS_DEBUG_SPEC \
766 " %{gz|gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
767 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
768 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
769 #elif HAVE_LD_COMPRESS_DEBUG == 3
770 /* ELF gABI style. */
771 #define LINK_COMPRESS_DEBUG_SPEC \
772 " %{gz|gz=zlib:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
773 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
774 " %{gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
775 #else
776 #error Unknown value for HAVE_LD_COMPRESS_DEBUG.
777 #endif
779 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
780 included. */
781 #ifndef LIBGCC_SPEC
782 #if defined(REAL_LIBGCC_SPEC)
783 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
784 #elif defined(LINK_LIBGCC_SPECIAL_1)
785 /* Have gcc do the search for libgcc.a. */
786 #define LIBGCC_SPEC "libgcc.a%s"
787 #else
788 #define LIBGCC_SPEC "-lgcc"
789 #endif
790 #endif
792 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
793 #ifndef STARTFILE_SPEC
794 #define STARTFILE_SPEC \
795 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
796 #endif
798 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
799 #ifndef ENDFILE_SPEC
800 #define ENDFILE_SPEC ""
801 #endif
803 #ifndef LINKER_NAME
804 #define LINKER_NAME "collect2"
805 #endif
807 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
808 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
809 #else
810 #define ASM_MAP ""
811 #endif
813 /* Assembler options for compressed debug sections. */
814 #if HAVE_LD_COMPRESS_DEBUG < 2
815 /* Reject if the linker cannot write compressed debug sections. */
816 #define ASM_COMPRESS_DEBUG_SPEC \
817 " %{gz*:%e-gz is not supported in this configuration} "
818 #else /* HAVE_LD_COMPRESS_DEBUG >= 2 */
819 #if HAVE_AS_COMPRESS_DEBUG == 0
820 /* No assembler support. Ignore silently. */
821 #define ASM_COMPRESS_DEBUG_SPEC \
822 " %{gz*:} "
823 #elif HAVE_AS_COMPRESS_DEBUG == 1
824 /* GNU style, GNU as options. */
825 #define ASM_COMPRESS_DEBUG_SPEC \
826 " %{gz|gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "}" \
827 " %{gz=none:" AS_NO_COMPRESS_DEBUG_OPTION "}" \
828 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
829 #elif HAVE_AS_COMPRESS_DEBUG == 2
830 /* ELF gABI style. */
831 #define ASM_COMPRESS_DEBUG_SPEC \
832 " %{gz|gz=zlib:" AS_COMPRESS_DEBUG_OPTION "=zlib}" \
833 " %{gz=none:" AS_COMPRESS_DEBUG_OPTION "=none}" \
834 " %{gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
835 #else
836 #error Unknown value for HAVE_AS_COMPRESS_DEBUG.
837 #endif
838 #endif /* HAVE_LD_COMPRESS_DEBUG >= 2 */
840 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
841 to the assembler. */
842 #ifndef ASM_DEBUG_SPEC
843 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
844 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
845 # define ASM_DEBUG_SPEC \
846 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
847 ? "%{%:debug-level-gt(0):" \
848 "%{gdwarf*:--gdwarf2}%{!gdwarf*:%{g*:--gstabs}}}" ASM_MAP \
849 : "%{%:debug-level-gt(0):" \
850 "%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
851 # else
852 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
853 # define ASM_DEBUG_SPEC "%{g*:%{%:debug-level-gt(0):--gstabs}}" ASM_MAP
854 # endif
855 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
856 # define ASM_DEBUG_SPEC "%{g*:%{%:debug-level-gt(0):--gdwarf2}}" ASM_MAP
857 # endif
858 # endif
859 #endif
860 #ifndef ASM_DEBUG_SPEC
861 # define ASM_DEBUG_SPEC ""
862 #endif
864 /* Here is the spec for running the linker, after compiling all files. */
866 /* This is overridable by the target in case they need to specify the
867 -lgcc and -lc order specially, yet not require them to override all
868 of LINK_COMMAND_SPEC. */
869 #ifndef LINK_GCC_C_SEQUENCE_SPEC
870 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
871 #endif
873 #ifndef LINK_SSP_SPEC
874 #ifdef TARGET_LIBC_PROVIDES_SSP
875 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
876 "|fstack-protector-strong|fstack-protector-explicit:}"
877 #else
878 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
879 "|fstack-protector-strong|fstack-protector-explicit" \
880 ":-lssp_nonshared -lssp}"
881 #endif
882 #endif
884 #ifdef ENABLE_DEFAULT_PIE
885 #define PIE_SPEC "!no-pie"
886 #define NO_FPIE1_SPEC "fno-pie"
887 #define FPIE1_SPEC NO_FPIE1_SPEC ":;"
888 #define NO_FPIE2_SPEC "fno-PIE"
889 #define FPIE2_SPEC NO_FPIE2_SPEC ":;"
890 #define NO_FPIE_SPEC NO_FPIE1_SPEC "|" NO_FPIE2_SPEC
891 #define FPIE_SPEC NO_FPIE_SPEC ":;"
892 #define NO_FPIC1_SPEC "fno-pic"
893 #define FPIC1_SPEC NO_FPIC1_SPEC ":;"
894 #define NO_FPIC2_SPEC "fno-PIC"
895 #define FPIC2_SPEC NO_FPIC2_SPEC ":;"
896 #define NO_FPIC_SPEC NO_FPIC1_SPEC "|" NO_FPIC2_SPEC
897 #define FPIC_SPEC NO_FPIC_SPEC ":;"
898 #define NO_FPIE1_AND_FPIC1_SPEC NO_FPIE1_SPEC "|" NO_FPIC1_SPEC
899 #define FPIE1_OR_FPIC1_SPEC NO_FPIE1_AND_FPIC1_SPEC ":;"
900 #define NO_FPIE2_AND_FPIC2_SPEC NO_FPIE2_SPEC "|" NO_FPIC2_SPEC
901 #define FPIE2_OR_FPIC2_SPEC NO_FPIE2_AND_FPIC2_SPEC ":;"
902 #define NO_FPIE_AND_FPIC_SPEC NO_FPIE_SPEC "|" NO_FPIC_SPEC
903 #define FPIE_OR_FPIC_SPEC NO_FPIE_AND_FPIC_SPEC ":;"
904 #else
905 #define PIE_SPEC "pie"
906 #define FPIE1_SPEC "fpie"
907 #define NO_FPIE1_SPEC FPIE1_SPEC ":;"
908 #define FPIE2_SPEC "fPIE"
909 #define NO_FPIE2_SPEC FPIE2_SPEC ":;"
910 #define FPIE_SPEC FPIE1_SPEC "|" FPIE2_SPEC
911 #define NO_FPIE_SPEC FPIE_SPEC ":;"
912 #define FPIC1_SPEC "fpic"
913 #define NO_FPIC1_SPEC FPIC1_SPEC ":;"
914 #define FPIC2_SPEC "fPIC"
915 #define NO_FPIC2_SPEC FPIC2_SPEC ":;"
916 #define FPIC_SPEC FPIC1_SPEC "|" FPIC2_SPEC
917 #define NO_FPIC_SPEC FPIC_SPEC ":;"
918 #define FPIE1_OR_FPIC1_SPEC FPIE1_SPEC "|" FPIC1_SPEC
919 #define NO_FPIE1_AND_FPIC1_SPEC FPIE1_OR_FPIC1_SPEC ":;"
920 #define FPIE2_OR_FPIC2_SPEC FPIE2_SPEC "|" FPIC2_SPEC
921 #define NO_FPIE2_AND_FPIC2_SPEC FPIE1_OR_FPIC2_SPEC ":;"
922 #define FPIE_OR_FPIC_SPEC FPIE_SPEC "|" FPIC_SPEC
923 #define NO_FPIE_AND_FPIC_SPEC FPIE_OR_FPIC_SPEC ":;"
924 #endif
926 #ifndef LINK_PIE_SPEC
927 #ifdef HAVE_LD_PIE
928 #ifndef LD_PIE_SPEC
929 #define LD_PIE_SPEC "-pie"
930 #endif
931 #else
932 #define LD_PIE_SPEC ""
933 #endif
934 #define LINK_PIE_SPEC "%{static|shared|r:;" PIE_SPEC ":" LD_PIE_SPEC "} "
935 #endif
937 #ifndef LINK_BUILDID_SPEC
938 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
939 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
940 # endif
941 #endif
943 /* Conditional to test whether the LTO plugin is used or not.
944 FIXME: For slim LTO we will need to enable plugin unconditionally. This
945 still cause problems with PLUGIN_LD != LD and when plugin is built but
946 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
947 plugin only when LTO is enabled. We still honor explicit
948 -fuse-linker-plugin if the linker used understands -plugin. */
950 /* The linker has some plugin support. */
951 #if HAVE_LTO_PLUGIN > 0
952 /* The linker used has full plugin support, use LTO plugin by default. */
953 #if HAVE_LTO_PLUGIN == 2
954 #define PLUGIN_COND "!fno-use-linker-plugin:%{!fno-lto"
955 #define PLUGIN_COND_CLOSE "}"
956 #else
957 /* The linker used has limited plugin support, use LTO plugin with explicit
958 -fuse-linker-plugin. */
959 #define PLUGIN_COND "fuse-linker-plugin"
960 #define PLUGIN_COND_CLOSE ""
961 #endif
962 #define LINK_PLUGIN_SPEC \
963 "%{" PLUGIN_COND": \
964 -plugin %(linker_plugin_file) \
965 -plugin-opt=%(lto_wrapper) \
966 -plugin-opt=-fresolution=%u.res \
967 %{flinker-output=*:-plugin-opt=-linker-output-known} \
968 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
969 }" PLUGIN_COND_CLOSE
970 #else
971 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
972 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
973 %e-fuse-linker-plugin is not supported in this configuration}"
974 #endif
976 /* Linker command line options for -fsanitize= early on the command line. */
977 #ifndef SANITIZER_EARLY_SPEC
978 #define SANITIZER_EARLY_SPEC "\
979 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_EARLY_SPEC "} \
980 %{%:sanitize(thread):" LIBTSAN_EARLY_SPEC "} \
981 %{%:sanitize(leak):" LIBLSAN_EARLY_SPEC "}}}"
982 #endif
984 /* Linker command line options for -fsanitize= late on the command line. */
985 #ifndef SANITIZER_SPEC
986 #define SANITIZER_SPEC "\
987 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_SPEC "\
988 %{static:%ecannot specify -static with -fsanitize=address}}\
989 %{%:sanitize(thread):" LIBTSAN_SPEC "\
990 %{static:%ecannot specify -static with -fsanitize=thread}}\
991 %{%:sanitize(undefined):" LIBUBSAN_SPEC "}\
992 %{%:sanitize(leak):" LIBLSAN_SPEC "}}}"
993 #endif
995 #ifndef POST_LINK_SPEC
996 #define POST_LINK_SPEC ""
997 #endif
999 /* This is the spec to use, once the code for creating the vtable
1000 verification runtime library, libvtv.so, has been created. Currently
1001 the vtable verification runtime functions are in libstdc++, so we use
1002 the spec just below this one. */
1003 #ifndef VTABLE_VERIFICATION_SPEC
1004 #if ENABLE_VTABLE_VERIFY
1005 #define VTABLE_VERIFICATION_SPEC "\
1006 %{!nostdlib:%{fvtable-verify=std: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}\
1007 %{fvtable-verify=preinit: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}}"
1008 #else
1009 #define VTABLE_VERIFICATION_SPEC "\
1010 %{fvtable-verify=none:} \
1011 %{fvtable-verify=std: \
1012 %e-fvtable-verify=std is not supported in this configuration} \
1013 %{fvtable-verify=preinit: \
1014 %e-fvtable-verify=preinit is not supported in this configuration}"
1015 #endif
1016 #endif
1018 /* -u* was put back because both BSD and SysV seem to support it. */
1019 /* %{static|no-pie|static-pie:} simply prevents an error message:
1020 1. If the target machine doesn't handle -static.
1021 2. If PIE isn't enabled by default.
1022 3. If the target machine doesn't handle -static-pie.
1024 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
1025 scripts which exist in user specified directories, or in standard
1026 directories. */
1027 /* We pass any -flto flags on to the linker, which is expected
1028 to understand them. In practice, this means it had better be collect2. */
1029 /* %{e*} includes -export-dynamic; see comment in common.opt. */
1030 #ifndef LINK_COMMAND_SPEC
1031 #define LINK_COMMAND_SPEC "\
1032 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
1033 %(linker) " \
1034 LINK_PLUGIN_SPEC \
1035 "%{flto|flto=*:%<fcompare-debug*} \
1036 %{flto} %{fno-lto} %{flto=*} %l " LINK_PIE_SPEC \
1037 "%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
1038 "%X %{o*} %{e*} %{N} %{n} %{r}\
1039 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}} \
1040 %{static|no-pie|static-pie:} %@{L*} %(mfwrap) %(link_libgcc) " \
1041 VTABLE_VERIFICATION_SPEC " " SANITIZER_EARLY_SPEC " %o "" \
1042 %{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1):\
1043 %:include(libgomp.spec)%(link_gomp)}\
1044 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
1045 %(mflib) " STACK_SPLIT_SPEC "\
1046 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
1047 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
1048 %{!nostdlib:%{!nostartfiles:%E}} %{T*} \n%(post_link) }}}}}}"
1049 #endif
1051 #ifndef LINK_LIBGCC_SPEC
1052 /* Generate -L options for startfile prefix list. */
1053 # define LINK_LIBGCC_SPEC "%D"
1054 #endif
1056 #ifndef STARTFILE_PREFIX_SPEC
1057 # define STARTFILE_PREFIX_SPEC ""
1058 #endif
1060 #ifndef SYSROOT_SPEC
1061 # define SYSROOT_SPEC "--sysroot=%R"
1062 #endif
1064 #ifndef SYSROOT_SUFFIX_SPEC
1065 # define SYSROOT_SUFFIX_SPEC ""
1066 #endif
1068 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
1069 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
1070 #endif
1072 static const char *asm_debug = ASM_DEBUG_SPEC;
1073 static const char *cpp_spec = CPP_SPEC;
1074 static const char *cc1_spec = CC1_SPEC;
1075 static const char *cc1plus_spec = CC1PLUS_SPEC;
1076 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
1077 static const char *link_ssp_spec = LINK_SSP_SPEC;
1078 static const char *asm_spec = ASM_SPEC;
1079 static const char *asm_final_spec = ASM_FINAL_SPEC;
1080 static const char *link_spec = LINK_SPEC;
1081 static const char *lib_spec = LIB_SPEC;
1082 static const char *link_gomp_spec = "";
1083 static const char *libgcc_spec = LIBGCC_SPEC;
1084 static const char *endfile_spec = ENDFILE_SPEC;
1085 static const char *startfile_spec = STARTFILE_SPEC;
1086 static const char *linker_name_spec = LINKER_NAME;
1087 static const char *linker_plugin_file_spec = "";
1088 static const char *lto_wrapper_spec = "";
1089 static const char *lto_gcc_spec = "";
1090 static const char *post_link_spec = POST_LINK_SPEC;
1091 static const char *link_command_spec = LINK_COMMAND_SPEC;
1092 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
1093 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
1094 static const char *sysroot_spec = SYSROOT_SPEC;
1095 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
1096 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
1097 static const char *self_spec = "";
1099 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
1100 There should be no need to override these in target dependent files,
1101 but we need to copy them to the specs file so that newer versions
1102 of the GCC driver can correctly drive older tool chains with the
1103 appropriate -B options. */
1105 /* When cpplib handles traditional preprocessing, get rid of this, and
1106 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
1107 that we default the front end language better. */
1108 static const char *trad_capable_cpp =
1109 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
1111 /* We don't wrap .d files in %W{} since a missing .d file, and
1112 therefore no dependency entry, confuses make into thinking a .o
1113 file that happens to exist is up-to-date. */
1114 static const char *cpp_unique_options =
1115 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %@{I*&F*} %{P} %I\
1116 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
1117 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
1118 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
1119 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
1120 %{remap} %{g3|ggdb3|gstabs3|gxcoff3|gvms3:-dD}\
1121 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1122 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
1123 %{E|M|MM:%W{o*}}";
1125 /* This contains cpp options which are common with cc1_options and are passed
1126 only when preprocessing only to avoid duplication. We pass the cc1 spec
1127 options to the preprocessor so that it the cc1 spec may manipulate
1128 options used to set target flags. Those special target flags settings may
1129 in turn cause preprocessor symbols to be defined specially. */
1130 static const char *cpp_options =
1131 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
1132 %{f*} %{g*:%{%:debug-level-gt(0):%{g*}\
1133 %{!fno-working-directory:-fworking-directory}}} %{O*}\
1134 %{undef} %{save-temps*:-fpch-preprocess}";
1136 /* This contains cpp options which are not passed when the preprocessor
1137 output will be used by another program. */
1138 static const char *cpp_debug_options = "%{d*}";
1140 /* NB: This is shared amongst all front-ends, except for Ada. */
1141 static const char *cc1_options =
1142 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
1143 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1144 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
1145 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
1146 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
1147 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
1148 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
1149 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
1150 %{-target-help:--target-help}\
1151 %{-version:--version}\
1152 %{-help=*:--help=%*}\
1153 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
1154 %{fsyntax-only:-o %j} %{-param*}\
1155 %{coverage:-fprofile-arcs -ftest-coverage}\
1156 %{fprofile-arcs|fprofile-generate*|coverage:\
1157 %{!fprofile-update=single:\
1158 %{pthread:-fprofile-update=prefer-atomic}}}";
1160 static const char *asm_options =
1161 "%{-target-help:%:print-asm-header()} "
1162 #if HAVE_GNU_AS
1163 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
1164 to the assembler equivalents. */
1165 "%{v} %{w:-W} %{I*} "
1166 #endif
1167 ASM_COMPRESS_DEBUG_SPEC
1168 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
1170 static const char *invoke_as =
1171 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1172 "%{!fwpa*:\
1173 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1174 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
1176 #else
1177 "%{!fwpa*:\
1178 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1179 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
1181 #endif
1183 /* Some compilers have limits on line lengths, and the multilib_select
1184 and/or multilib_matches strings can be very long, so we build them at
1185 run time. */
1186 static struct obstack multilib_obstack;
1187 static const char *multilib_select;
1188 static const char *multilib_matches;
1189 static const char *multilib_defaults;
1190 static const char *multilib_exclusions;
1191 static const char *multilib_reuse;
1193 /* Check whether a particular argument is a default argument. */
1195 #ifndef MULTILIB_DEFAULTS
1196 #define MULTILIB_DEFAULTS { "" }
1197 #endif
1199 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
1201 #ifndef DRIVER_SELF_SPECS
1202 #define DRIVER_SELF_SPECS ""
1203 #endif
1205 /* Linking to libgomp implies pthreads. This is particularly important
1206 for targets that use different start files and suchlike. */
1207 #ifndef GOMP_SELF_SPECS
1208 #define GOMP_SELF_SPECS \
1209 "%{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1): " \
1210 "-pthread}"
1211 #endif
1213 /* Likewise for -fgnu-tm. */
1214 #ifndef GTM_SELF_SPECS
1215 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
1216 #endif
1218 static const char *const driver_self_specs[] = {
1219 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
1220 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS
1223 #ifndef OPTION_DEFAULT_SPECS
1224 #define OPTION_DEFAULT_SPECS { "", "" }
1225 #endif
1227 struct default_spec
1229 const char *name;
1230 const char *spec;
1233 static const struct default_spec
1234 option_default_specs[] = { OPTION_DEFAULT_SPECS };
1236 struct user_specs
1238 struct user_specs *next;
1239 const char *filename;
1242 static struct user_specs *user_specs_head, *user_specs_tail;
1245 /* Record the mapping from file suffixes for compilation specs. */
1247 struct compiler
1249 const char *suffix; /* Use this compiler for input files
1250 whose names end in this suffix. */
1252 const char *spec; /* To use this compiler, run this spec. */
1254 const char *cpp_spec; /* If non-NULL, substitute this spec
1255 for `%C', rather than the usual
1256 cpp_spec. */
1257 int combinable; /* If nonzero, compiler can deal with
1258 multiple source files at once (IMA). */
1259 int needs_preprocessing; /* If nonzero, source files need to
1260 be run through a preprocessor. */
1263 /* Pointer to a vector of `struct compiler' that gives the spec for
1264 compiling a file, based on its suffix.
1265 A file that does not end in any of these suffixes will be passed
1266 unchanged to the loader and nothing else will be done to it.
1268 An entry containing two 0s is used to terminate the vector.
1270 If multiple entries match a file, the last matching one is used. */
1272 static struct compiler *compilers;
1274 /* Number of entries in `compilers', not counting the null terminator. */
1276 static int n_compilers;
1278 /* The default list of file name suffixes and their compilation specs. */
1280 static const struct compiler default_compilers[] =
1282 /* Add lists of suffixes of known languages here. If those languages
1283 were not present when we built the driver, we will hit these copies
1284 and be given a more meaningful error than "file not used since
1285 linking is not done". */
1286 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
1287 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
1288 {".mii", "#Objective-C++", 0, 0, 0},
1289 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
1290 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
1291 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
1292 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
1293 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
1294 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
1295 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
1296 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
1297 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
1298 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
1299 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
1300 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1301 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1302 {".r", "#Ratfor", 0, 0, 0},
1303 {".go", "#Go", 0, 1, 0},
1304 /* Next come the entries for C. */
1305 {".c", "@c", 0, 0, 1},
1306 {"@c",
1307 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1308 external preprocessor if -save-temps is given. */
1309 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1310 %{!E:%{!M:%{!MM:\
1311 %{traditional:\
1312 %eGNU C no longer supports -traditional without -E}\
1313 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1314 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1315 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1316 %(cc1_options)}\
1317 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1318 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1319 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1320 {"-",
1321 "%{!E:%e-E or -x required when input is from standard input}\
1322 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1323 {".h", "@c-header", 0, 0, 0},
1324 {"@c-header",
1325 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1326 external preprocessor if -save-temps is given. */
1327 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1328 %{!E:%{!M:%{!MM:\
1329 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1330 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1331 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1332 %(cc1_options)\
1333 %{!fsyntax-only:%{!S:-o %g.s} \
1334 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1335 %W{o*:--output-pch=%*}}%V}}\
1336 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1337 cc1 %(cpp_unique_options) %(cc1_options)\
1338 %{!fsyntax-only:%{!S:-o %g.s} \
1339 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1340 %W{o*:--output-pch=%*}}%V}}}}}}}", 0, 0, 0},
1341 {".i", "@cpp-output", 0, 0, 0},
1342 {"@cpp-output",
1343 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1344 {".s", "@assembler", 0, 0, 0},
1345 {"@assembler",
1346 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1347 {".sx", "@assembler-with-cpp", 0, 0, 0},
1348 {".S", "@assembler-with-cpp", 0, 0, 0},
1349 {"@assembler-with-cpp",
1350 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1351 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1352 %{E|M|MM:%(cpp_debug_options)}\
1353 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1354 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1355 #else
1356 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1357 %{E|M|MM:%(cpp_debug_options)}\
1358 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1359 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1360 #endif
1361 , 0, 0, 0},
1363 #include "specs.h"
1364 /* Mark end of table. */
1365 {0, 0, 0, 0, 0}
1368 /* Number of elements in default_compilers, not counting the terminator. */
1370 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1372 typedef char *char_p; /* For DEF_VEC_P. */
1374 /* A vector of options to give to the linker.
1375 These options are accumulated by %x,
1376 and substituted into the linker command with %X. */
1377 static vec<char_p> linker_options;
1379 /* A vector of options to give to the assembler.
1380 These options are accumulated by -Wa,
1381 and substituted into the assembler command with %Y. */
1382 static vec<char_p> assembler_options;
1384 /* A vector of options to give to the preprocessor.
1385 These options are accumulated by -Wp,
1386 and substituted into the preprocessor command with %Z. */
1387 static vec<char_p> preprocessor_options;
1389 static char *
1390 skip_whitespace (char *p)
1392 while (1)
1394 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1395 be considered whitespace. */
1396 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1397 return p + 1;
1398 else if (*p == '\n' || *p == ' ' || *p == '\t')
1399 p++;
1400 else if (*p == '#')
1402 while (*p != '\n')
1403 p++;
1404 p++;
1406 else
1407 break;
1410 return p;
1412 /* Structures to keep track of prefixes to try when looking for files. */
1414 struct prefix_list
1416 const char *prefix; /* String to prepend to the path. */
1417 struct prefix_list *next; /* Next in linked list. */
1418 int require_machine_suffix; /* Don't use without machine_suffix. */
1419 /* 2 means try both machine_suffix and just_machine_suffix. */
1420 int priority; /* Sort key - priority within list. */
1421 int os_multilib; /* 1 if OS multilib scheme should be used,
1422 0 for GCC multilib scheme. */
1425 struct path_prefix
1427 struct prefix_list *plist; /* List of prefixes to try */
1428 int max_len; /* Max length of a prefix in PLIST */
1429 const char *name; /* Name of this list (used in config stuff) */
1432 /* List of prefixes to try when looking for executables. */
1434 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1436 /* List of prefixes to try when looking for startup (crt0) files. */
1438 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1440 /* List of prefixes to try when looking for include files. */
1442 static struct path_prefix include_prefixes = { 0, 0, "include" };
1444 /* Suffix to attach to directories searched for commands.
1445 This looks like `MACHINE/VERSION/'. */
1447 static const char *machine_suffix = 0;
1449 /* Suffix to attach to directories searched for commands.
1450 This is just `MACHINE/'. */
1452 static const char *just_machine_suffix = 0;
1454 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1456 static const char *gcc_exec_prefix;
1458 /* Adjusted value of standard_libexec_prefix. */
1460 static const char *gcc_libexec_prefix;
1462 /* Default prefixes to attach to command names. */
1464 #ifndef STANDARD_STARTFILE_PREFIX_1
1465 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1466 #endif
1467 #ifndef STANDARD_STARTFILE_PREFIX_2
1468 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1469 #endif
1471 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1472 #undef MD_EXEC_PREFIX
1473 #undef MD_STARTFILE_PREFIX
1474 #undef MD_STARTFILE_PREFIX_1
1475 #endif
1477 /* If no prefixes defined, use the null string, which will disable them. */
1478 #ifndef MD_EXEC_PREFIX
1479 #define MD_EXEC_PREFIX ""
1480 #endif
1481 #ifndef MD_STARTFILE_PREFIX
1482 #define MD_STARTFILE_PREFIX ""
1483 #endif
1484 #ifndef MD_STARTFILE_PREFIX_1
1485 #define MD_STARTFILE_PREFIX_1 ""
1486 #endif
1488 /* These directories are locations set at configure-time based on the
1489 --prefix option provided to configure. Their initializers are
1490 defined in Makefile.in. These paths are not *directly* used when
1491 gcc_exec_prefix is set because, in that case, we know where the
1492 compiler has been installed, and use paths relative to that
1493 location instead. */
1494 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1495 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1496 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1497 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1499 /* For native compilers, these are well-known paths containing
1500 components that may be provided by the system. For cross
1501 compilers, these paths are not used. */
1502 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1503 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1504 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1505 static const char *const standard_startfile_prefix_1
1506 = STANDARD_STARTFILE_PREFIX_1;
1507 static const char *const standard_startfile_prefix_2
1508 = STANDARD_STARTFILE_PREFIX_2;
1510 /* A relative path to be used in finding the location of tools
1511 relative to the driver. */
1512 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1514 /* A prefix to be used when this is an accelerator compiler. */
1515 static const char *const accel_dir_suffix = ACCEL_DIR_SUFFIX;
1517 /* Subdirectory to use for locating libraries. Set by
1518 set_multilib_dir based on the compilation options. */
1520 static const char *multilib_dir;
1522 /* Subdirectory to use for locating libraries in OS conventions. Set by
1523 set_multilib_dir based on the compilation options. */
1525 static const char *multilib_os_dir;
1527 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1528 set_multilib_dir based on the compilation options. */
1530 static const char *multiarch_dir;
1532 /* Structure to keep track of the specs that have been defined so far.
1533 These are accessed using %(specname) in a compiler or link
1534 spec. */
1536 struct spec_list
1538 /* The following 2 fields must be first */
1539 /* to allow EXTRA_SPECS to be initialized */
1540 const char *name; /* name of the spec. */
1541 const char *ptr; /* available ptr if no static pointer */
1543 /* The following fields are not initialized */
1544 /* by EXTRA_SPECS */
1545 const char **ptr_spec; /* pointer to the spec itself. */
1546 struct spec_list *next; /* Next spec in linked list. */
1547 int name_len; /* length of the name */
1548 bool user_p; /* whether string come from file spec. */
1549 bool alloc_p; /* whether string was allocated */
1550 const char *default_ptr; /* The default value of *ptr_spec. */
1553 #define INIT_STATIC_SPEC(NAME,PTR) \
1554 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false, \
1555 *PTR }
1557 /* List of statically defined specs. */
1558 static struct spec_list static_specs[] =
1560 INIT_STATIC_SPEC ("asm", &asm_spec),
1561 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1562 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1563 INIT_STATIC_SPEC ("asm_options", &asm_options),
1564 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1565 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1566 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1567 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1568 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1569 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1570 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1571 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1572 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1573 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1574 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1575 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1576 INIT_STATIC_SPEC ("link", &link_spec),
1577 INIT_STATIC_SPEC ("lib", &lib_spec),
1578 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1579 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1580 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1581 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1582 INIT_STATIC_SPEC ("version", &compiler_version),
1583 INIT_STATIC_SPEC ("multilib", &multilib_select),
1584 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1585 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1586 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1587 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1588 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1589 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1590 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1591 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1592 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1593 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1594 INIT_STATIC_SPEC ("post_link", &post_link_spec),
1595 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1596 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1597 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1598 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1599 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1600 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1601 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1602 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1603 INIT_STATIC_SPEC ("self_spec", &self_spec),
1606 #ifdef EXTRA_SPECS /* additional specs needed */
1607 /* Structure to keep track of just the first two args of a spec_list.
1608 That is all that the EXTRA_SPECS macro gives us. */
1609 struct spec_list_1
1611 const char *const name;
1612 const char *const ptr;
1615 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1616 static struct spec_list *extra_specs = (struct spec_list *) 0;
1617 #endif
1619 /* List of dynamically allocates specs that have been defined so far. */
1621 static struct spec_list *specs = (struct spec_list *) 0;
1623 /* List of static spec functions. */
1625 static const struct spec_function static_spec_functions[] =
1627 { "getenv", getenv_spec_function },
1628 { "if-exists", if_exists_spec_function },
1629 { "if-exists-else", if_exists_else_spec_function },
1630 { "sanitize", sanitize_spec_function },
1631 { "replace-outfile", replace_outfile_spec_function },
1632 { "remove-outfile", remove_outfile_spec_function },
1633 { "version-compare", version_compare_spec_function },
1634 { "include", include_spec_function },
1635 { "find-file", find_file_spec_function },
1636 { "find-plugindir", find_plugindir_spec_function },
1637 { "print-asm-header", print_asm_header_spec_function },
1638 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1639 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1640 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1641 { "pass-through-libs", pass_through_libs_spec_func },
1642 { "replace-extension", replace_extension_spec_func },
1643 { "gt", greater_than_spec_func },
1644 { "debug-level-gt", debug_level_greater_than_spec_func },
1645 #ifdef EXTRA_SPEC_FUNCTIONS
1646 EXTRA_SPEC_FUNCTIONS
1647 #endif
1648 { 0, 0 }
1651 static int processing_spec_function;
1653 /* Add appropriate libgcc specs to OBSTACK, taking into account
1654 various permutations of -shared-libgcc, -shared, and such. */
1656 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1658 #ifndef USE_LD_AS_NEEDED
1659 #define USE_LD_AS_NEEDED 0
1660 #endif
1662 static void
1663 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1664 const char *static_name, const char *eh_name)
1666 char *buf;
1668 #if USE_LD_AS_NEEDED
1669 buf = concat ("%{static|static-libgcc|static-pie:", static_name, " ", eh_name, "}"
1670 "%{!static:%{!static-libgcc:%{!static-pie:"
1671 "%{!shared-libgcc:",
1672 static_name, " " LD_AS_NEEDED_OPTION " ",
1673 shared_name, " " LD_NO_AS_NEEDED_OPTION
1675 "%{shared-libgcc:",
1676 shared_name, "%{!shared: ", static_name, "}"
1677 "}}"
1678 #else
1679 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1680 "%{!static:%{!static-libgcc:"
1681 "%{!shared:"
1682 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1683 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1685 #ifdef LINK_EH_SPEC
1686 "%{shared:"
1687 "%{shared-libgcc:", shared_name, "}"
1688 "%{!shared-libgcc:", static_name, "}"
1690 #else
1691 "%{shared:", shared_name, "}"
1692 #endif
1693 #endif
1694 "}}", NULL);
1696 obstack_grow (obstack, buf, strlen (buf));
1697 free (buf);
1699 #endif /* ENABLE_SHARED_LIBGCC */
1701 /* Initialize the specs lookup routines. */
1703 static void
1704 init_spec (void)
1706 struct spec_list *next = (struct spec_list *) 0;
1707 struct spec_list *sl = (struct spec_list *) 0;
1708 int i;
1710 if (specs)
1711 return; /* Already initialized. */
1713 if (verbose_flag)
1714 fnotice (stderr, "Using built-in specs.\n");
1716 #ifdef EXTRA_SPECS
1717 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1719 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1721 sl = &extra_specs[i];
1722 sl->name = extra_specs_1[i].name;
1723 sl->ptr = extra_specs_1[i].ptr;
1724 sl->next = next;
1725 sl->name_len = strlen (sl->name);
1726 sl->ptr_spec = &sl->ptr;
1727 gcc_assert (sl->ptr_spec != NULL);
1728 sl->default_ptr = sl->ptr;
1729 next = sl;
1731 #endif
1733 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1735 sl = &static_specs[i];
1736 sl->next = next;
1737 next = sl;
1740 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1741 /* ??? If neither -shared-libgcc nor --static-libgcc was
1742 seen, then we should be making an educated guess. Some proposed
1743 heuristics for ELF include:
1745 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1746 program will be doing dynamic loading, which will likely
1747 need the shared libgcc.
1749 (2) If "-ldl", then it's also a fair bet that we're doing
1750 dynamic loading.
1752 (3) For each ET_DYN we're linking against (either through -lfoo
1753 or /some/path/foo.so), check to see whether it or one of
1754 its dependencies depends on a shared libgcc.
1756 (4) If "-shared"
1758 If the runtime is fixed to look for program headers instead
1759 of calling __register_frame_info at all, for each object,
1760 use the shared libgcc if any EH symbol referenced.
1762 If crtstuff is fixed to not invoke __register_frame_info
1763 automatically, for each object, use the shared libgcc if
1764 any non-empty unwind section found.
1766 Doing any of this probably requires invoking an external program to
1767 do the actual object file scanning. */
1769 const char *p = libgcc_spec;
1770 int in_sep = 1;
1772 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1773 when given the proper command line arguments. */
1774 while (*p)
1776 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1778 init_gcc_specs (&obstack,
1779 "-lgcc_s"
1780 #ifdef USE_LIBUNWIND_EXCEPTIONS
1781 " -lunwind"
1782 #endif
1784 "-lgcc",
1785 "-lgcc_eh"
1786 #ifdef USE_LIBUNWIND_EXCEPTIONS
1787 # ifdef HAVE_LD_STATIC_DYNAMIC
1788 " %{!static:%{!static-pie:" LD_STATIC_OPTION "}} -lunwind"
1789 " %{!static:%{!static-pie:" LD_DYNAMIC_OPTION "}}"
1790 # else
1791 " -lunwind"
1792 # endif
1793 #endif
1796 p += 5;
1797 in_sep = 0;
1799 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1801 /* Ug. We don't know shared library extensions. Hope that
1802 systems that use this form don't do shared libraries. */
1803 init_gcc_specs (&obstack,
1804 "-lgcc_s",
1805 "libgcc.a%s",
1806 "libgcc_eh.a%s"
1807 #ifdef USE_LIBUNWIND_EXCEPTIONS
1808 " -lunwind"
1809 #endif
1811 p += 10;
1812 in_sep = 0;
1814 else
1816 obstack_1grow (&obstack, *p);
1817 in_sep = (*p == ' ');
1818 p += 1;
1822 obstack_1grow (&obstack, '\0');
1823 libgcc_spec = XOBFINISH (&obstack, const char *);
1825 #endif
1826 #ifdef USE_AS_TRADITIONAL_FORMAT
1827 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1829 static const char tf[] = "--traditional-format ";
1830 obstack_grow (&obstack, tf, sizeof (tf) - 1);
1831 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1832 asm_spec = XOBFINISH (&obstack, const char *);
1834 #endif
1836 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1837 defined LINKER_HASH_STYLE
1838 # ifdef LINK_BUILDID_SPEC
1839 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1840 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof (LINK_BUILDID_SPEC) - 1);
1841 # endif
1842 # ifdef LINK_EH_SPEC
1843 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1844 obstack_grow (&obstack, LINK_EH_SPEC, sizeof (LINK_EH_SPEC) - 1);
1845 # endif
1846 # ifdef LINKER_HASH_STYLE
1847 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1848 before. */
1850 static const char hash_style[] = "--hash-style=";
1851 obstack_grow (&obstack, hash_style, sizeof (hash_style) - 1);
1852 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof (LINKER_HASH_STYLE) - 1);
1853 obstack_1grow (&obstack, ' ');
1855 # endif
1856 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1857 link_spec = XOBFINISH (&obstack, const char *);
1858 #endif
1860 specs = sl;
1863 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1864 removed; If the spec starts with a + then SPEC is added to the end of the
1865 current spec. */
1867 static void
1868 set_spec (const char *name, const char *spec, bool user_p)
1870 struct spec_list *sl;
1871 const char *old_spec;
1872 int name_len = strlen (name);
1873 int i;
1875 /* If this is the first call, initialize the statically allocated specs. */
1876 if (!specs)
1878 struct spec_list *next = (struct spec_list *) 0;
1879 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1881 sl = &static_specs[i];
1882 sl->next = next;
1883 next = sl;
1885 specs = sl;
1888 /* See if the spec already exists. */
1889 for (sl = specs; sl; sl = sl->next)
1890 if (name_len == sl->name_len && !strcmp (sl->name, name))
1891 break;
1893 if (!sl)
1895 /* Not found - make it. */
1896 sl = XNEW (struct spec_list);
1897 sl->name = xstrdup (name);
1898 sl->name_len = name_len;
1899 sl->ptr_spec = &sl->ptr;
1900 sl->alloc_p = 0;
1901 *(sl->ptr_spec) = "";
1902 sl->next = specs;
1903 sl->default_ptr = NULL;
1904 specs = sl;
1907 old_spec = *(sl->ptr_spec);
1908 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1909 ? concat (old_spec, spec + 1, NULL)
1910 : xstrdup (spec));
1912 #ifdef DEBUG_SPECS
1913 if (verbose_flag)
1914 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1915 #endif
1917 /* Free the old spec. */
1918 if (old_spec && sl->alloc_p)
1919 free (CONST_CAST (char *, old_spec));
1921 sl->user_p = user_p;
1922 sl->alloc_p = true;
1925 /* Accumulate a command (program name and args), and run it. */
1927 typedef const char *const_char_p; /* For DEF_VEC_P. */
1929 /* Vector of pointers to arguments in the current line of specifications. */
1930 static vec<const_char_p> argbuf;
1932 /* Likewise, but for the current @file. */
1933 static vec<const_char_p> at_file_argbuf;
1935 /* Whether an @file is currently open. */
1936 static bool in_at_file = false;
1938 /* Were the options -c, -S or -E passed. */
1939 static int have_c = 0;
1941 /* Was the option -o passed. */
1942 static int have_o = 0;
1944 /* Was the option -E passed. */
1945 static int have_E = 0;
1947 /* Pointer to output file name passed in with -o. */
1948 static const char *output_file = 0;
1950 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1951 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1952 it here. */
1954 static struct temp_name {
1955 const char *suffix; /* suffix associated with the code. */
1956 int length; /* strlen (suffix). */
1957 int unique; /* Indicates whether %g or %u/%U was used. */
1958 const char *filename; /* associated filename. */
1959 int filename_length; /* strlen (filename). */
1960 struct temp_name *next;
1961 } *temp_names;
1963 /* Number of commands executed so far. */
1965 static int execution_count;
1967 /* Number of commands that exited with a signal. */
1969 static int signal_count;
1971 /* Allocate the argument vector. */
1973 static void
1974 alloc_args (void)
1976 argbuf.create (10);
1977 at_file_argbuf.create (10);
1980 /* Clear out the vector of arguments (after a command is executed). */
1982 static void
1983 clear_args (void)
1985 argbuf.truncate (0);
1986 at_file_argbuf.truncate (0);
1989 /* Add one argument to the vector at the end.
1990 This is done when a space is seen or at the end of the line.
1991 If DELETE_ALWAYS is nonzero, the arg is a filename
1992 and the file should be deleted eventually.
1993 If DELETE_FAILURE is nonzero, the arg is a filename
1994 and the file should be deleted if this compilation fails. */
1996 static void
1997 store_arg (const char *arg, int delete_always, int delete_failure)
1999 if (in_at_file)
2000 at_file_argbuf.safe_push (arg);
2001 else
2002 argbuf.safe_push (arg);
2004 if (delete_always || delete_failure)
2006 const char *p;
2007 /* If the temporary file we should delete is specified as
2008 part of a joined argument extract the filename. */
2009 if (arg[0] == '-'
2010 && (p = strrchr (arg, '=')))
2011 arg = p + 1;
2012 record_temp_file (arg, delete_always, delete_failure);
2016 /* Open a temporary @file into which subsequent arguments will be stored. */
2018 static void
2019 open_at_file (void)
2021 if (in_at_file)
2022 fatal_error (input_location, "cannot open nested response file");
2023 else
2024 in_at_file = true;
2027 /* Close the temporary @file and add @file to the argument list. */
2029 static void
2030 close_at_file (void)
2032 if (!in_at_file)
2033 fatal_error (input_location, "cannot close nonexistent response file");
2035 in_at_file = false;
2037 const unsigned int n_args = at_file_argbuf.length ();
2038 if (n_args == 0)
2039 return;
2041 char **argv = (char **) alloca (sizeof (char *) * (n_args + 1));
2042 char *temp_file = make_temp_file ("");
2043 char *at_argument = concat ("@", temp_file, NULL);
2044 FILE *f = fopen (temp_file, "w");
2045 int status;
2046 unsigned int i;
2048 /* Copy the strings over. */
2049 for (i = 0; i < n_args; i++)
2050 argv[i] = CONST_CAST (char *, at_file_argbuf[i]);
2051 argv[i] = NULL;
2053 at_file_argbuf.truncate (0);
2055 if (f == NULL)
2056 fatal_error (input_location, "could not open temporary response file %s",
2057 temp_file);
2059 status = writeargv (argv, f);
2061 if (status)
2062 fatal_error (input_location,
2063 "could not write to temporary response file %s",
2064 temp_file);
2066 status = fclose (f);
2068 if (status == EOF)
2069 fatal_error (input_location, "could not close temporary response file %s",
2070 temp_file);
2072 store_arg (at_argument, 0, 0);
2074 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
2077 /* Load specs from a file name named FILENAME, replacing occurrences of
2078 various different types of line-endings, \r\n, \n\r and just \r, with
2079 a single \n. */
2081 static char *
2082 load_specs (const char *filename)
2084 int desc;
2085 int readlen;
2086 struct stat statbuf;
2087 char *buffer;
2088 char *buffer_p;
2089 char *specs;
2090 char *specs_p;
2092 if (verbose_flag)
2093 fnotice (stderr, "Reading specs from %s\n", filename);
2095 /* Open and stat the file. */
2096 desc = open (filename, O_RDONLY, 0);
2097 if (desc < 0)
2098 pfatal_with_name (filename);
2099 if (stat (filename, &statbuf) < 0)
2100 pfatal_with_name (filename);
2102 /* Read contents of file into BUFFER. */
2103 buffer = XNEWVEC (char, statbuf.st_size + 1);
2104 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
2105 if (readlen < 0)
2106 pfatal_with_name (filename);
2107 buffer[readlen] = 0;
2108 close (desc);
2110 specs = XNEWVEC (char, readlen + 1);
2111 specs_p = specs;
2112 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
2114 int skip = 0;
2115 char c = *buffer_p;
2116 if (c == '\r')
2118 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
2119 skip = 1;
2120 else if (*(buffer_p + 1) == '\n') /* \r\n */
2121 skip = 1;
2122 else /* \r */
2123 c = '\n';
2125 if (! skip)
2126 *specs_p++ = c;
2128 *specs_p = '\0';
2130 free (buffer);
2131 return (specs);
2134 /* Read compilation specs from a file named FILENAME,
2135 replacing the default ones.
2137 A suffix which starts with `*' is a definition for
2138 one of the machine-specific sub-specs. The "suffix" should be
2139 *asm, *cc1, *cpp, *link, *startfile, etc.
2140 The corresponding spec is stored in asm_spec, etc.,
2141 rather than in the `compilers' vector.
2143 Anything invalid in the file is a fatal error. */
2145 static void
2146 read_specs (const char *filename, bool main_p, bool user_p)
2148 char *buffer;
2149 char *p;
2151 buffer = load_specs (filename);
2153 /* Scan BUFFER for specs, putting them in the vector. */
2154 p = buffer;
2155 while (1)
2157 char *suffix;
2158 char *spec;
2159 char *in, *out, *p1, *p2, *p3;
2161 /* Advance P in BUFFER to the next nonblank nocomment line. */
2162 p = skip_whitespace (p);
2163 if (*p == 0)
2164 break;
2166 /* Is this a special command that starts with '%'? */
2167 /* Don't allow this for the main specs file, since it would
2168 encourage people to overwrite it. */
2169 if (*p == '%' && !main_p)
2171 p1 = p;
2172 while (*p && *p != '\n')
2173 p++;
2175 /* Skip '\n'. */
2176 p++;
2178 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
2179 && (p1[sizeof "%include" - 1] == ' '
2180 || p1[sizeof "%include" - 1] == '\t'))
2182 char *new_filename;
2184 p1 += sizeof ("%include");
2185 while (*p1 == ' ' || *p1 == '\t')
2186 p1++;
2188 if (*p1++ != '<' || p[-2] != '>')
2189 fatal_error (input_location,
2190 "specs %%include syntax malformed after "
2191 "%ld characters",
2192 (long) (p1 - buffer + 1));
2194 p[-2] = '\0';
2195 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2196 read_specs (new_filename ? new_filename : p1, false, user_p);
2197 continue;
2199 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
2200 && (p1[sizeof "%include_noerr" - 1] == ' '
2201 || p1[sizeof "%include_noerr" - 1] == '\t'))
2203 char *new_filename;
2205 p1 += sizeof "%include_noerr";
2206 while (*p1 == ' ' || *p1 == '\t')
2207 p1++;
2209 if (*p1++ != '<' || p[-2] != '>')
2210 fatal_error (input_location,
2211 "specs %%include syntax malformed after "
2212 "%ld characters",
2213 (long) (p1 - buffer + 1));
2215 p[-2] = '\0';
2216 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2217 if (new_filename)
2218 read_specs (new_filename, false, user_p);
2219 else if (verbose_flag)
2220 fnotice (stderr, "could not find specs file %s\n", p1);
2221 continue;
2223 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
2224 && (p1[sizeof "%rename" - 1] == ' '
2225 || p1[sizeof "%rename" - 1] == '\t'))
2227 int name_len;
2228 struct spec_list *sl;
2229 struct spec_list *newsl;
2231 /* Get original name. */
2232 p1 += sizeof "%rename";
2233 while (*p1 == ' ' || *p1 == '\t')
2234 p1++;
2236 if (! ISALPHA ((unsigned char) *p1))
2237 fatal_error (input_location,
2238 "specs %%rename syntax malformed after "
2239 "%ld characters",
2240 (long) (p1 - buffer));
2242 p2 = p1;
2243 while (*p2 && !ISSPACE ((unsigned char) *p2))
2244 p2++;
2246 if (*p2 != ' ' && *p2 != '\t')
2247 fatal_error (input_location,
2248 "specs %%rename syntax malformed after "
2249 "%ld characters",
2250 (long) (p2 - buffer));
2252 name_len = p2 - p1;
2253 *p2++ = '\0';
2254 while (*p2 == ' ' || *p2 == '\t')
2255 p2++;
2257 if (! ISALPHA ((unsigned char) *p2))
2258 fatal_error (input_location,
2259 "specs %%rename syntax malformed after "
2260 "%ld characters",
2261 (long) (p2 - buffer));
2263 /* Get new spec name. */
2264 p3 = p2;
2265 while (*p3 && !ISSPACE ((unsigned char) *p3))
2266 p3++;
2268 if (p3 != p - 1)
2269 fatal_error (input_location,
2270 "specs %%rename syntax malformed after "
2271 "%ld characters",
2272 (long) (p3 - buffer));
2273 *p3 = '\0';
2275 for (sl = specs; sl; sl = sl->next)
2276 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2277 break;
2279 if (!sl)
2280 fatal_error (input_location,
2281 "specs %s spec was not found to be renamed", p1);
2283 if (strcmp (p1, p2) == 0)
2284 continue;
2286 for (newsl = specs; newsl; newsl = newsl->next)
2287 if (strcmp (newsl->name, p2) == 0)
2288 fatal_error (input_location,
2289 "%s: attempt to rename spec %qs to "
2290 "already defined spec %qs",
2291 filename, p1, p2);
2293 if (verbose_flag)
2295 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
2296 #ifdef DEBUG_SPECS
2297 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
2298 #endif
2301 set_spec (p2, *(sl->ptr_spec), user_p);
2302 if (sl->alloc_p)
2303 free (CONST_CAST (char *, *(sl->ptr_spec)));
2305 *(sl->ptr_spec) = "";
2306 sl->alloc_p = 0;
2307 continue;
2309 else
2310 fatal_error (input_location,
2311 "specs unknown %% command after %ld characters",
2312 (long) (p1 - buffer));
2315 /* Find the colon that should end the suffix. */
2316 p1 = p;
2317 while (*p1 && *p1 != ':' && *p1 != '\n')
2318 p1++;
2320 /* The colon shouldn't be missing. */
2321 if (*p1 != ':')
2322 fatal_error (input_location,
2323 "specs file malformed after %ld characters",
2324 (long) (p1 - buffer));
2326 /* Skip back over trailing whitespace. */
2327 p2 = p1;
2328 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2329 p2--;
2331 /* Copy the suffix to a string. */
2332 suffix = save_string (p, p2 - p);
2333 /* Find the next line. */
2334 p = skip_whitespace (p1 + 1);
2335 if (p[1] == 0)
2336 fatal_error (input_location,
2337 "specs file malformed after %ld characters",
2338 (long) (p - buffer));
2340 p1 = p;
2341 /* Find next blank line or end of string. */
2342 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2343 p1++;
2345 /* Specs end at the blank line and do not include the newline. */
2346 spec = save_string (p, p1 - p);
2347 p = p1;
2349 /* Delete backslash-newline sequences from the spec. */
2350 in = spec;
2351 out = spec;
2352 while (*in != 0)
2354 if (in[0] == '\\' && in[1] == '\n')
2355 in += 2;
2356 else if (in[0] == '#')
2357 while (*in && *in != '\n')
2358 in++;
2360 else
2361 *out++ = *in++;
2363 *out = 0;
2365 if (suffix[0] == '*')
2367 if (! strcmp (suffix, "*link_command"))
2368 link_command_spec = spec;
2369 else
2371 set_spec (suffix + 1, spec, user_p);
2372 free (spec);
2375 else
2377 /* Add this pair to the vector. */
2378 compilers
2379 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
2381 compilers[n_compilers].suffix = suffix;
2382 compilers[n_compilers].spec = spec;
2383 n_compilers++;
2384 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2387 if (*suffix == 0)
2388 link_command_spec = spec;
2391 if (link_command_spec == 0)
2392 fatal_error (input_location, "spec file has no spec for linking");
2394 XDELETEVEC (buffer);
2397 /* Record the names of temporary files we tell compilers to write,
2398 and delete them at the end of the run. */
2400 /* This is the common prefix we use to make temp file names.
2401 It is chosen once for each run of this program.
2402 It is substituted into a spec by %g or %j.
2403 Thus, all temp file names contain this prefix.
2404 In practice, all temp file names start with this prefix.
2406 This prefix comes from the envvar TMPDIR if it is defined;
2407 otherwise, from the P_tmpdir macro if that is defined;
2408 otherwise, in /usr/tmp or /tmp;
2409 or finally the current directory if all else fails. */
2411 static const char *temp_filename;
2413 /* Length of the prefix. */
2415 static int temp_filename_length;
2417 /* Define the list of temporary files to delete. */
2419 struct temp_file
2421 const char *name;
2422 struct temp_file *next;
2425 /* Queue of files to delete on success or failure of compilation. */
2426 static struct temp_file *always_delete_queue;
2427 /* Queue of files to delete on failure of compilation. */
2428 static struct temp_file *failure_delete_queue;
2430 /* Record FILENAME as a file to be deleted automatically.
2431 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2432 otherwise delete it in any case.
2433 FAIL_DELETE nonzero means delete it if a compilation step fails;
2434 otherwise delete it in any case. */
2436 void
2437 record_temp_file (const char *filename, int always_delete, int fail_delete)
2439 char *const name = xstrdup (filename);
2441 if (always_delete)
2443 struct temp_file *temp;
2444 for (temp = always_delete_queue; temp; temp = temp->next)
2445 if (! filename_cmp (name, temp->name))
2447 free (name);
2448 goto already1;
2451 temp = XNEW (struct temp_file);
2452 temp->next = always_delete_queue;
2453 temp->name = name;
2454 always_delete_queue = temp;
2456 already1:;
2459 if (fail_delete)
2461 struct temp_file *temp;
2462 for (temp = failure_delete_queue; temp; temp = temp->next)
2463 if (! filename_cmp (name, temp->name))
2465 free (name);
2466 goto already2;
2469 temp = XNEW (struct temp_file);
2470 temp->next = failure_delete_queue;
2471 temp->name = name;
2472 failure_delete_queue = temp;
2474 already2:;
2478 /* Delete all the temporary files whose names we previously recorded. */
2480 #ifndef DELETE_IF_ORDINARY
2481 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2482 do \
2484 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2485 if (unlink (NAME) < 0) \
2486 if (VERBOSE_FLAG) \
2487 perror_with_name (NAME); \
2488 } while (0)
2489 #endif
2491 static void
2492 delete_if_ordinary (const char *name)
2494 struct stat st;
2495 #ifdef DEBUG
2496 int i, c;
2498 printf ("Delete %s? (y or n) ", name);
2499 fflush (stdout);
2500 i = getchar ();
2501 if (i != '\n')
2502 while ((c = getchar ()) != '\n' && c != EOF)
2505 if (i == 'y' || i == 'Y')
2506 #endif /* DEBUG */
2507 DELETE_IF_ORDINARY (name, st, verbose_flag);
2510 static void
2511 delete_temp_files (void)
2513 struct temp_file *temp;
2515 for (temp = always_delete_queue; temp; temp = temp->next)
2516 delete_if_ordinary (temp->name);
2517 always_delete_queue = 0;
2520 /* Delete all the files to be deleted on error. */
2522 static void
2523 delete_failure_queue (void)
2525 struct temp_file *temp;
2527 for (temp = failure_delete_queue; temp; temp = temp->next)
2528 delete_if_ordinary (temp->name);
2531 static void
2532 clear_failure_queue (void)
2534 failure_delete_queue = 0;
2537 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2538 returns non-NULL.
2539 If DO_MULTI is true iterate over the paths twice, first with multilib
2540 suffix then without, otherwise iterate over the paths once without
2541 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2542 to avoid visiting the same path twice, but we could do better. For
2543 instance, /usr/lib/../lib is considered different from /usr/lib.
2544 At least EXTRA_SPACE chars past the end of the path passed to
2545 CALLBACK are available for use by the callback.
2546 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2548 Returns the value returned by CALLBACK. */
2550 static void *
2551 for_each_path (const struct path_prefix *paths,
2552 bool do_multi,
2553 size_t extra_space,
2554 void *(*callback) (char *, void *),
2555 void *callback_info)
2557 struct prefix_list *pl;
2558 const char *multi_dir = NULL;
2559 const char *multi_os_dir = NULL;
2560 const char *multiarch_suffix = NULL;
2561 const char *multi_suffix;
2562 const char *just_multi_suffix;
2563 char *path = NULL;
2564 void *ret = NULL;
2565 bool skip_multi_dir = false;
2566 bool skip_multi_os_dir = false;
2568 multi_suffix = machine_suffix;
2569 just_multi_suffix = just_machine_suffix;
2570 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2572 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2573 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2574 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2576 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2577 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2578 if (multiarch_dir)
2579 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2581 while (1)
2583 size_t multi_dir_len = 0;
2584 size_t multi_os_dir_len = 0;
2585 size_t multiarch_len = 0;
2586 size_t suffix_len;
2587 size_t just_suffix_len;
2588 size_t len;
2590 if (multi_dir)
2591 multi_dir_len = strlen (multi_dir);
2592 if (multi_os_dir)
2593 multi_os_dir_len = strlen (multi_os_dir);
2594 if (multiarch_suffix)
2595 multiarch_len = strlen (multiarch_suffix);
2596 suffix_len = strlen (multi_suffix);
2597 just_suffix_len = strlen (just_multi_suffix);
2599 if (path == NULL)
2601 len = paths->max_len + extra_space + 1;
2602 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2603 path = XNEWVEC (char, len);
2606 for (pl = paths->plist; pl != 0; pl = pl->next)
2608 len = strlen (pl->prefix);
2609 memcpy (path, pl->prefix, len);
2611 /* Look first in MACHINE/VERSION subdirectory. */
2612 if (!skip_multi_dir)
2614 memcpy (path + len, multi_suffix, suffix_len + 1);
2615 ret = callback (path, callback_info);
2616 if (ret)
2617 break;
2620 /* Some paths are tried with just the machine (ie. target)
2621 subdir. This is used for finding as, ld, etc. */
2622 if (!skip_multi_dir
2623 && pl->require_machine_suffix == 2)
2625 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2626 ret = callback (path, callback_info);
2627 if (ret)
2628 break;
2631 /* Now try the multiarch path. */
2632 if (!skip_multi_dir
2633 && !pl->require_machine_suffix && multiarch_dir)
2635 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2636 ret = callback (path, callback_info);
2637 if (ret)
2638 break;
2641 /* Now try the base path. */
2642 if (!pl->require_machine_suffix
2643 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2645 const char *this_multi;
2646 size_t this_multi_len;
2648 if (pl->os_multilib)
2650 this_multi = multi_os_dir;
2651 this_multi_len = multi_os_dir_len;
2653 else
2655 this_multi = multi_dir;
2656 this_multi_len = multi_dir_len;
2659 if (this_multi_len)
2660 memcpy (path + len, this_multi, this_multi_len + 1);
2661 else
2662 path[len] = '\0';
2664 ret = callback (path, callback_info);
2665 if (ret)
2666 break;
2669 if (pl)
2670 break;
2672 if (multi_dir == NULL && multi_os_dir == NULL)
2673 break;
2675 /* Run through the paths again, this time without multilibs.
2676 Don't repeat any we have already seen. */
2677 if (multi_dir)
2679 free (CONST_CAST (char *, multi_dir));
2680 multi_dir = NULL;
2681 free (CONST_CAST (char *, multi_suffix));
2682 multi_suffix = machine_suffix;
2683 free (CONST_CAST (char *, just_multi_suffix));
2684 just_multi_suffix = just_machine_suffix;
2686 else
2687 skip_multi_dir = true;
2688 if (multi_os_dir)
2690 free (CONST_CAST (char *, multi_os_dir));
2691 multi_os_dir = NULL;
2693 else
2694 skip_multi_os_dir = true;
2697 if (multi_dir)
2699 free (CONST_CAST (char *, multi_dir));
2700 free (CONST_CAST (char *, multi_suffix));
2701 free (CONST_CAST (char *, just_multi_suffix));
2703 if (multi_os_dir)
2704 free (CONST_CAST (char *, multi_os_dir));
2705 if (ret != path)
2706 free (path);
2707 return ret;
2710 /* Callback for build_search_list. Adds path to obstack being built. */
2712 struct add_to_obstack_info {
2713 struct obstack *ob;
2714 bool check_dir;
2715 bool first_time;
2718 static void *
2719 add_to_obstack (char *path, void *data)
2721 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2723 if (info->check_dir && !is_directory (path, false))
2724 return NULL;
2726 if (!info->first_time)
2727 obstack_1grow (info->ob, PATH_SEPARATOR);
2729 obstack_grow (info->ob, path, strlen (path));
2731 info->first_time = false;
2732 return NULL;
2735 /* Add or change the value of an environment variable, outputting the
2736 change to standard error if in verbose mode. */
2737 static void
2738 xputenv (const char *string)
2740 env.xput (string);
2743 /* Build a list of search directories from PATHS.
2744 PREFIX is a string to prepend to the list.
2745 If CHECK_DIR_P is true we ensure the directory exists.
2746 If DO_MULTI is true, multilib paths are output first, then
2747 non-multilib paths.
2748 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2749 It is also used by the --print-search-dirs flag. */
2751 static char *
2752 build_search_list (const struct path_prefix *paths, const char *prefix,
2753 bool check_dir, bool do_multi)
2755 struct add_to_obstack_info info;
2757 info.ob = &collect_obstack;
2758 info.check_dir = check_dir;
2759 info.first_time = true;
2761 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2762 obstack_1grow (&collect_obstack, '=');
2764 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2766 obstack_1grow (&collect_obstack, '\0');
2767 return XOBFINISH (&collect_obstack, char *);
2770 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2771 for collect. */
2773 static void
2774 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2775 bool do_multi)
2777 xputenv (build_search_list (paths, env_var, true, do_multi));
2780 /* Check whether NAME can be accessed in MODE. This is like access,
2781 except that it never considers directories to be executable. */
2783 static int
2784 access_check (const char *name, int mode)
2786 if (mode == X_OK)
2788 struct stat st;
2790 if (stat (name, &st) < 0
2791 || S_ISDIR (st.st_mode))
2792 return -1;
2795 return access (name, mode);
2798 /* Callback for find_a_file. Appends the file name to the directory
2799 path. If the resulting file exists in the right mode, return the
2800 full pathname to the file. */
2802 struct file_at_path_info {
2803 const char *name;
2804 const char *suffix;
2805 int name_len;
2806 int suffix_len;
2807 int mode;
2810 static void *
2811 file_at_path (char *path, void *data)
2813 struct file_at_path_info *info = (struct file_at_path_info *) data;
2814 size_t len = strlen (path);
2816 memcpy (path + len, info->name, info->name_len);
2817 len += info->name_len;
2819 /* Some systems have a suffix for executable files.
2820 So try appending that first. */
2821 if (info->suffix_len)
2823 memcpy (path + len, info->suffix, info->suffix_len + 1);
2824 if (access_check (path, info->mode) == 0)
2825 return path;
2828 path[len] = '\0';
2829 if (access_check (path, info->mode) == 0)
2830 return path;
2832 return NULL;
2835 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2836 access to check permissions. If DO_MULTI is true, search multilib
2837 paths then non-multilib paths, otherwise do not search multilib paths.
2838 Return 0 if not found, otherwise return its name, allocated with malloc. */
2840 static char *
2841 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2842 bool do_multi)
2844 struct file_at_path_info info;
2846 #ifdef DEFAULT_ASSEMBLER
2847 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2848 return xstrdup (DEFAULT_ASSEMBLER);
2849 #endif
2851 #ifdef DEFAULT_LINKER
2852 if (! strcmp (name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2853 return xstrdup (DEFAULT_LINKER);
2854 #endif
2856 /* Determine the filename to execute (special case for absolute paths). */
2858 if (IS_ABSOLUTE_PATH (name))
2860 if (access (name, mode) == 0)
2861 return xstrdup (name);
2863 return NULL;
2866 info.name = name;
2867 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2868 info.name_len = strlen (info.name);
2869 info.suffix_len = strlen (info.suffix);
2870 info.mode = mode;
2872 return (char*) for_each_path (pprefix, do_multi,
2873 info.name_len + info.suffix_len,
2874 file_at_path, &info);
2877 /* Ranking of prefixes in the sort list. -B prefixes are put before
2878 all others. */
2880 enum path_prefix_priority
2882 PREFIX_PRIORITY_B_OPT,
2883 PREFIX_PRIORITY_LAST
2886 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2887 order according to PRIORITY. Within each PRIORITY, new entries are
2888 appended.
2890 If WARN is nonzero, we will warn if no file is found
2891 through this prefix. WARN should point to an int
2892 which will be set to 1 if this entry is used.
2894 COMPONENT is the value to be passed to update_path.
2896 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2897 the complete value of machine_suffix.
2898 2 means try both machine_suffix and just_machine_suffix. */
2900 static void
2901 add_prefix (struct path_prefix *pprefix, const char *prefix,
2902 const char *component, /* enum prefix_priority */ int priority,
2903 int require_machine_suffix, int os_multilib)
2905 struct prefix_list *pl, **prev;
2906 int len;
2908 for (prev = &pprefix->plist;
2909 (*prev) != NULL && (*prev)->priority <= priority;
2910 prev = &(*prev)->next)
2913 /* Keep track of the longest prefix. */
2915 prefix = update_path (prefix, component);
2916 len = strlen (prefix);
2917 if (len > pprefix->max_len)
2918 pprefix->max_len = len;
2920 pl = XNEW (struct prefix_list);
2921 pl->prefix = prefix;
2922 pl->require_machine_suffix = require_machine_suffix;
2923 pl->priority = priority;
2924 pl->os_multilib = os_multilib;
2926 /* Insert after PREV. */
2927 pl->next = (*prev);
2928 (*prev) = pl;
2931 /* Same as add_prefix, but prepending target_system_root to prefix. */
2932 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2933 static void
2934 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2935 const char *component,
2936 /* enum prefix_priority */ int priority,
2937 int require_machine_suffix, int os_multilib)
2939 if (!IS_ABSOLUTE_PATH (prefix))
2940 fatal_error (input_location, "system path %qs is not absolute", prefix);
2942 if (target_system_root)
2944 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2945 size_t sysroot_len = strlen (target_system_root);
2947 if (sysroot_len > 0
2948 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2949 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2951 if (target_sysroot_suffix)
2952 prefix = concat (sysroot_no_trailing_dir_separator,
2953 target_sysroot_suffix, prefix, NULL);
2954 else
2955 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2957 free (sysroot_no_trailing_dir_separator);
2959 /* We have to override this because GCC's notion of sysroot
2960 moves along with GCC. */
2961 component = "GCC";
2964 add_prefix (pprefix, prefix, component, priority,
2965 require_machine_suffix, os_multilib);
2968 /* Execute the command specified by the arguments on the current line of spec.
2969 When using pipes, this includes several piped-together commands
2970 with `|' between them.
2972 Return 0 if successful, -1 if failed. */
2974 static int
2975 execute (void)
2977 int i;
2978 int n_commands; /* # of command. */
2979 char *string;
2980 struct pex_obj *pex;
2981 struct command
2983 const char *prog; /* program name. */
2984 const char **argv; /* vector of args. */
2986 const char *arg;
2988 struct command *commands; /* each command buffer with above info. */
2990 gcc_assert (!processing_spec_function);
2992 if (wrapper_string)
2994 string = find_a_file (&exec_prefixes,
2995 argbuf[0], X_OK, false);
2996 if (string)
2997 argbuf[0] = string;
2998 insert_wrapper (wrapper_string);
3001 /* Count # of piped commands. */
3002 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
3003 if (strcmp (arg, "|") == 0)
3004 n_commands++;
3006 /* Get storage for each command. */
3007 commands = (struct command *) alloca (n_commands * sizeof (struct command));
3009 /* Split argbuf into its separate piped processes,
3010 and record info about each one.
3011 Also search for the programs that are to be run. */
3013 argbuf.safe_push (0);
3015 commands[0].prog = argbuf[0]; /* first command. */
3016 commands[0].argv = argbuf.address ();
3018 if (!wrapper_string)
3020 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
3021 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
3024 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
3025 if (arg && strcmp (arg, "|") == 0)
3026 { /* each command. */
3027 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
3028 fatal_error (input_location, "-pipe not supported");
3029 #endif
3030 argbuf[i] = 0; /* Termination of
3031 command args. */
3032 commands[n_commands].prog = argbuf[i + 1];
3033 commands[n_commands].argv
3034 = &(argbuf.address ())[i + 1];
3035 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
3036 X_OK, false);
3037 if (string)
3038 commands[n_commands].argv[0] = string;
3039 n_commands++;
3042 /* If -v, print what we are about to do, and maybe query. */
3044 if (verbose_flag)
3046 /* For help listings, put a blank line between sub-processes. */
3047 if (print_help_list)
3048 fputc ('\n', stderr);
3050 /* Print each piped command as a separate line. */
3051 for (i = 0; i < n_commands; i++)
3053 const char *const *j;
3055 if (verbose_only_flag)
3057 for (j = commands[i].argv; *j; j++)
3059 const char *p;
3060 for (p = *j; *p; ++p)
3061 if (!ISALNUM ((unsigned char) *p)
3062 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
3063 break;
3064 if (*p || !*j)
3066 fprintf (stderr, " \"");
3067 for (p = *j; *p; ++p)
3069 if (*p == '"' || *p == '\\' || *p == '$')
3070 fputc ('\\', stderr);
3071 fputc (*p, stderr);
3073 fputc ('"', stderr);
3075 /* If it's empty, print "". */
3076 else if (!**j)
3077 fprintf (stderr, " \"\"");
3078 else
3079 fprintf (stderr, " %s", *j);
3082 else
3083 for (j = commands[i].argv; *j; j++)
3084 /* If it's empty, print "". */
3085 if (!**j)
3086 fprintf (stderr, " \"\"");
3087 else
3088 fprintf (stderr, " %s", *j);
3090 /* Print a pipe symbol after all but the last command. */
3091 if (i + 1 != n_commands)
3092 fprintf (stderr, " |");
3093 fprintf (stderr, "\n");
3095 fflush (stderr);
3096 if (verbose_only_flag != 0)
3098 /* verbose_only_flag should act as if the spec was
3099 executed, so increment execution_count before
3100 returning. This prevents spurious warnings about
3101 unused linker input files, etc. */
3102 execution_count++;
3103 return 0;
3105 #ifdef DEBUG
3106 fnotice (stderr, "\nGo ahead? (y or n) ");
3107 fflush (stderr);
3108 i = getchar ();
3109 if (i != '\n')
3110 while (getchar () != '\n')
3113 if (i != 'y' && i != 'Y')
3114 return 0;
3115 #endif /* DEBUG */
3118 #ifdef ENABLE_VALGRIND_CHECKING
3119 /* Run the each command through valgrind. To simplify prepending the
3120 path to valgrind and the option "-q" (for quiet operation unless
3121 something triggers), we allocate a separate argv array. */
3123 for (i = 0; i < n_commands; i++)
3125 const char **argv;
3126 int argc;
3127 int j;
3129 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
3132 argv = XALLOCAVEC (const char *, argc + 3);
3134 argv[0] = VALGRIND_PATH;
3135 argv[1] = "-q";
3136 for (j = 2; j < argc + 2; j++)
3137 argv[j] = commands[i].argv[j - 2];
3138 argv[j] = NULL;
3140 commands[i].argv = argv;
3141 commands[i].prog = argv[0];
3143 #endif
3145 /* Run each piped subprocess. */
3147 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
3148 ? PEX_RECORD_TIMES : 0),
3149 progname, temp_filename);
3150 if (pex == NULL)
3151 fatal_error (input_location, "pex_init failed: %m");
3153 for (i = 0; i < n_commands; i++)
3155 const char *errmsg;
3156 int err;
3157 const char *string = commands[i].argv[0];
3159 errmsg = pex_run (pex,
3160 ((i + 1 == n_commands ? PEX_LAST : 0)
3161 | (string == commands[i].prog ? PEX_SEARCH : 0)),
3162 string, CONST_CAST (char **, commands[i].argv),
3163 NULL, NULL, &err);
3164 if (errmsg != NULL)
3166 if (err == 0)
3167 fatal_error (input_location, errmsg);
3168 else
3170 errno = err;
3171 pfatal_with_name (errmsg);
3175 if (i && string != commands[i].prog)
3176 free (CONST_CAST (char *, string));
3179 execution_count++;
3181 /* Wait for all the subprocesses to finish. */
3184 int *statuses;
3185 struct pex_time *times = NULL;
3186 int ret_code = 0;
3188 statuses = (int *) alloca (n_commands * sizeof (int));
3189 if (!pex_get_status (pex, n_commands, statuses))
3190 fatal_error (input_location, "failed to get exit status: %m");
3192 if (report_times || report_times_to_file)
3194 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
3195 if (!pex_get_times (pex, n_commands, times))
3196 fatal_error (input_location, "failed to get process times: %m");
3199 pex_free (pex);
3201 for (i = 0; i < n_commands; ++i)
3203 int status = statuses[i];
3205 if (WIFSIGNALED (status))
3206 switch (WTERMSIG (status))
3208 case SIGINT:
3209 case SIGTERM:
3210 /* SIGQUIT and SIGKILL are not available on MinGW. */
3211 #ifdef SIGQUIT
3212 case SIGQUIT:
3213 #endif
3214 #ifdef SIGKILL
3215 case SIGKILL:
3216 #endif
3217 /* The user (or environment) did something to the
3218 inferior. Making this an ICE confuses the user into
3219 thinking there's a compiler bug. Much more likely is
3220 the user or OOM killer nuked it. */
3221 fatal_error (input_location,
3222 "%s signal terminated program %s",
3223 strsignal (WTERMSIG (status)),
3224 commands[i].prog);
3225 break;
3227 #ifdef SIGPIPE
3228 case SIGPIPE:
3229 /* SIGPIPE is a special case. It happens in -pipe mode
3230 when the compiler dies before the preprocessor is
3231 done, or the assembler dies before the compiler is
3232 done. There's generally been an error already, and
3233 this is just fallout. So don't generate another
3234 error unless we would otherwise have succeeded. */
3235 if (signal_count || greatest_status >= MIN_FATAL_STATUS)
3237 signal_count++;
3238 ret_code = -1;
3239 break;
3241 #endif
3242 /* FALLTHROUGH */
3244 default:
3245 /* The inferior failed to catch the signal. */
3246 internal_error_no_backtrace ("%s signal terminated program %s",
3247 strsignal (WTERMSIG (status)),
3248 commands[i].prog);
3250 else if (WIFEXITED (status)
3251 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
3253 /* For ICEs in cc1, cc1obj, cc1plus see if it is
3254 reproducible or not. */
3255 const char *p;
3256 if (flag_report_bug
3257 && WEXITSTATUS (status) == ICE_EXIT_CODE
3258 && i == 0
3259 && (p = strrchr (commands[0].argv[0], DIR_SEPARATOR))
3260 && ! strncmp (p + 1, "cc1", 3))
3261 try_generate_repro (commands[0].argv);
3262 if (WEXITSTATUS (status) > greatest_status)
3263 greatest_status = WEXITSTATUS (status);
3264 ret_code = -1;
3267 if (report_times || report_times_to_file)
3269 struct pex_time *pt = &times[i];
3270 double ut, st;
3272 ut = ((double) pt->user_seconds
3273 + (double) pt->user_microseconds / 1.0e6);
3274 st = ((double) pt->system_seconds
3275 + (double) pt->system_microseconds / 1.0e6);
3277 if (ut + st != 0)
3279 if (report_times)
3280 fnotice (stderr, "# %s %.2f %.2f\n",
3281 commands[i].prog, ut, st);
3283 if (report_times_to_file)
3285 int c = 0;
3286 const char *const *j;
3288 fprintf (report_times_to_file, "%g %g", ut, st);
3290 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
3292 const char *p;
3293 for (p = *j; *p; ++p)
3294 if (*p == '"' || *p == '\\' || *p == '$'
3295 || ISSPACE (*p))
3296 break;
3298 if (*p)
3300 fprintf (report_times_to_file, " \"");
3301 for (p = *j; *p; ++p)
3303 if (*p == '"' || *p == '\\' || *p == '$')
3304 fputc ('\\', report_times_to_file);
3305 fputc (*p, report_times_to_file);
3307 fputc ('"', report_times_to_file);
3309 else
3310 fprintf (report_times_to_file, " %s", *j);
3313 fputc ('\n', report_times_to_file);
3319 if (commands[0].argv[0] != commands[0].prog)
3320 free (CONST_CAST (char *, commands[0].argv[0]));
3322 return ret_code;
3326 /* Find all the switches given to us
3327 and make a vector describing them.
3328 The elements of the vector are strings, one per switch given.
3329 If a switch uses following arguments, then the `part1' field
3330 is the switch itself and the `args' field
3331 is a null-terminated vector containing the following arguments.
3332 Bits in the `live_cond' field are:
3333 SWITCH_LIVE to indicate this switch is true in a conditional spec.
3334 SWITCH_FALSE to indicate this switch is overridden by a later switch.
3335 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
3336 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored.
3337 SWITCH_KEEP_FOR_GCC to indicate that this switch, otherwise ignored,
3338 should be included in COLLECT_GCC_OPTIONS.
3339 in all do_spec calls afterwards. Used for %<S from self specs.
3340 The `known' field describes whether this is an internal switch.
3341 The `validated' field describes whether any spec has looked at this switch;
3342 if it remains false at the end of the run, the switch must be meaningless.
3343 The `ordering' field is used to temporarily mark switches that have to be
3344 kept in a specific order. */
3346 #define SWITCH_LIVE (1 << 0)
3347 #define SWITCH_FALSE (1 << 1)
3348 #define SWITCH_IGNORE (1 << 2)
3349 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
3350 #define SWITCH_KEEP_FOR_GCC (1 << 4)
3352 struct switchstr
3354 const char *part1;
3355 const char **args;
3356 unsigned int live_cond;
3357 bool known;
3358 bool validated;
3359 bool ordering;
3362 static struct switchstr *switches;
3364 static int n_switches;
3366 static int n_switches_alloc;
3368 /* Set to zero if -fcompare-debug is disabled, positive if it's
3369 enabled and we're running the first compilation, negative if it's
3370 enabled and we're running the second compilation. For most of the
3371 time, it's in the range -1..1, but it can be temporarily set to 2
3372 or 3 to indicate that the -fcompare-debug flags didn't come from
3373 the command-line, but rather from the GCC_COMPARE_DEBUG environment
3374 variable, until a synthesized -fcompare-debug flag is added to the
3375 command line. */
3376 int compare_debug;
3378 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
3379 int compare_debug_second;
3381 /* Set to the flags that should be passed to the second compilation in
3382 a -fcompare-debug compilation. */
3383 const char *compare_debug_opt;
3385 static struct switchstr *switches_debug_check[2];
3387 static int n_switches_debug_check[2];
3389 static int n_switches_alloc_debug_check[2];
3391 static char *debug_check_temp_file[2];
3393 /* Language is one of three things:
3395 1) The name of a real programming language.
3396 2) NULL, indicating that no one has figured out
3397 what it is yet.
3398 3) '*', indicating that the file should be passed
3399 to the linker. */
3400 struct infile
3402 const char *name;
3403 const char *language;
3404 struct compiler *incompiler;
3405 bool compiled;
3406 bool preprocessed;
3409 /* Also a vector of input files specified. */
3411 static struct infile *infiles;
3413 int n_infiles;
3415 static int n_infiles_alloc;
3417 /* True if undefined environment variables encountered during spec processing
3418 are ok to ignore, typically when we're running for --help or --version. */
3420 static bool spec_undefvar_allowed;
3422 /* True if multiple input files are being compiled to a single
3423 assembly file. */
3425 static bool combine_inputs;
3427 /* This counts the number of libraries added by lang_specific_driver, so that
3428 we can tell if there were any user supplied any files or libraries. */
3430 static int added_libraries;
3432 /* And a vector of corresponding output files is made up later. */
3434 const char **outfiles;
3436 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3438 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3439 is true if we should look for an executable suffix. DO_OBJ
3440 is true if we should look for an object suffix. */
3442 static const char *
3443 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3444 int do_obj ATTRIBUTE_UNUSED)
3446 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3447 int i;
3448 #endif
3449 int len;
3451 if (name == NULL)
3452 return NULL;
3454 len = strlen (name);
3456 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3457 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3458 if (do_obj && len > 2
3459 && name[len - 2] == '.'
3460 && name[len - 1] == 'o')
3462 obstack_grow (&obstack, name, len - 2);
3463 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3464 name = XOBFINISH (&obstack, const char *);
3466 #endif
3468 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3469 /* If there is no filetype, make it the executable suffix (which includes
3470 the "."). But don't get confused if we have just "-o". */
3471 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3472 return name;
3474 for (i = len - 1; i >= 0; i--)
3475 if (IS_DIR_SEPARATOR (name[i]))
3476 break;
3478 for (i++; i < len; i++)
3479 if (name[i] == '.')
3480 return name;
3482 obstack_grow (&obstack, name, len);
3483 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3484 strlen (TARGET_EXECUTABLE_SUFFIX));
3485 name = XOBFINISH (&obstack, const char *);
3486 #endif
3488 return name;
3490 #endif
3492 /* Display the command line switches accepted by gcc. */
3493 static void
3494 display_help (void)
3496 printf (_("Usage: %s [options] file...\n"), progname);
3497 fputs (_("Options:\n"), stdout);
3499 fputs (_(" -pass-exit-codes Exit with highest error code from a phase.\n"), stdout);
3500 fputs (_(" --help Display this information.\n"), stdout);
3501 fputs (_(" --target-help Display target specific command line options.\n"), stdout);
3502 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...].\n"), stdout);
3503 fputs (_(" Display specific types of command line options.\n"), stdout);
3504 if (! verbose_flag)
3505 fputs (_(" (Use '-v --help' to display command line options of sub-processes).\n"), stdout);
3506 fputs (_(" --version Display compiler version information.\n"), stdout);
3507 fputs (_(" -dumpspecs Display all of the built in spec strings.\n"), stdout);
3508 fputs (_(" -dumpversion Display the version of the compiler.\n"), stdout);
3509 fputs (_(" -dumpmachine Display the compiler's target processor.\n"), stdout);
3510 fputs (_(" -print-search-dirs Display the directories in the compiler's search path.\n"), stdout);
3511 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library.\n"), stdout);
3512 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>.\n"), stdout);
3513 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>.\n"), stdout);
3514 fputs (_("\
3515 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3516 a component in the library path.\n"), stdout);
3517 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc.\n"), stdout);
3518 fputs (_("\
3519 -print-multi-lib Display the mapping between command line options and\n\
3520 multiple library search directories.\n"), stdout);
3521 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries.\n"), stdout);
3522 fputs (_(" -print-sysroot Display the target libraries directory.\n"), stdout);
3523 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers.\n"), stdout);
3524 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler.\n"), stdout);
3525 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor.\n"), stdout);
3526 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker.\n"), stdout);
3527 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler.\n"), stdout);
3528 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor.\n"), stdout);
3529 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker.\n"), stdout);
3530 fputs (_(" -save-temps Do not delete intermediate files.\n"), stdout);
3531 fputs (_(" -save-temps=<arg> Do not delete intermediate files.\n"), stdout);
3532 fputs (_("\
3533 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3534 prefixes to other gcc components.\n"), stdout);
3535 fputs (_(" -pipe Use pipes rather than intermediate files.\n"), stdout);
3536 fputs (_(" -time Time the execution of each subprocess.\n"), stdout);
3537 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>.\n"), stdout);
3538 fputs (_(" -std=<standard> Assume that the input sources are for <standard>.\n"), stdout);
3539 fputs (_("\
3540 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3541 and libraries.\n"), stdout);
3542 fputs (_(" -B <directory> Add <directory> to the compiler's search paths.\n"), stdout);
3543 fputs (_(" -v Display the programs invoked by the compiler.\n"), stdout);
3544 fputs (_(" -### Like -v but options quoted and commands not executed.\n"), stdout);
3545 fputs (_(" -E Preprocess only; do not compile, assemble or link.\n"), stdout);
3546 fputs (_(" -S Compile only; do not assemble or link.\n"), stdout);
3547 fputs (_(" -c Compile and assemble, but do not link.\n"), stdout);
3548 fputs (_(" -o <file> Place the output into <file>.\n"), stdout);
3549 fputs (_(" -pie Create a dynamically linked position independent\n\
3550 executable.\n"), stdout);
3551 fputs (_(" -shared Create a shared library.\n"), stdout);
3552 fputs (_("\
3553 -x <language> Specify the language of the following input files.\n\
3554 Permissible languages include: c c++ assembler none\n\
3555 'none' means revert to the default behavior of\n\
3556 guessing the language based on the file's extension.\n\
3557 "), stdout);
3559 printf (_("\
3560 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3561 passed on to the various sub-processes invoked by %s. In order to pass\n\
3562 other options on to these processes the -W<letter> options must be used.\n\
3563 "), progname);
3565 /* The rest of the options are displayed by invocations of the various
3566 sub-processes. */
3569 static void
3570 add_preprocessor_option (const char *option, int len)
3572 preprocessor_options.safe_push (save_string (option, len));
3575 static void
3576 add_assembler_option (const char *option, int len)
3578 assembler_options.safe_push (save_string (option, len));
3581 static void
3582 add_linker_option (const char *option, int len)
3584 linker_options.safe_push (save_string (option, len));
3587 /* Allocate space for an input file in infiles. */
3589 static void
3590 alloc_infile (void)
3592 if (n_infiles_alloc == 0)
3594 n_infiles_alloc = 16;
3595 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3597 else if (n_infiles_alloc == n_infiles)
3599 n_infiles_alloc *= 2;
3600 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3604 /* Store an input file with the given NAME and LANGUAGE in
3605 infiles. */
3607 static void
3608 add_infile (const char *name, const char *language)
3610 alloc_infile ();
3611 infiles[n_infiles].name = name;
3612 infiles[n_infiles++].language = language;
3615 /* Allocate space for a switch in switches. */
3617 static void
3618 alloc_switch (void)
3620 if (n_switches_alloc == 0)
3622 n_switches_alloc = 16;
3623 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3625 else if (n_switches_alloc == n_switches)
3627 n_switches_alloc *= 2;
3628 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3632 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3633 as validated if VALIDATED and KNOWN if it is an internal switch. */
3635 static void
3636 save_switch (const char *opt, size_t n_args, const char *const *args,
3637 bool validated, bool known)
3639 alloc_switch ();
3640 switches[n_switches].part1 = opt + 1;
3641 if (n_args == 0)
3642 switches[n_switches].args = 0;
3643 else
3645 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3646 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3647 switches[n_switches].args[n_args] = NULL;
3650 switches[n_switches].live_cond = 0;
3651 switches[n_switches].validated = validated;
3652 switches[n_switches].known = known;
3653 switches[n_switches].ordering = 0;
3654 n_switches++;
3657 /* Set the SOURCE_DATE_EPOCH environment variable to the current time if it is
3658 not set already. */
3660 static void
3661 set_source_date_epoch_envvar ()
3663 /* Array size is 21 = ceil(log_10(2^64)) + 1 to hold string representations
3664 of 64 bit integers. */
3665 char source_date_epoch[21];
3666 time_t tt;
3668 errno = 0;
3669 tt = time (NULL);
3670 if (tt < (time_t) 0 || errno != 0)
3671 tt = (time_t) 0;
3673 snprintf (source_date_epoch, 21, "%llu", (unsigned long long) tt);
3674 /* Using setenv instead of xputenv because we want the variable to remain
3675 after finalizing so that it's still set in the second run when using
3676 -fcompare-debug. */
3677 setenv ("SOURCE_DATE_EPOCH", source_date_epoch, 0);
3680 /* Handle an option DECODED that is unknown to the option-processing
3681 machinery. */
3683 static bool
3684 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3686 const char *opt = decoded->arg;
3687 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3688 && !(decoded->errors & CL_ERR_NEGATIVE))
3690 /* Leave unknown -Wno-* options for the compiler proper, to be
3691 diagnosed only if there are warnings. */
3692 save_switch (decoded->canonical_option[0],
3693 decoded->canonical_option_num_elements - 1,
3694 &decoded->canonical_option[1], false, true);
3695 return false;
3697 if (decoded->opt_index == OPT_SPECIAL_unknown)
3699 /* Give it a chance to define it a spec file. */
3700 save_switch (decoded->canonical_option[0],
3701 decoded->canonical_option_num_elements - 1,
3702 &decoded->canonical_option[1], false, false);
3703 return false;
3705 else
3706 return true;
3709 /* Handle an option DECODED that is not marked as CL_DRIVER.
3710 LANG_MASK will always be CL_DRIVER. */
3712 static void
3713 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3714 unsigned int lang_mask ATTRIBUTE_UNUSED)
3716 /* At this point, non-driver options are accepted (and expected to
3717 be passed down by specs) unless marked to be rejected by the
3718 driver. Options to be rejected by the driver but accepted by the
3719 compilers proper are treated just like completely unknown
3720 options. */
3721 const struct cl_option *option = &cl_options[decoded->opt_index];
3723 if (option->cl_reject_driver)
3724 error ("unrecognized command line option %qs",
3725 decoded->orig_option_with_args_text);
3726 else
3727 save_switch (decoded->canonical_option[0],
3728 decoded->canonical_option_num_elements - 1,
3729 &decoded->canonical_option[1], false, true);
3732 static const char *spec_lang = 0;
3733 static int last_language_n_infiles;
3735 /* Parse -foffload option argument. */
3737 static void
3738 handle_foffload_option (const char *arg)
3740 const char *c, *cur, *n, *next, *end;
3741 char *target;
3743 /* If option argument starts with '-' then no target is specified and we
3744 do not need to parse it. */
3745 if (arg[0] == '-')
3746 return;
3748 end = strchr (arg, '=');
3749 if (end == NULL)
3750 end = strchr (arg, '\0');
3751 cur = arg;
3753 while (cur < end)
3755 next = strchr (cur, ',');
3756 if (next == NULL)
3757 next = end;
3758 next = (next > end) ? end : next;
3760 target = XNEWVEC (char, next - cur + 1);
3761 memcpy (target, cur, next - cur);
3762 target[next - cur] = '\0';
3764 /* If 'disable' is passed to the option, stop parsing the option and clean
3765 the list of offload targets. */
3766 if (strcmp (target, "disable") == 0)
3768 free (offload_targets);
3769 offload_targets = xstrdup ("");
3770 break;
3773 /* Check that GCC is configured to support the offload target. */
3774 c = OFFLOAD_TARGETS;
3775 while (c)
3777 n = strchr (c, ',');
3778 if (n == NULL)
3779 n = strchr (c, '\0');
3781 if (next - cur == n - c && strncmp (target, c, n - c) == 0)
3782 break;
3784 c = *n ? n + 1 : NULL;
3787 if (!c)
3788 fatal_error (input_location,
3789 "GCC is not configured to support %s as offload target",
3790 target);
3792 if (!offload_targets)
3794 offload_targets = target;
3795 target = NULL;
3797 else
3799 /* Check that the target hasn't already presented in the list. */
3800 c = offload_targets;
3803 n = strchr (c, ':');
3804 if (n == NULL)
3805 n = strchr (c, '\0');
3807 if (next - cur == n - c && strncmp (c, target, n - c) == 0)
3808 break;
3810 c = n + 1;
3812 while (*n);
3814 /* If duplicate is not found, append the target to the list. */
3815 if (c > n)
3817 size_t offload_targets_len = strlen (offload_targets);
3818 offload_targets
3819 = XRESIZEVEC (char, offload_targets,
3820 offload_targets_len + 1 + next - cur + 1);
3821 offload_targets[offload_targets_len++] = ':';
3822 memcpy (offload_targets + offload_targets_len, target, next - cur + 1);
3826 cur = next + 1;
3827 XDELETEVEC (target);
3831 /* Handle a driver option; arguments and return value as for
3832 handle_option. */
3834 static bool
3835 driver_handle_option (struct gcc_options *opts,
3836 struct gcc_options *opts_set,
3837 const struct cl_decoded_option *decoded,
3838 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3839 location_t loc,
3840 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3841 diagnostic_context *dc,
3842 void (*) (void))
3844 size_t opt_index = decoded->opt_index;
3845 const char *arg = decoded->arg;
3846 const char *compare_debug_replacement_opt;
3847 int value = decoded->value;
3848 bool validated = false;
3849 bool do_save = true;
3851 gcc_assert (opts == &global_options);
3852 gcc_assert (opts_set == &global_options_set);
3853 gcc_assert (kind == DK_UNSPECIFIED);
3854 gcc_assert (loc == UNKNOWN_LOCATION);
3855 gcc_assert (dc == global_dc);
3857 switch (opt_index)
3859 case OPT_dumpspecs:
3861 struct spec_list *sl;
3862 init_spec ();
3863 for (sl = specs; sl; sl = sl->next)
3864 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3865 if (link_command_spec)
3866 printf ("*link_command:\n%s\n\n", link_command_spec);
3867 exit (0);
3870 case OPT_dumpversion:
3871 printf ("%s\n", spec_version);
3872 exit (0);
3874 case OPT_dumpmachine:
3875 printf ("%s\n", spec_machine);
3876 exit (0);
3878 case OPT_dumpfullversion:
3879 printf ("%s\n", BASEVER);
3880 exit (0);
3882 case OPT__version:
3883 print_version = 1;
3885 /* CPP driver cannot obtain switch from cc1_options. */
3886 if (is_cpp_driver)
3887 add_preprocessor_option ("--version", strlen ("--version"));
3888 add_assembler_option ("--version", strlen ("--version"));
3889 add_linker_option ("--version", strlen ("--version"));
3890 break;
3892 case OPT__help:
3893 print_help_list = 1;
3895 /* CPP driver cannot obtain switch from cc1_options. */
3896 if (is_cpp_driver)
3897 add_preprocessor_option ("--help", 6);
3898 add_assembler_option ("--help", 6);
3899 add_linker_option ("--help", 6);
3900 break;
3902 case OPT__help_:
3903 print_subprocess_help = 2;
3904 break;
3906 case OPT__target_help:
3907 print_subprocess_help = 1;
3909 /* CPP driver cannot obtain switch from cc1_options. */
3910 if (is_cpp_driver)
3911 add_preprocessor_option ("--target-help", 13);
3912 add_assembler_option ("--target-help", 13);
3913 add_linker_option ("--target-help", 13);
3914 break;
3916 case OPT__no_sysroot_suffix:
3917 case OPT_pass_exit_codes:
3918 case OPT_print_search_dirs:
3919 case OPT_print_file_name_:
3920 case OPT_print_prog_name_:
3921 case OPT_print_multi_lib:
3922 case OPT_print_multi_directory:
3923 case OPT_print_sysroot:
3924 case OPT_print_multi_os_directory:
3925 case OPT_print_multiarch:
3926 case OPT_print_sysroot_headers_suffix:
3927 case OPT_time:
3928 case OPT_wrapper:
3929 /* These options set the variables specified in common.opt
3930 automatically, and do not need to be saved for spec
3931 processing. */
3932 do_save = false;
3933 break;
3935 case OPT_print_libgcc_file_name:
3936 print_file_name = "libgcc.a";
3937 do_save = false;
3938 break;
3940 case OPT_fuse_ld_bfd:
3941 use_ld = ".bfd";
3942 break;
3944 case OPT_fuse_ld_gold:
3945 use_ld = ".gold";
3946 break;
3948 case OPT_fcompare_debug_second:
3949 compare_debug_second = 1;
3950 break;
3952 case OPT_fcompare_debug:
3953 switch (value)
3955 case 0:
3956 compare_debug_replacement_opt = "-fcompare-debug=";
3957 arg = "";
3958 goto compare_debug_with_arg;
3960 case 1:
3961 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3962 arg = "-gtoggle";
3963 goto compare_debug_with_arg;
3965 default:
3966 gcc_unreachable ();
3968 break;
3970 case OPT_fcompare_debug_:
3971 compare_debug_replacement_opt = decoded->canonical_option[0];
3972 compare_debug_with_arg:
3973 gcc_assert (decoded->canonical_option_num_elements == 1);
3974 gcc_assert (arg != NULL);
3975 if (*arg)
3976 compare_debug = 1;
3977 else
3978 compare_debug = -1;
3979 if (compare_debug < 0)
3980 compare_debug_opt = NULL;
3981 else
3982 compare_debug_opt = arg;
3983 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3984 set_source_date_epoch_envvar ();
3985 return true;
3987 case OPT_fdiagnostics_color_:
3988 diagnostic_color_init (dc, value);
3989 break;
3991 case OPT_Wa_:
3993 int prev, j;
3994 /* Pass the rest of this option to the assembler. */
3996 /* Split the argument at commas. */
3997 prev = 0;
3998 for (j = 0; arg[j]; j++)
3999 if (arg[j] == ',')
4001 add_assembler_option (arg + prev, j - prev);
4002 prev = j + 1;
4005 /* Record the part after the last comma. */
4006 add_assembler_option (arg + prev, j - prev);
4008 do_save = false;
4009 break;
4011 case OPT_Wp_:
4013 int prev, j;
4014 /* Pass the rest of this option to the preprocessor. */
4016 /* Split the argument at commas. */
4017 prev = 0;
4018 for (j = 0; arg[j]; j++)
4019 if (arg[j] == ',')
4021 add_preprocessor_option (arg + prev, j - prev);
4022 prev = j + 1;
4025 /* Record the part after the last comma. */
4026 add_preprocessor_option (arg + prev, j - prev);
4028 do_save = false;
4029 break;
4031 case OPT_Wl_:
4033 int prev, j;
4034 /* Split the argument at commas. */
4035 prev = 0;
4036 for (j = 0; arg[j]; j++)
4037 if (arg[j] == ',')
4039 add_infile (save_string (arg + prev, j - prev), "*");
4040 prev = j + 1;
4042 /* Record the part after the last comma. */
4043 add_infile (arg + prev, "*");
4045 do_save = false;
4046 break;
4048 case OPT_Xlinker:
4049 add_infile (arg, "*");
4050 do_save = false;
4051 break;
4053 case OPT_Xpreprocessor:
4054 add_preprocessor_option (arg, strlen (arg));
4055 do_save = false;
4056 break;
4058 case OPT_Xassembler:
4059 add_assembler_option (arg, strlen (arg));
4060 do_save = false;
4061 break;
4063 case OPT_l:
4064 /* POSIX allows separation of -l and the lib arg; canonicalize
4065 by concatenating -l with its arg */
4066 add_infile (concat ("-l", arg, NULL), "*");
4067 do_save = false;
4068 break;
4070 case OPT_L:
4071 /* Similarly, canonicalize -L for linkers that may not accept
4072 separate arguments. */
4073 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
4074 return true;
4076 case OPT_F:
4077 /* Likewise -F. */
4078 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
4079 return true;
4081 case OPT_save_temps:
4082 save_temps_flag = SAVE_TEMPS_CWD;
4083 validated = true;
4084 break;
4086 case OPT_save_temps_:
4087 if (strcmp (arg, "cwd") == 0)
4088 save_temps_flag = SAVE_TEMPS_CWD;
4089 else if (strcmp (arg, "obj") == 0
4090 || strcmp (arg, "object") == 0)
4091 save_temps_flag = SAVE_TEMPS_OBJ;
4092 else
4093 fatal_error (input_location, "%qs is an unknown -save-temps option",
4094 decoded->orig_option_with_args_text);
4095 break;
4097 case OPT_no_canonical_prefixes:
4098 /* Already handled as a special case, so ignored here. */
4099 do_save = false;
4100 break;
4102 case OPT_pipe:
4103 validated = true;
4104 /* These options set the variables specified in common.opt
4105 automatically, but do need to be saved for spec
4106 processing. */
4107 break;
4109 case OPT_specs_:
4111 struct user_specs *user = XNEW (struct user_specs);
4113 user->next = (struct user_specs *) 0;
4114 user->filename = arg;
4115 if (user_specs_tail)
4116 user_specs_tail->next = user;
4117 else
4118 user_specs_head = user;
4119 user_specs_tail = user;
4121 validated = true;
4122 break;
4124 case OPT__sysroot_:
4125 target_system_root = arg;
4126 target_system_root_changed = 1;
4127 do_save = false;
4128 break;
4130 case OPT_time_:
4131 if (report_times_to_file)
4132 fclose (report_times_to_file);
4133 report_times_to_file = fopen (arg, "a");
4134 do_save = false;
4135 break;
4137 case OPT____:
4138 /* "-###"
4139 This is similar to -v except that there is no execution
4140 of the commands and the echoed arguments are quoted. It
4141 is intended for use in shell scripts to capture the
4142 driver-generated command line. */
4143 verbose_only_flag++;
4144 verbose_flag = 1;
4145 do_save = false;
4146 break;
4148 case OPT_B:
4150 size_t len = strlen (arg);
4152 /* Catch the case where the user has forgotten to append a
4153 directory separator to the path. Note, they may be using
4154 -B to add an executable name prefix, eg "i386-elf-", in
4155 order to distinguish between multiple installations of
4156 GCC in the same directory. Hence we must check to see
4157 if appending a directory separator actually makes a
4158 valid directory name. */
4159 if (!IS_DIR_SEPARATOR (arg[len - 1])
4160 && is_directory (arg, false))
4162 char *tmp = XNEWVEC (char, len + 2);
4163 strcpy (tmp, arg);
4164 tmp[len] = DIR_SEPARATOR;
4165 tmp[++len] = 0;
4166 arg = tmp;
4169 add_prefix (&exec_prefixes, arg, NULL,
4170 PREFIX_PRIORITY_B_OPT, 0, 0);
4171 add_prefix (&startfile_prefixes, arg, NULL,
4172 PREFIX_PRIORITY_B_OPT, 0, 0);
4173 add_prefix (&include_prefixes, arg, NULL,
4174 PREFIX_PRIORITY_B_OPT, 0, 0);
4176 validated = true;
4177 break;
4179 case OPT_E:
4180 have_E = true;
4181 break;
4183 case OPT_x:
4184 spec_lang = arg;
4185 if (!strcmp (spec_lang, "none"))
4186 /* Suppress the warning if -xnone comes after the last input
4187 file, because alternate command interfaces like g++ might
4188 find it useful to place -xnone after each input file. */
4189 spec_lang = 0;
4190 else
4191 last_language_n_infiles = n_infiles;
4192 do_save = false;
4193 break;
4195 case OPT_o:
4196 have_o = 1;
4197 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
4198 arg = convert_filename (arg, ! have_c, 0);
4199 #endif
4200 output_file = arg;
4201 /* Save the output name in case -save-temps=obj was used. */
4202 save_temps_prefix = xstrdup (arg);
4203 /* On some systems, ld cannot handle "-o" without a space. So
4204 split the option from its argument. */
4205 save_switch ("-o", 1, &arg, validated, true);
4206 return true;
4208 #ifdef ENABLE_DEFAULT_PIE
4209 case OPT_pie:
4210 /* -pie is turned on by default. */
4211 #endif
4213 case OPT_static_libgcc:
4214 case OPT_shared_libgcc:
4215 case OPT_static_libgfortran:
4216 case OPT_static_libstdc__:
4217 /* These are always valid, since gcc.c itself understands the
4218 first two, gfortranspec.c understands -static-libgfortran and
4219 g++spec.c understands -static-libstdc++ */
4220 validated = true;
4221 break;
4223 case OPT_fwpa:
4224 flag_wpa = "";
4225 break;
4227 case OPT_foffload_:
4228 handle_foffload_option (arg);
4229 break;
4231 default:
4232 /* Various driver options need no special processing at this
4233 point, having been handled in a prescan above or being
4234 handled by specs. */
4235 break;
4238 if (do_save)
4239 save_switch (decoded->canonical_option[0],
4240 decoded->canonical_option_num_elements - 1,
4241 &decoded->canonical_option[1], validated, true);
4242 return true;
4245 /* Put the driver's standard set of option handlers in *HANDLERS. */
4247 static void
4248 set_option_handlers (struct cl_option_handlers *handlers)
4250 handlers->unknown_option_callback = driver_unknown_option_callback;
4251 handlers->wrong_lang_callback = driver_wrong_lang_callback;
4252 handlers->num_handlers = 3;
4253 handlers->handlers[0].handler = driver_handle_option;
4254 handlers->handlers[0].mask = CL_DRIVER;
4255 handlers->handlers[1].handler = common_handle_option;
4256 handlers->handlers[1].mask = CL_COMMON;
4257 handlers->handlers[2].handler = target_handle_option;
4258 handlers->handlers[2].mask = CL_TARGET;
4261 /* Create the vector `switches' and its contents.
4262 Store its length in `n_switches'. */
4264 static void
4265 process_command (unsigned int decoded_options_count,
4266 struct cl_decoded_option *decoded_options)
4268 const char *temp;
4269 char *temp1;
4270 char *tooldir_prefix, *tooldir_prefix2;
4271 char *(*get_relative_prefix) (const char *, const char *,
4272 const char *) = NULL;
4273 struct cl_option_handlers handlers;
4274 unsigned int j;
4276 gcc_exec_prefix = env.get ("GCC_EXEC_PREFIX");
4278 n_switches = 0;
4279 n_infiles = 0;
4280 added_libraries = 0;
4282 /* Figure compiler version from version string. */
4284 compiler_version = temp1 = xstrdup (version_string);
4286 for (; *temp1; ++temp1)
4288 if (*temp1 == ' ')
4290 *temp1 = '\0';
4291 break;
4295 /* Handle any -no-canonical-prefixes flag early, to assign the function
4296 that builds relative prefixes. This function creates default search
4297 paths that are needed later in normal option handling. */
4299 for (j = 1; j < decoded_options_count; j++)
4301 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
4303 get_relative_prefix = make_relative_prefix_ignore_links;
4304 break;
4307 if (! get_relative_prefix)
4308 get_relative_prefix = make_relative_prefix;
4310 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
4311 see if we can create it from the pathname specified in
4312 decoded_options[0].arg. */
4314 gcc_libexec_prefix = standard_libexec_prefix;
4315 #ifndef VMS
4316 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
4317 if (!gcc_exec_prefix)
4319 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
4320 standard_bindir_prefix,
4321 standard_exec_prefix);
4322 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
4323 standard_bindir_prefix,
4324 standard_libexec_prefix);
4325 if (gcc_exec_prefix)
4326 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
4328 else
4330 /* make_relative_prefix requires a program name, but
4331 GCC_EXEC_PREFIX is typically a directory name with a trailing
4332 / (which is ignored by make_relative_prefix), so append a
4333 program name. */
4334 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
4335 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
4336 standard_exec_prefix,
4337 standard_libexec_prefix);
4339 /* The path is unrelocated, so fallback to the original setting. */
4340 if (!gcc_libexec_prefix)
4341 gcc_libexec_prefix = standard_libexec_prefix;
4343 free (tmp_prefix);
4345 #else
4346 #endif
4347 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
4348 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
4349 or an automatically created GCC_EXEC_PREFIX from
4350 decoded_options[0].arg. */
4352 /* Do language-specific adjustment/addition of flags. */
4353 lang_specific_driver (&decoded_options, &decoded_options_count,
4354 &added_libraries);
4356 if (gcc_exec_prefix)
4358 int len = strlen (gcc_exec_prefix);
4360 if (len > (int) sizeof ("/lib/gcc/") - 1
4361 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
4363 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
4364 if (IS_DIR_SEPARATOR (*temp)
4365 && filename_ncmp (temp + 1, "lib", 3) == 0
4366 && IS_DIR_SEPARATOR (temp[4])
4367 && filename_ncmp (temp + 5, "gcc", 3) == 0)
4368 len -= sizeof ("/lib/gcc/") - 1;
4371 set_std_prefix (gcc_exec_prefix, len);
4372 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
4373 PREFIX_PRIORITY_LAST, 0, 0);
4374 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
4375 PREFIX_PRIORITY_LAST, 0, 0);
4378 /* COMPILER_PATH and LIBRARY_PATH have values
4379 that are lists of directory names with colons. */
4381 temp = env.get ("COMPILER_PATH");
4382 if (temp)
4384 const char *startp, *endp;
4385 char *nstore = (char *) alloca (strlen (temp) + 3);
4387 startp = endp = temp;
4388 while (1)
4390 if (*endp == PATH_SEPARATOR || *endp == 0)
4392 strncpy (nstore, startp, endp - startp);
4393 if (endp == startp)
4394 strcpy (nstore, concat (".", dir_separator_str, NULL));
4395 else if (!IS_DIR_SEPARATOR (endp[-1]))
4397 nstore[endp - startp] = DIR_SEPARATOR;
4398 nstore[endp - startp + 1] = 0;
4400 else
4401 nstore[endp - startp] = 0;
4402 add_prefix (&exec_prefixes, nstore, 0,
4403 PREFIX_PRIORITY_LAST, 0, 0);
4404 add_prefix (&include_prefixes, nstore, 0,
4405 PREFIX_PRIORITY_LAST, 0, 0);
4406 if (*endp == 0)
4407 break;
4408 endp = startp = endp + 1;
4410 else
4411 endp++;
4415 temp = env.get (LIBRARY_PATH_ENV);
4416 if (temp && *cross_compile == '0')
4418 const char *startp, *endp;
4419 char *nstore = (char *) alloca (strlen (temp) + 3);
4421 startp = endp = temp;
4422 while (1)
4424 if (*endp == PATH_SEPARATOR || *endp == 0)
4426 strncpy (nstore, startp, endp - startp);
4427 if (endp == startp)
4428 strcpy (nstore, concat (".", dir_separator_str, NULL));
4429 else if (!IS_DIR_SEPARATOR (endp[-1]))
4431 nstore[endp - startp] = DIR_SEPARATOR;
4432 nstore[endp - startp + 1] = 0;
4434 else
4435 nstore[endp - startp] = 0;
4436 add_prefix (&startfile_prefixes, nstore, NULL,
4437 PREFIX_PRIORITY_LAST, 0, 1);
4438 if (*endp == 0)
4439 break;
4440 endp = startp = endp + 1;
4442 else
4443 endp++;
4447 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
4448 temp = env.get ("LPATH");
4449 if (temp && *cross_compile == '0')
4451 const char *startp, *endp;
4452 char *nstore = (char *) alloca (strlen (temp) + 3);
4454 startp = endp = temp;
4455 while (1)
4457 if (*endp == PATH_SEPARATOR || *endp == 0)
4459 strncpy (nstore, startp, endp - startp);
4460 if (endp == startp)
4461 strcpy (nstore, concat (".", dir_separator_str, NULL));
4462 else if (!IS_DIR_SEPARATOR (endp[-1]))
4464 nstore[endp - startp] = DIR_SEPARATOR;
4465 nstore[endp - startp + 1] = 0;
4467 else
4468 nstore[endp - startp] = 0;
4469 add_prefix (&startfile_prefixes, nstore, NULL,
4470 PREFIX_PRIORITY_LAST, 0, 1);
4471 if (*endp == 0)
4472 break;
4473 endp = startp = endp + 1;
4475 else
4476 endp++;
4480 /* Process the options and store input files and switches in their
4481 vectors. */
4483 last_language_n_infiles = -1;
4485 set_option_handlers (&handlers);
4487 for (j = 1; j < decoded_options_count; j++)
4489 switch (decoded_options[j].opt_index)
4491 case OPT_S:
4492 case OPT_c:
4493 case OPT_E:
4494 have_c = 1;
4495 break;
4497 if (have_c)
4498 break;
4501 for (j = 1; j < decoded_options_count; j++)
4503 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
4505 const char *arg = decoded_options[j].arg;
4506 const char *p = strrchr (arg, '@');
4507 char *fname;
4508 long offset;
4509 int consumed;
4510 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4511 arg = convert_filename (arg, 0, access (arg, F_OK));
4512 #endif
4513 /* For LTO static archive support we handle input file
4514 specifications that are composed of a filename and
4515 an offset like FNAME@OFFSET. */
4516 if (p
4517 && p != arg
4518 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
4519 && strlen (p) == (unsigned int)consumed)
4521 fname = (char *)xmalloc (p - arg + 1);
4522 memcpy (fname, arg, p - arg);
4523 fname[p - arg] = '\0';
4524 /* Only accept non-stdin and existing FNAME parts, otherwise
4525 try with the full name. */
4526 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
4528 free (fname);
4529 fname = xstrdup (arg);
4532 else
4533 fname = xstrdup (arg);
4535 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
4537 if (fname[0] == '@' && access (fname + 1, F_OK) < 0)
4538 perror_with_name (fname + 1);
4539 else
4540 perror_with_name (fname);
4542 else
4543 add_infile (arg, spec_lang);
4545 free (fname);
4546 continue;
4549 read_cmdline_option (&global_options, &global_options_set,
4550 decoded_options + j, UNKNOWN_LOCATION,
4551 CL_DRIVER, &handlers, global_dc);
4554 /* If the user didn't specify any, default to all configured offload
4555 targets. */
4556 if (ENABLE_OFFLOADING && offload_targets == NULL)
4557 handle_foffload_option (OFFLOAD_TARGETS);
4559 if (output_file
4560 && strcmp (output_file, "-") != 0
4561 && strcmp (output_file, HOST_BIT_BUCKET) != 0)
4563 int i;
4564 for (i = 0; i < n_infiles; i++)
4565 if ((!infiles[i].language || infiles[i].language[0] != '*')
4566 && canonical_filename_eq (infiles[i].name, output_file))
4567 fatal_error (input_location,
4568 "input file %qs is the same as output file",
4569 output_file);
4572 if (output_file != NULL && output_file[0] == '\0')
4573 fatal_error (input_location, "output filename may not be empty");
4575 /* If -save-temps=obj and -o name, create the prefix to use for %b.
4576 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
4577 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
4579 save_temps_length = strlen (save_temps_prefix);
4580 temp = strrchr (lbasename (save_temps_prefix), '.');
4581 if (temp)
4583 save_temps_length -= strlen (temp);
4584 save_temps_prefix[save_temps_length] = '\0';
4588 else if (save_temps_prefix != NULL)
4590 free (save_temps_prefix);
4591 save_temps_prefix = NULL;
4594 if (save_temps_flag && use_pipes)
4596 /* -save-temps overrides -pipe, so that temp files are produced */
4597 if (save_temps_flag)
4598 warning (0, "-pipe ignored because -save-temps specified");
4599 use_pipes = 0;
4602 if (!compare_debug)
4604 const char *gcd = env.get ("GCC_COMPARE_DEBUG");
4606 if (gcd && gcd[0] == '-')
4608 compare_debug = 2;
4609 compare_debug_opt = gcd;
4611 else if (gcd && *gcd && strcmp (gcd, "0"))
4613 compare_debug = 3;
4614 compare_debug_opt = "-gtoggle";
4617 else if (compare_debug < 0)
4619 compare_debug = 0;
4620 gcc_assert (!compare_debug_opt);
4623 /* Set up the search paths. We add directories that we expect to
4624 contain GNU Toolchain components before directories specified by
4625 the machine description so that we will find GNU components (like
4626 the GNU assembler) before those of the host system. */
4628 /* If we don't know where the toolchain has been installed, use the
4629 configured-in locations. */
4630 if (!gcc_exec_prefix)
4632 #ifndef OS2
4633 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
4634 PREFIX_PRIORITY_LAST, 1, 0);
4635 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
4636 PREFIX_PRIORITY_LAST, 2, 0);
4637 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
4638 PREFIX_PRIORITY_LAST, 2, 0);
4639 #endif
4640 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
4641 PREFIX_PRIORITY_LAST, 1, 0);
4644 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
4645 tooldir_prefix2 = concat (tooldir_base_prefix, spec_machine,
4646 dir_separator_str, NULL);
4648 /* Look for tools relative to the location from which the driver is
4649 running, or, if that is not available, the configured prefix. */
4650 tooldir_prefix
4651 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4652 spec_host_machine, dir_separator_str, spec_version,
4653 accel_dir_suffix, dir_separator_str, tooldir_prefix2, NULL);
4654 free (tooldir_prefix2);
4656 add_prefix (&exec_prefixes,
4657 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4658 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4659 add_prefix (&startfile_prefixes,
4660 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4661 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4662 free (tooldir_prefix);
4664 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4665 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4666 then consider it to relocate with the rest of the GCC installation
4667 if GCC_EXEC_PREFIX is set.
4668 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4669 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
4671 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
4672 standard_bindir_prefix,
4673 target_system_root);
4674 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4676 target_system_root = tmp_prefix;
4677 target_system_root_changed = 1;
4680 #endif
4682 /* More prefixes are enabled in main, after we read the specs file
4683 and determine whether this is cross-compilation or not. */
4685 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4686 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
4688 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
4689 environment variable. */
4690 if (compare_debug == 2 || compare_debug == 3)
4692 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
4693 save_switch (opt, 0, NULL, false, true);
4694 compare_debug = 1;
4697 /* Ensure we only invoke each subprocess once. */
4698 if (print_subprocess_help || print_help_list || print_version)
4700 n_infiles = 0;
4702 /* Create a dummy input file, so that we can pass
4703 the help option on to the various sub-processes. */
4704 add_infile ("help-dummy", "c");
4707 /* Decide if undefined variable references are allowed in specs. */
4709 /* -v alone is safe. --version and --help alone or together are safe. Note
4710 that -v would make them unsafe, as they'd then be run for subprocesses as
4711 well, the location of which might depend on variables possibly coming
4712 from self-specs. Note also that the command name is counted in
4713 decoded_options_count. */
4715 unsigned help_version_count = 0;
4717 if (print_version)
4718 help_version_count++;
4720 if (print_help_list)
4721 help_version_count++;
4723 spec_undefvar_allowed =
4724 ((verbose_flag && decoded_options_count == 2)
4725 || help_version_count == decoded_options_count - 1);
4727 alloc_switch ();
4728 switches[n_switches].part1 = 0;
4729 alloc_infile ();
4730 infiles[n_infiles].name = 0;
4733 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4734 and place that in the environment. */
4736 static void
4737 set_collect_gcc_options (void)
4739 int i;
4740 int first_time;
4742 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4743 the compiler. */
4744 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4745 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4747 first_time = TRUE;
4748 for (i = 0; (int) i < n_switches; i++)
4750 const char *const *args;
4751 const char *p, *q;
4752 if (!first_time)
4753 obstack_grow (&collect_obstack, " ", 1);
4755 first_time = FALSE;
4757 /* Ignore elided switches. */
4758 if ((switches[i].live_cond
4759 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4760 == SWITCH_IGNORE)
4761 continue;
4763 obstack_grow (&collect_obstack, "'-", 2);
4764 q = switches[i].part1;
4765 while ((p = strchr (q, '\'')))
4767 obstack_grow (&collect_obstack, q, p - q);
4768 obstack_grow (&collect_obstack, "'\\''", 4);
4769 q = ++p;
4771 obstack_grow (&collect_obstack, q, strlen (q));
4772 obstack_grow (&collect_obstack, "'", 1);
4774 for (args = switches[i].args; args && *args; args++)
4776 obstack_grow (&collect_obstack, " '", 2);
4777 q = *args;
4778 while ((p = strchr (q, '\'')))
4780 obstack_grow (&collect_obstack, q, p - q);
4781 obstack_grow (&collect_obstack, "'\\''", 4);
4782 q = ++p;
4784 obstack_grow (&collect_obstack, q, strlen (q));
4785 obstack_grow (&collect_obstack, "'", 1);
4788 obstack_grow (&collect_obstack, "\0", 1);
4789 xputenv (XOBFINISH (&collect_obstack, char *));
4792 /* Process a spec string, accumulating and running commands. */
4794 /* These variables describe the input file name.
4795 input_file_number is the index on outfiles of this file,
4796 so that the output file name can be stored for later use by %o.
4797 input_basename is the start of the part of the input file
4798 sans all directory names, and basename_length is the number
4799 of characters starting there excluding the suffix .c or whatever. */
4801 static const char *gcc_input_filename;
4802 static int input_file_number;
4803 size_t input_filename_length;
4804 static int basename_length;
4805 static int suffixed_basename_length;
4806 static const char *input_basename;
4807 static const char *input_suffix;
4808 #ifndef HOST_LACKS_INODE_NUMBERS
4809 static struct stat input_stat;
4810 #endif
4811 static int input_stat_set;
4813 /* The compiler used to process the current input file. */
4814 static struct compiler *input_file_compiler;
4816 /* These are variables used within do_spec and do_spec_1. */
4818 /* Nonzero if an arg has been started and not yet terminated
4819 (with space, tab or newline). */
4820 static int arg_going;
4822 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4823 is a temporary file name. */
4824 static int delete_this_arg;
4826 /* Nonzero means %w has been seen; the next arg to be terminated
4827 is the output file name of this compilation. */
4828 static int this_is_output_file;
4830 /* Nonzero means %s has been seen; the next arg to be terminated
4831 is the name of a library file and we should try the standard
4832 search dirs for it. */
4833 static int this_is_library_file;
4835 /* Nonzero means %T has been seen; the next arg to be terminated
4836 is the name of a linker script and we should try all of the
4837 standard search dirs for it. If it is found insert a --script
4838 command line switch and then substitute the full path in place,
4839 otherwise generate an error message. */
4840 static int this_is_linker_script;
4842 /* Nonzero means that the input of this command is coming from a pipe. */
4843 static int input_from_pipe;
4845 /* Nonnull means substitute this for any suffix when outputting a switches
4846 arguments. */
4847 static const char *suffix_subst;
4849 /* If there is an argument being accumulated, terminate it and store it. */
4851 static void
4852 end_going_arg (void)
4854 if (arg_going)
4856 const char *string;
4858 obstack_1grow (&obstack, 0);
4859 string = XOBFINISH (&obstack, const char *);
4860 if (this_is_library_file)
4861 string = find_file (string);
4862 if (this_is_linker_script)
4864 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4866 if (full_script_path == NULL)
4868 error ("unable to locate default linker script %qs in the library search paths", string);
4869 /* Script was not found on search path. */
4870 return;
4872 store_arg ("--script", false, false);
4873 string = full_script_path;
4875 store_arg (string, delete_this_arg, this_is_output_file);
4876 if (this_is_output_file)
4877 outfiles[input_file_number] = string;
4878 arg_going = 0;
4883 /* Parse the WRAPPER string which is a comma separated list of the command line
4884 and insert them into the beginning of argbuf. */
4886 static void
4887 insert_wrapper (const char *wrapper)
4889 int n = 0;
4890 int i;
4891 char *buf = xstrdup (wrapper);
4892 char *p = buf;
4893 unsigned int old_length = argbuf.length ();
4897 n++;
4898 while (*p == ',')
4899 p++;
4901 while ((p = strchr (p, ',')) != NULL);
4903 argbuf.safe_grow (old_length + n);
4904 memmove (argbuf.address () + n,
4905 argbuf.address (),
4906 old_length * sizeof (const_char_p));
4908 i = 0;
4909 p = buf;
4912 while (*p == ',')
4914 *p = 0;
4915 p++;
4917 argbuf[i] = p;
4918 i++;
4920 while ((p = strchr (p, ',')) != NULL);
4921 gcc_assert (i == n);
4924 /* Process the spec SPEC and run the commands specified therein.
4925 Returns 0 if the spec is successfully processed; -1 if failed. */
4928 do_spec (const char *spec)
4930 int value;
4932 value = do_spec_2 (spec);
4934 /* Force out any unfinished command.
4935 If -pipe, this forces out the last command if it ended in `|'. */
4936 if (value == 0)
4938 if (argbuf.length () > 0
4939 && !strcmp (argbuf.last (), "|"))
4940 argbuf.pop ();
4942 set_collect_gcc_options ();
4944 if (argbuf.length () > 0)
4945 value = execute ();
4948 return value;
4951 static int
4952 do_spec_2 (const char *spec)
4954 int result;
4956 clear_args ();
4957 arg_going = 0;
4958 delete_this_arg = 0;
4959 this_is_output_file = 0;
4960 this_is_library_file = 0;
4961 this_is_linker_script = 0;
4962 input_from_pipe = 0;
4963 suffix_subst = NULL;
4965 result = do_spec_1 (spec, 0, NULL);
4967 end_going_arg ();
4969 return result;
4973 /* Process the given spec string and add any new options to the end
4974 of the switches/n_switches array. */
4976 static void
4977 do_option_spec (const char *name, const char *spec)
4979 unsigned int i, value_count, value_len;
4980 const char *p, *q, *value;
4981 char *tmp_spec, *tmp_spec_p;
4983 if (configure_default_options[0].name == NULL)
4984 return;
4986 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4987 if (strcmp (configure_default_options[i].name, name) == 0)
4988 break;
4989 if (i == ARRAY_SIZE (configure_default_options))
4990 return;
4992 value = configure_default_options[i].value;
4993 value_len = strlen (value);
4995 /* Compute the size of the final spec. */
4996 value_count = 0;
4997 p = spec;
4998 while ((p = strstr (p, "%(VALUE)")) != NULL)
5000 p ++;
5001 value_count ++;
5004 /* Replace each %(VALUE) by the specified value. */
5005 tmp_spec = (char *) alloca (strlen (spec) + 1
5006 + value_count * (value_len - strlen ("%(VALUE)")));
5007 tmp_spec_p = tmp_spec;
5008 q = spec;
5009 while ((p = strstr (q, "%(VALUE)")) != NULL)
5011 memcpy (tmp_spec_p, q, p - q);
5012 tmp_spec_p = tmp_spec_p + (p - q);
5013 memcpy (tmp_spec_p, value, value_len);
5014 tmp_spec_p += value_len;
5015 q = p + strlen ("%(VALUE)");
5017 strcpy (tmp_spec_p, q);
5019 do_self_spec (tmp_spec);
5022 /* Process the given spec string and add any new options to the end
5023 of the switches/n_switches array. */
5025 static void
5026 do_self_spec (const char *spec)
5028 int i;
5030 do_spec_2 (spec);
5031 do_spec_1 (" ", 0, NULL);
5033 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
5034 do_self_specs adds the replacements to switches array, so it shouldn't
5035 be processed afterwards. */
5036 for (i = 0; i < n_switches; i++)
5037 if ((switches[i].live_cond & SWITCH_IGNORE))
5038 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
5040 if (argbuf.length () > 0)
5042 const char **argbuf_copy;
5043 struct cl_decoded_option *decoded_options;
5044 struct cl_option_handlers handlers;
5045 unsigned int decoded_options_count;
5046 unsigned int j;
5048 /* Create a copy of argbuf with a dummy argv[0] entry for
5049 decode_cmdline_options_to_array. */
5050 argbuf_copy = XNEWVEC (const char *,
5051 argbuf.length () + 1);
5052 argbuf_copy[0] = "";
5053 memcpy (argbuf_copy + 1, argbuf.address (),
5054 argbuf.length () * sizeof (const char *));
5056 decode_cmdline_options_to_array (argbuf.length () + 1,
5057 argbuf_copy,
5058 CL_DRIVER, &decoded_options,
5059 &decoded_options_count);
5060 free (argbuf_copy);
5062 set_option_handlers (&handlers);
5064 for (j = 1; j < decoded_options_count; j++)
5066 switch (decoded_options[j].opt_index)
5068 case OPT_SPECIAL_input_file:
5069 /* Specs should only generate options, not input
5070 files. */
5071 if (strcmp (decoded_options[j].arg, "-") != 0)
5072 fatal_error (input_location,
5073 "switch %qs does not start with %<-%>",
5074 decoded_options[j].arg);
5075 else
5076 fatal_error (input_location,
5077 "spec-generated switch is just %<-%>");
5078 break;
5080 case OPT_fcompare_debug_second:
5081 case OPT_fcompare_debug:
5082 case OPT_fcompare_debug_:
5083 case OPT_o:
5084 /* Avoid duplicate processing of some options from
5085 compare-debug specs; just save them here. */
5086 save_switch (decoded_options[j].canonical_option[0],
5087 (decoded_options[j].canonical_option_num_elements
5088 - 1),
5089 &decoded_options[j].canonical_option[1], false, true);
5090 break;
5092 default:
5093 read_cmdline_option (&global_options, &global_options_set,
5094 decoded_options + j, UNKNOWN_LOCATION,
5095 CL_DRIVER, &handlers, global_dc);
5096 break;
5100 free (decoded_options);
5102 alloc_switch ();
5103 switches[n_switches].part1 = 0;
5107 /* Callback for processing %D and %I specs. */
5109 struct spec_path_info {
5110 const char *option;
5111 const char *append;
5112 size_t append_len;
5113 bool omit_relative;
5114 bool separate_options;
5117 static void *
5118 spec_path (char *path, void *data)
5120 struct spec_path_info *info = (struct spec_path_info *) data;
5121 size_t len = 0;
5122 char save = 0;
5124 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
5125 return NULL;
5127 if (info->append_len != 0)
5129 len = strlen (path);
5130 memcpy (path + len, info->append, info->append_len + 1);
5133 if (!is_directory (path, true))
5134 return NULL;
5136 do_spec_1 (info->option, 1, NULL);
5137 if (info->separate_options)
5138 do_spec_1 (" ", 0, NULL);
5140 if (info->append_len == 0)
5142 len = strlen (path);
5143 save = path[len - 1];
5144 if (IS_DIR_SEPARATOR (path[len - 1]))
5145 path[len - 1] = '\0';
5148 do_spec_1 (path, 1, NULL);
5149 do_spec_1 (" ", 0, NULL);
5151 /* Must not damage the original path. */
5152 if (info->append_len == 0)
5153 path[len - 1] = save;
5155 return NULL;
5158 /* True if we should compile INFILE. */
5160 static bool
5161 compile_input_file_p (struct infile *infile)
5163 if ((!infile->language) || (infile->language[0] != '*'))
5164 if (infile->incompiler == input_file_compiler)
5165 return true;
5166 return false;
5169 /* Process each member of VEC as a spec. */
5171 static void
5172 do_specs_vec (vec<char_p> vec)
5174 unsigned ix;
5175 char *opt;
5177 FOR_EACH_VEC_ELT (vec, ix, opt)
5179 do_spec_1 (opt, 1, NULL);
5180 /* Make each accumulated option a separate argument. */
5181 do_spec_1 (" ", 0, NULL);
5185 /* Process the sub-spec SPEC as a portion of a larger spec.
5186 This is like processing a whole spec except that we do
5187 not initialize at the beginning and we do not supply a
5188 newline by default at the end.
5189 INSWITCH nonzero means don't process %-sequences in SPEC;
5190 in this case, % is treated as an ordinary character.
5191 This is used while substituting switches.
5192 INSWITCH nonzero also causes SPC not to terminate an argument.
5194 Value is zero unless a line was finished
5195 and the command on that line reported an error. */
5197 static int
5198 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
5200 const char *p = spec;
5201 int c;
5202 int i;
5203 int value;
5205 /* If it's an empty string argument to a switch, keep it as is. */
5206 if (inswitch && !*p)
5207 arg_going = 1;
5209 while ((c = *p++))
5210 /* If substituting a switch, treat all chars like letters.
5211 Otherwise, NL, SPC, TAB and % are special. */
5212 switch (inswitch ? 'a' : c)
5214 case '\n':
5215 end_going_arg ();
5217 if (argbuf.length () > 0
5218 && !strcmp (argbuf.last (), "|"))
5220 /* A `|' before the newline means use a pipe here,
5221 but only if -pipe was specified.
5222 Otherwise, execute now and don't pass the `|' as an arg. */
5223 if (use_pipes)
5225 input_from_pipe = 1;
5226 break;
5228 else
5229 argbuf.pop ();
5232 set_collect_gcc_options ();
5234 if (argbuf.length () > 0)
5236 value = execute ();
5237 if (value)
5238 return value;
5240 /* Reinitialize for a new command, and for a new argument. */
5241 clear_args ();
5242 arg_going = 0;
5243 delete_this_arg = 0;
5244 this_is_output_file = 0;
5245 this_is_library_file = 0;
5246 this_is_linker_script = 0;
5247 input_from_pipe = 0;
5248 break;
5250 case '|':
5251 end_going_arg ();
5253 /* Use pipe */
5254 obstack_1grow (&obstack, c);
5255 arg_going = 1;
5256 break;
5258 case '\t':
5259 case ' ':
5260 end_going_arg ();
5262 /* Reinitialize for a new argument. */
5263 delete_this_arg = 0;
5264 this_is_output_file = 0;
5265 this_is_library_file = 0;
5266 this_is_linker_script = 0;
5267 break;
5269 case '%':
5270 switch (c = *p++)
5272 case 0:
5273 fatal_error (input_location, "spec %qs invalid", spec);
5275 case 'b':
5276 if (save_temps_length)
5277 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
5278 else
5279 obstack_grow (&obstack, input_basename, basename_length);
5280 if (compare_debug < 0)
5281 obstack_grow (&obstack, ".gk", 3);
5282 arg_going = 1;
5283 break;
5285 case 'B':
5286 if (save_temps_length)
5287 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
5288 else
5289 obstack_grow (&obstack, input_basename, suffixed_basename_length);
5290 if (compare_debug < 0)
5291 obstack_grow (&obstack, ".gk", 3);
5292 arg_going = 1;
5293 break;
5295 case 'd':
5296 delete_this_arg = 2;
5297 break;
5299 /* Dump out the directories specified with LIBRARY_PATH,
5300 followed by the absolute directories
5301 that we search for startfiles. */
5302 case 'D':
5304 struct spec_path_info info;
5306 info.option = "-L";
5307 info.append_len = 0;
5308 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
5309 /* Used on systems which record the specified -L dirs
5310 and use them to search for dynamic linking.
5311 Relative directories always come from -B,
5312 and it is better not to use them for searching
5313 at run time. In particular, stage1 loses. */
5314 info.omit_relative = true;
5315 #else
5316 info.omit_relative = false;
5317 #endif
5318 info.separate_options = false;
5320 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
5322 break;
5324 case 'e':
5325 /* %efoo means report an error with `foo' as error message
5326 and don't execute any more commands for this file. */
5328 const char *q = p;
5329 char *buf;
5330 while (*p != 0 && *p != '\n')
5331 p++;
5332 buf = (char *) alloca (p - q + 1);
5333 strncpy (buf, q, p - q);
5334 buf[p - q] = 0;
5335 error ("%s", _(buf));
5336 return -1;
5338 break;
5339 case 'n':
5340 /* %nfoo means report a notice with `foo' on stderr. */
5342 const char *q = p;
5343 char *buf;
5344 while (*p != 0 && *p != '\n')
5345 p++;
5346 buf = (char *) alloca (p - q + 1);
5347 strncpy (buf, q, p - q);
5348 buf[p - q] = 0;
5349 inform (UNKNOWN_LOCATION, "%s", _(buf));
5350 if (*p)
5351 p++;
5353 break;
5355 case 'j':
5357 struct stat st;
5359 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
5360 defined, and it is not a directory, and it is
5361 writable, use it. Otherwise, treat this like any
5362 other temporary file. */
5364 if ((!save_temps_flag)
5365 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
5366 && (access (HOST_BIT_BUCKET, W_OK) == 0))
5368 obstack_grow (&obstack, HOST_BIT_BUCKET,
5369 strlen (HOST_BIT_BUCKET));
5370 delete_this_arg = 0;
5371 arg_going = 1;
5372 break;
5375 goto create_temp_file;
5376 case '|':
5377 if (use_pipes)
5379 obstack_1grow (&obstack, '-');
5380 delete_this_arg = 0;
5381 arg_going = 1;
5383 /* consume suffix */
5384 while (*p == '.' || ISALNUM ((unsigned char) *p))
5385 p++;
5386 if (p[0] == '%' && p[1] == 'O')
5387 p += 2;
5389 break;
5391 goto create_temp_file;
5392 case 'm':
5393 if (use_pipes)
5395 /* consume suffix */
5396 while (*p == '.' || ISALNUM ((unsigned char) *p))
5397 p++;
5398 if (p[0] == '%' && p[1] == 'O')
5399 p += 2;
5401 break;
5403 goto create_temp_file;
5404 case 'g':
5405 case 'u':
5406 case 'U':
5407 create_temp_file:
5409 struct temp_name *t;
5410 int suffix_length;
5411 const char *suffix = p;
5412 char *saved_suffix = NULL;
5414 while (*p == '.' || ISALNUM ((unsigned char) *p))
5415 p++;
5416 suffix_length = p - suffix;
5417 if (p[0] == '%' && p[1] == 'O')
5419 p += 2;
5420 /* We don't support extra suffix characters after %O. */
5421 if (*p == '.' || ISALNUM ((unsigned char) *p))
5422 fatal_error (input_location,
5423 "spec %qs has invalid %<%%0%c%>", spec, *p);
5424 if (suffix_length == 0)
5425 suffix = TARGET_OBJECT_SUFFIX;
5426 else
5428 saved_suffix
5429 = XNEWVEC (char, suffix_length
5430 + strlen (TARGET_OBJECT_SUFFIX) + 1);
5431 strncpy (saved_suffix, suffix, suffix_length);
5432 strcpy (saved_suffix + suffix_length,
5433 TARGET_OBJECT_SUFFIX);
5435 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
5438 if (compare_debug < 0)
5440 suffix = concat (".gk", suffix, NULL);
5441 suffix_length += 3;
5444 /* If -save-temps=obj and -o were specified, use that for the
5445 temp file. */
5446 if (save_temps_length)
5448 char *tmp;
5449 temp_filename_length
5450 = save_temps_length + suffix_length + 1;
5451 tmp = (char *) alloca (temp_filename_length);
5452 memcpy (tmp, save_temps_prefix, save_temps_length);
5453 memcpy (tmp + save_temps_length, suffix, suffix_length);
5454 tmp[save_temps_length + suffix_length] = '\0';
5455 temp_filename = save_string (tmp, save_temps_length
5456 + suffix_length);
5457 obstack_grow (&obstack, temp_filename,
5458 temp_filename_length);
5459 arg_going = 1;
5460 delete_this_arg = 0;
5461 break;
5464 /* If the gcc_input_filename has the same suffix specified
5465 for the %g, %u, or %U, and -save-temps is specified,
5466 we could end up using that file as an intermediate
5467 thus clobbering the user's source file (.e.g.,
5468 gcc -save-temps foo.s would clobber foo.s with the
5469 output of cpp0). So check for this condition and
5470 generate a temp file as the intermediate. */
5472 if (save_temps_flag)
5474 char *tmp;
5475 temp_filename_length = basename_length + suffix_length + 1;
5476 tmp = (char *) alloca (temp_filename_length);
5477 memcpy (tmp, input_basename, basename_length);
5478 memcpy (tmp + basename_length, suffix, suffix_length);
5479 tmp[basename_length + suffix_length] = '\0';
5480 temp_filename = tmp;
5482 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
5484 #ifndef HOST_LACKS_INODE_NUMBERS
5485 struct stat st_temp;
5487 /* Note, set_input() resets input_stat_set to 0. */
5488 if (input_stat_set == 0)
5490 input_stat_set = stat (gcc_input_filename,
5491 &input_stat);
5492 if (input_stat_set >= 0)
5493 input_stat_set = 1;
5496 /* If we have the stat for the gcc_input_filename
5497 and we can do the stat for the temp_filename
5498 then the they could still refer to the same
5499 file if st_dev/st_ino's are the same. */
5500 if (input_stat_set != 1
5501 || stat (temp_filename, &st_temp) < 0
5502 || input_stat.st_dev != st_temp.st_dev
5503 || input_stat.st_ino != st_temp.st_ino)
5504 #else
5505 /* Just compare canonical pathnames. */
5506 char* input_realname = lrealpath (gcc_input_filename);
5507 char* temp_realname = lrealpath (temp_filename);
5508 bool files_differ = filename_cmp (input_realname, temp_realname);
5509 free (input_realname);
5510 free (temp_realname);
5511 if (files_differ)
5512 #endif
5514 temp_filename
5515 = save_string (temp_filename,
5516 temp_filename_length - 1);
5517 obstack_grow (&obstack, temp_filename,
5518 temp_filename_length);
5519 arg_going = 1;
5520 delete_this_arg = 0;
5521 break;
5526 /* See if we already have an association of %g/%u/%U and
5527 suffix. */
5528 for (t = temp_names; t; t = t->next)
5529 if (t->length == suffix_length
5530 && strncmp (t->suffix, suffix, suffix_length) == 0
5531 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
5532 break;
5534 /* Make a new association if needed. %u and %j
5535 require one. */
5536 if (t == 0 || c == 'u' || c == 'j')
5538 if (t == 0)
5540 t = XNEW (struct temp_name);
5541 t->next = temp_names;
5542 temp_names = t;
5544 t->length = suffix_length;
5545 if (saved_suffix)
5547 t->suffix = saved_suffix;
5548 saved_suffix = NULL;
5550 else
5551 t->suffix = save_string (suffix, suffix_length);
5552 t->unique = (c == 'u' || c == 'U' || c == 'j');
5553 temp_filename = make_temp_file (t->suffix);
5554 temp_filename_length = strlen (temp_filename);
5555 t->filename = temp_filename;
5556 t->filename_length = temp_filename_length;
5559 free (saved_suffix);
5561 obstack_grow (&obstack, t->filename, t->filename_length);
5562 delete_this_arg = 1;
5564 arg_going = 1;
5565 break;
5567 case 'i':
5568 if (combine_inputs)
5570 /* We are going to expand `%i' into `@FILE', where FILE
5571 is a newly-created temporary filename. The filenames
5572 that would usually be expanded in place of %o will be
5573 written to the temporary file. */
5574 if (at_file_supplied)
5575 open_at_file ();
5577 for (i = 0; (int) i < n_infiles; i++)
5578 if (compile_input_file_p (&infiles[i]))
5580 store_arg (infiles[i].name, 0, 0);
5581 infiles[i].compiled = true;
5584 if (at_file_supplied)
5585 close_at_file ();
5587 else
5589 obstack_grow (&obstack, gcc_input_filename,
5590 input_filename_length);
5591 arg_going = 1;
5593 break;
5595 case 'I':
5597 struct spec_path_info info;
5599 if (multilib_dir)
5601 do_spec_1 ("-imultilib", 1, NULL);
5602 /* Make this a separate argument. */
5603 do_spec_1 (" ", 0, NULL);
5604 do_spec_1 (multilib_dir, 1, NULL);
5605 do_spec_1 (" ", 0, NULL);
5608 if (multiarch_dir)
5610 do_spec_1 ("-imultiarch", 1, NULL);
5611 /* Make this a separate argument. */
5612 do_spec_1 (" ", 0, NULL);
5613 do_spec_1 (multiarch_dir, 1, NULL);
5614 do_spec_1 (" ", 0, NULL);
5617 if (gcc_exec_prefix)
5619 do_spec_1 ("-iprefix", 1, NULL);
5620 /* Make this a separate argument. */
5621 do_spec_1 (" ", 0, NULL);
5622 do_spec_1 (gcc_exec_prefix, 1, NULL);
5623 do_spec_1 (" ", 0, NULL);
5626 if (target_system_root_changed ||
5627 (target_system_root && target_sysroot_hdrs_suffix))
5629 do_spec_1 ("-isysroot", 1, NULL);
5630 /* Make this a separate argument. */
5631 do_spec_1 (" ", 0, NULL);
5632 do_spec_1 (target_system_root, 1, NULL);
5633 if (target_sysroot_hdrs_suffix)
5634 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
5635 do_spec_1 (" ", 0, NULL);
5638 info.option = "-isystem";
5639 info.append = "include";
5640 info.append_len = strlen (info.append);
5641 info.omit_relative = false;
5642 info.separate_options = true;
5644 for_each_path (&include_prefixes, false, info.append_len,
5645 spec_path, &info);
5647 info.append = "include-fixed";
5648 if (*sysroot_hdrs_suffix_spec)
5649 info.append = concat (info.append, dir_separator_str,
5650 multilib_dir, NULL);
5651 info.append_len = strlen (info.append);
5652 for_each_path (&include_prefixes, false, info.append_len,
5653 spec_path, &info);
5655 break;
5657 case 'o':
5658 /* We are going to expand `%o' into `@FILE', where FILE
5659 is a newly-created temporary filename. The filenames
5660 that would usually be expanded in place of %o will be
5661 written to the temporary file. */
5662 if (at_file_supplied)
5663 open_at_file ();
5665 for (i = 0; i < n_infiles + lang_specific_extra_outfiles; i++)
5666 if (outfiles[i])
5667 store_arg (outfiles[i], 0, 0);
5669 if (at_file_supplied)
5670 close_at_file ();
5671 break;
5673 case 'O':
5674 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5675 arg_going = 1;
5676 break;
5678 case 's':
5679 this_is_library_file = 1;
5680 break;
5682 case 'T':
5683 this_is_linker_script = 1;
5684 break;
5686 case 'V':
5687 outfiles[input_file_number] = NULL;
5688 break;
5690 case 'w':
5691 this_is_output_file = 1;
5692 break;
5694 case 'W':
5696 unsigned int cur_index = argbuf.length ();
5697 /* Handle the {...} following the %W. */
5698 if (*p != '{')
5699 fatal_error (input_location,
5700 "spec %qs has invalid %<%%W%c%>", spec, *p);
5701 p = handle_braces (p + 1);
5702 if (p == 0)
5703 return -1;
5704 end_going_arg ();
5705 /* If any args were output, mark the last one for deletion
5706 on failure. */
5707 if (argbuf.length () != cur_index)
5708 record_temp_file (argbuf.last (), 0, 1);
5709 break;
5712 case '@':
5713 /* Handle the {...} following the %@. */
5714 if (*p != '{')
5715 fatal_error (input_location,
5716 "spec %qs has invalid %<%%@%c%>", spec, *p);
5717 if (at_file_supplied)
5718 open_at_file ();
5719 p = handle_braces (p + 1);
5720 if (at_file_supplied)
5721 close_at_file ();
5722 if (p == 0)
5723 return -1;
5724 break;
5726 /* %x{OPTION} records OPTION for %X to output. */
5727 case 'x':
5729 const char *p1 = p;
5730 char *string;
5731 char *opt;
5732 unsigned ix;
5734 /* Skip past the option value and make a copy. */
5735 if (*p != '{')
5736 fatal_error (input_location,
5737 "spec %qs has invalid %<%%x%c%>", spec, *p);
5738 while (*p++ != '}')
5740 string = save_string (p1 + 1, p - p1 - 2);
5742 /* See if we already recorded this option. */
5743 FOR_EACH_VEC_ELT (linker_options, ix, opt)
5744 if (! strcmp (string, opt))
5746 free (string);
5747 return 0;
5750 /* This option is new; add it. */
5751 add_linker_option (string, strlen (string));
5752 free (string);
5754 break;
5756 /* Dump out the options accumulated previously using %x. */
5757 case 'X':
5758 do_specs_vec (linker_options);
5759 break;
5761 /* Dump out the options accumulated previously using -Wa,. */
5762 case 'Y':
5763 do_specs_vec (assembler_options);
5764 break;
5766 /* Dump out the options accumulated previously using -Wp,. */
5767 case 'Z':
5768 do_specs_vec (preprocessor_options);
5769 break;
5771 /* Here are digits and numbers that just process
5772 a certain constant string as a spec. */
5774 case '1':
5775 value = do_spec_1 (cc1_spec, 0, NULL);
5776 if (value != 0)
5777 return value;
5778 break;
5780 case '2':
5781 value = do_spec_1 (cc1plus_spec, 0, NULL);
5782 if (value != 0)
5783 return value;
5784 break;
5786 case 'a':
5787 value = do_spec_1 (asm_spec, 0, NULL);
5788 if (value != 0)
5789 return value;
5790 break;
5792 case 'A':
5793 value = do_spec_1 (asm_final_spec, 0, NULL);
5794 if (value != 0)
5795 return value;
5796 break;
5798 case 'C':
5800 const char *const spec
5801 = (input_file_compiler->cpp_spec
5802 ? input_file_compiler->cpp_spec
5803 : cpp_spec);
5804 value = do_spec_1 (spec, 0, NULL);
5805 if (value != 0)
5806 return value;
5808 break;
5810 case 'E':
5811 value = do_spec_1 (endfile_spec, 0, NULL);
5812 if (value != 0)
5813 return value;
5814 break;
5816 case 'l':
5817 value = do_spec_1 (link_spec, 0, NULL);
5818 if (value != 0)
5819 return value;
5820 break;
5822 case 'L':
5823 value = do_spec_1 (lib_spec, 0, NULL);
5824 if (value != 0)
5825 return value;
5826 break;
5828 case 'M':
5829 if (multilib_os_dir == NULL)
5830 obstack_1grow (&obstack, '.');
5831 else
5832 obstack_grow (&obstack, multilib_os_dir,
5833 strlen (multilib_os_dir));
5834 break;
5836 case 'G':
5837 value = do_spec_1 (libgcc_spec, 0, NULL);
5838 if (value != 0)
5839 return value;
5840 break;
5842 case 'R':
5843 /* We assume there is a directory
5844 separator at the end of this string. */
5845 if (target_system_root)
5847 obstack_grow (&obstack, target_system_root,
5848 strlen (target_system_root));
5849 if (target_sysroot_suffix)
5850 obstack_grow (&obstack, target_sysroot_suffix,
5851 strlen (target_sysroot_suffix));
5853 break;
5855 case 'S':
5856 value = do_spec_1 (startfile_spec, 0, NULL);
5857 if (value != 0)
5858 return value;
5859 break;
5861 /* Here we define characters other than letters and digits. */
5863 case '{':
5864 p = handle_braces (p);
5865 if (p == 0)
5866 return -1;
5867 break;
5869 case ':':
5870 p = handle_spec_function (p, NULL);
5871 if (p == 0)
5872 return -1;
5873 break;
5875 case '%':
5876 obstack_1grow (&obstack, '%');
5877 break;
5879 case '.':
5881 unsigned len = 0;
5883 while (p[len] && p[len] != ' ' && p[len] != '%')
5884 len++;
5885 suffix_subst = save_string (p - 1, len + 1);
5886 p += len;
5888 break;
5890 /* Henceforth ignore the option(s) matching the pattern
5891 after the %<. */
5892 case '<':
5893 case '>':
5895 unsigned len = 0;
5896 int have_wildcard = 0;
5897 int i;
5898 int switch_option;
5900 if (c == '>')
5901 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5902 else
5903 switch_option = SWITCH_IGNORE;
5905 while (p[len] && p[len] != ' ' && p[len] != '\t')
5906 len++;
5908 if (p[len-1] == '*')
5909 have_wildcard = 1;
5911 for (i = 0; i < n_switches; i++)
5912 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5913 && (have_wildcard || switches[i].part1[len] == '\0'))
5915 switches[i].live_cond |= switch_option;
5916 /* User switch be validated from validate_all_switches.
5917 when the definition is seen from the spec file.
5918 If not defined anywhere, will be rejected. */
5919 if (switches[i].known)
5920 switches[i].validated = true;
5923 p += len;
5925 break;
5927 case '*':
5928 if (soft_matched_part)
5930 if (soft_matched_part[0])
5931 do_spec_1 (soft_matched_part, 1, NULL);
5932 /* Only insert a space after the substitution if it is at the
5933 end of the current sequence. So if:
5935 "%{foo=*:bar%*}%{foo=*:one%*two}"
5937 matches -foo=hello then it will produce:
5939 barhello onehellotwo
5941 if (*p == 0 || *p == '}')
5942 do_spec_1 (" ", 0, NULL);
5944 else
5945 /* Catch the case where a spec string contains something like
5946 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5947 hand side of the :. */
5948 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5949 break;
5951 /* Process a string found as the value of a spec given by name.
5952 This feature allows individual machine descriptions
5953 to add and use their own specs. */
5954 case '(':
5956 const char *name = p;
5957 struct spec_list *sl;
5958 int len;
5960 /* The string after the S/P is the name of a spec that is to be
5961 processed. */
5962 while (*p && *p != ')')
5963 p++;
5965 /* See if it's in the list. */
5966 for (len = p - name, sl = specs; sl; sl = sl->next)
5967 if (sl->name_len == len && !strncmp (sl->name, name, len))
5969 name = *(sl->ptr_spec);
5970 #ifdef DEBUG_SPECS
5971 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5972 sl->name, name);
5973 #endif
5974 break;
5977 if (sl)
5979 value = do_spec_1 (name, 0, NULL);
5980 if (value != 0)
5981 return value;
5984 /* Discard the closing paren. */
5985 if (*p)
5986 p++;
5988 break;
5990 default:
5991 error ("spec failure: unrecognized spec option %qc", c);
5992 break;
5994 break;
5996 case '\\':
5997 /* Backslash: treat next character as ordinary. */
5998 c = *p++;
6000 /* Fall through. */
6001 default:
6002 /* Ordinary character: put it into the current argument. */
6003 obstack_1grow (&obstack, c);
6004 arg_going = 1;
6007 /* End of string. If we are processing a spec function, we need to
6008 end any pending argument. */
6009 if (processing_spec_function)
6010 end_going_arg ();
6012 return 0;
6015 /* Look up a spec function. */
6017 static const struct spec_function *
6018 lookup_spec_function (const char *name)
6020 const struct spec_function *sf;
6022 for (sf = static_spec_functions; sf->name != NULL; sf++)
6023 if (strcmp (sf->name, name) == 0)
6024 return sf;
6026 return NULL;
6029 /* Evaluate a spec function. */
6031 static const char *
6032 eval_spec_function (const char *func, const char *args)
6034 const struct spec_function *sf;
6035 const char *funcval;
6037 /* Saved spec processing context. */
6038 vec<const_char_p> save_argbuf;
6040 int save_arg_going;
6041 int save_delete_this_arg;
6042 int save_this_is_output_file;
6043 int save_this_is_library_file;
6044 int save_input_from_pipe;
6045 int save_this_is_linker_script;
6046 const char *save_suffix_subst;
6048 int save_growing_size;
6049 void *save_growing_value = NULL;
6051 sf = lookup_spec_function (func);
6052 if (sf == NULL)
6053 fatal_error (input_location, "unknown spec function %qs", func);
6055 /* Push the spec processing context. */
6056 save_argbuf = argbuf;
6058 save_arg_going = arg_going;
6059 save_delete_this_arg = delete_this_arg;
6060 save_this_is_output_file = this_is_output_file;
6061 save_this_is_library_file = this_is_library_file;
6062 save_this_is_linker_script = this_is_linker_script;
6063 save_input_from_pipe = input_from_pipe;
6064 save_suffix_subst = suffix_subst;
6066 /* If we have some object growing now, finalize it so the args and function
6067 eval proceed from a cleared context. This is needed to prevent the first
6068 constructed arg from mistakenly including the growing value. We'll push
6069 this value back on the obstack once the function evaluation is done, to
6070 restore a consistent processing context for our caller. This is fine as
6071 the address of growing objects isn't guaranteed to remain stable until
6072 they are finalized, and we expect this situation to be rare enough for
6073 the extra copy not to be an issue. */
6074 save_growing_size = obstack_object_size (&obstack);
6075 if (save_growing_size > 0)
6076 save_growing_value = obstack_finish (&obstack);
6078 /* Create a new spec processing context, and build the function
6079 arguments. */
6081 alloc_args ();
6082 if (do_spec_2 (args) < 0)
6083 fatal_error (input_location, "error in args to spec function %qs", func);
6085 /* argbuf_index is an index for the next argument to be inserted, and
6086 so contains the count of the args already inserted. */
6088 funcval = (*sf->func) (argbuf.length (),
6089 argbuf.address ());
6091 /* Pop the spec processing context. */
6092 argbuf.release ();
6093 argbuf = save_argbuf;
6095 arg_going = save_arg_going;
6096 delete_this_arg = save_delete_this_arg;
6097 this_is_output_file = save_this_is_output_file;
6098 this_is_library_file = save_this_is_library_file;
6099 this_is_linker_script = save_this_is_linker_script;
6100 input_from_pipe = save_input_from_pipe;
6101 suffix_subst = save_suffix_subst;
6103 if (save_growing_size > 0)
6104 obstack_grow (&obstack, save_growing_value, save_growing_size);
6106 return funcval;
6109 /* Handle a spec function call of the form:
6111 %:function(args)
6113 ARGS is processed as a spec in a separate context and split into an
6114 argument vector in the normal fashion. The function returns a string
6115 containing a spec which we then process in the caller's context, or
6116 NULL if no processing is required.
6118 If RETVAL_NONNULL is not NULL, then store a bool whether function
6119 returned non-NULL. */
6121 static const char *
6122 handle_spec_function (const char *p, bool *retval_nonnull)
6124 char *func, *args;
6125 const char *endp, *funcval;
6126 int count;
6128 processing_spec_function++;
6130 /* Get the function name. */
6131 for (endp = p; *endp != '\0'; endp++)
6133 if (*endp == '(') /* ) */
6134 break;
6135 /* Only allow [A-Za-z0-9], -, and _ in function names. */
6136 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
6137 fatal_error (input_location, "malformed spec function name");
6139 if (*endp != '(') /* ) */
6140 fatal_error (input_location, "no arguments for spec function");
6141 func = save_string (p, endp - p);
6142 p = ++endp;
6144 /* Get the arguments. */
6145 for (count = 0; *endp != '\0'; endp++)
6147 /* ( */
6148 if (*endp == ')')
6150 if (count == 0)
6151 break;
6152 count--;
6154 else if (*endp == '(') /* ) */
6155 count++;
6157 /* ( */
6158 if (*endp != ')')
6159 fatal_error (input_location, "malformed spec function arguments");
6160 args = save_string (p, endp - p);
6161 p = ++endp;
6163 /* p now points to just past the end of the spec function expression. */
6165 funcval = eval_spec_function (func, args);
6166 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
6167 p = NULL;
6168 if (retval_nonnull)
6169 *retval_nonnull = funcval != NULL;
6171 free (func);
6172 free (args);
6174 processing_spec_function--;
6176 return p;
6179 /* Inline subroutine of handle_braces. Returns true if the current
6180 input suffix matches the atom bracketed by ATOM and END_ATOM. */
6181 static inline bool
6182 input_suffix_matches (const char *atom, const char *end_atom)
6184 return (input_suffix
6185 && !strncmp (input_suffix, atom, end_atom - atom)
6186 && input_suffix[end_atom - atom] == '\0');
6189 /* Subroutine of handle_braces. Returns true if the current
6190 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
6191 static bool
6192 input_spec_matches (const char *atom, const char *end_atom)
6194 return (input_file_compiler
6195 && input_file_compiler->suffix
6196 && input_file_compiler->suffix[0] != '\0'
6197 && !strncmp (input_file_compiler->suffix + 1, atom,
6198 end_atom - atom)
6199 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
6202 /* Subroutine of handle_braces. Returns true if a switch
6203 matching the atom bracketed by ATOM and END_ATOM appeared on the
6204 command line. */
6205 static bool
6206 switch_matches (const char *atom, const char *end_atom, int starred)
6208 int i;
6209 int len = end_atom - atom;
6210 int plen = starred ? len : -1;
6212 for (i = 0; i < n_switches; i++)
6213 if (!strncmp (switches[i].part1, atom, len)
6214 && (starred || switches[i].part1[len] == '\0')
6215 && check_live_switch (i, plen))
6216 return true;
6218 /* Check if a switch with separated form matching the atom.
6219 We check -D and -U switches. */
6220 else if (switches[i].args != 0)
6222 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
6223 && *switches[i].part1 == atom[0])
6225 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
6226 && (starred || (switches[i].part1[1] == '\0'
6227 && switches[i].args[0][len - 1] == '\0'))
6228 && check_live_switch (i, (starred ? 1 : -1)))
6229 return true;
6233 return false;
6236 /* Inline subroutine of handle_braces. Mark all of the switches which
6237 match ATOM (extends to END_ATOM; STARRED indicates whether there
6238 was a star after the atom) for later processing. */
6239 static inline void
6240 mark_matching_switches (const char *atom, const char *end_atom, int starred)
6242 int i;
6243 int len = end_atom - atom;
6244 int plen = starred ? len : -1;
6246 for (i = 0; i < n_switches; i++)
6247 if (!strncmp (switches[i].part1, atom, len)
6248 && (starred || switches[i].part1[len] == '\0')
6249 && check_live_switch (i, plen))
6250 switches[i].ordering = 1;
6253 /* Inline subroutine of handle_braces. Process all the currently
6254 marked switches through give_switch, and clear the marks. */
6255 static inline void
6256 process_marked_switches (void)
6258 int i;
6260 for (i = 0; i < n_switches; i++)
6261 if (switches[i].ordering == 1)
6263 switches[i].ordering = 0;
6264 give_switch (i, 0);
6268 /* Handle a %{ ... } construct. P points just inside the leading {.
6269 Returns a pointer one past the end of the brace block, or 0
6270 if we call do_spec_1 and that returns -1. */
6272 static const char *
6273 handle_braces (const char *p)
6275 const char *atom, *end_atom;
6276 const char *d_atom = NULL, *d_end_atom = NULL;
6277 char *esc_buf = NULL, *d_esc_buf = NULL;
6278 int esc;
6279 const char *orig = p;
6281 bool a_is_suffix;
6282 bool a_is_spectype;
6283 bool a_is_starred;
6284 bool a_is_negated;
6285 bool a_matched;
6287 bool a_must_be_last = false;
6288 bool ordered_set = false;
6289 bool disjunct_set = false;
6290 bool disj_matched = false;
6291 bool disj_starred = true;
6292 bool n_way_choice = false;
6293 bool n_way_matched = false;
6295 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
6299 if (a_must_be_last)
6300 goto invalid;
6302 /* Scan one "atom" (S in the description above of %{}, possibly
6303 with '!', '.', '@', ',', or '*' modifiers). */
6304 a_matched = false;
6305 a_is_suffix = false;
6306 a_is_starred = false;
6307 a_is_negated = false;
6308 a_is_spectype = false;
6310 SKIP_WHITE ();
6311 if (*p == '!')
6312 p++, a_is_negated = true;
6314 SKIP_WHITE ();
6315 if (*p == '%' && p[1] == ':')
6317 atom = NULL;
6318 end_atom = NULL;
6319 p = handle_spec_function (p + 2, &a_matched);
6321 else
6323 if (*p == '.')
6324 p++, a_is_suffix = true;
6325 else if (*p == ',')
6326 p++, a_is_spectype = true;
6328 atom = p;
6329 esc = 0;
6330 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
6331 || *p == ',' || *p == '.' || *p == '@' || *p == '\\')
6333 if (*p == '\\')
6335 p++;
6336 if (!*p)
6337 fatal_error (input_location,
6338 "braced spec %qs ends in escape", orig);
6339 esc++;
6341 p++;
6343 end_atom = p;
6345 if (esc)
6347 const char *ap;
6348 char *ep;
6350 if (esc_buf && esc_buf != d_esc_buf)
6351 free (esc_buf);
6352 esc_buf = NULL;
6353 ep = esc_buf = (char *) xmalloc (end_atom - atom - esc + 1);
6354 for (ap = atom; ap != end_atom; ap++, ep++)
6356 if (*ap == '\\')
6357 ap++;
6358 *ep = *ap;
6360 *ep = '\0';
6361 atom = esc_buf;
6362 end_atom = ep;
6365 if (*p == '*')
6366 p++, a_is_starred = 1;
6369 SKIP_WHITE ();
6370 switch (*p)
6372 case '&': case '}':
6373 /* Substitute the switch(es) indicated by the current atom. */
6374 ordered_set = true;
6375 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
6376 || a_is_spectype || atom == end_atom)
6377 goto invalid;
6379 mark_matching_switches (atom, end_atom, a_is_starred);
6381 if (*p == '}')
6382 process_marked_switches ();
6383 break;
6385 case '|': case ':':
6386 /* Substitute some text if the current atom appears as a switch
6387 or suffix. */
6388 disjunct_set = true;
6389 if (ordered_set)
6390 goto invalid;
6392 if (atom && atom == end_atom)
6394 if (!n_way_choice || disj_matched || *p == '|'
6395 || a_is_negated || a_is_suffix || a_is_spectype
6396 || a_is_starred)
6397 goto invalid;
6399 /* An empty term may appear as the last choice of an
6400 N-way choice set; it means "otherwise". */
6401 a_must_be_last = true;
6402 disj_matched = !n_way_matched;
6403 disj_starred = false;
6405 else
6407 if ((a_is_suffix || a_is_spectype) && a_is_starred)
6408 goto invalid;
6410 if (!a_is_starred)
6411 disj_starred = false;
6413 /* Don't bother testing this atom if we already have a
6414 match. */
6415 if (!disj_matched && !n_way_matched)
6417 if (atom == NULL)
6418 /* a_matched is already set by handle_spec_function. */;
6419 else if (a_is_suffix)
6420 a_matched = input_suffix_matches (atom, end_atom);
6421 else if (a_is_spectype)
6422 a_matched = input_spec_matches (atom, end_atom);
6423 else
6424 a_matched = switch_matches (atom, end_atom, a_is_starred);
6426 if (a_matched != a_is_negated)
6428 disj_matched = true;
6429 d_atom = atom;
6430 d_end_atom = end_atom;
6431 d_esc_buf = esc_buf;
6436 if (*p == ':')
6438 /* Found the body, that is, the text to substitute if the
6439 current disjunction matches. */
6440 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
6441 disj_matched && !n_way_matched);
6442 if (p == 0)
6443 goto done;
6445 /* If we have an N-way choice, reset state for the next
6446 disjunction. */
6447 if (*p == ';')
6449 n_way_choice = true;
6450 n_way_matched |= disj_matched;
6451 disj_matched = false;
6452 disj_starred = true;
6453 d_atom = d_end_atom = NULL;
6456 break;
6458 default:
6459 goto invalid;
6462 while (*p++ != '}');
6464 done:
6465 if (d_esc_buf && d_esc_buf != esc_buf)
6466 free (d_esc_buf);
6467 if (esc_buf)
6468 free (esc_buf);
6470 return p;
6472 invalid:
6473 fatal_error (input_location, "braced spec %qs is invalid at %qc", orig, *p);
6475 #undef SKIP_WHITE
6478 /* Subroutine of handle_braces. Scan and process a brace substitution body
6479 (X in the description of %{} syntax). P points one past the colon;
6480 ATOM and END_ATOM bracket the first atom which was found to be true
6481 (present) in the current disjunction; STARRED indicates whether all
6482 the atoms in the current disjunction were starred (for syntax validation);
6483 MATCHED indicates whether the disjunction matched or not, and therefore
6484 whether or not the body is to be processed through do_spec_1 or just
6485 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
6486 returns -1. */
6488 static const char *
6489 process_brace_body (const char *p, const char *atom, const char *end_atom,
6490 int starred, int matched)
6492 const char *body, *end_body;
6493 unsigned int nesting_level;
6494 bool have_subst = false;
6496 /* Locate the closing } or ;, honoring nested braces.
6497 Trim trailing whitespace. */
6498 body = p;
6499 nesting_level = 1;
6500 for (;;)
6502 if (*p == '{')
6503 nesting_level++;
6504 else if (*p == '}')
6506 if (!--nesting_level)
6507 break;
6509 else if (*p == ';' && nesting_level == 1)
6510 break;
6511 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
6512 have_subst = true;
6513 else if (*p == '\0')
6514 goto invalid;
6515 p++;
6518 end_body = p;
6519 while (end_body[-1] == ' ' || end_body[-1] == '\t')
6520 end_body--;
6522 if (have_subst && !starred)
6523 goto invalid;
6525 if (matched)
6527 /* Copy the substitution body to permanent storage and execute it.
6528 If have_subst is false, this is a simple matter of running the
6529 body through do_spec_1... */
6530 char *string = save_string (body, end_body - body);
6531 if (!have_subst)
6533 if (do_spec_1 (string, 0, NULL) < 0)
6535 free (string);
6536 return 0;
6539 else
6541 /* ... but if have_subst is true, we have to process the
6542 body once for each matching switch, with %* set to the
6543 variant part of the switch. */
6544 unsigned int hard_match_len = end_atom - atom;
6545 int i;
6547 for (i = 0; i < n_switches; i++)
6548 if (!strncmp (switches[i].part1, atom, hard_match_len)
6549 && check_live_switch (i, hard_match_len))
6551 if (do_spec_1 (string, 0,
6552 &switches[i].part1[hard_match_len]) < 0)
6554 free (string);
6555 return 0;
6557 /* Pass any arguments this switch has. */
6558 give_switch (i, 1);
6559 suffix_subst = NULL;
6562 free (string);
6565 return p;
6567 invalid:
6568 fatal_error (input_location, "braced spec body %qs is invalid", body);
6571 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
6572 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
6573 spec, or -1 if either exact match or %* is used.
6575 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
6576 whose value does not begin with "no-" is obsoleted by the same value
6577 with the "no-", similarly for a switch with the "no-" prefix. */
6579 static int
6580 check_live_switch (int switchnum, int prefix_length)
6582 const char *name = switches[switchnum].part1;
6583 int i;
6585 /* If we already processed this switch and determined if it was
6586 live or not, return our past determination. */
6587 if (switches[switchnum].live_cond != 0)
6588 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
6589 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
6590 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
6591 == 0);
6593 /* In the common case of {<at-most-one-letter>*}, a negating
6594 switch would always match, so ignore that case. We will just
6595 send the conflicting switches to the compiler phase. */
6596 if (prefix_length >= 0 && prefix_length <= 1)
6597 return 1;
6599 /* Now search for duplicate in a manner that depends on the name. */
6600 switch (*name)
6602 case 'O':
6603 for (i = switchnum + 1; i < n_switches; i++)
6604 if (switches[i].part1[0] == 'O')
6606 switches[switchnum].validated = true;
6607 switches[switchnum].live_cond = SWITCH_FALSE;
6608 return 0;
6610 break;
6612 case 'W': case 'f': case 'm': case 'g':
6613 if (! strncmp (name + 1, "no-", 3))
6615 /* We have Xno-YYY, search for XYYY. */
6616 for (i = switchnum + 1; i < n_switches; i++)
6617 if (switches[i].part1[0] == name[0]
6618 && ! strcmp (&switches[i].part1[1], &name[4]))
6620 /* --specs are validated with the validate_switches mechanism. */
6621 if (switches[switchnum].known)
6622 switches[switchnum].validated = true;
6623 switches[switchnum].live_cond = SWITCH_FALSE;
6624 return 0;
6627 else
6629 /* We have XYYY, search for Xno-YYY. */
6630 for (i = switchnum + 1; i < n_switches; i++)
6631 if (switches[i].part1[0] == name[0]
6632 && switches[i].part1[1] == 'n'
6633 && switches[i].part1[2] == 'o'
6634 && switches[i].part1[3] == '-'
6635 && !strcmp (&switches[i].part1[4], &name[1]))
6637 /* --specs are validated with the validate_switches mechanism. */
6638 if (switches[switchnum].known)
6639 switches[switchnum].validated = true;
6640 switches[switchnum].live_cond = SWITCH_FALSE;
6641 return 0;
6644 break;
6647 /* Otherwise the switch is live. */
6648 switches[switchnum].live_cond |= SWITCH_LIVE;
6649 return 1;
6652 /* Pass a switch to the current accumulating command
6653 in the same form that we received it.
6654 SWITCHNUM identifies the switch; it is an index into
6655 the vector of switches gcc received, which is `switches'.
6656 This cannot fail since it never finishes a command line.
6658 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
6660 static void
6661 give_switch (int switchnum, int omit_first_word)
6663 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
6664 return;
6666 if (!omit_first_word)
6668 do_spec_1 ("-", 0, NULL);
6669 do_spec_1 (switches[switchnum].part1, 1, NULL);
6672 if (switches[switchnum].args != 0)
6674 const char **p;
6675 for (p = switches[switchnum].args; *p; p++)
6677 const char *arg = *p;
6679 do_spec_1 (" ", 0, NULL);
6680 if (suffix_subst)
6682 unsigned length = strlen (arg);
6683 int dot = 0;
6685 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
6686 if (arg[length] == '.')
6688 (CONST_CAST (char *, arg))[length] = 0;
6689 dot = 1;
6690 break;
6692 do_spec_1 (arg, 1, NULL);
6693 if (dot)
6694 (CONST_CAST (char *, arg))[length] = '.';
6695 do_spec_1 (suffix_subst, 1, NULL);
6697 else
6698 do_spec_1 (arg, 1, NULL);
6702 do_spec_1 (" ", 0, NULL);
6703 switches[switchnum].validated = true;
6706 /* Print GCC configuration (e.g. version, thread model, target,
6707 configuration_arguments) to a given FILE. */
6709 static void
6710 print_configuration (FILE *file)
6712 int n;
6713 const char *thrmod;
6715 fnotice (file, "Target: %s\n", spec_machine);
6716 fnotice (file, "Configured with: %s\n", configuration_arguments);
6718 #ifdef THREAD_MODEL_SPEC
6719 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6720 but there's no point in doing all this processing just to get
6721 thread_model back. */
6722 obstack_init (&obstack);
6723 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6724 obstack_1grow (&obstack, '\0');
6725 thrmod = XOBFINISH (&obstack, const char *);
6726 #else
6727 thrmod = thread_model;
6728 #endif
6730 fnotice (file, "Thread model: %s\n", thrmod);
6732 /* compiler_version is truncated at the first space when initialized
6733 from version string, so truncate version_string at the first space
6734 before comparing. */
6735 for (n = 0; version_string[n]; n++)
6736 if (version_string[n] == ' ')
6737 break;
6739 if (! strncmp (version_string, compiler_version, n)
6740 && compiler_version[n] == 0)
6741 fnotice (file, "gcc version %s %s\n", version_string,
6742 pkgversion_string);
6743 else
6744 fnotice (file, "gcc driver version %s %sexecuting gcc version %s\n",
6745 version_string, pkgversion_string, compiler_version);
6749 #define RETRY_ICE_ATTEMPTS 3
6751 /* Returns true if FILE1 and FILE2 contain equivalent data, 0 otherwise. */
6753 static bool
6754 files_equal_p (char *file1, char *file2)
6756 struct stat st1, st2;
6757 off_t n, len;
6758 int fd1, fd2;
6759 const int bufsize = 8192;
6760 char *buf = XNEWVEC (char, bufsize);
6762 fd1 = open (file1, O_RDONLY);
6763 fd2 = open (file2, O_RDONLY);
6765 if (fd1 < 0 || fd2 < 0)
6766 goto error;
6768 if (fstat (fd1, &st1) < 0 || fstat (fd2, &st2) < 0)
6769 goto error;
6771 if (st1.st_size != st2.st_size)
6772 goto error;
6774 for (n = st1.st_size; n; n -= len)
6776 len = n;
6777 if ((int) len > bufsize / 2)
6778 len = bufsize / 2;
6780 if (read (fd1, buf, len) != (int) len
6781 || read (fd2, buf + bufsize / 2, len) != (int) len)
6783 goto error;
6786 if (memcmp (buf, buf + bufsize / 2, len) != 0)
6787 goto error;
6790 free (buf);
6791 close (fd1);
6792 close (fd2);
6794 return 1;
6796 error:
6797 free (buf);
6798 close (fd1);
6799 close (fd2);
6800 return 0;
6803 /* Check that compiler's output doesn't differ across runs.
6804 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are arrays of files, containing
6805 stdout and stderr for each compiler run. Return true if all of
6806 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are equivalent. */
6808 static bool
6809 check_repro (char **temp_stdout_files, char **temp_stderr_files)
6811 int i;
6812 for (i = 0; i < RETRY_ICE_ATTEMPTS - 2; ++i)
6814 if (!files_equal_p (temp_stdout_files[i], temp_stdout_files[i + 1])
6815 || !files_equal_p (temp_stderr_files[i], temp_stderr_files[i + 1]))
6817 fnotice (stderr, "The bug is not reproducible, so it is"
6818 " likely a hardware or OS problem.\n");
6819 break;
6822 return i == RETRY_ICE_ATTEMPTS - 2;
6825 enum attempt_status {
6826 ATTEMPT_STATUS_FAIL_TO_RUN,
6827 ATTEMPT_STATUS_SUCCESS,
6828 ATTEMPT_STATUS_ICE
6832 /* Run compiler with arguments NEW_ARGV to reproduce the ICE, storing stdout
6833 to OUT_TEMP and stderr to ERR_TEMP. If APPEND is TRUE, append to OUT_TEMP
6834 and ERR_TEMP instead of truncating. If EMIT_SYSTEM_INFO is TRUE, also write
6835 GCC configuration into to ERR_TEMP. Return ATTEMPT_STATUS_FAIL_TO_RUN if
6836 compiler failed to run, ATTEMPT_STATUS_ICE if compiled ICE-ed and
6837 ATTEMPT_STATUS_SUCCESS otherwise. */
6839 static enum attempt_status
6840 run_attempt (const char **new_argv, const char *out_temp,
6841 const char *err_temp, int emit_system_info, int append)
6844 if (emit_system_info)
6846 FILE *file_out = fopen (err_temp, "a");
6847 print_configuration (file_out);
6848 fputs ("\n", file_out);
6849 fclose (file_out);
6852 int exit_status;
6853 const char *errmsg;
6854 struct pex_obj *pex;
6855 int err;
6856 int pex_flags = PEX_USE_PIPES | PEX_LAST;
6857 enum attempt_status status = ATTEMPT_STATUS_FAIL_TO_RUN;
6859 if (append)
6860 pex_flags |= PEX_STDOUT_APPEND | PEX_STDERR_APPEND;
6862 pex = pex_init (PEX_USE_PIPES, new_argv[0], NULL);
6863 if (!pex)
6864 fatal_error (input_location, "pex_init failed: %m");
6866 errmsg = pex_run (pex, pex_flags, new_argv[0],
6867 CONST_CAST2 (char *const *, const char **, &new_argv[1]), out_temp,
6868 err_temp, &err);
6869 if (errmsg != NULL)
6871 if (err == 0)
6872 fatal_error (input_location, errmsg);
6873 else
6875 errno = err;
6876 pfatal_with_name (errmsg);
6880 if (!pex_get_status (pex, 1, &exit_status))
6881 goto out;
6883 switch (WEXITSTATUS (exit_status))
6885 case ICE_EXIT_CODE:
6886 status = ATTEMPT_STATUS_ICE;
6887 break;
6889 case SUCCESS_EXIT_CODE:
6890 status = ATTEMPT_STATUS_SUCCESS;
6891 break;
6893 default:
6897 out:
6898 pex_free (pex);
6899 return status;
6902 /* This routine reads lines from IN file, adds C++ style comments
6903 at the begining of each line and writes result into OUT. */
6905 static void
6906 insert_comments (const char *file_in, const char *file_out)
6908 FILE *in = fopen (file_in, "rb");
6909 FILE *out = fopen (file_out, "wb");
6910 char line[256];
6912 bool add_comment = true;
6913 while (fgets (line, sizeof (line), in))
6915 if (add_comment)
6916 fputs ("// ", out);
6917 fputs (line, out);
6918 add_comment = strchr (line, '\n') != NULL;
6921 fclose (in);
6922 fclose (out);
6925 /* This routine adds preprocessed source code into the given ERR_FILE.
6926 To do this, it adds "-E" to NEW_ARGV and execute RUN_ATTEMPT routine to
6927 add information in report file. RUN_ATTEMPT should return
6928 ATTEMPT_STATUS_SUCCESS, in other case we cannot generate the report. */
6930 static void
6931 do_report_bug (const char **new_argv, const int nargs,
6932 char **out_file, char **err_file)
6934 int i, status;
6935 int fd = open (*out_file, O_RDWR | O_APPEND);
6936 if (fd < 0)
6937 return;
6938 write (fd, "\n//", 3);
6939 for (i = 0; i < nargs; i++)
6941 write (fd, " ", 1);
6942 write (fd, new_argv[i], strlen (new_argv[i]));
6944 write (fd, "\n\n", 2);
6945 close (fd);
6946 new_argv[nargs] = "-E";
6947 new_argv[nargs + 1] = NULL;
6949 status = run_attempt (new_argv, *out_file, *err_file, 0, 1);
6951 if (status == ATTEMPT_STATUS_SUCCESS)
6953 fnotice (stderr, "Preprocessed source stored into %s file,"
6954 " please attach this to your bugreport.\n", *out_file);
6955 /* Make sure it is not deleted. */
6956 free (*out_file);
6957 *out_file = NULL;
6961 /* Try to reproduce ICE. If bug is reproducible, generate report .err file
6962 containing GCC configuration, backtrace, compiler's command line options
6963 and preprocessed source code. */
6965 static void
6966 try_generate_repro (const char **argv)
6968 int i, nargs, out_arg = -1, quiet = 0, attempt;
6969 const char **new_argv;
6970 char *temp_files[RETRY_ICE_ATTEMPTS * 2];
6971 char **temp_stdout_files = &temp_files[0];
6972 char **temp_stderr_files = &temp_files[RETRY_ICE_ATTEMPTS];
6974 if (gcc_input_filename == NULL || ! strcmp (gcc_input_filename, "-"))
6975 return;
6977 for (nargs = 0; argv[nargs] != NULL; ++nargs)
6978 /* Only retry compiler ICEs, not preprocessor ones. */
6979 if (! strcmp (argv[nargs], "-E"))
6980 return;
6981 else if (argv[nargs][0] == '-' && argv[nargs][1] == 'o')
6983 if (out_arg == -1)
6984 out_arg = nargs;
6985 else
6986 return;
6988 /* If the compiler is going to output any time information,
6989 it might varry between invocations. */
6990 else if (! strcmp (argv[nargs], "-quiet"))
6991 quiet = 1;
6992 else if (! strcmp (argv[nargs], "-ftime-report"))
6993 return;
6995 if (out_arg == -1 || !quiet)
6996 return;
6998 memset (temp_files, '\0', sizeof (temp_files));
6999 new_argv = XALLOCAVEC (const char *, nargs + 4);
7000 memcpy (new_argv, argv, (nargs + 1) * sizeof (const char *));
7001 new_argv[nargs++] = "-frandom-seed=0";
7002 new_argv[nargs++] = "-fdump-noaddr";
7003 new_argv[nargs] = NULL;
7004 if (new_argv[out_arg][2] == '\0')
7005 new_argv[out_arg + 1] = "-";
7006 else
7007 new_argv[out_arg] = "-o-";
7009 int status;
7010 for (attempt = 0; attempt < RETRY_ICE_ATTEMPTS; ++attempt)
7012 int emit_system_info = 0;
7013 int append = 0;
7014 temp_stdout_files[attempt] = make_temp_file (".out");
7015 temp_stderr_files[attempt] = make_temp_file (".err");
7017 if (attempt == RETRY_ICE_ATTEMPTS - 1)
7019 append = 1;
7020 emit_system_info = 1;
7023 status = run_attempt (new_argv, temp_stdout_files[attempt],
7024 temp_stderr_files[attempt], emit_system_info,
7025 append);
7027 if (status != ATTEMPT_STATUS_ICE)
7029 fnotice (stderr, "The bug is not reproducible, so it is"
7030 " likely a hardware or OS problem.\n");
7031 goto out;
7035 if (!check_repro (temp_stdout_files, temp_stderr_files))
7036 goto out;
7039 /* Insert commented out backtrace into report file. */
7040 char **stderr_commented = &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1];
7041 insert_comments (temp_stderr_files[RETRY_ICE_ATTEMPTS - 1],
7042 *stderr_commented);
7044 /* In final attempt we append compiler options and preprocesssed code to last
7045 generated .out file with configuration and backtrace. */
7046 char **err = &temp_stderr_files[RETRY_ICE_ATTEMPTS - 1];
7047 do_report_bug (new_argv, nargs, stderr_commented, err);
7050 out:
7051 for (i = 0; i < RETRY_ICE_ATTEMPTS * 2; i++)
7052 if (temp_files[i])
7054 unlink (temp_stdout_files[i]);
7055 free (temp_stdout_files[i]);
7059 /* Search for a file named NAME trying various prefixes including the
7060 user's -B prefix and some standard ones.
7061 Return the absolute file name found. If nothing is found, return NAME. */
7063 static const char *
7064 find_file (const char *name)
7066 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
7067 return newname ? newname : name;
7070 /* Determine whether a directory exists. If LINKER, return 0 for
7071 certain fixed names not needed by the linker. */
7073 static int
7074 is_directory (const char *path1, bool linker)
7076 int len1;
7077 char *path;
7078 char *cp;
7079 struct stat st;
7081 /* Ensure the string ends with "/.". The resulting path will be a
7082 directory even if the given path is a symbolic link. */
7083 len1 = strlen (path1);
7084 path = (char *) alloca (3 + len1);
7085 memcpy (path, path1, len1);
7086 cp = path + len1;
7087 if (!IS_DIR_SEPARATOR (cp[-1]))
7088 *cp++ = DIR_SEPARATOR;
7089 *cp++ = '.';
7090 *cp = '\0';
7092 /* Exclude directories that the linker is known to search. */
7093 if (linker
7094 && IS_DIR_SEPARATOR (path[0])
7095 && ((cp - path == 6
7096 && filename_ncmp (path + 1, "lib", 3) == 0)
7097 || (cp - path == 10
7098 && filename_ncmp (path + 1, "usr", 3) == 0
7099 && IS_DIR_SEPARATOR (path[4])
7100 && filename_ncmp (path + 5, "lib", 3) == 0)))
7101 return 0;
7103 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
7106 /* Set up the various global variables to indicate that we're processing
7107 the input file named FILENAME. */
7109 void
7110 set_input (const char *filename)
7112 const char *p;
7114 gcc_input_filename = filename;
7115 input_filename_length = strlen (gcc_input_filename);
7116 input_basename = lbasename (gcc_input_filename);
7118 /* Find a suffix starting with the last period,
7119 and set basename_length to exclude that suffix. */
7120 basename_length = strlen (input_basename);
7121 suffixed_basename_length = basename_length;
7122 p = input_basename + basename_length;
7123 while (p != input_basename && *p != '.')
7124 --p;
7125 if (*p == '.' && p != input_basename)
7127 basename_length = p - input_basename;
7128 input_suffix = p + 1;
7130 else
7131 input_suffix = "";
7133 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
7134 we will need to do a stat on the gcc_input_filename. The
7135 INPUT_STAT_SET signals that the stat is needed. */
7136 input_stat_set = 0;
7139 /* On fatal signals, delete all the temporary files. */
7141 static void
7142 fatal_signal (int signum)
7144 signal (signum, SIG_DFL);
7145 delete_failure_queue ();
7146 delete_temp_files ();
7147 /* Get the same signal again, this time not handled,
7148 so its normal effect occurs. */
7149 kill (getpid (), signum);
7152 /* Compare the contents of the two files named CMPFILE[0] and
7153 CMPFILE[1]. Return zero if they're identical, nonzero
7154 otherwise. */
7156 static int
7157 compare_files (char *cmpfile[])
7159 int ret = 0;
7160 FILE *temp[2] = { NULL, NULL };
7161 int i;
7163 #if HAVE_MMAP_FILE
7165 size_t length[2];
7166 void *map[2] = { NULL, NULL };
7168 for (i = 0; i < 2; i++)
7170 struct stat st;
7172 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
7174 error ("%s: could not determine length of compare-debug file %s",
7175 gcc_input_filename, cmpfile[i]);
7176 ret = 1;
7177 break;
7180 length[i] = st.st_size;
7183 if (!ret && length[0] != length[1])
7185 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
7186 ret = 1;
7189 if (!ret)
7190 for (i = 0; i < 2; i++)
7192 int fd = open (cmpfile[i], O_RDONLY);
7193 if (fd < 0)
7195 error ("%s: could not open compare-debug file %s",
7196 gcc_input_filename, cmpfile[i]);
7197 ret = 1;
7198 break;
7201 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
7202 close (fd);
7204 if (map[i] == (void *) MAP_FAILED)
7206 ret = -1;
7207 break;
7211 if (!ret)
7213 if (memcmp (map[0], map[1], length[0]) != 0)
7215 error ("%s: -fcompare-debug failure", gcc_input_filename);
7216 ret = 1;
7220 for (i = 0; i < 2; i++)
7221 if (map[i])
7222 munmap ((caddr_t) map[i], length[i]);
7224 if (ret >= 0)
7225 return ret;
7227 ret = 0;
7229 #endif
7231 for (i = 0; i < 2; i++)
7233 temp[i] = fopen (cmpfile[i], "r");
7234 if (!temp[i])
7236 error ("%s: could not open compare-debug file %s",
7237 gcc_input_filename, cmpfile[i]);
7238 ret = 1;
7239 break;
7243 if (!ret && temp[0] && temp[1])
7244 for (;;)
7246 int c0, c1;
7247 c0 = fgetc (temp[0]);
7248 c1 = fgetc (temp[1]);
7250 if (c0 != c1)
7252 error ("%s: -fcompare-debug failure",
7253 gcc_input_filename);
7254 ret = 1;
7255 break;
7258 if (c0 == EOF)
7259 break;
7262 for (i = 1; i >= 0; i--)
7264 if (temp[i])
7265 fclose (temp[i]);
7268 return ret;
7271 driver::driver (bool can_finalize, bool debug) :
7272 explicit_link_files (NULL),
7273 decoded_options (NULL),
7274 m_option_suggestions (NULL)
7276 env.init (can_finalize, debug);
7279 driver::~driver ()
7281 XDELETEVEC (explicit_link_files);
7282 XDELETEVEC (decoded_options);
7283 if (m_option_suggestions)
7285 int i;
7286 char *str;
7287 FOR_EACH_VEC_ELT (*m_option_suggestions, i, str)
7288 free (str);
7289 delete m_option_suggestions;
7293 /* driver::main is implemented as a series of driver:: method calls. */
7296 driver::main (int argc, char **argv)
7298 bool early_exit;
7300 set_progname (argv[0]);
7301 expand_at_files (&argc, &argv);
7302 decode_argv (argc, const_cast <const char **> (argv));
7303 global_initializations ();
7304 build_multilib_strings ();
7305 set_up_specs ();
7306 putenv_COLLECT_GCC (argv[0]);
7307 maybe_putenv_COLLECT_LTO_WRAPPER ();
7308 maybe_putenv_OFFLOAD_TARGETS ();
7309 handle_unrecognized_options ();
7311 if (!maybe_print_and_exit ())
7312 return 0;
7314 early_exit = prepare_infiles ();
7315 if (early_exit)
7316 return get_exit_code ();
7318 do_spec_on_infiles ();
7319 maybe_run_linker (argv[0]);
7320 final_actions ();
7321 return get_exit_code ();
7324 /* Locate the final component of argv[0] after any leading path, and set
7325 the program name accordingly. */
7327 void
7328 driver::set_progname (const char *argv0) const
7330 const char *p = argv0 + strlen (argv0);
7331 while (p != argv0 && !IS_DIR_SEPARATOR (p[-1]))
7332 --p;
7333 progname = p;
7335 xmalloc_set_program_name (progname);
7338 /* Expand any @ files within the command-line args,
7339 setting at_file_supplied if any were expanded. */
7341 void
7342 driver::expand_at_files (int *argc, char ***argv) const
7344 char **old_argv = *argv;
7346 expandargv (argc, argv);
7348 /* Determine if any expansions were made. */
7349 if (*argv != old_argv)
7350 at_file_supplied = true;
7353 /* Decode the command-line arguments from argc/argv into the
7354 decoded_options array. */
7356 void
7357 driver::decode_argv (int argc, const char **argv)
7359 /* Register the language-independent parameters. */
7360 global_init_params ();
7361 finish_params ();
7363 init_opts_obstack ();
7364 init_options_struct (&global_options, &global_options_set);
7366 decode_cmdline_options_to_array (argc, argv,
7367 CL_DRIVER,
7368 &decoded_options, &decoded_options_count);
7371 /* Perform various initializations and setup. */
7373 void
7374 driver::global_initializations ()
7376 /* Unlock the stdio streams. */
7377 unlock_std_streams ();
7379 gcc_init_libintl ();
7381 diagnostic_initialize (global_dc, 0);
7382 diagnostic_color_init (global_dc);
7384 #ifdef GCC_DRIVER_HOST_INITIALIZATION
7385 /* Perform host dependent initialization when needed. */
7386 GCC_DRIVER_HOST_INITIALIZATION;
7387 #endif
7389 if (atexit (delete_temp_files) != 0)
7390 fatal_error (input_location, "atexit failed");
7392 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
7393 signal (SIGINT, fatal_signal);
7394 #ifdef SIGHUP
7395 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
7396 signal (SIGHUP, fatal_signal);
7397 #endif
7398 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
7399 signal (SIGTERM, fatal_signal);
7400 #ifdef SIGPIPE
7401 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
7402 signal (SIGPIPE, fatal_signal);
7403 #endif
7404 #ifdef SIGCHLD
7405 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
7406 receive the signal. A different setting is inheritable */
7407 signal (SIGCHLD, SIG_DFL);
7408 #endif
7410 /* Parsing and gimplification sometimes need quite large stack.
7411 Increase stack size limits if possible. */
7412 stack_limit_increase (64 * 1024 * 1024);
7414 /* Allocate the argument vector. */
7415 alloc_args ();
7417 obstack_init (&obstack);
7420 /* Build multilib_select, et. al from the separate lines that make up each
7421 multilib selection. */
7423 void
7424 driver::build_multilib_strings () const
7427 const char *p;
7428 const char *const *q = multilib_raw;
7429 int need_space;
7431 obstack_init (&multilib_obstack);
7432 while ((p = *q++) != (char *) 0)
7433 obstack_grow (&multilib_obstack, p, strlen (p));
7435 obstack_1grow (&multilib_obstack, 0);
7436 multilib_select = XOBFINISH (&multilib_obstack, const char *);
7438 q = multilib_matches_raw;
7439 while ((p = *q++) != (char *) 0)
7440 obstack_grow (&multilib_obstack, p, strlen (p));
7442 obstack_1grow (&multilib_obstack, 0);
7443 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
7445 q = multilib_exclusions_raw;
7446 while ((p = *q++) != (char *) 0)
7447 obstack_grow (&multilib_obstack, p, strlen (p));
7449 obstack_1grow (&multilib_obstack, 0);
7450 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
7452 q = multilib_reuse_raw;
7453 while ((p = *q++) != (char *) 0)
7454 obstack_grow (&multilib_obstack, p, strlen (p));
7456 obstack_1grow (&multilib_obstack, 0);
7457 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
7459 need_space = FALSE;
7460 for (size_t i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
7462 if (need_space)
7463 obstack_1grow (&multilib_obstack, ' ');
7464 obstack_grow (&multilib_obstack,
7465 multilib_defaults_raw[i],
7466 strlen (multilib_defaults_raw[i]));
7467 need_space = TRUE;
7470 obstack_1grow (&multilib_obstack, 0);
7471 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
7475 /* Set up the spec-handling machinery. */
7477 void
7478 driver::set_up_specs () const
7480 const char *spec_machine_suffix;
7481 char *specs_file;
7482 size_t i;
7484 #ifdef INIT_ENVIRONMENT
7485 /* Set up any other necessary machine specific environment variables. */
7486 xputenv (INIT_ENVIRONMENT);
7487 #endif
7489 /* Make a table of what switches there are (switches, n_switches).
7490 Make a table of specified input files (infiles, n_infiles).
7491 Decode switches that are handled locally. */
7493 process_command (decoded_options_count, decoded_options);
7495 /* Initialize the vector of specs to just the default.
7496 This means one element containing 0s, as a terminator. */
7498 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
7499 memcpy (compilers, default_compilers, sizeof default_compilers);
7500 n_compilers = n_default_compilers;
7502 /* Read specs from a file if there is one. */
7504 machine_suffix = concat (spec_host_machine, dir_separator_str, spec_version,
7505 accel_dir_suffix, dir_separator_str, NULL);
7506 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
7508 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
7509 /* Read the specs file unless it is a default one. */
7510 if (specs_file != 0 && strcmp (specs_file, "specs"))
7511 read_specs (specs_file, true, false);
7512 else
7513 init_spec ();
7515 #ifdef ACCEL_COMPILER
7516 spec_machine_suffix = machine_suffix;
7517 #else
7518 spec_machine_suffix = just_machine_suffix;
7519 #endif
7521 /* We need to check standard_exec_prefix/spec_machine_suffix/specs
7522 for any override of as, ld and libraries. */
7523 specs_file = (char *) alloca (strlen (standard_exec_prefix)
7524 + strlen (spec_machine_suffix) + sizeof ("specs"));
7525 strcpy (specs_file, standard_exec_prefix);
7526 strcat (specs_file, spec_machine_suffix);
7527 strcat (specs_file, "specs");
7528 if (access (specs_file, R_OK) == 0)
7529 read_specs (specs_file, true, false);
7531 /* Process any configure-time defaults specified for the command line
7532 options, via OPTION_DEFAULT_SPECS. */
7533 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
7534 do_option_spec (option_default_specs[i].name,
7535 option_default_specs[i].spec);
7537 /* Process DRIVER_SELF_SPECS, adding any new options to the end
7538 of the command line. */
7540 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
7541 do_self_spec (driver_self_specs[i]);
7543 /* If not cross-compiling, look for executables in the standard
7544 places. */
7545 if (*cross_compile == '0')
7547 if (*md_exec_prefix)
7549 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
7550 PREFIX_PRIORITY_LAST, 0, 0);
7554 /* Process sysroot_suffix_spec. */
7555 if (*sysroot_suffix_spec != 0
7556 && !no_sysroot_suffix
7557 && do_spec_2 (sysroot_suffix_spec) == 0)
7559 if (argbuf.length () > 1)
7560 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
7561 else if (argbuf.length () == 1)
7562 target_sysroot_suffix = xstrdup (argbuf.last ());
7565 #ifdef HAVE_LD_SYSROOT
7566 /* Pass the --sysroot option to the linker, if it supports that. If
7567 there is a sysroot_suffix_spec, it has already been processed by
7568 this point, so target_system_root really is the system root we
7569 should be using. */
7570 if (target_system_root)
7572 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
7573 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
7574 set_spec ("link", XOBFINISH (&obstack, const char *), false);
7576 #endif
7578 /* Process sysroot_hdrs_suffix_spec. */
7579 if (*sysroot_hdrs_suffix_spec != 0
7580 && !no_sysroot_suffix
7581 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
7583 if (argbuf.length () > 1)
7584 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
7585 else if (argbuf.length () == 1)
7586 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
7589 /* Look for startfiles in the standard places. */
7590 if (*startfile_prefix_spec != 0
7591 && do_spec_2 (startfile_prefix_spec) == 0
7592 && do_spec_1 (" ", 0, NULL) == 0)
7594 const char *arg;
7595 int ndx;
7596 FOR_EACH_VEC_ELT (argbuf, ndx, arg)
7597 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
7598 PREFIX_PRIORITY_LAST, 0, 1);
7600 /* We should eventually get rid of all these and stick to
7601 startfile_prefix_spec exclusively. */
7602 else if (*cross_compile == '0' || target_system_root)
7604 if (*md_startfile_prefix)
7605 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
7606 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7608 if (*md_startfile_prefix_1)
7609 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
7610 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7612 /* If standard_startfile_prefix is relative, base it on
7613 standard_exec_prefix. This lets us move the installed tree
7614 as a unit. If GCC_EXEC_PREFIX is defined, base
7615 standard_startfile_prefix on that as well.
7617 If the prefix is relative, only search it for native compilers;
7618 otherwise we will search a directory containing host libraries. */
7619 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
7620 add_sysrooted_prefix (&startfile_prefixes,
7621 standard_startfile_prefix, "BINUTILS",
7622 PREFIX_PRIORITY_LAST, 0, 1);
7623 else if (*cross_compile == '0')
7625 add_prefix (&startfile_prefixes,
7626 concat (gcc_exec_prefix
7627 ? gcc_exec_prefix : standard_exec_prefix,
7628 machine_suffix,
7629 standard_startfile_prefix, NULL),
7630 NULL, PREFIX_PRIORITY_LAST, 0, 1);
7633 /* Sysrooted prefixes are relocated because target_system_root is
7634 also relocated by gcc_exec_prefix. */
7635 if (*standard_startfile_prefix_1)
7636 add_sysrooted_prefix (&startfile_prefixes,
7637 standard_startfile_prefix_1, "BINUTILS",
7638 PREFIX_PRIORITY_LAST, 0, 1);
7639 if (*standard_startfile_prefix_2)
7640 add_sysrooted_prefix (&startfile_prefixes,
7641 standard_startfile_prefix_2, "BINUTILS",
7642 PREFIX_PRIORITY_LAST, 0, 1);
7645 /* Process any user specified specs in the order given on the command
7646 line. */
7647 for (struct user_specs *uptr = user_specs_head; uptr; uptr = uptr->next)
7649 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
7650 R_OK, true);
7651 read_specs (filename ? filename : uptr->filename, false, true);
7654 /* Process any user self specs. */
7656 struct spec_list *sl;
7657 for (sl = specs; sl; sl = sl->next)
7658 if (sl->name_len == sizeof "self_spec" - 1
7659 && !strcmp (sl->name, "self_spec"))
7660 do_self_spec (*sl->ptr_spec);
7663 if (compare_debug)
7665 enum save_temps save;
7667 if (!compare_debug_second)
7669 n_switches_debug_check[1] = n_switches;
7670 n_switches_alloc_debug_check[1] = n_switches_alloc;
7671 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
7672 n_switches_alloc);
7674 do_self_spec ("%:compare-debug-self-opt()");
7675 n_switches_debug_check[0] = n_switches;
7676 n_switches_alloc_debug_check[0] = n_switches_alloc;
7677 switches_debug_check[0] = switches;
7679 n_switches = n_switches_debug_check[1];
7680 n_switches_alloc = n_switches_alloc_debug_check[1];
7681 switches = switches_debug_check[1];
7684 /* Avoid crash when computing %j in this early. */
7685 save = save_temps_flag;
7686 save_temps_flag = SAVE_TEMPS_NONE;
7688 compare_debug = -compare_debug;
7689 do_self_spec ("%:compare-debug-self-opt()");
7691 save_temps_flag = save;
7693 if (!compare_debug_second)
7695 n_switches_debug_check[1] = n_switches;
7696 n_switches_alloc_debug_check[1] = n_switches_alloc;
7697 switches_debug_check[1] = switches;
7698 compare_debug = -compare_debug;
7699 n_switches = n_switches_debug_check[0];
7700 n_switches_alloc = n_switches_debug_check[0];
7701 switches = switches_debug_check[0];
7706 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
7707 if (gcc_exec_prefix)
7708 gcc_exec_prefix = concat (gcc_exec_prefix, spec_host_machine,
7709 dir_separator_str, spec_version,
7710 accel_dir_suffix, dir_separator_str, NULL);
7712 /* Now we have the specs.
7713 Set the `valid' bits for switches that match anything in any spec. */
7715 validate_all_switches ();
7717 /* Now that we have the switches and the specs, set
7718 the subdirectory based on the options. */
7719 set_multilib_dir ();
7722 /* Set up to remember the pathname of gcc and any options
7723 needed for collect. We use argv[0] instead of progname because
7724 we need the complete pathname. */
7726 void
7727 driver::putenv_COLLECT_GCC (const char *argv0) const
7729 obstack_init (&collect_obstack);
7730 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
7731 obstack_grow (&collect_obstack, argv0, strlen (argv0) + 1);
7732 xputenv (XOBFINISH (&collect_obstack, char *));
7735 /* Set up to remember the pathname of the lto wrapper. */
7737 void
7738 driver::maybe_putenv_COLLECT_LTO_WRAPPER () const
7740 char *lto_wrapper_file;
7742 if (have_c)
7743 lto_wrapper_file = NULL;
7744 else
7745 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
7746 X_OK, false);
7747 if (lto_wrapper_file)
7749 lto_wrapper_file = convert_white_space (lto_wrapper_file);
7750 lto_wrapper_spec = lto_wrapper_file;
7751 obstack_init (&collect_obstack);
7752 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
7753 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
7754 obstack_grow (&collect_obstack, lto_wrapper_spec,
7755 strlen (lto_wrapper_spec) + 1);
7756 xputenv (XOBFINISH (&collect_obstack, char *));
7761 /* Set up to remember the names of offload targets. */
7763 void
7764 driver::maybe_putenv_OFFLOAD_TARGETS () const
7766 if (offload_targets && offload_targets[0] != '\0')
7768 obstack_grow (&collect_obstack, "OFFLOAD_TARGET_NAMES=",
7769 sizeof ("OFFLOAD_TARGET_NAMES=") - 1);
7770 obstack_grow (&collect_obstack, offload_targets,
7771 strlen (offload_targets) + 1);
7772 xputenv (XOBFINISH (&collect_obstack, char *));
7775 free (offload_targets);
7776 offload_targets = NULL;
7779 /* Helper function for driver::suggest_option. Populate
7780 m_option_suggestions with candidate strings for misspelled options.
7781 The strings will be freed by the driver's dtor. */
7783 void
7784 driver::build_option_suggestions (void)
7786 gcc_assert (m_option_suggestions == NULL);
7787 m_option_suggestions = new auto_vec <char *> ();
7789 /* We build a vec of m_option_suggestions, using add_misspelling_candidates
7790 to add copies of strings, without a leading dash. */
7792 for (unsigned int i = 0; i < cl_options_count; i++)
7794 const struct cl_option *option = &cl_options[i];
7795 const char *opt_text = option->opt_text;
7796 switch (i)
7798 default:
7799 if (option->var_type == CLVC_ENUM)
7801 const struct cl_enum *e = &cl_enums[option->var_enum];
7802 for (unsigned j = 0; e->values[j].arg != NULL; j++)
7804 char *with_arg = concat (opt_text, e->values[j].arg, NULL);
7805 add_misspelling_candidates (m_option_suggestions, option,
7806 with_arg);
7807 free (with_arg);
7810 else
7811 add_misspelling_candidates (m_option_suggestions, option,
7812 opt_text);
7813 break;
7815 case OPT_fsanitize_:
7816 case OPT_fsanitize_recover_:
7817 /* -fsanitize= and -fsanitize-recover= can take
7818 a comma-separated list of arguments. Given that combinations
7819 are supported, we can't add all potential candidates to the
7820 vec, but if we at least add them individually without commas,
7821 we should do a better job e.g. correcting
7822 "-sanitize=address"
7824 "-fsanitize=address"
7825 rather than to "-Wframe-address" (PR driver/69265). */
7827 for (int j = 0; sanitizer_opts[j].name != NULL; ++j)
7829 struct cl_option optb;
7830 /* -fsanitize=all is not valid, only -fno-sanitize=all.
7831 So don't register the positive misspelling candidates
7832 for it. */
7833 if (sanitizer_opts[j].flag == ~0U && i == OPT_fsanitize_)
7835 optb = *option;
7836 optb.opt_text = opt_text = "-fno-sanitize=";
7837 optb.cl_reject_negative = true;
7838 option = &optb;
7840 /* Get one arg at a time e.g. "-fsanitize=address". */
7841 char *with_arg = concat (opt_text,
7842 sanitizer_opts[j].name,
7843 NULL);
7844 /* Add with_arg and all of its variant spellings e.g.
7845 "-fno-sanitize=address" to candidates (albeit without
7846 leading dashes). */
7847 add_misspelling_candidates (m_option_suggestions, option,
7848 with_arg);
7849 free (with_arg);
7852 break;
7857 /* Helper function for driver::handle_unrecognized_options.
7859 Given an unrecognized option BAD_OPT (without the leading dash),
7860 locate the closest reasonable matching option (again, without the
7861 leading dash), or NULL.
7863 The returned string is owned by the driver instance. */
7865 const char *
7866 driver::suggest_option (const char *bad_opt)
7868 /* Lazily populate m_option_suggestions. */
7869 if (!m_option_suggestions)
7870 build_option_suggestions ();
7871 gcc_assert (m_option_suggestions);
7873 /* "m_option_suggestions" is now populated. Use it. */
7874 return find_closest_string
7875 (bad_opt,
7876 (auto_vec <const char *> *) m_option_suggestions);
7879 /* Reject switches that no pass was interested in. */
7881 void
7882 driver::handle_unrecognized_options ()
7884 for (size_t i = 0; (int) i < n_switches; i++)
7885 if (! switches[i].validated)
7887 const char *hint = suggest_option (switches[i].part1);
7888 if (hint)
7889 error ("unrecognized command line option %<-%s%>;"
7890 " did you mean %<-%s%>?",
7891 switches[i].part1, hint);
7892 else
7893 error ("unrecognized command line option %<-%s%>",
7894 switches[i].part1);
7898 /* Handle the various -print-* options, returning 0 if the driver
7899 should exit, or nonzero if the driver should continue. */
7902 driver::maybe_print_and_exit () const
7904 if (print_search_dirs)
7906 printf (_("install: %s%s\n"),
7907 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
7908 gcc_exec_prefix ? "" : machine_suffix);
7909 printf (_("programs: %s\n"),
7910 build_search_list (&exec_prefixes, "", false, false));
7911 printf (_("libraries: %s\n"),
7912 build_search_list (&startfile_prefixes, "", false, true));
7913 return (0);
7916 if (print_file_name)
7918 printf ("%s\n", find_file (print_file_name));
7919 return (0);
7922 if (print_prog_name)
7924 if (use_ld != NULL && ! strcmp (print_prog_name, "ld"))
7926 /* Append USE_LD to the default linker. */
7927 #ifdef DEFAULT_LINKER
7928 char *ld;
7929 # ifdef HAVE_HOST_EXECUTABLE_SUFFIX
7930 int len = (sizeof (DEFAULT_LINKER)
7931 - sizeof (HOST_EXECUTABLE_SUFFIX));
7932 ld = NULL;
7933 if (len > 0)
7935 char *default_linker = xstrdup (DEFAULT_LINKER);
7936 /* Strip HOST_EXECUTABLE_SUFFIX if DEFAULT_LINKER contains
7937 HOST_EXECUTABLE_SUFFIX. */
7938 if (! strcmp (&default_linker[len], HOST_EXECUTABLE_SUFFIX))
7940 default_linker[len] = '\0';
7941 ld = concat (default_linker, use_ld,
7942 HOST_EXECUTABLE_SUFFIX, NULL);
7945 if (ld == NULL)
7946 # endif
7947 ld = concat (DEFAULT_LINKER, use_ld, NULL);
7948 if (access (ld, X_OK) == 0)
7950 printf ("%s\n", ld);
7951 return (0);
7953 #endif
7954 print_prog_name = concat (print_prog_name, use_ld, NULL);
7956 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
7957 printf ("%s\n", (newname ? newname : print_prog_name));
7958 return (0);
7961 if (print_multi_lib)
7963 print_multilib_info ();
7964 return (0);
7967 if (print_multi_directory)
7969 if (multilib_dir == NULL)
7970 printf (".\n");
7971 else
7972 printf ("%s\n", multilib_dir);
7973 return (0);
7976 if (print_multiarch)
7978 if (multiarch_dir == NULL)
7979 printf ("\n");
7980 else
7981 printf ("%s\n", multiarch_dir);
7982 return (0);
7985 if (print_sysroot)
7987 if (target_system_root)
7989 if (target_sysroot_suffix)
7990 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
7991 else
7992 printf ("%s\n", target_system_root);
7994 return (0);
7997 if (print_multi_os_directory)
7999 if (multilib_os_dir == NULL)
8000 printf (".\n");
8001 else
8002 printf ("%s\n", multilib_os_dir);
8003 return (0);
8006 if (print_sysroot_headers_suffix)
8008 if (*sysroot_hdrs_suffix_spec)
8010 printf("%s\n", (target_sysroot_hdrs_suffix
8011 ? target_sysroot_hdrs_suffix
8012 : ""));
8013 return (0);
8015 else
8016 /* The error status indicates that only one set of fixed
8017 headers should be built. */
8018 fatal_error (input_location,
8019 "not configured with sysroot headers suffix");
8022 if (print_help_list)
8024 display_help ();
8026 if (! verbose_flag)
8028 printf (_("\nFor bug reporting instructions, please see:\n"));
8029 printf ("%s.\n", bug_report_url);
8031 return (0);
8034 /* We do not exit here. Instead we have created a fake input file
8035 called 'help-dummy' which needs to be compiled, and we pass this
8036 on the various sub-processes, along with the --help switch.
8037 Ensure their output appears after ours. */
8038 fputc ('\n', stdout);
8039 fflush (stdout);
8042 if (print_version)
8044 printf (_("%s %s%s\n"), progname, pkgversion_string,
8045 version_string);
8046 printf ("Copyright %s 2018 Free Software Foundation, Inc.\n",
8047 _("(C)"));
8048 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
8049 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
8050 stdout);
8051 if (! verbose_flag)
8052 return 0;
8054 /* We do not exit here. We use the same mechanism of --help to print
8055 the version of the sub-processes. */
8056 fputc ('\n', stdout);
8057 fflush (stdout);
8060 if (verbose_flag)
8062 print_configuration (stderr);
8063 if (n_infiles == 0)
8064 return (0);
8067 return 1;
8070 /* Figure out what to do with each input file.
8071 Return true if we need to exit early from "main", false otherwise. */
8073 bool
8074 driver::prepare_infiles ()
8076 size_t i;
8077 int lang_n_infiles = 0;
8079 if (n_infiles == added_libraries)
8080 fatal_error (input_location, "no input files");
8082 if (seen_error ())
8083 /* Early exit needed from main. */
8084 return true;
8086 /* Make a place to record the compiler output file names
8087 that correspond to the input files. */
8089 i = n_infiles;
8090 i += lang_specific_extra_outfiles;
8091 outfiles = XCNEWVEC (const char *, i);
8093 /* Record which files were specified explicitly as link input. */
8095 explicit_link_files = XCNEWVEC (char, n_infiles);
8097 combine_inputs = have_o || flag_wpa;
8099 for (i = 0; (int) i < n_infiles; i++)
8101 const char *name = infiles[i].name;
8102 struct compiler *compiler = lookup_compiler (name,
8103 strlen (name),
8104 infiles[i].language);
8106 if (compiler && !(compiler->combinable))
8107 combine_inputs = false;
8109 if (lang_n_infiles > 0 && compiler != input_file_compiler
8110 && infiles[i].language && infiles[i].language[0] != '*')
8111 infiles[i].incompiler = compiler;
8112 else if (compiler)
8114 lang_n_infiles++;
8115 input_file_compiler = compiler;
8116 infiles[i].incompiler = compiler;
8118 else
8120 /* Since there is no compiler for this input file, assume it is a
8121 linker file. */
8122 explicit_link_files[i] = 1;
8123 infiles[i].incompiler = NULL;
8125 infiles[i].compiled = false;
8126 infiles[i].preprocessed = false;
8129 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
8130 fatal_error (input_location,
8131 "cannot specify -o with -c, -S or -E with multiple files");
8133 /* No early exit needed from main; we can continue. */
8134 return false;
8137 /* Run the spec machinery on each input file. */
8139 void
8140 driver::do_spec_on_infiles () const
8142 size_t i;
8144 for (i = 0; (int) i < n_infiles; i++)
8146 int this_file_error = 0;
8148 /* Tell do_spec what to substitute for %i. */
8150 input_file_number = i;
8151 set_input (infiles[i].name);
8153 if (infiles[i].compiled)
8154 continue;
8156 /* Use the same thing in %o, unless cp->spec says otherwise. */
8158 outfiles[i] = gcc_input_filename;
8160 /* Figure out which compiler from the file's suffix. */
8162 input_file_compiler
8163 = lookup_compiler (infiles[i].name, input_filename_length,
8164 infiles[i].language);
8166 if (input_file_compiler)
8168 /* Ok, we found an applicable compiler. Run its spec. */
8170 if (input_file_compiler->spec[0] == '#')
8172 error ("%s: %s compiler not installed on this system",
8173 gcc_input_filename, &input_file_compiler->spec[1]);
8174 this_file_error = 1;
8176 else
8178 int value;
8180 if (compare_debug)
8182 free (debug_check_temp_file[0]);
8183 debug_check_temp_file[0] = NULL;
8185 free (debug_check_temp_file[1]);
8186 debug_check_temp_file[1] = NULL;
8189 value = do_spec (input_file_compiler->spec);
8190 infiles[i].compiled = true;
8191 if (value < 0)
8192 this_file_error = 1;
8193 else if (compare_debug && debug_check_temp_file[0])
8195 if (verbose_flag)
8196 inform (UNKNOWN_LOCATION,
8197 "recompiling with -fcompare-debug");
8199 compare_debug = -compare_debug;
8200 n_switches = n_switches_debug_check[1];
8201 n_switches_alloc = n_switches_alloc_debug_check[1];
8202 switches = switches_debug_check[1];
8204 value = do_spec (input_file_compiler->spec);
8206 compare_debug = -compare_debug;
8207 n_switches = n_switches_debug_check[0];
8208 n_switches_alloc = n_switches_alloc_debug_check[0];
8209 switches = switches_debug_check[0];
8211 if (value < 0)
8213 error ("during -fcompare-debug recompilation");
8214 this_file_error = 1;
8217 gcc_assert (debug_check_temp_file[1]
8218 && filename_cmp (debug_check_temp_file[0],
8219 debug_check_temp_file[1]));
8221 if (verbose_flag)
8222 inform (UNKNOWN_LOCATION, "comparing final insns dumps");
8224 if (compare_files (debug_check_temp_file))
8225 this_file_error = 1;
8228 if (compare_debug)
8230 free (debug_check_temp_file[0]);
8231 debug_check_temp_file[0] = NULL;
8233 free (debug_check_temp_file[1]);
8234 debug_check_temp_file[1] = NULL;
8239 /* If this file's name does not contain a recognized suffix,
8240 record it as explicit linker input. */
8242 else
8243 explicit_link_files[i] = 1;
8245 /* Clear the delete-on-failure queue, deleting the files in it
8246 if this compilation failed. */
8248 if (this_file_error)
8250 delete_failure_queue ();
8251 errorcount++;
8253 /* If this compilation succeeded, don't delete those files later. */
8254 clear_failure_queue ();
8257 /* Reset the input file name to the first compile/object file name, for use
8258 with %b in LINK_SPEC. We use the first input file that we can find
8259 a compiler to compile it instead of using infiles.language since for
8260 languages other than C we use aliases that we then lookup later. */
8261 if (n_infiles > 0)
8263 int i;
8265 for (i = 0; i < n_infiles ; i++)
8266 if (infiles[i].incompiler
8267 || (infiles[i].language && infiles[i].language[0] != '*'))
8269 set_input (infiles[i].name);
8270 break;
8274 if (!seen_error ())
8276 /* Make sure INPUT_FILE_NUMBER points to first available open
8277 slot. */
8278 input_file_number = n_infiles;
8279 if (lang_specific_pre_link ())
8280 errorcount++;
8284 /* If we have to run the linker, do it now. */
8286 void
8287 driver::maybe_run_linker (const char *argv0) const
8289 size_t i;
8290 int linker_was_run = 0;
8291 int num_linker_inputs;
8293 /* Determine if there are any linker input files. */
8294 num_linker_inputs = 0;
8295 for (i = 0; (int) i < n_infiles; i++)
8296 if (explicit_link_files[i] || outfiles[i] != NULL)
8297 num_linker_inputs++;
8299 /* Run ld to link all the compiler output files. */
8301 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
8303 int tmp = execution_count;
8305 if (! have_c)
8307 #if HAVE_LTO_PLUGIN > 0
8308 #if HAVE_LTO_PLUGIN == 2
8309 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
8310 #else
8311 const char *fuse_linker_plugin = "fuse-linker-plugin";
8312 #endif
8313 #endif
8315 /* We'll use ld if we can't find collect2. */
8316 if (! strcmp (linker_name_spec, "collect2"))
8318 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
8319 if (s == NULL)
8320 linker_name_spec = "ld";
8323 #if HAVE_LTO_PLUGIN > 0
8324 #if HAVE_LTO_PLUGIN == 2
8325 if (!switch_matches (fno_use_linker_plugin,
8326 fno_use_linker_plugin
8327 + strlen (fno_use_linker_plugin), 0))
8328 #else
8329 if (switch_matches (fuse_linker_plugin,
8330 fuse_linker_plugin
8331 + strlen (fuse_linker_plugin), 0))
8332 #endif
8334 char *temp_spec = find_a_file (&exec_prefixes,
8335 LTOPLUGINSONAME, R_OK,
8336 false);
8337 if (!temp_spec)
8338 fatal_error (input_location,
8339 "-fuse-linker-plugin, but %s not found",
8340 LTOPLUGINSONAME);
8341 linker_plugin_file_spec = convert_white_space (temp_spec);
8343 #endif
8344 lto_gcc_spec = argv0;
8347 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
8348 for collect. */
8349 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
8350 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
8352 if (print_subprocess_help == 1)
8354 printf (_("\nLinker options\n==============\n\n"));
8355 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
8356 " to the linker.\n\n"));
8357 fflush (stdout);
8359 int value = do_spec (link_command_spec);
8360 if (value < 0)
8361 errorcount = 1;
8362 linker_was_run = (tmp != execution_count);
8365 /* If options said don't run linker,
8366 complain about input files to be given to the linker. */
8368 if (! linker_was_run && !seen_error ())
8369 for (i = 0; (int) i < n_infiles; i++)
8370 if (explicit_link_files[i]
8371 && !(infiles[i].language && infiles[i].language[0] == '*'))
8372 warning (0, "%s: linker input file unused because linking not done",
8373 outfiles[i]);
8376 /* The end of "main". */
8378 void
8379 driver::final_actions () const
8381 /* Delete some or all of the temporary files we made. */
8383 if (seen_error ())
8384 delete_failure_queue ();
8385 delete_temp_files ();
8387 if (print_help_list)
8389 printf (("\nFor bug reporting instructions, please see:\n"));
8390 printf ("%s\n", bug_report_url);
8394 /* Determine what the exit code of the driver should be. */
8397 driver::get_exit_code () const
8399 return (signal_count != 0 ? 2
8400 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
8401 : 0);
8404 /* Find the proper compilation spec for the file name NAME,
8405 whose length is LENGTH. LANGUAGE is the specified language,
8406 or 0 if this file is to be passed to the linker. */
8408 static struct compiler *
8409 lookup_compiler (const char *name, size_t length, const char *language)
8411 struct compiler *cp;
8413 /* If this was specified by the user to be a linker input, indicate that. */
8414 if (language != 0 && language[0] == '*')
8415 return 0;
8417 /* Otherwise, look for the language, if one is spec'd. */
8418 if (language != 0)
8420 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8421 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
8423 if (name != NULL && strcmp (name, "-") == 0
8424 && (strcmp (cp->suffix, "@c-header") == 0
8425 || strcmp (cp->suffix, "@c++-header") == 0)
8426 && !have_E)
8427 fatal_error (input_location,
8428 "cannot use %<-%> as input filename for a "
8429 "precompiled header");
8431 return cp;
8434 error ("language %s not recognized", language);
8435 return 0;
8438 /* Look for a suffix. */
8439 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8441 if (/* The suffix `-' matches only the file name `-'. */
8442 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
8443 || (strlen (cp->suffix) < length
8444 /* See if the suffix matches the end of NAME. */
8445 && !strcmp (cp->suffix,
8446 name + length - strlen (cp->suffix))
8448 break;
8451 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
8452 /* Look again, but case-insensitively this time. */
8453 if (cp < compilers)
8454 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8456 if (/* The suffix `-' matches only the file name `-'. */
8457 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
8458 || (strlen (cp->suffix) < length
8459 /* See if the suffix matches the end of NAME. */
8460 && ((!strcmp (cp->suffix,
8461 name + length - strlen (cp->suffix))
8462 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
8463 && !strcasecmp (cp->suffix,
8464 name + length - strlen (cp->suffix)))
8466 break;
8468 #endif
8470 if (cp >= compilers)
8472 if (cp->spec[0] != '@')
8473 /* A non-alias entry: return it. */
8474 return cp;
8476 /* An alias entry maps a suffix to a language.
8477 Search for the language; pass 0 for NAME and LENGTH
8478 to avoid infinite recursion if language not found. */
8479 return lookup_compiler (NULL, 0, cp->spec + 1);
8481 return 0;
8484 static char *
8485 save_string (const char *s, int len)
8487 char *result = XNEWVEC (char, len + 1);
8489 gcc_checking_assert (strlen (s) >= (unsigned int) len);
8490 memcpy (result, s, len);
8491 result[len] = 0;
8492 return result;
8495 void
8496 pfatal_with_name (const char *name)
8498 perror_with_name (name);
8499 delete_temp_files ();
8500 exit (1);
8503 static void
8504 perror_with_name (const char *name)
8506 error ("%s: %m", name);
8509 static inline void
8510 validate_switches_from_spec (const char *spec, bool user)
8512 const char *p = spec;
8513 char c;
8514 while ((c = *p++))
8515 if (c == '%'
8516 && (*p == '{'
8517 || *p == '<'
8518 || (*p == 'W' && *++p == '{')
8519 || (*p == '@' && *++p == '{')))
8520 /* We have a switch spec. */
8521 p = validate_switches (p + 1, user);
8524 static void
8525 validate_all_switches (void)
8527 struct compiler *comp;
8528 struct spec_list *spec;
8530 for (comp = compilers; comp->spec; comp++)
8531 validate_switches_from_spec (comp->spec, false);
8533 /* Look through the linked list of specs read from the specs file. */
8534 for (spec = specs; spec; spec = spec->next)
8535 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
8537 validate_switches_from_spec (link_command_spec, false);
8540 /* Look at the switch-name that comes after START
8541 and mark as valid all supplied switches that match it. */
8543 static const char *
8544 validate_switches (const char *start, bool user_spec)
8546 const char *p = start;
8547 const char *atom;
8548 size_t len;
8549 int i;
8550 bool suffix = false;
8551 bool starred = false;
8553 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
8555 next_member:
8556 SKIP_WHITE ();
8558 if (*p == '!')
8559 p++;
8561 SKIP_WHITE ();
8562 if (*p == '.' || *p == ',')
8563 suffix = true, p++;
8565 atom = p;
8566 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
8567 || *p == ',' || *p == '.' || *p == '@')
8568 p++;
8569 len = p - atom;
8571 if (*p == '*')
8572 starred = true, p++;
8574 SKIP_WHITE ();
8576 if (!suffix)
8578 /* Mark all matching switches as valid. */
8579 for (i = 0; i < n_switches; i++)
8580 if (!strncmp (switches[i].part1, atom, len)
8581 && (starred || switches[i].part1[len] == '\0')
8582 && (switches[i].known || user_spec))
8583 switches[i].validated = true;
8586 if (*p) p++;
8587 if (*p && (p[-1] == '|' || p[-1] == '&'))
8588 goto next_member;
8590 if (*p && p[-1] == ':')
8592 while (*p && *p != ';' && *p != '}')
8594 if (*p == '%')
8596 p++;
8597 if (*p == '{' || *p == '<')
8598 p = validate_switches (p+1, user_spec);
8599 else if (p[0] == 'W' && p[1] == '{')
8600 p = validate_switches (p+2, user_spec);
8601 else if (p[0] == '@' && p[1] == '{')
8602 p = validate_switches (p+2, user_spec);
8604 else
8605 p++;
8608 if (*p) p++;
8609 if (*p && p[-1] == ';')
8610 goto next_member;
8613 return p;
8614 #undef SKIP_WHITE
8617 struct mdswitchstr
8619 const char *str;
8620 int len;
8623 static struct mdswitchstr *mdswitches;
8624 static int n_mdswitches;
8626 /* Check whether a particular argument was used. The first time we
8627 canonicalize the switches to keep only the ones we care about. */
8629 class used_arg_t
8631 public:
8632 int operator () (const char *p, int len);
8633 void finalize ();
8635 private:
8636 struct mswitchstr
8638 const char *str;
8639 const char *replace;
8640 int len;
8641 int rep_len;
8644 mswitchstr *mswitches;
8645 int n_mswitches;
8649 used_arg_t used_arg;
8652 used_arg_t::operator () (const char *p, int len)
8654 int i, j;
8656 if (!mswitches)
8658 struct mswitchstr *matches;
8659 const char *q;
8660 int cnt = 0;
8662 /* Break multilib_matches into the component strings of string
8663 and replacement string. */
8664 for (q = multilib_matches; *q != '\0'; q++)
8665 if (*q == ';')
8666 cnt++;
8668 matches
8669 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
8670 i = 0;
8671 q = multilib_matches;
8672 while (*q != '\0')
8674 matches[i].str = q;
8675 while (*q != ' ')
8677 if (*q == '\0')
8679 invalid_matches:
8680 fatal_error (input_location, "multilib spec %qs is invalid",
8681 multilib_matches);
8683 q++;
8685 matches[i].len = q - matches[i].str;
8687 matches[i].replace = ++q;
8688 while (*q != ';' && *q != '\0')
8690 if (*q == ' ')
8691 goto invalid_matches;
8692 q++;
8694 matches[i].rep_len = q - matches[i].replace;
8695 i++;
8696 if (*q == ';')
8697 q++;
8700 /* Now build a list of the replacement string for switches that we care
8701 about. Make sure we allocate at least one entry. This prevents
8702 xmalloc from calling fatal, and prevents us from re-executing this
8703 block of code. */
8704 mswitches
8705 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
8706 for (i = 0; i < n_switches; i++)
8707 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
8709 int xlen = strlen (switches[i].part1);
8710 for (j = 0; j < cnt; j++)
8711 if (xlen == matches[j].len
8712 && ! strncmp (switches[i].part1, matches[j].str, xlen))
8714 mswitches[n_mswitches].str = matches[j].replace;
8715 mswitches[n_mswitches].len = matches[j].rep_len;
8716 mswitches[n_mswitches].replace = (char *) 0;
8717 mswitches[n_mswitches].rep_len = 0;
8718 n_mswitches++;
8719 break;
8723 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
8724 on the command line nor any options mutually incompatible with
8725 them. */
8726 for (i = 0; i < n_mdswitches; i++)
8728 const char *r;
8730 for (q = multilib_options; *q != '\0'; *q && q++)
8732 while (*q == ' ')
8733 q++;
8735 r = q;
8736 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
8737 || strchr (" /", q[mdswitches[i].len]) == NULL)
8739 while (*q != ' ' && *q != '/' && *q != '\0')
8740 q++;
8741 if (*q != '/')
8742 break;
8743 q++;
8746 if (*q != ' ' && *q != '\0')
8748 while (*r != ' ' && *r != '\0')
8750 q = r;
8751 while (*q != ' ' && *q != '/' && *q != '\0')
8752 q++;
8754 if (used_arg (r, q - r))
8755 break;
8757 if (*q != '/')
8759 mswitches[n_mswitches].str = mdswitches[i].str;
8760 mswitches[n_mswitches].len = mdswitches[i].len;
8761 mswitches[n_mswitches].replace = (char *) 0;
8762 mswitches[n_mswitches].rep_len = 0;
8763 n_mswitches++;
8764 break;
8767 r = q + 1;
8769 break;
8775 for (i = 0; i < n_mswitches; i++)
8776 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
8777 return 1;
8779 return 0;
8782 void used_arg_t::finalize ()
8784 XDELETEVEC (mswitches);
8785 mswitches = NULL;
8786 n_mswitches = 0;
8790 static int
8791 default_arg (const char *p, int len)
8793 int i;
8795 for (i = 0; i < n_mdswitches; i++)
8796 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
8797 return 1;
8799 return 0;
8802 /* Work out the subdirectory to use based on the options. The format of
8803 multilib_select is a list of elements. Each element is a subdirectory
8804 name followed by a list of options followed by a semicolon. The format
8805 of multilib_exclusions is the same, but without the preceding
8806 directory. First gcc will check the exclusions, if none of the options
8807 beginning with an exclamation point are present, and all of the other
8808 options are present, then we will ignore this completely. Passing
8809 that, gcc will consider each multilib_select in turn using the same
8810 rules for matching the options. If a match is found, that subdirectory
8811 will be used.
8812 A subdirectory name is optionally followed by a colon and the corresponding
8813 multiarch name. */
8815 static void
8816 set_multilib_dir (void)
8818 const char *p;
8819 unsigned int this_path_len;
8820 const char *this_path, *this_arg;
8821 const char *start, *end;
8822 int not_arg;
8823 int ok, ndfltok, first;
8825 n_mdswitches = 0;
8826 start = multilib_defaults;
8827 while (*start == ' ' || *start == '\t')
8828 start++;
8829 while (*start != '\0')
8831 n_mdswitches++;
8832 while (*start != ' ' && *start != '\t' && *start != '\0')
8833 start++;
8834 while (*start == ' ' || *start == '\t')
8835 start++;
8838 if (n_mdswitches)
8840 int i = 0;
8842 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
8843 for (start = multilib_defaults; *start != '\0'; start = end + 1)
8845 while (*start == ' ' || *start == '\t')
8846 start++;
8848 if (*start == '\0')
8849 break;
8851 for (end = start + 1;
8852 *end != ' ' && *end != '\t' && *end != '\0'; end++)
8855 obstack_grow (&multilib_obstack, start, end - start);
8856 obstack_1grow (&multilib_obstack, 0);
8857 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
8858 mdswitches[i++].len = end - start;
8860 if (*end == '\0')
8861 break;
8865 p = multilib_exclusions;
8866 while (*p != '\0')
8868 /* Ignore newlines. */
8869 if (*p == '\n')
8871 ++p;
8872 continue;
8875 /* Check the arguments. */
8876 ok = 1;
8877 while (*p != ';')
8879 if (*p == '\0')
8881 invalid_exclusions:
8882 fatal_error (input_location, "multilib exclusions %qs is invalid",
8883 multilib_exclusions);
8886 if (! ok)
8888 ++p;
8889 continue;
8892 this_arg = p;
8893 while (*p != ' ' && *p != ';')
8895 if (*p == '\0')
8896 goto invalid_exclusions;
8897 ++p;
8900 if (*this_arg != '!')
8901 not_arg = 0;
8902 else
8904 not_arg = 1;
8905 ++this_arg;
8908 ok = used_arg (this_arg, p - this_arg);
8909 if (not_arg)
8910 ok = ! ok;
8912 if (*p == ' ')
8913 ++p;
8916 if (ok)
8917 return;
8919 ++p;
8922 first = 1;
8923 p = multilib_select;
8925 /* Append multilib reuse rules if any. With those rules, we can reuse
8926 one multilib for certain different options sets. */
8927 if (strlen (multilib_reuse) > 0)
8928 p = concat (p, multilib_reuse, NULL);
8930 while (*p != '\0')
8932 /* Ignore newlines. */
8933 if (*p == '\n')
8935 ++p;
8936 continue;
8939 /* Get the initial path. */
8940 this_path = p;
8941 while (*p != ' ')
8943 if (*p == '\0')
8945 invalid_select:
8946 fatal_error (input_location, "multilib select %qs %qs is invalid",
8947 multilib_select, multilib_reuse);
8949 ++p;
8951 this_path_len = p - this_path;
8953 /* Check the arguments. */
8954 ok = 1;
8955 ndfltok = 1;
8956 ++p;
8957 while (*p != ';')
8959 if (*p == '\0')
8960 goto invalid_select;
8962 if (! ok)
8964 ++p;
8965 continue;
8968 this_arg = p;
8969 while (*p != ' ' && *p != ';')
8971 if (*p == '\0')
8972 goto invalid_select;
8973 ++p;
8976 if (*this_arg != '!')
8977 not_arg = 0;
8978 else
8980 not_arg = 1;
8981 ++this_arg;
8984 /* If this is a default argument, we can just ignore it.
8985 This is true even if this_arg begins with '!'. Beginning
8986 with '!' does not mean that this argument is necessarily
8987 inappropriate for this library: it merely means that
8988 there is a more specific library which uses this
8989 argument. If this argument is a default, we need not
8990 consider that more specific library. */
8991 ok = used_arg (this_arg, p - this_arg);
8992 if (not_arg)
8993 ok = ! ok;
8995 if (! ok)
8996 ndfltok = 0;
8998 if (default_arg (this_arg, p - this_arg))
8999 ok = 1;
9001 if (*p == ' ')
9002 ++p;
9005 if (ok && first)
9007 if (this_path_len != 1
9008 || this_path[0] != '.')
9010 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
9011 char *q;
9013 strncpy (new_multilib_dir, this_path, this_path_len);
9014 new_multilib_dir[this_path_len] = '\0';
9015 q = strchr (new_multilib_dir, ':');
9016 if (q != NULL)
9017 *q = '\0';
9018 multilib_dir = new_multilib_dir;
9020 first = 0;
9023 if (ndfltok)
9025 const char *q = this_path, *end = this_path + this_path_len;
9027 while (q < end && *q != ':')
9028 q++;
9029 if (q < end)
9031 const char *q2 = q + 1, *ml_end = end;
9032 char *new_multilib_os_dir;
9034 while (q2 < end && *q2 != ':')
9035 q2++;
9036 if (*q2 == ':')
9037 ml_end = q2;
9038 if (ml_end - q == 1)
9039 multilib_os_dir = xstrdup (".");
9040 else
9042 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
9043 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
9044 new_multilib_os_dir[ml_end - q - 1] = '\0';
9045 multilib_os_dir = new_multilib_os_dir;
9048 if (q2 < end && *q2 == ':')
9050 char *new_multiarch_dir = XNEWVEC (char, end - q2);
9051 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
9052 new_multiarch_dir[end - q2 - 1] = '\0';
9053 multiarch_dir = new_multiarch_dir;
9055 break;
9059 ++p;
9062 if (multilib_dir == NULL && multilib_os_dir != NULL
9063 && strcmp (multilib_os_dir, ".") == 0)
9065 free (CONST_CAST (char *, multilib_os_dir));
9066 multilib_os_dir = NULL;
9068 else if (multilib_dir != NULL && multilib_os_dir == NULL)
9069 multilib_os_dir = multilib_dir;
9072 /* Print out the multiple library subdirectory selection
9073 information. This prints out a series of lines. Each line looks
9074 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
9075 required. Only the desired options are printed out, the negative
9076 matches. The options are print without a leading dash. There are
9077 no spaces to make it easy to use the information in the shell.
9078 Each subdirectory is printed only once. This assumes the ordering
9079 generated by the genmultilib script. Also, we leave out ones that match
9080 the exclusions. */
9082 static void
9083 print_multilib_info (void)
9085 const char *p = multilib_select;
9086 const char *last_path = 0, *this_path;
9087 int skip;
9088 unsigned int last_path_len = 0;
9090 while (*p != '\0')
9092 skip = 0;
9093 /* Ignore newlines. */
9094 if (*p == '\n')
9096 ++p;
9097 continue;
9100 /* Get the initial path. */
9101 this_path = p;
9102 while (*p != ' ')
9104 if (*p == '\0')
9106 invalid_select:
9107 fatal_error (input_location,
9108 "multilib select %qs is invalid", multilib_select);
9111 ++p;
9114 /* When --disable-multilib was used but target defines
9115 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
9116 with .:: for multiarch configurations) are there just to find
9117 multilib_os_dir, so skip them from output. */
9118 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
9119 skip = 1;
9121 /* Check for matches with the multilib_exclusions. We don't bother
9122 with the '!' in either list. If any of the exclusion rules match
9123 all of its options with the select rule, we skip it. */
9125 const char *e = multilib_exclusions;
9126 const char *this_arg;
9128 while (*e != '\0')
9130 int m = 1;
9131 /* Ignore newlines. */
9132 if (*e == '\n')
9134 ++e;
9135 continue;
9138 /* Check the arguments. */
9139 while (*e != ';')
9141 const char *q;
9142 int mp = 0;
9144 if (*e == '\0')
9146 invalid_exclusion:
9147 fatal_error (input_location,
9148 "multilib exclusion %qs is invalid",
9149 multilib_exclusions);
9152 if (! m)
9154 ++e;
9155 continue;
9158 this_arg = e;
9160 while (*e != ' ' && *e != ';')
9162 if (*e == '\0')
9163 goto invalid_exclusion;
9164 ++e;
9167 q = p + 1;
9168 while (*q != ';')
9170 const char *arg;
9171 int len = e - this_arg;
9173 if (*q == '\0')
9174 goto invalid_select;
9176 arg = q;
9178 while (*q != ' ' && *q != ';')
9180 if (*q == '\0')
9181 goto invalid_select;
9182 ++q;
9185 if (! strncmp (arg, this_arg,
9186 (len < q - arg) ? q - arg : len)
9187 || default_arg (this_arg, e - this_arg))
9189 mp = 1;
9190 break;
9193 if (*q == ' ')
9194 ++q;
9197 if (! mp)
9198 m = 0;
9200 if (*e == ' ')
9201 ++e;
9204 if (m)
9206 skip = 1;
9207 break;
9210 if (*e != '\0')
9211 ++e;
9215 if (! skip)
9217 /* If this is a duplicate, skip it. */
9218 skip = (last_path != 0
9219 && (unsigned int) (p - this_path) == last_path_len
9220 && ! filename_ncmp (last_path, this_path, last_path_len));
9222 last_path = this_path;
9223 last_path_len = p - this_path;
9226 /* If this directory requires any default arguments, we can skip
9227 it. We will already have printed a directory identical to
9228 this one which does not require that default argument. */
9229 if (! skip)
9231 const char *q;
9233 q = p + 1;
9234 while (*q != ';')
9236 const char *arg;
9238 if (*q == '\0')
9239 goto invalid_select;
9241 if (*q == '!')
9242 arg = NULL;
9243 else
9244 arg = q;
9246 while (*q != ' ' && *q != ';')
9248 if (*q == '\0')
9249 goto invalid_select;
9250 ++q;
9253 if (arg != NULL
9254 && default_arg (arg, q - arg))
9256 skip = 1;
9257 break;
9260 if (*q == ' ')
9261 ++q;
9265 if (! skip)
9267 const char *p1;
9269 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
9270 putchar (*p1);
9271 putchar (';');
9274 ++p;
9275 while (*p != ';')
9277 int use_arg;
9279 if (*p == '\0')
9280 goto invalid_select;
9282 if (skip)
9284 ++p;
9285 continue;
9288 use_arg = *p != '!';
9290 if (use_arg)
9291 putchar ('@');
9293 while (*p != ' ' && *p != ';')
9295 if (*p == '\0')
9296 goto invalid_select;
9297 if (use_arg)
9298 putchar (*p);
9299 ++p;
9302 if (*p == ' ')
9303 ++p;
9306 if (! skip)
9308 /* If there are extra options, print them now. */
9309 if (multilib_extra && *multilib_extra)
9311 int print_at = TRUE;
9312 const char *q;
9314 for (q = multilib_extra; *q != '\0'; q++)
9316 if (*q == ' ')
9317 print_at = TRUE;
9318 else
9320 if (print_at)
9321 putchar ('@');
9322 putchar (*q);
9323 print_at = FALSE;
9328 putchar ('\n');
9331 ++p;
9335 /* getenv built-in spec function.
9337 Returns the value of the environment variable given by its first argument,
9338 concatenated with the second argument. If the variable is not defined, a
9339 fatal error is issued unless such undefs are internally allowed, in which
9340 case the variable name is used as the variable value. */
9342 static const char *
9343 getenv_spec_function (int argc, const char **argv)
9345 const char *value;
9346 const char *varname;
9348 char *result;
9349 char *ptr;
9350 size_t len;
9352 if (argc != 2)
9353 return NULL;
9355 varname = argv[0];
9356 value = env.get (varname);
9358 if (!value && spec_undefvar_allowed)
9359 value = varname;
9361 if (!value)
9362 fatal_error (input_location,
9363 "environment variable %qs not defined", varname);
9365 /* We have to escape every character of the environment variable so
9366 they are not interpreted as active spec characters. A
9367 particularly painful case is when we are reading a variable
9368 holding a windows path complete with \ separators. */
9369 len = strlen (value) * 2 + strlen (argv[1]) + 1;
9370 result = XNEWVAR (char, len);
9371 for (ptr = result; *value; ptr += 2)
9373 ptr[0] = '\\';
9374 ptr[1] = *value++;
9377 strcpy (ptr, argv[1]);
9379 return result;
9382 /* if-exists built-in spec function.
9384 Checks to see if the file specified by the absolute pathname in
9385 ARGS exists. Returns that pathname if found.
9387 The usual use for this function is to check for a library file
9388 (whose name has been expanded with %s). */
9390 static const char *
9391 if_exists_spec_function (int argc, const char **argv)
9393 /* Must have only one argument. */
9394 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
9395 return argv[0];
9397 return NULL;
9400 /* if-exists-else built-in spec function.
9402 This is like if-exists, but takes an additional argument which
9403 is returned if the first argument does not exist. */
9405 static const char *
9406 if_exists_else_spec_function (int argc, const char **argv)
9408 /* Must have exactly two arguments. */
9409 if (argc != 2)
9410 return NULL;
9412 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
9413 return argv[0];
9415 return argv[1];
9418 /* sanitize built-in spec function.
9420 This returns non-NULL, if sanitizing address, thread or
9421 any of the undefined behavior sanitizers. */
9423 static const char *
9424 sanitize_spec_function (int argc, const char **argv)
9426 if (argc != 1)
9427 return NULL;
9429 if (strcmp (argv[0], "address") == 0)
9430 return (flag_sanitize & SANITIZE_USER_ADDRESS) ? "" : NULL;
9431 if (strcmp (argv[0], "kernel-address") == 0)
9432 return (flag_sanitize & SANITIZE_KERNEL_ADDRESS) ? "" : NULL;
9433 if (strcmp (argv[0], "thread") == 0)
9434 return (flag_sanitize & SANITIZE_THREAD) ? "" : NULL;
9435 if (strcmp (argv[0], "undefined") == 0)
9436 return ((flag_sanitize
9437 & (SANITIZE_UNDEFINED | SANITIZE_UNDEFINED_NONDEFAULT))
9438 && !flag_sanitize_undefined_trap_on_error) ? "" : NULL;
9439 if (strcmp (argv[0], "leak") == 0)
9440 return ((flag_sanitize
9441 & (SANITIZE_ADDRESS | SANITIZE_LEAK | SANITIZE_THREAD))
9442 == SANITIZE_LEAK) ? "" : NULL;
9443 return NULL;
9446 /* replace-outfile built-in spec function.
9448 This looks for the first argument in the outfiles array's name and
9449 replaces it with the second argument. */
9451 static const char *
9452 replace_outfile_spec_function (int argc, const char **argv)
9454 int i;
9455 /* Must have exactly two arguments. */
9456 if (argc != 2)
9457 abort ();
9459 for (i = 0; i < n_infiles; i++)
9461 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
9462 outfiles[i] = xstrdup (argv[1]);
9464 return NULL;
9467 /* remove-outfile built-in spec function.
9469 * This looks for the first argument in the outfiles array's name and
9470 * removes it. */
9472 static const char *
9473 remove_outfile_spec_function (int argc, const char **argv)
9475 int i;
9476 /* Must have exactly one argument. */
9477 if (argc != 1)
9478 abort ();
9480 for (i = 0; i < n_infiles; i++)
9482 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
9483 outfiles[i] = NULL;
9485 return NULL;
9488 /* Given two version numbers, compares the two numbers.
9489 A version number must match the regular expression
9490 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
9492 static int
9493 compare_version_strings (const char *v1, const char *v2)
9495 int rresult;
9496 regex_t r;
9498 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
9499 REG_EXTENDED | REG_NOSUB) != 0)
9500 abort ();
9501 rresult = regexec (&r, v1, 0, NULL, 0);
9502 if (rresult == REG_NOMATCH)
9503 fatal_error (input_location, "invalid version number %qs", v1);
9504 else if (rresult != 0)
9505 abort ();
9506 rresult = regexec (&r, v2, 0, NULL, 0);
9507 if (rresult == REG_NOMATCH)
9508 fatal_error (input_location, "invalid version number %qs", v2);
9509 else if (rresult != 0)
9510 abort ();
9512 return strverscmp (v1, v2);
9516 /* version_compare built-in spec function.
9518 This takes an argument of the following form:
9520 <comparison-op> <arg1> [<arg2>] <switch> <result>
9522 and produces "result" if the comparison evaluates to true,
9523 and nothing if it doesn't.
9525 The supported <comparison-op> values are:
9527 >= true if switch is a later (or same) version than arg1
9528 !> opposite of >=
9529 < true if switch is an earlier version than arg1
9530 !< opposite of <
9531 >< true if switch is arg1 or later, and earlier than arg2
9532 <> true if switch is earlier than arg1 or is arg2 or later
9534 If the switch is not present, the condition is false unless
9535 the first character of the <comparison-op> is '!'.
9537 For example,
9538 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
9539 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
9541 static const char *
9542 version_compare_spec_function (int argc, const char **argv)
9544 int comp1, comp2;
9545 size_t switch_len;
9546 const char *switch_value = NULL;
9547 int nargs = 1, i;
9548 bool result;
9550 if (argc < 3)
9551 fatal_error (input_location, "too few arguments to %%:version-compare");
9552 if (argv[0][0] == '\0')
9553 abort ();
9554 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
9555 nargs = 2;
9556 if (argc != nargs + 3)
9557 fatal_error (input_location, "too many arguments to %%:version-compare");
9559 switch_len = strlen (argv[nargs + 1]);
9560 for (i = 0; i < n_switches; i++)
9561 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
9562 && check_live_switch (i, switch_len))
9563 switch_value = switches[i].part1 + switch_len;
9565 if (switch_value == NULL)
9566 comp1 = comp2 = -1;
9567 else
9569 comp1 = compare_version_strings (switch_value, argv[1]);
9570 if (nargs == 2)
9571 comp2 = compare_version_strings (switch_value, argv[2]);
9572 else
9573 comp2 = -1; /* This value unused. */
9576 switch (argv[0][0] << 8 | argv[0][1])
9578 case '>' << 8 | '=':
9579 result = comp1 >= 0;
9580 break;
9581 case '!' << 8 | '<':
9582 result = comp1 >= 0 || switch_value == NULL;
9583 break;
9584 case '<' << 8:
9585 result = comp1 < 0;
9586 break;
9587 case '!' << 8 | '>':
9588 result = comp1 < 0 || switch_value == NULL;
9589 break;
9590 case '>' << 8 | '<':
9591 result = comp1 >= 0 && comp2 < 0;
9592 break;
9593 case '<' << 8 | '>':
9594 result = comp1 < 0 || comp2 >= 0;
9595 break;
9597 default:
9598 fatal_error (input_location,
9599 "unknown operator %qs in %%:version-compare", argv[0]);
9601 if (! result)
9602 return NULL;
9604 return argv[nargs + 2];
9607 /* %:include builtin spec function. This differs from %include in that it
9608 can be nested inside a spec, and thus be conditionalized. It takes
9609 one argument, the filename, and looks for it in the startfile path.
9610 The result is always NULL, i.e. an empty expansion. */
9612 static const char *
9613 include_spec_function (int argc, const char **argv)
9615 char *file;
9617 if (argc != 1)
9618 abort ();
9620 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
9621 read_specs (file ? file : argv[0], false, false);
9623 return NULL;
9626 /* %:find-file spec function. This function replaces its argument by
9627 the file found through find_file, that is the -print-file-name gcc
9628 program option. */
9629 static const char *
9630 find_file_spec_function (int argc, const char **argv)
9632 const char *file;
9634 if (argc != 1)
9635 abort ();
9637 file = find_file (argv[0]);
9638 return file;
9642 /* %:find-plugindir spec function. This function replaces its argument
9643 by the -iplugindir=<dir> option. `dir' is found through find_file, that
9644 is the -print-file-name gcc program option. */
9645 static const char *
9646 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
9648 const char *option;
9650 if (argc != 0)
9651 abort ();
9653 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
9654 return option;
9658 /* %:print-asm-header spec function. Print a banner to say that the
9659 following output is from the assembler. */
9661 static const char *
9662 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
9663 const char **argv ATTRIBUTE_UNUSED)
9665 printf (_("Assembler options\n=================\n\n"));
9666 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
9667 fflush (stdout);
9668 return NULL;
9671 /* Get a random number for -frandom-seed */
9673 static unsigned HOST_WIDE_INT
9674 get_random_number (void)
9676 unsigned HOST_WIDE_INT ret = 0;
9677 int fd;
9679 fd = open ("/dev/urandom", O_RDONLY);
9680 if (fd >= 0)
9682 read (fd, &ret, sizeof (HOST_WIDE_INT));
9683 close (fd);
9684 if (ret)
9685 return ret;
9688 /* Get some more or less random data. */
9689 #ifdef HAVE_GETTIMEOFDAY
9691 struct timeval tv;
9693 gettimeofday (&tv, NULL);
9694 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
9696 #else
9698 time_t now = time (NULL);
9700 if (now != (time_t)-1)
9701 ret = (unsigned) now;
9703 #endif
9705 return ret ^ getpid ();
9708 /* %:compare-debug-dump-opt spec function. Save the last argument,
9709 expected to be the last -fdump-final-insns option, or generate a
9710 temporary. */
9712 static const char *
9713 compare_debug_dump_opt_spec_function (int arg,
9714 const char **argv ATTRIBUTE_UNUSED)
9716 char *ret;
9717 char *name;
9718 int which;
9719 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
9721 if (arg != 0)
9722 fatal_error (input_location,
9723 "too many arguments to %%:compare-debug-dump-opt");
9725 do_spec_2 ("%{fdump-final-insns=*:%*}");
9726 do_spec_1 (" ", 0, NULL);
9728 if (argbuf.length () > 0
9729 && strcmp (argv[argbuf.length () - 1], "."))
9731 if (!compare_debug)
9732 return NULL;
9734 name = xstrdup (argv[argbuf.length () - 1]);
9735 ret = NULL;
9737 else
9739 const char *ext = NULL;
9741 if (argbuf.length () > 0)
9743 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
9744 ext = ".gkd";
9746 else if (!compare_debug)
9747 return NULL;
9748 else
9749 do_spec_2 ("%g.gkd");
9751 do_spec_1 (" ", 0, NULL);
9753 gcc_assert (argbuf.length () > 0);
9755 name = concat (argbuf.last (), ext, NULL);
9757 ret = concat ("-fdump-final-insns=", name, NULL);
9760 which = compare_debug < 0;
9761 debug_check_temp_file[which] = name;
9763 if (!which)
9765 unsigned HOST_WIDE_INT value = get_random_number ();
9767 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
9770 if (*random_seed)
9772 char *tmp = ret;
9773 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
9774 ret, NULL);
9775 free (tmp);
9778 if (which)
9779 *random_seed = 0;
9781 return ret;
9784 static const char *debug_auxbase_opt;
9786 /* %:compare-debug-self-opt spec function. Expands to the options
9787 that are to be passed in the second compilation of
9788 compare-debug. */
9790 static const char *
9791 compare_debug_self_opt_spec_function (int arg,
9792 const char **argv ATTRIBUTE_UNUSED)
9794 if (arg != 0)
9795 fatal_error (input_location,
9796 "too many arguments to %%:compare-debug-self-opt");
9798 if (compare_debug >= 0)
9799 return NULL;
9801 do_spec_2 ("%{c|S:%{o*:%*}}");
9802 do_spec_1 (" ", 0, NULL);
9804 if (argbuf.length () > 0)
9805 debug_auxbase_opt = concat ("-auxbase-strip ",
9806 argbuf.last (),
9807 NULL);
9808 else
9809 debug_auxbase_opt = NULL;
9811 return concat ("\
9812 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
9813 %<fdump-final-insns=* -w -S -o %j \
9814 %{!fcompare-debug-second:-fcompare-debug-second} \
9815 ", compare_debug_opt, NULL);
9818 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
9819 options that are to be passed in the second compilation of
9820 compare-debug. It expects, as an argument, the basename of the
9821 current input file name, with the .gk suffix appended to it. */
9823 static const char *
9824 compare_debug_auxbase_opt_spec_function (int arg,
9825 const char **argv)
9827 char *name;
9828 int len;
9830 if (arg == 0)
9831 fatal_error (input_location,
9832 "too few arguments to %%:compare-debug-auxbase-opt");
9834 if (arg != 1)
9835 fatal_error (input_location,
9836 "too many arguments to %%:compare-debug-auxbase-opt");
9838 if (compare_debug >= 0)
9839 return NULL;
9841 len = strlen (argv[0]);
9842 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
9843 fatal_error (input_location, "argument to %%:compare-debug-auxbase-opt "
9844 "does not end in .gk");
9846 if (debug_auxbase_opt)
9847 return debug_auxbase_opt;
9849 #define OPT "-auxbase "
9851 len -= 3;
9852 name = (char*) xmalloc (sizeof (OPT) + len);
9853 memcpy (name, OPT, sizeof (OPT) - 1);
9854 memcpy (name + sizeof (OPT) - 1, argv[0], len);
9855 name[sizeof (OPT) - 1 + len] = '\0';
9857 #undef OPT
9859 return name;
9862 /* %:pass-through-libs spec function. Finds all -l options and input
9863 file names in the lib spec passed to it, and makes a list of them
9864 prepended with the plugin option to cause them to be passed through
9865 to the final link after all the new object files have been added. */
9867 const char *
9868 pass_through_libs_spec_func (int argc, const char **argv)
9870 char *prepended = xstrdup (" ");
9871 int n;
9872 /* Shlemiel the painter's algorithm. Innately horrible, but at least
9873 we know that there will never be more than a handful of strings to
9874 concat, and it's only once per run, so it's not worth optimising. */
9875 for (n = 0; n < argc; n++)
9877 char *old = prepended;
9878 /* Anything that isn't an option is a full path to an output
9879 file; pass it through if it ends in '.a'. Among options,
9880 pass only -l. */
9881 if (argv[n][0] == '-' && argv[n][1] == 'l')
9883 const char *lopt = argv[n] + 2;
9884 /* Handle both joined and non-joined -l options. If for any
9885 reason there's a trailing -l with no joined or following
9886 arg just discard it. */
9887 if (!*lopt && ++n >= argc)
9888 break;
9889 else if (!*lopt)
9890 lopt = argv[n];
9891 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
9892 lopt, " ", NULL);
9894 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
9896 prepended = concat (prepended, "-plugin-opt=-pass-through=",
9897 argv[n], " ", NULL);
9899 if (prepended != old)
9900 free (old);
9902 return prepended;
9905 /* %:replace-extension spec function. Replaces the extension of the
9906 first argument with the second argument. */
9908 const char *
9909 replace_extension_spec_func (int argc, const char **argv)
9911 char *name;
9912 char *p;
9913 char *result;
9914 int i;
9916 if (argc != 2)
9917 fatal_error (input_location, "too few arguments to %%:replace-extension");
9919 name = xstrdup (argv[0]);
9921 for (i = strlen (name) - 1; i >= 0; i--)
9922 if (IS_DIR_SEPARATOR (name[i]))
9923 break;
9925 p = strrchr (name + i + 1, '.');
9926 if (p != NULL)
9927 *p = '\0';
9929 result = concat (name, argv[1], NULL);
9931 free (name);
9932 return result;
9935 /* Returns "" if ARGV[ARGC - 2] is greater than ARGV[ARGC-1].
9936 Otherwise, return NULL. */
9938 static const char *
9939 greater_than_spec_func (int argc, const char **argv)
9941 char *converted;
9943 if (argc == 1)
9944 return NULL;
9946 gcc_assert (argc >= 2);
9948 long arg = strtol (argv[argc - 2], &converted, 10);
9949 gcc_assert (converted != argv[argc - 2]);
9951 long lim = strtol (argv[argc - 1], &converted, 10);
9952 gcc_assert (converted != argv[argc - 1]);
9954 if (arg > lim)
9955 return "";
9957 return NULL;
9960 /* Returns "" if debug_info_level is greater than ARGV[ARGC-1].
9961 Otherwise, return NULL. */
9963 static const char *
9964 debug_level_greater_than_spec_func (int argc, const char **argv)
9966 char *converted;
9968 if (argc != 1)
9969 fatal_error (input_location,
9970 "wrong number of arguments to %%:debug-level-gt");
9972 long arg = strtol (argv[0], &converted, 10);
9973 gcc_assert (converted != argv[0]);
9975 if (debug_info_level > arg)
9976 return "";
9978 return NULL;
9981 /* Insert backslash before spaces in ORIG (usually a file path), to
9982 avoid being broken by spec parser.
9984 This function is needed as do_spec_1 treats white space (' ' and '\t')
9985 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
9986 the file name should be treated as a single argument rather than being
9987 broken into multiple. Solution is to insert '\\' before the space in a
9988 file name.
9990 This function converts and only converts all occurrence of ' '
9991 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
9992 "a b" -> "a\\ b"
9993 "a b" -> "a\\ \\ b"
9994 "a\tb" -> "a\\\tb"
9995 "a\\ b" -> "a\\\\ b"
9997 orig: input null-terminating string that was allocated by xalloc. The
9998 memory it points to might be freed in this function. Behavior undefined
9999 if ORIG wasn't xalloced or was freed already at entry.
10001 Return: ORIG if no conversion needed. Otherwise a newly allocated string
10002 that was converted from ORIG. */
10004 static char *
10005 convert_white_space (char *orig)
10007 int len, number_of_space = 0;
10009 for (len = 0; orig[len]; len++)
10010 if (orig[len] == ' ' || orig[len] == '\t') number_of_space++;
10012 if (number_of_space)
10014 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
10015 int j, k;
10016 for (j = 0, k = 0; j <= len; j++, k++)
10018 if (orig[j] == ' ' || orig[j] == '\t')
10019 new_spec[k++] = '\\';
10020 new_spec[k] = orig[j];
10022 free (orig);
10023 return new_spec;
10025 else
10026 return orig;
10029 static void
10030 path_prefix_reset (path_prefix *prefix)
10032 struct prefix_list *iter, *next;
10033 iter = prefix->plist;
10034 while (iter)
10036 next = iter->next;
10037 free (const_cast <char *> (iter->prefix));
10038 XDELETE (iter);
10039 iter = next;
10041 prefix->plist = 0;
10042 prefix->max_len = 0;
10045 /* Restore all state within gcc.c to the initial state, so that the driver
10046 code can be safely re-run in-process.
10048 Many const char * variables are referenced by static specs (see
10049 INIT_STATIC_SPEC above). These variables are restored to their default
10050 values by a simple loop over the static specs.
10052 For other variables, we directly restore them all to their initial
10053 values (often implicitly 0).
10055 Free the various obstacks in this file, along with "opts_obstack"
10056 from opts.c.
10058 This function also restores any environment variables that were changed. */
10060 void
10061 driver::finalize ()
10063 env.restore ();
10064 params_c_finalize ();
10065 diagnostic_finish (global_dc);
10067 is_cpp_driver = 0;
10068 at_file_supplied = 0;
10069 print_help_list = 0;
10070 print_version = 0;
10071 verbose_only_flag = 0;
10072 print_subprocess_help = 0;
10073 use_ld = NULL;
10074 report_times_to_file = NULL;
10075 target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
10076 target_system_root_changed = 0;
10077 target_sysroot_suffix = 0;
10078 target_sysroot_hdrs_suffix = 0;
10079 save_temps_flag = SAVE_TEMPS_NONE;
10080 save_temps_prefix = 0;
10081 save_temps_length = 0;
10082 spec_machine = DEFAULT_TARGET_MACHINE;
10083 greatest_status = 1;
10085 finalize_options_struct (&global_options);
10086 finalize_options_struct (&global_options_set);
10088 obstack_free (&obstack, NULL);
10089 obstack_free (&opts_obstack, NULL); /* in opts.c */
10090 obstack_free (&collect_obstack, NULL);
10092 link_command_spec = LINK_COMMAND_SPEC;
10094 obstack_free (&multilib_obstack, NULL);
10096 user_specs_head = NULL;
10097 user_specs_tail = NULL;
10099 /* Within the "compilers" vec, the fields "suffix" and "spec" were
10100 statically allocated for the default compilers, but dynamically
10101 allocated for additional compilers. Delete them for the latter. */
10102 for (int i = n_default_compilers; i < n_compilers; i++)
10104 free (const_cast <char *> (compilers[i].suffix));
10105 free (const_cast <char *> (compilers[i].spec));
10107 XDELETEVEC (compilers);
10108 compilers = NULL;
10109 n_compilers = 0;
10111 linker_options.truncate (0);
10112 assembler_options.truncate (0);
10113 preprocessor_options.truncate (0);
10115 path_prefix_reset (&exec_prefixes);
10116 path_prefix_reset (&startfile_prefixes);
10117 path_prefix_reset (&include_prefixes);
10119 machine_suffix = 0;
10120 just_machine_suffix = 0;
10121 gcc_exec_prefix = 0;
10122 gcc_libexec_prefix = 0;
10123 md_exec_prefix = MD_EXEC_PREFIX;
10124 md_startfile_prefix = MD_STARTFILE_PREFIX;
10125 md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
10126 multilib_dir = 0;
10127 multilib_os_dir = 0;
10128 multiarch_dir = 0;
10130 /* Free any specs dynamically-allocated by set_spec.
10131 These will be at the head of the list, before the
10132 statically-allocated ones. */
10133 if (specs)
10135 while (specs != static_specs)
10137 spec_list *next = specs->next;
10138 free (const_cast <char *> (specs->name));
10139 XDELETE (specs);
10140 specs = next;
10142 specs = 0;
10144 for (unsigned i = 0; i < ARRAY_SIZE (static_specs); i++)
10146 spec_list *sl = &static_specs[i];
10147 if (sl->alloc_p)
10149 if (0)
10150 free (const_cast <char *> (*(sl->ptr_spec)));
10151 sl->alloc_p = false;
10153 *(sl->ptr_spec) = sl->default_ptr;
10155 #ifdef EXTRA_SPECS
10156 extra_specs = NULL;
10157 #endif
10159 processing_spec_function = 0;
10161 clear_args ();
10163 have_c = 0;
10164 have_o = 0;
10166 temp_names = NULL;
10167 execution_count = 0;
10168 signal_count = 0;
10170 temp_filename = NULL;
10171 temp_filename_length = 0;
10172 always_delete_queue = NULL;
10173 failure_delete_queue = NULL;
10175 XDELETEVEC (switches);
10176 switches = NULL;
10177 n_switches = 0;
10178 n_switches_alloc = 0;
10180 compare_debug = 0;
10181 compare_debug_second = 0;
10182 compare_debug_opt = NULL;
10183 for (int i = 0; i < 2; i++)
10185 switches_debug_check[i] = NULL;
10186 n_switches_debug_check[i] = 0;
10187 n_switches_alloc_debug_check[i] = 0;
10188 debug_check_temp_file[i] = NULL;
10191 XDELETEVEC (infiles);
10192 infiles = NULL;
10193 n_infiles = 0;
10194 n_infiles_alloc = 0;
10196 combine_inputs = false;
10197 added_libraries = 0;
10198 XDELETEVEC (outfiles);
10199 outfiles = NULL;
10200 spec_lang = 0;
10201 last_language_n_infiles = 0;
10202 gcc_input_filename = NULL;
10203 input_file_number = 0;
10204 input_filename_length = 0;
10205 basename_length = 0;
10206 suffixed_basename_length = 0;
10207 input_basename = NULL;
10208 input_suffix = NULL;
10209 /* We don't need to purge "input_stat", just to unset "input_stat_set". */
10210 input_stat_set = 0;
10211 input_file_compiler = NULL;
10212 arg_going = 0;
10213 delete_this_arg = 0;
10214 this_is_output_file = 0;
10215 this_is_library_file = 0;
10216 this_is_linker_script = 0;
10217 input_from_pipe = 0;
10218 suffix_subst = NULL;
10220 mdswitches = NULL;
10221 n_mdswitches = 0;
10223 debug_auxbase_opt = NULL;
10225 used_arg.finalize ();
10228 /* PR jit/64810.
10229 Targets can provide configure-time default options in
10230 OPTION_DEFAULT_SPECS. The jit needs to access these, but
10231 they are expressed in the spec language.
10233 Run just enough of the driver to be able to expand these
10234 specs, and then call the callback CB on each
10235 such option. The options strings are *without* a leading
10236 '-' character e.g. ("march=x86-64"). Finally, clean up. */
10238 void
10239 driver_get_configure_time_options (void (*cb) (const char *option,
10240 void *user_data),
10241 void *user_data)
10243 size_t i;
10245 obstack_init (&obstack);
10246 init_opts_obstack ();
10247 n_switches = 0;
10249 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
10250 do_option_spec (option_default_specs[i].name,
10251 option_default_specs[i].spec);
10253 for (i = 0; (int) i < n_switches; i++)
10255 gcc_assert (switches[i].part1);
10256 (*cb) (switches[i].part1, user_data);
10259 obstack_free (&opts_obstack, NULL);
10260 obstack_free (&obstack, NULL);
10261 n_switches = 0;