PR tree-optimization/67955
[official-gcc.git] / gcc / gcc.c
blobf78acd68606ceba08cd096ccee972a6b3336c681
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987-2016 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 /* FIXME: when autoconf is fixed, remove the host check - dj */
174 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
175 #define HAVE_TARGET_EXECUTABLE_SUFFIX
176 #endif
178 /* By default there is no special suffix for host executables. */
179 #ifdef HOST_EXECUTABLE_SUFFIX
180 #define HAVE_HOST_EXECUTABLE_SUFFIX
181 #else
182 #define HOST_EXECUTABLE_SUFFIX ""
183 #endif
185 /* By default, the suffix for target object files is ".o". */
186 #ifdef TARGET_OBJECT_SUFFIX
187 #define HAVE_TARGET_OBJECT_SUFFIX
188 #else
189 #define TARGET_OBJECT_SUFFIX ".o"
190 #endif
192 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
194 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
195 #ifndef LIBRARY_PATH_ENV
196 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
197 #endif
199 /* If a stage of compilation returns an exit status >= 1,
200 compilation of that file ceases. */
202 #define MIN_FATAL_STATUS 1
204 /* Flag set by cppspec.c to 1. */
205 int is_cpp_driver;
207 /* Flag set to nonzero if an @file argument has been supplied to gcc. */
208 static bool at_file_supplied;
210 /* Definition of string containing the arguments given to configure. */
211 #include "configargs.h"
213 /* Flag saying to print the command line options understood by gcc and its
214 sub-processes. */
216 static int print_help_list;
218 /* Flag saying to print the version of gcc and its sub-processes. */
220 static int print_version;
222 /* Flag indicating whether we should ONLY print the command and
223 arguments (like verbose_flag) without executing the command.
224 Displayed arguments are quoted so that the generated command
225 line is suitable for execution. This is intended for use in
226 shell scripts to capture the driver-generated command line. */
227 static int verbose_only_flag;
229 /* Flag indicating how to print command line options of sub-processes. */
231 static int print_subprocess_help;
233 /* Linker suffix passed to -fuse-ld=... */
234 static const char *use_ld;
236 /* Whether we should report subprocess execution times to a file. */
238 FILE *report_times_to_file = NULL;
240 /* Nonzero means place this string before uses of /, so that include
241 and library files can be found in an alternate location. */
243 #ifdef TARGET_SYSTEM_ROOT
244 #define DEFAULT_TARGET_SYSTEM_ROOT (TARGET_SYSTEM_ROOT)
245 #else
246 #define DEFAULT_TARGET_SYSTEM_ROOT (0)
247 #endif
248 static const char *target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
250 /* Nonzero means pass the updated target_system_root to the compiler. */
252 static int target_system_root_changed;
254 /* Nonzero means append this string to target_system_root. */
256 static const char *target_sysroot_suffix = 0;
258 /* Nonzero means append this string to target_system_root for headers. */
260 static const char *target_sysroot_hdrs_suffix = 0;
262 /* Nonzero means write "temp" files in source directory
263 and use the source file's name in them, and don't delete them. */
265 static enum save_temps {
266 SAVE_TEMPS_NONE, /* no -save-temps */
267 SAVE_TEMPS_CWD, /* -save-temps in current directory */
268 SAVE_TEMPS_OBJ /* -save-temps in object directory */
269 } save_temps_flag;
271 /* Output file to use to get the object directory for -save-temps=obj */
272 static char *save_temps_prefix = 0;
273 static size_t save_temps_length = 0;
275 /* The compiler version. */
277 static const char *compiler_version;
279 /* The target version. */
281 static const char *const spec_version = DEFAULT_TARGET_VERSION;
283 /* The target machine. */
285 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
286 static const char *spec_host_machine = DEFAULT_REAL_TARGET_MACHINE;
288 /* List of offload targets. Separated by colon. Empty string for
289 -foffload=disable. */
291 static char *offload_targets = NULL;
293 /* Nonzero if cross-compiling.
294 When -b is used, the value comes from the `specs' file. */
296 #ifdef CROSS_DIRECTORY_STRUCTURE
297 static const char *cross_compile = "1";
298 #else
299 static const char *cross_compile = "0";
300 #endif
302 /* Greatest exit code of sub-processes that has been encountered up to
303 now. */
304 static int greatest_status = 1;
306 /* This is the obstack which we use to allocate many strings. */
308 static struct obstack obstack;
310 /* This is the obstack to build an environment variable to pass to
311 collect2 that describes all of the relevant switches of what to
312 pass the compiler in building the list of pointers to constructors
313 and destructors. */
315 static struct obstack collect_obstack;
317 /* Forward declaration for prototypes. */
318 struct path_prefix;
319 struct prefix_list;
321 static void init_spec (void);
322 static void store_arg (const char *, int, int);
323 static void insert_wrapper (const char *);
324 static char *load_specs (const char *);
325 static void read_specs (const char *, bool, bool);
326 static void set_spec (const char *, const char *, bool);
327 static struct compiler *lookup_compiler (const char *, size_t, const char *);
328 static char *build_search_list (const struct path_prefix *, const char *,
329 bool, bool);
330 static void xputenv (const char *);
331 static void putenv_from_prefixes (const struct path_prefix *, const char *,
332 bool);
333 static int access_check (const char *, int);
334 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
335 static void add_prefix (struct path_prefix *, const char *, const char *,
336 int, int, int);
337 static void add_sysrooted_prefix (struct path_prefix *, const char *,
338 const char *, int, int, int);
339 static char *skip_whitespace (char *);
340 static void delete_if_ordinary (const char *);
341 static void delete_temp_files (void);
342 static void delete_failure_queue (void);
343 static void clear_failure_queue (void);
344 static int check_live_switch (int, int);
345 static const char *handle_braces (const char *);
346 static inline bool input_suffix_matches (const char *, const char *);
347 static inline bool switch_matches (const char *, const char *, int);
348 static inline void mark_matching_switches (const char *, const char *, int);
349 static inline void process_marked_switches (void);
350 static const char *process_brace_body (const char *, const char *, const char *, int, int);
351 static const struct spec_function *lookup_spec_function (const char *);
352 static const char *eval_spec_function (const char *, const char *);
353 static const char *handle_spec_function (const char *, bool *);
354 static char *save_string (const char *, int);
355 static void set_collect_gcc_options (void);
356 static int do_spec_1 (const char *, int, const char *);
357 static int do_spec_2 (const char *);
358 static void do_option_spec (const char *, const char *);
359 static void do_self_spec (const char *);
360 static const char *find_file (const char *);
361 static int is_directory (const char *, bool);
362 static const char *validate_switches (const char *, bool);
363 static void validate_all_switches (void);
364 static inline void validate_switches_from_spec (const char *, bool);
365 static void give_switch (int, int);
366 static int default_arg (const char *, int);
367 static void set_multilib_dir (void);
368 static void print_multilib_info (void);
369 static void perror_with_name (const char *);
370 static void display_help (void);
371 static void add_preprocessor_option (const char *, int);
372 static void add_assembler_option (const char *, int);
373 static void add_linker_option (const char *, int);
374 static void process_command (unsigned int, struct cl_decoded_option *);
375 static int execute (void);
376 static void alloc_args (void);
377 static void clear_args (void);
378 static void fatal_signal (int);
379 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
380 static void init_gcc_specs (struct obstack *, const char *, const char *,
381 const char *);
382 #endif
383 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
384 static const char *convert_filename (const char *, int, int);
385 #endif
387 static void try_generate_repro (const char **argv);
388 static const char *getenv_spec_function (int, const char **);
389 static const char *if_exists_spec_function (int, const char **);
390 static const char *if_exists_else_spec_function (int, const char **);
391 static const char *sanitize_spec_function (int, const char **);
392 static const char *replace_outfile_spec_function (int, const char **);
393 static const char *remove_outfile_spec_function (int, const char **);
394 static const char *version_compare_spec_function (int, const char **);
395 static const char *include_spec_function (int, const char **);
396 static const char *find_file_spec_function (int, const char **);
397 static const char *find_plugindir_spec_function (int, const char **);
398 static const char *print_asm_header_spec_function (int, const char **);
399 static const char *compare_debug_dump_opt_spec_function (int, const char **);
400 static const char *compare_debug_self_opt_spec_function (int, const char **);
401 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
402 static const char *pass_through_libs_spec_func (int, const char **);
403 static const char *replace_extension_spec_func (int, const char **);
404 static const char *greater_than_spec_func (int, const char **);
405 static char *convert_white_space (char *);
407 /* The Specs Language
409 Specs are strings containing lines, each of which (if not blank)
410 is made up of a program name, and arguments separated by spaces.
411 The program name must be exact and start from root, since no path
412 is searched and it is unreliable to depend on the current working directory.
413 Redirection of input or output is not supported; the subprograms must
414 accept filenames saying what files to read and write.
416 In addition, the specs can contain %-sequences to substitute variable text
417 or for conditional text. Here is a table of all defined %-sequences.
418 Note that spaces are not generated automatically around the results of
419 expanding these sequences; therefore, you can concatenate them together
420 or with constant text in a single argument.
422 %% substitute one % into the program name or argument.
423 %i substitute the name of the input file being processed.
424 %b substitute the basename of the input file being processed.
425 This is the substring up to (and not including) the last period
426 and not including the directory unless -save-temps was specified
427 to put temporaries in a different location.
428 %B same as %b, but include the file suffix (text after the last period).
429 %gSUFFIX
430 substitute a file name that has suffix SUFFIX and is chosen
431 once per compilation, and mark the argument a la %d. To reduce
432 exposure to denial-of-service attacks, the file name is now
433 chosen in a way that is hard to predict even when previously
434 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
435 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
436 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
437 had been pre-processed. Previously, %g was simply substituted
438 with a file name chosen once per compilation, without regard
439 to any appended suffix (which was therefore treated just like
440 ordinary text), making such attacks more likely to succeed.
441 %|SUFFIX
442 like %g, but if -pipe is in effect, expands simply to "-".
443 %mSUFFIX
444 like %g, but if -pipe is in effect, expands to nothing. (We have both
445 %| and %m to accommodate differences between system assemblers; see
446 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
447 %uSUFFIX
448 like %g, but generates a new temporary file name even if %uSUFFIX
449 was already seen.
450 %USUFFIX
451 substitutes the last file name generated with %uSUFFIX, generating a
452 new one if there is no such last file name. In the absence of any
453 %uSUFFIX, this is just like %gSUFFIX, except they don't share
454 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
455 would involve the generation of two distinct file names, one
456 for each `%g.s' and another for each `%U.s'. Previously, %U was
457 simply substituted with a file name chosen for the previous %u,
458 without regard to any appended suffix.
459 %jSUFFIX
460 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
461 writable, and if save-temps is off; otherwise, substitute the name
462 of a temporary file, just like %u. This temporary file is not
463 meant for communication between processes, but rather as a junk
464 disposal mechanism.
465 %.SUFFIX
466 substitutes .SUFFIX for the suffixes of a matched switch's args when
467 it is subsequently output with %*. SUFFIX is terminated by the next
468 space or %.
469 %d marks the argument containing or following the %d as a
470 temporary file name, so that file will be deleted if GCC exits
471 successfully. Unlike %g, this contributes no text to the argument.
472 %w marks the argument containing or following the %w as the
473 "output file" of this compilation. This puts the argument
474 into the sequence of arguments that %o will substitute later.
475 %V indicates that this compilation produces no "output file".
476 %W{...}
477 like %{...} but mark last argument supplied within
478 as a file to be deleted on failure.
479 %o substitutes the names of all the output files, with spaces
480 automatically placed around them. You should write spaces
481 around the %o as well or the results are undefined.
482 %o is for use in the specs for running the linker.
483 Input files whose names have no recognized suffix are not compiled
484 at all, but they are included among the output files, so they will
485 be linked.
486 %O substitutes the suffix for object files. Note that this is
487 handled specially when it immediately follows %g, %u, or %U
488 (with or without a suffix argument) because of the need for
489 those to form complete file names. The handling is such that
490 %O is treated exactly as if it had already been substituted,
491 except that %g, %u, and %U do not currently support additional
492 SUFFIX characters following %O as they would following, for
493 example, `.o'.
494 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
495 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
496 and -B options) and -imultilib as necessary.
497 %s current argument is the name of a library or startup file of some sort.
498 Search for that file in a standard list of directories
499 and substitute the full name found.
500 %eSTR Print STR as an error message. STR is terminated by a newline.
501 Use this when inconsistent options are detected.
502 %nSTR Print STR as a notice. STR is terminated by a newline.
503 %x{OPTION} Accumulate an option for %X.
504 %X Output the accumulated linker options specified by compilations.
505 %Y Output the accumulated assembler options specified by compilations.
506 %Z Output the accumulated preprocessor options specified by compilations.
507 %a process ASM_SPEC as a spec.
508 This allows config.h to specify part of the spec for running as.
509 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
510 used here. This can be used to run a post-processor after the
511 assembler has done its job.
512 %D Dump out a -L option for each directory in startfile_prefixes.
513 If multilib_dir is set, extra entries are generated with it affixed.
514 %l process LINK_SPEC as a spec.
515 %L process LIB_SPEC as a spec.
516 %M Output multilib_os_dir.
517 %G process LIBGCC_SPEC as a spec.
518 %R Output the concatenation of target_system_root and
519 target_sysroot_suffix.
520 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
521 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
522 %C process CPP_SPEC as a spec.
523 %1 process CC1_SPEC as a spec.
524 %2 process CC1PLUS_SPEC as a spec.
525 %* substitute the variable part of a matched option. (See below.)
526 Note that each comma in the substituted string is replaced by
527 a single space. A space is appended after the last substition
528 unless there is more text in current sequence.
529 %<S remove all occurrences of -S from the command line.
530 Note - this command is position dependent. % commands in the
531 spec string before this one will see -S, % commands in the
532 spec string after this one will not.
533 %>S Similar to "%<S", but keep it in the GCC command line.
534 %<S* remove all occurrences of all switches beginning with -S from the
535 command line.
536 %:function(args)
537 Call the named function FUNCTION, passing it ARGS. ARGS is
538 first processed as a nested spec string, then split into an
539 argument vector in the usual fashion. The function returns
540 a string which is processed as if it had appeared literally
541 as part of the current spec.
542 %{S} substitutes the -S switch, if that switch was given to GCC.
543 If that switch was not specified, this substitutes nothing.
544 Here S is a metasyntactic variable.
545 %{S*} substitutes all the switches specified to GCC whose names start
546 with -S. This is used for -o, -I, etc; switches that take
547 arguments. GCC considers `-o foo' as being one switch whose
548 name starts with `o'. %{o*} would substitute this text,
549 including the space; thus, two arguments would be generated.
550 %{S*&T*} likewise, but preserve order of S and T options (the order
551 of S and T in the spec is not significant). Can be any number
552 of ampersand-separated variables; for each the wild card is
553 optional. Useful for CPP as %{D*&U*&A*}.
555 %{S:X} substitutes X, if the -S switch was given to GCC.
556 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
557 %{S*:X} substitutes X if one or more switches whose names start
558 with -S was given to GCC. Normally X is substituted only
559 once, no matter how many such switches appeared. However,
560 if %* appears somewhere in X, then X will be substituted
561 once for each matching switch, with the %* replaced by the
562 part of that switch that matched the '*'. A space will be
563 appended after the last substition unless there is more
564 text in current sequence.
565 %{.S:X} substitutes X, if processing a file with suffix S.
566 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
567 %{,S:X} substitutes X, if processing a file which will use spec S.
568 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
570 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
571 combined with '!', '.', ',', and '*' as above binding stronger
572 than the OR.
573 If %* appears in X, all of the alternatives must be starred, and
574 only the first matching alternative is substituted.
575 %{%:function(args):X}
576 Call function named FUNCTION with args ARGS. If the function
577 returns non-NULL, then X is substituted, if it returns
578 NULL, it isn't substituted.
579 %{S:X; if S was given to GCC, substitutes X;
580 T:Y; else if T was given to GCC, substitutes Y;
581 :D} else substitutes D. There can be as many clauses as you need.
582 This may be combined with '.', '!', ',', '|', and '*' as above.
584 %(Spec) processes a specification defined in a specs file as *Spec:
586 The conditional text X in a %{S:X} or similar construct may contain
587 other nested % constructs or spaces, or even newlines. They are
588 processed as usual, as described above. Trailing white space in X is
589 ignored. White space may also appear anywhere on the left side of the
590 colon in these constructs, except between . or * and the corresponding
591 word.
593 The -O, -f, -g, -m, and -W switches are handled specifically in these
594 constructs. If another value of -O or the negated form of a -f, -m, or
595 -W switch is found later in the command line, the earlier switch
596 value is ignored, except with {S*} where S is just one letter; this
597 passes all matching options.
599 The character | at the beginning of the predicate text is used to indicate
600 that a command should be piped to the following command, but only if -pipe
601 is specified.
603 Note that it is built into GCC which switches take arguments and which
604 do not. You might think it would be useful to generalize this to
605 allow each compiler's spec to say which switches take arguments. But
606 this cannot be done in a consistent fashion. GCC cannot even decide
607 which input files have been specified without knowing which switches
608 take arguments, and it must know which input files to compile in order
609 to tell which compilers to run.
611 GCC also knows implicitly that arguments starting in `-l' are to be
612 treated as compiler output files, and passed to the linker in their
613 proper position among the other output files. */
615 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
617 /* config.h can define ASM_SPEC to provide extra args to the assembler
618 or extra switch-translations. */
619 #ifndef ASM_SPEC
620 #define ASM_SPEC ""
621 #endif
623 /* config.h can define ASM_FINAL_SPEC to run a post processor after
624 the assembler has run. */
625 #ifndef ASM_FINAL_SPEC
626 #define ASM_FINAL_SPEC \
627 "%{gsplit-dwarf: \n\
628 objcopy --extract-dwo \
629 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
630 %{c:%{o*:%:replace-extension(%{o*:%*} .dwo)}%{!o*:%b.dwo}}%{!c:%b.dwo} \n\
631 objcopy --strip-dwo \
632 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
634 #endif
636 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
637 or extra switch-translations. */
638 #ifndef CPP_SPEC
639 #define CPP_SPEC ""
640 #endif
642 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
643 or extra switch-translations. */
644 #ifndef CC1_SPEC
645 #define CC1_SPEC ""
646 #endif
648 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
649 or extra switch-translations. */
650 #ifndef CC1PLUS_SPEC
651 #define CC1PLUS_SPEC ""
652 #endif
654 /* config.h can define LINK_SPEC to provide extra args to the linker
655 or extra switch-translations. */
656 #ifndef LINK_SPEC
657 #define LINK_SPEC ""
658 #endif
660 /* config.h can define LIB_SPEC to override the default libraries. */
661 #ifndef LIB_SPEC
662 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
663 #endif
665 /* When using -fsplit-stack we need to wrap pthread_create, in order
666 to initialize the stack guard. We always use wrapping, rather than
667 shared library ordering, and we keep the wrapper function in
668 libgcc. This is not yet a real spec, though it could become one;
669 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
670 only works with GNU ld and gold. */
671 #ifdef HAVE_GOLD_NON_DEFAULT_SPLIT_STACK
672 #define STACK_SPLIT_SPEC " %{fsplit-stack: -fuse-ld=gold --wrap=pthread_create}"
673 #else
674 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
675 #endif
677 #ifndef LIBASAN_SPEC
678 #define STATIC_LIBASAN_LIBS \
679 " %{static-libasan:%:include(libsanitizer.spec)%(link_libasan)}"
680 #ifdef LIBASAN_EARLY_SPEC
681 #define LIBASAN_SPEC STATIC_LIBASAN_LIBS
682 #elif defined(HAVE_LD_STATIC_DYNAMIC)
683 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
684 "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
685 STATIC_LIBASAN_LIBS
686 #else
687 #define LIBASAN_SPEC "-lasan" STATIC_LIBASAN_LIBS
688 #endif
689 #endif
691 #ifndef LIBASAN_EARLY_SPEC
692 #define LIBASAN_EARLY_SPEC ""
693 #endif
695 #ifndef LIBTSAN_SPEC
696 #define STATIC_LIBTSAN_LIBS \
697 " %{static-libtsan:%:include(libsanitizer.spec)%(link_libtsan)}"
698 #ifdef LIBTSAN_EARLY_SPEC
699 #define LIBTSAN_SPEC STATIC_LIBTSAN_LIBS
700 #elif defined(HAVE_LD_STATIC_DYNAMIC)
701 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
702 "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}" \
703 STATIC_LIBTSAN_LIBS
704 #else
705 #define LIBTSAN_SPEC "-ltsan" STATIC_LIBTSAN_LIBS
706 #endif
707 #endif
709 #ifndef LIBTSAN_EARLY_SPEC
710 #define LIBTSAN_EARLY_SPEC ""
711 #endif
713 #ifndef LIBLSAN_SPEC
714 #define STATIC_LIBLSAN_LIBS \
715 " %{static-liblsan:%:include(libsanitizer.spec)%(link_liblsan)}"
716 #ifdef LIBLSAN_EARLY_SPEC
717 #define LIBLSAN_SPEC STATIC_LIBLSAN_LIBS
718 #elif defined(HAVE_LD_STATIC_DYNAMIC)
719 #define LIBLSAN_SPEC "%{static-liblsan:" LD_STATIC_OPTION \
720 "} -llsan %{static-liblsan:" LD_DYNAMIC_OPTION "}" \
721 STATIC_LIBLSAN_LIBS
722 #else
723 #define LIBLSAN_SPEC "-llsan" STATIC_LIBLSAN_LIBS
724 #endif
725 #endif
727 #ifndef LIBLSAN_EARLY_SPEC
728 #define LIBLSAN_EARLY_SPEC ""
729 #endif
731 #ifndef LIBUBSAN_SPEC
732 #define STATIC_LIBUBSAN_LIBS \
733 " %{static-libubsan:%:include(libsanitizer.spec)%(link_libubsan)}"
734 #ifdef HAVE_LD_STATIC_DYNAMIC
735 #define LIBUBSAN_SPEC "%{static-libubsan:" LD_STATIC_OPTION \
736 "} -lubsan %{static-libubsan:" LD_DYNAMIC_OPTION "}" \
737 STATIC_LIBUBSAN_LIBS
738 #else
739 #define LIBUBSAN_SPEC "-lubsan" STATIC_LIBUBSAN_LIBS
740 #endif
741 #endif
743 /* Linker options for compressed debug sections. */
744 #if HAVE_LD_COMPRESS_DEBUG == 0
745 /* No linker support. */
746 #define LINK_COMPRESS_DEBUG_SPEC \
747 " %{gz*:%e-gz is not supported in this configuration} "
748 #elif HAVE_LD_COMPRESS_DEBUG == 1
749 /* GNU style on input, GNU ld options. Reject, not useful. */
750 #define LINK_COMPRESS_DEBUG_SPEC \
751 " %{gz*:%e-gz is not supported in this configuration} "
752 #elif HAVE_LD_COMPRESS_DEBUG == 2
753 /* GNU style, GNU gold options. */
754 #define LINK_COMPRESS_DEBUG_SPEC \
755 " %{gz|gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
756 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
757 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
758 #elif HAVE_LD_COMPRESS_DEBUG == 3
759 /* ELF gABI style. */
760 #define LINK_COMPRESS_DEBUG_SPEC \
761 " %{gz|gz=zlib:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
762 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
763 " %{gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
764 #else
765 #error Unknown value for HAVE_LD_COMPRESS_DEBUG.
766 #endif
768 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
769 included. */
770 #ifndef LIBGCC_SPEC
771 #if defined(REAL_LIBGCC_SPEC)
772 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
773 #elif defined(LINK_LIBGCC_SPECIAL_1)
774 /* Have gcc do the search for libgcc.a. */
775 #define LIBGCC_SPEC "libgcc.a%s"
776 #else
777 #define LIBGCC_SPEC "-lgcc"
778 #endif
779 #endif
781 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
782 #ifndef STARTFILE_SPEC
783 #define STARTFILE_SPEC \
784 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
785 #endif
787 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
788 #ifndef ENDFILE_SPEC
789 #define ENDFILE_SPEC ""
790 #endif
792 #ifndef LINKER_NAME
793 #define LINKER_NAME "collect2"
794 #endif
796 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
797 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
798 #else
799 #define ASM_MAP ""
800 #endif
802 /* Assembler options for compressed debug sections. */
803 #if HAVE_LD_COMPRESS_DEBUG < 2
804 /* Reject if the linker cannot write compressed debug sections. */
805 #define ASM_COMPRESS_DEBUG_SPEC \
806 " %{gz*:%e-gz is not supported in this configuration} "
807 #else /* HAVE_LD_COMPRESS_DEBUG >= 2 */
808 #if HAVE_AS_COMPRESS_DEBUG == 0
809 /* No assembler support. Ignore silently. */
810 #define ASM_COMPRESS_DEBUG_SPEC \
811 " %{gz*:} "
812 #elif HAVE_AS_COMPRESS_DEBUG == 1
813 /* GNU style, GNU as options. */
814 #define ASM_COMPRESS_DEBUG_SPEC \
815 " %{gz|gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "}" \
816 " %{gz=none:" AS_NO_COMPRESS_DEBUG_OPTION "}" \
817 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
818 #elif HAVE_AS_COMPRESS_DEBUG == 2
819 /* ELF gABI style. */
820 #define ASM_COMPRESS_DEBUG_SPEC \
821 " %{gz|gz=zlib:" AS_COMPRESS_DEBUG_OPTION "=zlib}" \
822 " %{gz=none:" AS_COMPRESS_DEBUG_OPTION "=none}" \
823 " %{gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
824 #else
825 #error Unknown value for HAVE_AS_COMPRESS_DEBUG.
826 #endif
827 #endif /* HAVE_LD_COMPRESS_DEBUG >= 2 */
829 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
830 to the assembler. */
831 #ifndef ASM_DEBUG_SPEC
832 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
833 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
834 # define ASM_DEBUG_SPEC \
835 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
836 ? "%{!g0:%{gdwarf*:--gdwarf2}%{!gdwarf*:%{g*:--gstabs}}}" ASM_MAP \
837 : "%{!g0:%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
838 # else
839 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
840 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gstabs}}" ASM_MAP
841 # endif
842 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
843 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gdwarf2}}" ASM_MAP
844 # endif
845 # endif
846 #endif
847 #ifndef ASM_DEBUG_SPEC
848 # define ASM_DEBUG_SPEC ""
849 #endif
851 /* Here is the spec for running the linker, after compiling all files. */
853 /* This is overridable by the target in case they need to specify the
854 -lgcc and -lc order specially, yet not require them to override all
855 of LINK_COMMAND_SPEC. */
856 #ifndef LINK_GCC_C_SEQUENCE_SPEC
857 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
858 #endif
860 #ifndef LINK_SSP_SPEC
861 #ifdef TARGET_LIBC_PROVIDES_SSP
862 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
863 "|fstack-protector-strong|fstack-protector-explicit:}"
864 #else
865 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
866 "|fstack-protector-strong|fstack-protector-explicit" \
867 ":-lssp_nonshared -lssp}"
868 #endif
869 #endif
871 #ifdef ENABLE_DEFAULT_PIE
872 #define NO_PIE_SPEC "no-pie|static"
873 #define PIE_SPEC NO_PIE_SPEC "|r|shared:;"
874 #define NO_FPIE1_SPEC "fno-pie"
875 #define FPIE1_SPEC NO_FPIE1_SPEC ":;"
876 #define NO_FPIE2_SPEC "fno-PIE"
877 #define FPIE2_SPEC NO_FPIE2_SPEC ":;"
878 #define NO_FPIE_SPEC NO_FPIE1_SPEC "|" NO_FPIE2_SPEC
879 #define FPIE_SPEC NO_FPIE_SPEC ":;"
880 #define NO_FPIC1_SPEC "fno-pic"
881 #define FPIC1_SPEC NO_FPIC1_SPEC ":;"
882 #define NO_FPIC2_SPEC "fno-PIC"
883 #define FPIC2_SPEC NO_FPIC2_SPEC ":;"
884 #define NO_FPIC_SPEC NO_FPIC1_SPEC "|" NO_FPIC2_SPEC
885 #define FPIC_SPEC NO_FPIC_SPEC ":;"
886 #define NO_FPIE1_AND_FPIC1_SPEC NO_FPIE1_SPEC "|" NO_FPIC1_SPEC
887 #define FPIE1_OR_FPIC1_SPEC NO_FPIE1_AND_FPIC1_SPEC ":;"
888 #define NO_FPIE2_AND_FPIC2_SPEC NO_FPIE2_SPEC "|" NO_FPIC2_SPEC
889 #define FPIE2_OR_FPIC2_SPEC NO_FPIE2_AND_FPIC2_SPEC ":;"
890 #define NO_FPIE_AND_FPIC_SPEC NO_FPIE_SPEC "|" NO_FPIC_SPEC
891 #define FPIE_OR_FPIC_SPEC NO_FPIE_AND_FPIC_SPEC ":;"
892 #else
893 #define PIE_SPEC "pie"
894 #define NO_PIE_SPEC PIE_SPEC "|r|shared:;"
895 #define FPIE1_SPEC "fpie"
896 #define NO_FPIE1_SPEC FPIE1_SPEC ":;"
897 #define FPIE2_SPEC "fPIE"
898 #define NO_FPIE2_SPEC FPIE2_SPEC ":;"
899 #define FPIE_SPEC FPIE1_SPEC "|" FPIE2_SPEC
900 #define NO_FPIE_SPEC FPIE_SPEC ":;"
901 #define FPIC1_SPEC "fpic"
902 #define NO_FPIC1_SPEC FPIC1_SPEC ":;"
903 #define FPIC2_SPEC "fPIC"
904 #define NO_FPIC2_SPEC FPIC2_SPEC ":;"
905 #define FPIC_SPEC FPIC1_SPEC "|" FPIC2_SPEC
906 #define NO_FPIC_SPEC FPIC_SPEC ":;"
907 #define FPIE1_OR_FPIC1_SPEC FPIE1_SPEC "|" FPIC1_SPEC
908 #define NO_FPIE1_AND_FPIC1_SPEC FPIE1_OR_FPIC1_SPEC ":;"
909 #define FPIE2_OR_FPIC2_SPEC FPIE2_SPEC "|" FPIC2_SPEC
910 #define NO_FPIE2_AND_FPIC2_SPEC FPIE1_OR_FPIC2_SPEC ":;"
911 #define FPIE_OR_FPIC_SPEC FPIE_SPEC "|" FPIC_SPEC
912 #define NO_FPIE_AND_FPIC_SPEC FPIE_OR_FPIC_SPEC ":;"
913 #endif
915 #ifndef LINK_PIE_SPEC
916 #ifdef HAVE_LD_PIE
917 #ifndef LD_PIE_SPEC
918 #define LD_PIE_SPEC "-pie"
919 #endif
920 #else
921 #define LD_PIE_SPEC ""
922 #endif
923 #define LINK_PIE_SPEC "%{no-pie:} " "%{" PIE_SPEC ":" LD_PIE_SPEC "} "
924 #endif
926 #ifndef LINK_BUILDID_SPEC
927 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
928 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
929 # endif
930 #endif
932 /* Conditional to test whether the LTO plugin is used or not.
933 FIXME: For slim LTO we will need to enable plugin unconditionally. This
934 still cause problems with PLUGIN_LD != LD and when plugin is built but
935 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
936 plugin only when LTO is enabled. We still honor explicit
937 -fuse-linker-plugin if the linker used understands -plugin. */
939 /* The linker has some plugin support. */
940 #if HAVE_LTO_PLUGIN > 0
941 /* The linker used has full plugin support, use LTO plugin by default. */
942 #if HAVE_LTO_PLUGIN == 2
943 #define PLUGIN_COND "!fno-use-linker-plugin:%{!fno-lto"
944 #define PLUGIN_COND_CLOSE "}"
945 #else
946 /* The linker used has limited plugin support, use LTO plugin with explicit
947 -fuse-linker-plugin. */
948 #define PLUGIN_COND "fuse-linker-plugin"
949 #define PLUGIN_COND_CLOSE ""
950 #endif
951 #define LINK_PLUGIN_SPEC \
952 "%{" PLUGIN_COND": \
953 -plugin %(linker_plugin_file) \
954 -plugin-opt=%(lto_wrapper) \
955 -plugin-opt=-fresolution=%u.res \
956 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
957 }" PLUGIN_COND_CLOSE
958 #else
959 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
960 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
961 %e-fuse-linker-plugin is not supported in this configuration}"
962 #endif
964 /* Linker command line options for -fsanitize= early on the command line. */
965 #ifndef SANITIZER_EARLY_SPEC
966 #define SANITIZER_EARLY_SPEC "\
967 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_EARLY_SPEC "} \
968 %{%:sanitize(thread):" LIBTSAN_EARLY_SPEC "} \
969 %{%:sanitize(leak):" LIBLSAN_EARLY_SPEC "}}}"
970 #endif
972 /* Linker command line options for -fsanitize= late on the command line. */
973 #ifndef SANITIZER_SPEC
974 #define SANITIZER_SPEC "\
975 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_SPEC "\
976 %{static:%ecannot specify -static with -fsanitize=address}}\
977 %{%:sanitize(thread):" LIBTSAN_SPEC "\
978 %{static:%ecannot specify -static with -fsanitize=thread}}\
979 %{%:sanitize(undefined):" LIBUBSAN_SPEC "}\
980 %{%:sanitize(leak):" LIBLSAN_SPEC "}}}"
981 #endif
983 #ifndef POST_LINK_SPEC
984 #define POST_LINK_SPEC ""
985 #endif
987 /* This is the spec to use, once the code for creating the vtable
988 verification runtime library, libvtv.so, has been created. Currently
989 the vtable verification runtime functions are in libstdc++, so we use
990 the spec just below this one. */
991 #ifndef VTABLE_VERIFICATION_SPEC
992 #if ENABLE_VTABLE_VERIFY
993 #define VTABLE_VERIFICATION_SPEC "\
994 %{!nostdlib:%{fvtable-verify=std: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}\
995 %{fvtable-verify=preinit: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}}"
996 #else
997 #define VTABLE_VERIFICATION_SPEC "\
998 %{fvtable-verify=none:} \
999 %{fvtable-verify=std: \
1000 %e-fvtable-verify=std is not supported in this configuration} \
1001 %{fvtable-verify=preinit: \
1002 %e-fvtable-verify=preinit is not supported in this configuration}"
1003 #endif
1004 #endif
1006 #ifndef CHKP_SPEC
1007 #define CHKP_SPEC ""
1008 #endif
1010 /* -u* was put back because both BSD and SysV seem to support it. */
1011 /* %{static:} simply prevents an error message if the target machine
1012 doesn't handle -static. */
1013 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
1014 scripts which exist in user specified directories, or in standard
1015 directories. */
1016 /* We pass any -flto flags on to the linker, which is expected
1017 to understand them. In practice, this means it had better be collect2. */
1018 /* %{e*} includes -export-dynamic; see comment in common.opt. */
1019 #ifndef LINK_COMMAND_SPEC
1020 #define LINK_COMMAND_SPEC "\
1021 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
1022 %(linker) " \
1023 LINK_PLUGIN_SPEC \
1024 "%{flto|flto=*:%<fcompare-debug*} \
1025 %{flto} %{fno-lto} %{flto=*} %l " LINK_PIE_SPEC \
1026 "%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
1027 "%X %{o*} %{e*} %{N} %{n} %{r}\
1028 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}} \
1029 %{static:} %{L*} %(mfwrap) %(link_libgcc) " \
1030 VTABLE_VERIFICATION_SPEC " " SANITIZER_EARLY_SPEC " %o " CHKP_SPEC " \
1031 %{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1):\
1032 %:include(libgomp.spec)%(link_gomp)}\
1033 %{fcilkplus:%:include(libcilkrts.spec)%(link_cilkrts)}\
1034 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
1035 %(mflib) " STACK_SPLIT_SPEC "\
1036 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
1037 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
1038 %{!nostdlib:%{!nostartfiles:%E}} %{T*} \n%(post_link) }}}}}}"
1039 #endif
1041 #ifndef LINK_LIBGCC_SPEC
1042 /* Generate -L options for startfile prefix list. */
1043 # define LINK_LIBGCC_SPEC "%D"
1044 #endif
1046 #ifndef STARTFILE_PREFIX_SPEC
1047 # define STARTFILE_PREFIX_SPEC ""
1048 #endif
1050 #ifndef SYSROOT_SPEC
1051 # define SYSROOT_SPEC "--sysroot=%R"
1052 #endif
1054 #ifndef SYSROOT_SUFFIX_SPEC
1055 # define SYSROOT_SUFFIX_SPEC ""
1056 #endif
1058 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
1059 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
1060 #endif
1062 static const char *asm_debug = ASM_DEBUG_SPEC;
1063 static const char *cpp_spec = CPP_SPEC;
1064 static const char *cc1_spec = CC1_SPEC;
1065 static const char *cc1plus_spec = CC1PLUS_SPEC;
1066 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
1067 static const char *link_ssp_spec = LINK_SSP_SPEC;
1068 static const char *asm_spec = ASM_SPEC;
1069 static const char *asm_final_spec = ASM_FINAL_SPEC;
1070 static const char *link_spec = LINK_SPEC;
1071 static const char *lib_spec = LIB_SPEC;
1072 static const char *link_gomp_spec = "";
1073 static const char *libgcc_spec = LIBGCC_SPEC;
1074 static const char *endfile_spec = ENDFILE_SPEC;
1075 static const char *startfile_spec = STARTFILE_SPEC;
1076 static const char *linker_name_spec = LINKER_NAME;
1077 static const char *linker_plugin_file_spec = "";
1078 static const char *lto_wrapper_spec = "";
1079 static const char *lto_gcc_spec = "";
1080 static const char *post_link_spec = POST_LINK_SPEC;
1081 static const char *link_command_spec = LINK_COMMAND_SPEC;
1082 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
1083 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
1084 static const char *sysroot_spec = SYSROOT_SPEC;
1085 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
1086 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
1087 static const char *self_spec = "";
1089 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
1090 There should be no need to override these in target dependent files,
1091 but we need to copy them to the specs file so that newer versions
1092 of the GCC driver can correctly drive older tool chains with the
1093 appropriate -B options. */
1095 /* When cpplib handles traditional preprocessing, get rid of this, and
1096 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
1097 that we default the front end language better. */
1098 static const char *trad_capable_cpp =
1099 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
1101 /* We don't wrap .d files in %W{} since a missing .d file, and
1102 therefore no dependency entry, confuses make into thinking a .o
1103 file that happens to exist is up-to-date. */
1104 static const char *cpp_unique_options =
1105 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
1106 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
1107 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
1108 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
1109 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
1110 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
1111 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1112 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
1113 %{E|M|MM:%W{o*}}";
1115 /* This contains cpp options which are common with cc1_options and are passed
1116 only when preprocessing only to avoid duplication. We pass the cc1 spec
1117 options to the preprocessor so that it the cc1 spec may manipulate
1118 options used to set target flags. Those special target flags settings may
1119 in turn cause preprocessor symbols to be defined specially. */
1120 static const char *cpp_options =
1121 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
1122 %{f*} %{g*:%{!g0:%{g*} %{!fno-working-directory:-fworking-directory}}} %{O*}\
1123 %{undef} %{save-temps*:-fpch-preprocess}";
1125 /* This contains cpp options which are not passed when the preprocessor
1126 output will be used by another program. */
1127 static const char *cpp_debug_options = "%{d*}";
1129 /* NB: This is shared amongst all front-ends, except for Ada. */
1130 static const char *cc1_options =
1131 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
1132 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1133 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
1134 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
1135 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
1136 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
1137 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
1138 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
1139 %{-target-help:--target-help}\
1140 %{-version:--version}\
1141 %{-help=*:--help=%*}\
1142 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
1143 %{fsyntax-only:-o %j} %{-param*}\
1144 %{coverage:-fprofile-arcs -ftest-coverage}\
1145 %{fprofile-arcs|fprofile-generate*|coverage:\
1146 %{!fprofile-update=single:\
1147 %{pthread:-fprofile-update=prefer-atomic}}}";
1149 static const char *asm_options =
1150 "%{-target-help:%:print-asm-header()} "
1151 #if HAVE_GNU_AS
1152 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
1153 to the assembler equivalents. */
1154 "%{v} %{w:-W} %{I*} "
1155 #endif
1156 ASM_COMPRESS_DEBUG_SPEC
1157 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
1159 static const char *invoke_as =
1160 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1161 "%{!fwpa*:\
1162 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1163 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
1165 #else
1166 "%{!fwpa*:\
1167 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1168 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
1170 #endif
1172 /* Some compilers have limits on line lengths, and the multilib_select
1173 and/or multilib_matches strings can be very long, so we build them at
1174 run time. */
1175 static struct obstack multilib_obstack;
1176 static const char *multilib_select;
1177 static const char *multilib_matches;
1178 static const char *multilib_defaults;
1179 static const char *multilib_exclusions;
1180 static const char *multilib_reuse;
1182 /* Check whether a particular argument is a default argument. */
1184 #ifndef MULTILIB_DEFAULTS
1185 #define MULTILIB_DEFAULTS { "" }
1186 #endif
1188 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
1190 #ifndef DRIVER_SELF_SPECS
1191 #define DRIVER_SELF_SPECS ""
1192 #endif
1194 /* Linking to libgomp implies pthreads. This is particularly important
1195 for targets that use different start files and suchlike. */
1196 #ifndef GOMP_SELF_SPECS
1197 #define GOMP_SELF_SPECS \
1198 "%{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1): " \
1199 "-pthread}"
1200 #endif
1202 /* Likewise for -fgnu-tm. */
1203 #ifndef GTM_SELF_SPECS
1204 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
1205 #endif
1207 /* Likewise for -fcilkplus. */
1208 #ifndef CILK_SELF_SPECS
1209 #define CILK_SELF_SPECS "%{fcilkplus: -pthread}"
1210 #endif
1212 static const char *const driver_self_specs[] = {
1213 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
1214 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS,
1215 CILK_SELF_SPECS
1218 #ifndef OPTION_DEFAULT_SPECS
1219 #define OPTION_DEFAULT_SPECS { "", "" }
1220 #endif
1222 struct default_spec
1224 const char *name;
1225 const char *spec;
1228 static const struct default_spec
1229 option_default_specs[] = { OPTION_DEFAULT_SPECS };
1231 struct user_specs
1233 struct user_specs *next;
1234 const char *filename;
1237 static struct user_specs *user_specs_head, *user_specs_tail;
1240 /* Record the mapping from file suffixes for compilation specs. */
1242 struct compiler
1244 const char *suffix; /* Use this compiler for input files
1245 whose names end in this suffix. */
1247 const char *spec; /* To use this compiler, run this spec. */
1249 const char *cpp_spec; /* If non-NULL, substitute this spec
1250 for `%C', rather than the usual
1251 cpp_spec. */
1252 const int combinable; /* If nonzero, compiler can deal with
1253 multiple source files at once (IMA). */
1254 const int needs_preprocessing; /* If nonzero, source files need to
1255 be run through a preprocessor. */
1258 /* Pointer to a vector of `struct compiler' that gives the spec for
1259 compiling a file, based on its suffix.
1260 A file that does not end in any of these suffixes will be passed
1261 unchanged to the loader and nothing else will be done to it.
1263 An entry containing two 0s is used to terminate the vector.
1265 If multiple entries match a file, the last matching one is used. */
1267 static struct compiler *compilers;
1269 /* Number of entries in `compilers', not counting the null terminator. */
1271 static int n_compilers;
1273 /* The default list of file name suffixes and their compilation specs. */
1275 static const struct compiler default_compilers[] =
1277 /* Add lists of suffixes of known languages here. If those languages
1278 were not present when we built the driver, we will hit these copies
1279 and be given a more meaningful error than "file not used since
1280 linking is not done". */
1281 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
1282 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
1283 {".mii", "#Objective-C++", 0, 0, 0},
1284 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
1285 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
1286 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
1287 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
1288 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
1289 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
1290 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
1291 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
1292 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
1293 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
1294 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
1295 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1296 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1297 {".r", "#Ratfor", 0, 0, 0},
1298 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
1299 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
1300 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
1301 {".go", "#Go", 0, 1, 0},
1302 /* Next come the entries for C. */
1303 {".c", "@c", 0, 0, 1},
1304 {"@c",
1305 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1306 external preprocessor if -save-temps is given. */
1307 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1308 %{!E:%{!M:%{!MM:\
1309 %{traditional:\
1310 %eGNU C no longer supports -traditional without -E}\
1311 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1312 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1313 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1314 %(cc1_options)}\
1315 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1316 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1317 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1318 {"-",
1319 "%{!E:%e-E or -x required when input is from standard input}\
1320 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1321 {".h", "@c-header", 0, 0, 0},
1322 {"@c-header",
1323 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1324 external preprocessor if -save-temps is given. */
1325 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1326 %{!E:%{!M:%{!MM:\
1327 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1328 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1329 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1330 %(cc1_options)\
1331 %{!fsyntax-only:-o %g.s \
1332 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1333 %W{o*:--output-pch=%*}}%V}}\
1334 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1335 cc1 %(cpp_unique_options) %(cc1_options)\
1336 %{!fsyntax-only:%{!S:-o %g.s} \
1337 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1338 %W{o*:--output-pch=%*}}%V}}}}}}}", 0, 0, 0},
1339 {".i", "@cpp-output", 0, 0, 0},
1340 {"@cpp-output",
1341 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1342 {".s", "@assembler", 0, 0, 0},
1343 {"@assembler",
1344 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1345 {".sx", "@assembler-with-cpp", 0, 0, 0},
1346 {".S", "@assembler-with-cpp", 0, 0, 0},
1347 {"@assembler-with-cpp",
1348 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1349 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1350 %{E|M|MM:%(cpp_debug_options)}\
1351 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1352 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1353 #else
1354 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1355 %{E|M|MM:%(cpp_debug_options)}\
1356 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1357 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1358 #endif
1359 , 0, 0, 0},
1361 #include "specs.h"
1362 /* Mark end of table. */
1363 {0, 0, 0, 0, 0}
1366 /* Number of elements in default_compilers, not counting the terminator. */
1368 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1370 typedef char *char_p; /* For DEF_VEC_P. */
1372 /* A vector of options to give to the linker.
1373 These options are accumulated by %x,
1374 and substituted into the linker command with %X. */
1375 static vec<char_p> linker_options;
1377 /* A vector of options to give to the assembler.
1378 These options are accumulated by -Wa,
1379 and substituted into the assembler command with %Y. */
1380 static vec<char_p> assembler_options;
1382 /* A vector of options to give to the preprocessor.
1383 These options are accumulated by -Wp,
1384 and substituted into the preprocessor command with %Z. */
1385 static vec<char_p> preprocessor_options;
1387 static char *
1388 skip_whitespace (char *p)
1390 while (1)
1392 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1393 be considered whitespace. */
1394 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1395 return p + 1;
1396 else if (*p == '\n' || *p == ' ' || *p == '\t')
1397 p++;
1398 else if (*p == '#')
1400 while (*p != '\n')
1401 p++;
1402 p++;
1404 else
1405 break;
1408 return p;
1410 /* Structures to keep track of prefixes to try when looking for files. */
1412 struct prefix_list
1414 const char *prefix; /* String to prepend to the path. */
1415 struct prefix_list *next; /* Next in linked list. */
1416 int require_machine_suffix; /* Don't use without machine_suffix. */
1417 /* 2 means try both machine_suffix and just_machine_suffix. */
1418 int priority; /* Sort key - priority within list. */
1419 int os_multilib; /* 1 if OS multilib scheme should be used,
1420 0 for GCC multilib scheme. */
1423 struct path_prefix
1425 struct prefix_list *plist; /* List of prefixes to try */
1426 int max_len; /* Max length of a prefix in PLIST */
1427 const char *name; /* Name of this list (used in config stuff) */
1430 /* List of prefixes to try when looking for executables. */
1432 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1434 /* List of prefixes to try when looking for startup (crt0) files. */
1436 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1438 /* List of prefixes to try when looking for include files. */
1440 static struct path_prefix include_prefixes = { 0, 0, "include" };
1442 /* Suffix to attach to directories searched for commands.
1443 This looks like `MACHINE/VERSION/'. */
1445 static const char *machine_suffix = 0;
1447 /* Suffix to attach to directories searched for commands.
1448 This is just `MACHINE/'. */
1450 static const char *just_machine_suffix = 0;
1452 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1454 static const char *gcc_exec_prefix;
1456 /* Adjusted value of standard_libexec_prefix. */
1458 static const char *gcc_libexec_prefix;
1460 /* Default prefixes to attach to command names. */
1462 #ifndef STANDARD_STARTFILE_PREFIX_1
1463 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1464 #endif
1465 #ifndef STANDARD_STARTFILE_PREFIX_2
1466 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1467 #endif
1469 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1470 #undef MD_EXEC_PREFIX
1471 #undef MD_STARTFILE_PREFIX
1472 #undef MD_STARTFILE_PREFIX_1
1473 #endif
1475 /* If no prefixes defined, use the null string, which will disable them. */
1476 #ifndef MD_EXEC_PREFIX
1477 #define MD_EXEC_PREFIX ""
1478 #endif
1479 #ifndef MD_STARTFILE_PREFIX
1480 #define MD_STARTFILE_PREFIX ""
1481 #endif
1482 #ifndef MD_STARTFILE_PREFIX_1
1483 #define MD_STARTFILE_PREFIX_1 ""
1484 #endif
1486 /* These directories are locations set at configure-time based on the
1487 --prefix option provided to configure. Their initializers are
1488 defined in Makefile.in. These paths are not *directly* used when
1489 gcc_exec_prefix is set because, in that case, we know where the
1490 compiler has been installed, and use paths relative to that
1491 location instead. */
1492 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1493 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1494 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1495 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1497 /* For native compilers, these are well-known paths containing
1498 components that may be provided by the system. For cross
1499 compilers, these paths are not used. */
1500 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1501 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1502 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1503 static const char *const standard_startfile_prefix_1
1504 = STANDARD_STARTFILE_PREFIX_1;
1505 static const char *const standard_startfile_prefix_2
1506 = STANDARD_STARTFILE_PREFIX_2;
1508 /* A relative path to be used in finding the location of tools
1509 relative to the driver. */
1510 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1512 /* A prefix to be used when this is an accelerator compiler. */
1513 static const char *const accel_dir_suffix = ACCEL_DIR_SUFFIX;
1515 /* Subdirectory to use for locating libraries. Set by
1516 set_multilib_dir based on the compilation options. */
1518 static const char *multilib_dir;
1520 /* Subdirectory to use for locating libraries in OS conventions. Set by
1521 set_multilib_dir based on the compilation options. */
1523 static const char *multilib_os_dir;
1525 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1526 set_multilib_dir based on the compilation options. */
1528 static const char *multiarch_dir;
1530 /* Structure to keep track of the specs that have been defined so far.
1531 These are accessed using %(specname) in a compiler or link
1532 spec. */
1534 struct spec_list
1536 /* The following 2 fields must be first */
1537 /* to allow EXTRA_SPECS to be initialized */
1538 const char *name; /* name of the spec. */
1539 const char *ptr; /* available ptr if no static pointer */
1541 /* The following fields are not initialized */
1542 /* by EXTRA_SPECS */
1543 const char **ptr_spec; /* pointer to the spec itself. */
1544 struct spec_list *next; /* Next spec in linked list. */
1545 int name_len; /* length of the name */
1546 bool user_p; /* whether string come from file spec. */
1547 bool alloc_p; /* whether string was allocated */
1548 const char *default_ptr; /* The default value of *ptr_spec. */
1551 #define INIT_STATIC_SPEC(NAME,PTR) \
1552 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false, \
1553 *PTR }
1555 /* List of statically defined specs. */
1556 static struct spec_list static_specs[] =
1558 INIT_STATIC_SPEC ("asm", &asm_spec),
1559 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1560 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1561 INIT_STATIC_SPEC ("asm_options", &asm_options),
1562 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1563 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1564 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1565 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1566 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1567 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1568 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1569 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1570 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1571 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1572 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1573 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1574 INIT_STATIC_SPEC ("link", &link_spec),
1575 INIT_STATIC_SPEC ("lib", &lib_spec),
1576 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1577 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1578 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1579 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1580 INIT_STATIC_SPEC ("version", &compiler_version),
1581 INIT_STATIC_SPEC ("multilib", &multilib_select),
1582 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1583 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1584 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1585 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1586 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1587 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1588 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1589 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1590 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1591 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1592 INIT_STATIC_SPEC ("post_link", &post_link_spec),
1593 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1594 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1595 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1596 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1597 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1598 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1599 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1600 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1601 INIT_STATIC_SPEC ("self_spec", &self_spec),
1604 #ifdef EXTRA_SPECS /* additional specs needed */
1605 /* Structure to keep track of just the first two args of a spec_list.
1606 That is all that the EXTRA_SPECS macro gives us. */
1607 struct spec_list_1
1609 const char *const name;
1610 const char *const ptr;
1613 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1614 static struct spec_list *extra_specs = (struct spec_list *) 0;
1615 #endif
1617 /* List of dynamically allocates specs that have been defined so far. */
1619 static struct spec_list *specs = (struct spec_list *) 0;
1621 /* List of static spec functions. */
1623 static const struct spec_function static_spec_functions[] =
1625 { "getenv", getenv_spec_function },
1626 { "if-exists", if_exists_spec_function },
1627 { "if-exists-else", if_exists_else_spec_function },
1628 { "sanitize", sanitize_spec_function },
1629 { "replace-outfile", replace_outfile_spec_function },
1630 { "remove-outfile", remove_outfile_spec_function },
1631 { "version-compare", version_compare_spec_function },
1632 { "include", include_spec_function },
1633 { "find-file", find_file_spec_function },
1634 { "find-plugindir", find_plugindir_spec_function },
1635 { "print-asm-header", print_asm_header_spec_function },
1636 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1637 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1638 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1639 { "pass-through-libs", pass_through_libs_spec_func },
1640 { "replace-extension", replace_extension_spec_func },
1641 { "gt", greater_than_spec_func },
1642 #ifdef EXTRA_SPEC_FUNCTIONS
1643 EXTRA_SPEC_FUNCTIONS
1644 #endif
1645 { 0, 0 }
1648 static int processing_spec_function;
1650 /* Add appropriate libgcc specs to OBSTACK, taking into account
1651 various permutations of -shared-libgcc, -shared, and such. */
1653 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1655 #ifndef USE_LD_AS_NEEDED
1656 #define USE_LD_AS_NEEDED 0
1657 #endif
1659 static void
1660 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1661 const char *static_name, const char *eh_name)
1663 char *buf;
1665 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1666 "%{!static:%{!static-libgcc:"
1667 #if USE_LD_AS_NEEDED
1668 "%{!shared-libgcc:",
1669 static_name, " " LD_AS_NEEDED_OPTION " ",
1670 shared_name, " " LD_NO_AS_NEEDED_OPTION
1672 "%{shared-libgcc:",
1673 shared_name, "%{!shared: ", static_name, "}"
1675 #else
1676 "%{!shared:"
1677 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1678 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1680 #ifdef LINK_EH_SPEC
1681 "%{shared:"
1682 "%{shared-libgcc:", shared_name, "}"
1683 "%{!shared-libgcc:", static_name, "}"
1685 #else
1686 "%{shared:", shared_name, "}"
1687 #endif
1688 #endif
1689 "}}", NULL);
1691 obstack_grow (obstack, buf, strlen (buf));
1692 free (buf);
1694 #endif /* ENABLE_SHARED_LIBGCC */
1696 /* Initialize the specs lookup routines. */
1698 static void
1699 init_spec (void)
1701 struct spec_list *next = (struct spec_list *) 0;
1702 struct spec_list *sl = (struct spec_list *) 0;
1703 int i;
1705 if (specs)
1706 return; /* Already initialized. */
1708 if (verbose_flag)
1709 fnotice (stderr, "Using built-in specs.\n");
1711 #ifdef EXTRA_SPECS
1712 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1714 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1716 sl = &extra_specs[i];
1717 sl->name = extra_specs_1[i].name;
1718 sl->ptr = extra_specs_1[i].ptr;
1719 sl->next = next;
1720 sl->name_len = strlen (sl->name);
1721 sl->ptr_spec = &sl->ptr;
1722 gcc_assert (sl->ptr_spec != NULL);
1723 sl->default_ptr = sl->ptr;
1724 next = sl;
1726 #endif
1728 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1730 sl = &static_specs[i];
1731 sl->next = next;
1732 next = sl;
1735 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1736 /* ??? If neither -shared-libgcc nor --static-libgcc was
1737 seen, then we should be making an educated guess. Some proposed
1738 heuristics for ELF include:
1740 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1741 program will be doing dynamic loading, which will likely
1742 need the shared libgcc.
1744 (2) If "-ldl", then it's also a fair bet that we're doing
1745 dynamic loading.
1747 (3) For each ET_DYN we're linking against (either through -lfoo
1748 or /some/path/foo.so), check to see whether it or one of
1749 its dependencies depends on a shared libgcc.
1751 (4) If "-shared"
1753 If the runtime is fixed to look for program headers instead
1754 of calling __register_frame_info at all, for each object,
1755 use the shared libgcc if any EH symbol referenced.
1757 If crtstuff is fixed to not invoke __register_frame_info
1758 automatically, for each object, use the shared libgcc if
1759 any non-empty unwind section found.
1761 Doing any of this probably requires invoking an external program to
1762 do the actual object file scanning. */
1764 const char *p = libgcc_spec;
1765 int in_sep = 1;
1767 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1768 when given the proper command line arguments. */
1769 while (*p)
1771 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1773 init_gcc_specs (&obstack,
1774 "-lgcc_s"
1775 #ifdef USE_LIBUNWIND_EXCEPTIONS
1776 " -lunwind"
1777 #endif
1779 "-lgcc",
1780 "-lgcc_eh"
1781 #ifdef USE_LIBUNWIND_EXCEPTIONS
1782 # ifdef HAVE_LD_STATIC_DYNAMIC
1783 " %{!static:" LD_STATIC_OPTION "} -lunwind"
1784 " %{!static:" LD_DYNAMIC_OPTION "}"
1785 # else
1786 " -lunwind"
1787 # endif
1788 #endif
1791 p += 5;
1792 in_sep = 0;
1794 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1796 /* Ug. We don't know shared library extensions. Hope that
1797 systems that use this form don't do shared libraries. */
1798 init_gcc_specs (&obstack,
1799 "-lgcc_s",
1800 "libgcc.a%s",
1801 "libgcc_eh.a%s"
1802 #ifdef USE_LIBUNWIND_EXCEPTIONS
1803 " -lunwind"
1804 #endif
1806 p += 10;
1807 in_sep = 0;
1809 else
1811 obstack_1grow (&obstack, *p);
1812 in_sep = (*p == ' ');
1813 p += 1;
1817 obstack_1grow (&obstack, '\0');
1818 libgcc_spec = XOBFINISH (&obstack, const char *);
1820 #endif
1821 #ifdef USE_AS_TRADITIONAL_FORMAT
1822 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1824 static const char tf[] = "--traditional-format ";
1825 obstack_grow (&obstack, tf, sizeof (tf) - 1);
1826 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1827 asm_spec = XOBFINISH (&obstack, const char *);
1829 #endif
1831 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1832 defined LINKER_HASH_STYLE
1833 # ifdef LINK_BUILDID_SPEC
1834 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1835 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof (LINK_BUILDID_SPEC) - 1);
1836 # endif
1837 # ifdef LINK_EH_SPEC
1838 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1839 obstack_grow (&obstack, LINK_EH_SPEC, sizeof (LINK_EH_SPEC) - 1);
1840 # endif
1841 # ifdef LINKER_HASH_STYLE
1842 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1843 before. */
1845 static const char hash_style[] = "--hash-style=";
1846 obstack_grow (&obstack, hash_style, sizeof (hash_style) - 1);
1847 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof (LINKER_HASH_STYLE) - 1);
1848 obstack_1grow (&obstack, ' ');
1850 # endif
1851 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1852 link_spec = XOBFINISH (&obstack, const char *);
1853 #endif
1855 specs = sl;
1858 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1859 removed; If the spec starts with a + then SPEC is added to the end of the
1860 current spec. */
1862 static void
1863 set_spec (const char *name, const char *spec, bool user_p)
1865 struct spec_list *sl;
1866 const char *old_spec;
1867 int name_len = strlen (name);
1868 int i;
1870 /* If this is the first call, initialize the statically allocated specs. */
1871 if (!specs)
1873 struct spec_list *next = (struct spec_list *) 0;
1874 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1876 sl = &static_specs[i];
1877 sl->next = next;
1878 next = sl;
1880 specs = sl;
1883 /* See if the spec already exists. */
1884 for (sl = specs; sl; sl = sl->next)
1885 if (name_len == sl->name_len && !strcmp (sl->name, name))
1886 break;
1888 if (!sl)
1890 /* Not found - make it. */
1891 sl = XNEW (struct spec_list);
1892 sl->name = xstrdup (name);
1893 sl->name_len = name_len;
1894 sl->ptr_spec = &sl->ptr;
1895 sl->alloc_p = 0;
1896 *(sl->ptr_spec) = "";
1897 sl->next = specs;
1898 sl->default_ptr = NULL;
1899 specs = sl;
1902 old_spec = *(sl->ptr_spec);
1903 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1904 ? concat (old_spec, spec + 1, NULL)
1905 : xstrdup (spec));
1907 #ifdef DEBUG_SPECS
1908 if (verbose_flag)
1909 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1910 #endif
1912 /* Free the old spec. */
1913 if (old_spec && sl->alloc_p)
1914 free (CONST_CAST (char *, old_spec));
1916 sl->user_p = user_p;
1917 sl->alloc_p = true;
1920 /* Accumulate a command (program name and args), and run it. */
1922 typedef const char *const_char_p; /* For DEF_VEC_P. */
1924 /* Vector of pointers to arguments in the current line of specifications. */
1926 static vec<const_char_p> argbuf;
1928 /* Were the options -c, -S or -E passed. */
1929 static int have_c = 0;
1931 /* Was the option -o passed. */
1932 static int have_o = 0;
1934 /* Pointer to output file name passed in with -o. */
1935 static const char *output_file = 0;
1937 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1938 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1939 it here. */
1941 static struct temp_name {
1942 const char *suffix; /* suffix associated with the code. */
1943 int length; /* strlen (suffix). */
1944 int unique; /* Indicates whether %g or %u/%U was used. */
1945 const char *filename; /* associated filename. */
1946 int filename_length; /* strlen (filename). */
1947 struct temp_name *next;
1948 } *temp_names;
1950 /* Number of commands executed so far. */
1952 static int execution_count;
1954 /* Number of commands that exited with a signal. */
1956 static int signal_count;
1958 /* Allocate the argument vector. */
1960 static void
1961 alloc_args (void)
1963 argbuf.create (10);
1966 /* Clear out the vector of arguments (after a command is executed). */
1968 static void
1969 clear_args (void)
1971 argbuf.truncate (0);
1974 /* Add one argument to the vector at the end.
1975 This is done when a space is seen or at the end of the line.
1976 If DELETE_ALWAYS is nonzero, the arg is a filename
1977 and the file should be deleted eventually.
1978 If DELETE_FAILURE is nonzero, the arg is a filename
1979 and the file should be deleted if this compilation fails. */
1981 static void
1982 store_arg (const char *arg, int delete_always, int delete_failure)
1984 argbuf.safe_push (arg);
1986 if (delete_always || delete_failure)
1988 const char *p;
1989 /* If the temporary file we should delete is specified as
1990 part of a joined argument extract the filename. */
1991 if (arg[0] == '-'
1992 && (p = strrchr (arg, '=')))
1993 arg = p + 1;
1994 record_temp_file (arg, delete_always, delete_failure);
1998 /* Load specs from a file name named FILENAME, replacing occurrences of
1999 various different types of line-endings, \r\n, \n\r and just \r, with
2000 a single \n. */
2002 static char *
2003 load_specs (const char *filename)
2005 int desc;
2006 int readlen;
2007 struct stat statbuf;
2008 char *buffer;
2009 char *buffer_p;
2010 char *specs;
2011 char *specs_p;
2013 if (verbose_flag)
2014 fnotice (stderr, "Reading specs from %s\n", filename);
2016 /* Open and stat the file. */
2017 desc = open (filename, O_RDONLY, 0);
2018 if (desc < 0)
2019 pfatal_with_name (filename);
2020 if (stat (filename, &statbuf) < 0)
2021 pfatal_with_name (filename);
2023 /* Read contents of file into BUFFER. */
2024 buffer = XNEWVEC (char, statbuf.st_size + 1);
2025 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
2026 if (readlen < 0)
2027 pfatal_with_name (filename);
2028 buffer[readlen] = 0;
2029 close (desc);
2031 specs = XNEWVEC (char, readlen + 1);
2032 specs_p = specs;
2033 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
2035 int skip = 0;
2036 char c = *buffer_p;
2037 if (c == '\r')
2039 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
2040 skip = 1;
2041 else if (*(buffer_p + 1) == '\n') /* \r\n */
2042 skip = 1;
2043 else /* \r */
2044 c = '\n';
2046 if (! skip)
2047 *specs_p++ = c;
2049 *specs_p = '\0';
2051 free (buffer);
2052 return (specs);
2055 /* Read compilation specs from a file named FILENAME,
2056 replacing the default ones.
2058 A suffix which starts with `*' is a definition for
2059 one of the machine-specific sub-specs. The "suffix" should be
2060 *asm, *cc1, *cpp, *link, *startfile, etc.
2061 The corresponding spec is stored in asm_spec, etc.,
2062 rather than in the `compilers' vector.
2064 Anything invalid in the file is a fatal error. */
2066 static void
2067 read_specs (const char *filename, bool main_p, bool user_p)
2069 char *buffer;
2070 char *p;
2072 buffer = load_specs (filename);
2074 /* Scan BUFFER for specs, putting them in the vector. */
2075 p = buffer;
2076 while (1)
2078 char *suffix;
2079 char *spec;
2080 char *in, *out, *p1, *p2, *p3;
2082 /* Advance P in BUFFER to the next nonblank nocomment line. */
2083 p = skip_whitespace (p);
2084 if (*p == 0)
2085 break;
2087 /* Is this a special command that starts with '%'? */
2088 /* Don't allow this for the main specs file, since it would
2089 encourage people to overwrite it. */
2090 if (*p == '%' && !main_p)
2092 p1 = p;
2093 while (*p && *p != '\n')
2094 p++;
2096 /* Skip '\n'. */
2097 p++;
2099 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
2100 && (p1[sizeof "%include" - 1] == ' '
2101 || p1[sizeof "%include" - 1] == '\t'))
2103 char *new_filename;
2105 p1 += sizeof ("%include");
2106 while (*p1 == ' ' || *p1 == '\t')
2107 p1++;
2109 if (*p1++ != '<' || p[-2] != '>')
2110 fatal_error (input_location,
2111 "specs %%include syntax malformed after "
2112 "%ld characters",
2113 (long) (p1 - buffer + 1));
2115 p[-2] = '\0';
2116 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2117 read_specs (new_filename ? new_filename : p1, false, user_p);
2118 continue;
2120 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
2121 && (p1[sizeof "%include_noerr" - 1] == ' '
2122 || p1[sizeof "%include_noerr" - 1] == '\t'))
2124 char *new_filename;
2126 p1 += sizeof "%include_noerr";
2127 while (*p1 == ' ' || *p1 == '\t')
2128 p1++;
2130 if (*p1++ != '<' || p[-2] != '>')
2131 fatal_error (input_location,
2132 "specs %%include syntax malformed after "
2133 "%ld characters",
2134 (long) (p1 - buffer + 1));
2136 p[-2] = '\0';
2137 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2138 if (new_filename)
2139 read_specs (new_filename, false, user_p);
2140 else if (verbose_flag)
2141 fnotice (stderr, "could not find specs file %s\n", p1);
2142 continue;
2144 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
2145 && (p1[sizeof "%rename" - 1] == ' '
2146 || p1[sizeof "%rename" - 1] == '\t'))
2148 int name_len;
2149 struct spec_list *sl;
2150 struct spec_list *newsl;
2152 /* Get original name. */
2153 p1 += sizeof "%rename";
2154 while (*p1 == ' ' || *p1 == '\t')
2155 p1++;
2157 if (! ISALPHA ((unsigned char) *p1))
2158 fatal_error (input_location,
2159 "specs %%rename syntax malformed after "
2160 "%ld characters",
2161 (long) (p1 - buffer));
2163 p2 = p1;
2164 while (*p2 && !ISSPACE ((unsigned char) *p2))
2165 p2++;
2167 if (*p2 != ' ' && *p2 != '\t')
2168 fatal_error (input_location,
2169 "specs %%rename syntax malformed after "
2170 "%ld characters",
2171 (long) (p2 - buffer));
2173 name_len = p2 - p1;
2174 *p2++ = '\0';
2175 while (*p2 == ' ' || *p2 == '\t')
2176 p2++;
2178 if (! ISALPHA ((unsigned char) *p2))
2179 fatal_error (input_location,
2180 "specs %%rename syntax malformed after "
2181 "%ld characters",
2182 (long) (p2 - buffer));
2184 /* Get new spec name. */
2185 p3 = p2;
2186 while (*p3 && !ISSPACE ((unsigned char) *p3))
2187 p3++;
2189 if (p3 != p - 1)
2190 fatal_error (input_location,
2191 "specs %%rename syntax malformed after "
2192 "%ld characters",
2193 (long) (p3 - buffer));
2194 *p3 = '\0';
2196 for (sl = specs; sl; sl = sl->next)
2197 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2198 break;
2200 if (!sl)
2201 fatal_error (input_location,
2202 "specs %s spec was not found to be renamed", p1);
2204 if (strcmp (p1, p2) == 0)
2205 continue;
2207 for (newsl = specs; newsl; newsl = newsl->next)
2208 if (strcmp (newsl->name, p2) == 0)
2209 fatal_error (input_location,
2210 "%s: attempt to rename spec %qs to "
2211 "already defined spec %qs",
2212 filename, p1, p2);
2214 if (verbose_flag)
2216 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
2217 #ifdef DEBUG_SPECS
2218 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
2219 #endif
2222 set_spec (p2, *(sl->ptr_spec), user_p);
2223 if (sl->alloc_p)
2224 free (CONST_CAST (char *, *(sl->ptr_spec)));
2226 *(sl->ptr_spec) = "";
2227 sl->alloc_p = 0;
2228 continue;
2230 else
2231 fatal_error (input_location,
2232 "specs unknown %% command after %ld characters",
2233 (long) (p1 - buffer));
2236 /* Find the colon that should end the suffix. */
2237 p1 = p;
2238 while (*p1 && *p1 != ':' && *p1 != '\n')
2239 p1++;
2241 /* The colon shouldn't be missing. */
2242 if (*p1 != ':')
2243 fatal_error (input_location,
2244 "specs file malformed after %ld characters",
2245 (long) (p1 - buffer));
2247 /* Skip back over trailing whitespace. */
2248 p2 = p1;
2249 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2250 p2--;
2252 /* Copy the suffix to a string. */
2253 suffix = save_string (p, p2 - p);
2254 /* Find the next line. */
2255 p = skip_whitespace (p1 + 1);
2256 if (p[1] == 0)
2257 fatal_error (input_location,
2258 "specs file malformed after %ld characters",
2259 (long) (p - buffer));
2261 p1 = p;
2262 /* Find next blank line or end of string. */
2263 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2264 p1++;
2266 /* Specs end at the blank line and do not include the newline. */
2267 spec = save_string (p, p1 - p);
2268 p = p1;
2270 /* Delete backslash-newline sequences from the spec. */
2271 in = spec;
2272 out = spec;
2273 while (*in != 0)
2275 if (in[0] == '\\' && in[1] == '\n')
2276 in += 2;
2277 else if (in[0] == '#')
2278 while (*in && *in != '\n')
2279 in++;
2281 else
2282 *out++ = *in++;
2284 *out = 0;
2286 if (suffix[0] == '*')
2288 if (! strcmp (suffix, "*link_command"))
2289 link_command_spec = spec;
2290 else
2292 set_spec (suffix + 1, spec, user_p);
2293 free (spec);
2296 else
2298 /* Add this pair to the vector. */
2299 compilers
2300 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
2302 compilers[n_compilers].suffix = suffix;
2303 compilers[n_compilers].spec = spec;
2304 n_compilers++;
2305 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2308 if (*suffix == 0)
2309 link_command_spec = spec;
2312 if (link_command_spec == 0)
2313 fatal_error (input_location, "spec file has no spec for linking");
2315 XDELETEVEC (buffer);
2318 /* Record the names of temporary files we tell compilers to write,
2319 and delete them at the end of the run. */
2321 /* This is the common prefix we use to make temp file names.
2322 It is chosen once for each run of this program.
2323 It is substituted into a spec by %g or %j.
2324 Thus, all temp file names contain this prefix.
2325 In practice, all temp file names start with this prefix.
2327 This prefix comes from the envvar TMPDIR if it is defined;
2328 otherwise, from the P_tmpdir macro if that is defined;
2329 otherwise, in /usr/tmp or /tmp;
2330 or finally the current directory if all else fails. */
2332 static const char *temp_filename;
2334 /* Length of the prefix. */
2336 static int temp_filename_length;
2338 /* Define the list of temporary files to delete. */
2340 struct temp_file
2342 const char *name;
2343 struct temp_file *next;
2346 /* Queue of files to delete on success or failure of compilation. */
2347 static struct temp_file *always_delete_queue;
2348 /* Queue of files to delete on failure of compilation. */
2349 static struct temp_file *failure_delete_queue;
2351 /* Record FILENAME as a file to be deleted automatically.
2352 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2353 otherwise delete it in any case.
2354 FAIL_DELETE nonzero means delete it if a compilation step fails;
2355 otherwise delete it in any case. */
2357 void
2358 record_temp_file (const char *filename, int always_delete, int fail_delete)
2360 char *const name = xstrdup (filename);
2362 if (always_delete)
2364 struct temp_file *temp;
2365 for (temp = always_delete_queue; temp; temp = temp->next)
2366 if (! filename_cmp (name, temp->name))
2368 free (name);
2369 goto already1;
2372 temp = XNEW (struct temp_file);
2373 temp->next = always_delete_queue;
2374 temp->name = name;
2375 always_delete_queue = temp;
2377 already1:;
2380 if (fail_delete)
2382 struct temp_file *temp;
2383 for (temp = failure_delete_queue; temp; temp = temp->next)
2384 if (! filename_cmp (name, temp->name))
2386 free (name);
2387 goto already2;
2390 temp = XNEW (struct temp_file);
2391 temp->next = failure_delete_queue;
2392 temp->name = name;
2393 failure_delete_queue = temp;
2395 already2:;
2399 /* Delete all the temporary files whose names we previously recorded. */
2401 #ifndef DELETE_IF_ORDINARY
2402 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2403 do \
2405 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2406 if (unlink (NAME) < 0) \
2407 if (VERBOSE_FLAG) \
2408 perror_with_name (NAME); \
2409 } while (0)
2410 #endif
2412 static void
2413 delete_if_ordinary (const char *name)
2415 struct stat st;
2416 #ifdef DEBUG
2417 int i, c;
2419 printf ("Delete %s? (y or n) ", name);
2420 fflush (stdout);
2421 i = getchar ();
2422 if (i != '\n')
2423 while ((c = getchar ()) != '\n' && c != EOF)
2426 if (i == 'y' || i == 'Y')
2427 #endif /* DEBUG */
2428 DELETE_IF_ORDINARY (name, st, verbose_flag);
2431 static void
2432 delete_temp_files (void)
2434 struct temp_file *temp;
2436 for (temp = always_delete_queue; temp; temp = temp->next)
2437 delete_if_ordinary (temp->name);
2438 always_delete_queue = 0;
2441 /* Delete all the files to be deleted on error. */
2443 static void
2444 delete_failure_queue (void)
2446 struct temp_file *temp;
2448 for (temp = failure_delete_queue; temp; temp = temp->next)
2449 delete_if_ordinary (temp->name);
2452 static void
2453 clear_failure_queue (void)
2455 failure_delete_queue = 0;
2458 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2459 returns non-NULL.
2460 If DO_MULTI is true iterate over the paths twice, first with multilib
2461 suffix then without, otherwise iterate over the paths once without
2462 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2463 to avoid visiting the same path twice, but we could do better. For
2464 instance, /usr/lib/../lib is considered different from /usr/lib.
2465 At least EXTRA_SPACE chars past the end of the path passed to
2466 CALLBACK are available for use by the callback.
2467 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2469 Returns the value returned by CALLBACK. */
2471 static void *
2472 for_each_path (const struct path_prefix *paths,
2473 bool do_multi,
2474 size_t extra_space,
2475 void *(*callback) (char *, void *),
2476 void *callback_info)
2478 struct prefix_list *pl;
2479 const char *multi_dir = NULL;
2480 const char *multi_os_dir = NULL;
2481 const char *multiarch_suffix = NULL;
2482 const char *multi_suffix;
2483 const char *just_multi_suffix;
2484 char *path = NULL;
2485 void *ret = NULL;
2486 bool skip_multi_dir = false;
2487 bool skip_multi_os_dir = false;
2489 multi_suffix = machine_suffix;
2490 just_multi_suffix = just_machine_suffix;
2491 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2493 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2494 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2495 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2497 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2498 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2499 if (multiarch_dir)
2500 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2502 while (1)
2504 size_t multi_dir_len = 0;
2505 size_t multi_os_dir_len = 0;
2506 size_t multiarch_len = 0;
2507 size_t suffix_len;
2508 size_t just_suffix_len;
2509 size_t len;
2511 if (multi_dir)
2512 multi_dir_len = strlen (multi_dir);
2513 if (multi_os_dir)
2514 multi_os_dir_len = strlen (multi_os_dir);
2515 if (multiarch_suffix)
2516 multiarch_len = strlen (multiarch_suffix);
2517 suffix_len = strlen (multi_suffix);
2518 just_suffix_len = strlen (just_multi_suffix);
2520 if (path == NULL)
2522 len = paths->max_len + extra_space + 1;
2523 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2524 path = XNEWVEC (char, len);
2527 for (pl = paths->plist; pl != 0; pl = pl->next)
2529 len = strlen (pl->prefix);
2530 memcpy (path, pl->prefix, len);
2532 /* Look first in MACHINE/VERSION subdirectory. */
2533 if (!skip_multi_dir)
2535 memcpy (path + len, multi_suffix, suffix_len + 1);
2536 ret = callback (path, callback_info);
2537 if (ret)
2538 break;
2541 /* Some paths are tried with just the machine (ie. target)
2542 subdir. This is used for finding as, ld, etc. */
2543 if (!skip_multi_dir
2544 && pl->require_machine_suffix == 2)
2546 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2547 ret = callback (path, callback_info);
2548 if (ret)
2549 break;
2552 /* Now try the multiarch path. */
2553 if (!skip_multi_dir
2554 && !pl->require_machine_suffix && multiarch_dir)
2556 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2557 ret = callback (path, callback_info);
2558 if (ret)
2559 break;
2562 /* Now try the base path. */
2563 if (!pl->require_machine_suffix
2564 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2566 const char *this_multi;
2567 size_t this_multi_len;
2569 if (pl->os_multilib)
2571 this_multi = multi_os_dir;
2572 this_multi_len = multi_os_dir_len;
2574 else
2576 this_multi = multi_dir;
2577 this_multi_len = multi_dir_len;
2580 if (this_multi_len)
2581 memcpy (path + len, this_multi, this_multi_len + 1);
2582 else
2583 path[len] = '\0';
2585 ret = callback (path, callback_info);
2586 if (ret)
2587 break;
2590 if (pl)
2591 break;
2593 if (multi_dir == NULL && multi_os_dir == NULL)
2594 break;
2596 /* Run through the paths again, this time without multilibs.
2597 Don't repeat any we have already seen. */
2598 if (multi_dir)
2600 free (CONST_CAST (char *, multi_dir));
2601 multi_dir = NULL;
2602 free (CONST_CAST (char *, multi_suffix));
2603 multi_suffix = machine_suffix;
2604 free (CONST_CAST (char *, just_multi_suffix));
2605 just_multi_suffix = just_machine_suffix;
2607 else
2608 skip_multi_dir = true;
2609 if (multi_os_dir)
2611 free (CONST_CAST (char *, multi_os_dir));
2612 multi_os_dir = NULL;
2614 else
2615 skip_multi_os_dir = true;
2618 if (multi_dir)
2620 free (CONST_CAST (char *, multi_dir));
2621 free (CONST_CAST (char *, multi_suffix));
2622 free (CONST_CAST (char *, just_multi_suffix));
2624 if (multi_os_dir)
2625 free (CONST_CAST (char *, multi_os_dir));
2626 if (ret != path)
2627 free (path);
2628 return ret;
2631 /* Callback for build_search_list. Adds path to obstack being built. */
2633 struct add_to_obstack_info {
2634 struct obstack *ob;
2635 bool check_dir;
2636 bool first_time;
2639 static void *
2640 add_to_obstack (char *path, void *data)
2642 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2644 if (info->check_dir && !is_directory (path, false))
2645 return NULL;
2647 if (!info->first_time)
2648 obstack_1grow (info->ob, PATH_SEPARATOR);
2650 obstack_grow (info->ob, path, strlen (path));
2652 info->first_time = false;
2653 return NULL;
2656 /* Add or change the value of an environment variable, outputting the
2657 change to standard error if in verbose mode. */
2658 static void
2659 xputenv (const char *string)
2661 env.xput (string);
2664 /* Build a list of search directories from PATHS.
2665 PREFIX is a string to prepend to the list.
2666 If CHECK_DIR_P is true we ensure the directory exists.
2667 If DO_MULTI is true, multilib paths are output first, then
2668 non-multilib paths.
2669 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2670 It is also used by the --print-search-dirs flag. */
2672 static char *
2673 build_search_list (const struct path_prefix *paths, const char *prefix,
2674 bool check_dir, bool do_multi)
2676 struct add_to_obstack_info info;
2678 info.ob = &collect_obstack;
2679 info.check_dir = check_dir;
2680 info.first_time = true;
2682 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2683 obstack_1grow (&collect_obstack, '=');
2685 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2687 obstack_1grow (&collect_obstack, '\0');
2688 return XOBFINISH (&collect_obstack, char *);
2691 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2692 for collect. */
2694 static void
2695 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2696 bool do_multi)
2698 xputenv (build_search_list (paths, env_var, true, do_multi));
2701 /* Check whether NAME can be accessed in MODE. This is like access,
2702 except that it never considers directories to be executable. */
2704 static int
2705 access_check (const char *name, int mode)
2707 if (mode == X_OK)
2709 struct stat st;
2711 if (stat (name, &st) < 0
2712 || S_ISDIR (st.st_mode))
2713 return -1;
2716 return access (name, mode);
2719 /* Callback for find_a_file. Appends the file name to the directory
2720 path. If the resulting file exists in the right mode, return the
2721 full pathname to the file. */
2723 struct file_at_path_info {
2724 const char *name;
2725 const char *suffix;
2726 int name_len;
2727 int suffix_len;
2728 int mode;
2731 static void *
2732 file_at_path (char *path, void *data)
2734 struct file_at_path_info *info = (struct file_at_path_info *) data;
2735 size_t len = strlen (path);
2737 memcpy (path + len, info->name, info->name_len);
2738 len += info->name_len;
2740 /* Some systems have a suffix for executable files.
2741 So try appending that first. */
2742 if (info->suffix_len)
2744 memcpy (path + len, info->suffix, info->suffix_len + 1);
2745 if (access_check (path, info->mode) == 0)
2746 return path;
2749 path[len] = '\0';
2750 if (access_check (path, info->mode) == 0)
2751 return path;
2753 return NULL;
2756 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2757 access to check permissions. If DO_MULTI is true, search multilib
2758 paths then non-multilib paths, otherwise do not search multilib paths.
2759 Return 0 if not found, otherwise return its name, allocated with malloc. */
2761 static char *
2762 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2763 bool do_multi)
2765 struct file_at_path_info info;
2767 #ifdef DEFAULT_ASSEMBLER
2768 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2769 return xstrdup (DEFAULT_ASSEMBLER);
2770 #endif
2772 #ifdef DEFAULT_LINKER
2773 if (! strcmp (name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2774 return xstrdup (DEFAULT_LINKER);
2775 #endif
2777 /* Determine the filename to execute (special case for absolute paths). */
2779 if (IS_ABSOLUTE_PATH (name))
2781 if (access (name, mode) == 0)
2782 return xstrdup (name);
2784 return NULL;
2787 info.name = name;
2788 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2789 info.name_len = strlen (info.name);
2790 info.suffix_len = strlen (info.suffix);
2791 info.mode = mode;
2793 return (char*) for_each_path (pprefix, do_multi,
2794 info.name_len + info.suffix_len,
2795 file_at_path, &info);
2798 /* Ranking of prefixes in the sort list. -B prefixes are put before
2799 all others. */
2801 enum path_prefix_priority
2803 PREFIX_PRIORITY_B_OPT,
2804 PREFIX_PRIORITY_LAST
2807 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2808 order according to PRIORITY. Within each PRIORITY, new entries are
2809 appended.
2811 If WARN is nonzero, we will warn if no file is found
2812 through this prefix. WARN should point to an int
2813 which will be set to 1 if this entry is used.
2815 COMPONENT is the value to be passed to update_path.
2817 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2818 the complete value of machine_suffix.
2819 2 means try both machine_suffix and just_machine_suffix. */
2821 static void
2822 add_prefix (struct path_prefix *pprefix, const char *prefix,
2823 const char *component, /* enum prefix_priority */ int priority,
2824 int require_machine_suffix, int os_multilib)
2826 struct prefix_list *pl, **prev;
2827 int len;
2829 for (prev = &pprefix->plist;
2830 (*prev) != NULL && (*prev)->priority <= priority;
2831 prev = &(*prev)->next)
2834 /* Keep track of the longest prefix. */
2836 prefix = update_path (prefix, component);
2837 len = strlen (prefix);
2838 if (len > pprefix->max_len)
2839 pprefix->max_len = len;
2841 pl = XNEW (struct prefix_list);
2842 pl->prefix = prefix;
2843 pl->require_machine_suffix = require_machine_suffix;
2844 pl->priority = priority;
2845 pl->os_multilib = os_multilib;
2847 /* Insert after PREV. */
2848 pl->next = (*prev);
2849 (*prev) = pl;
2852 /* Same as add_prefix, but prepending target_system_root to prefix. */
2853 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2854 static void
2855 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2856 const char *component,
2857 /* enum prefix_priority */ int priority,
2858 int require_machine_suffix, int os_multilib)
2860 if (!IS_ABSOLUTE_PATH (prefix))
2861 fatal_error (input_location, "system path %qs is not absolute", prefix);
2863 if (target_system_root)
2865 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2866 size_t sysroot_len = strlen (target_system_root);
2868 if (sysroot_len > 0
2869 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2870 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2872 if (target_sysroot_suffix)
2873 prefix = concat (sysroot_no_trailing_dir_separator,
2874 target_sysroot_suffix, prefix, NULL);
2875 else
2876 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2878 free (sysroot_no_trailing_dir_separator);
2880 /* We have to override this because GCC's notion of sysroot
2881 moves along with GCC. */
2882 component = "GCC";
2885 add_prefix (pprefix, prefix, component, priority,
2886 require_machine_suffix, os_multilib);
2889 /* Execute the command specified by the arguments on the current line of spec.
2890 When using pipes, this includes several piped-together commands
2891 with `|' between them.
2893 Return 0 if successful, -1 if failed. */
2895 static int
2896 execute (void)
2898 int i;
2899 int n_commands; /* # of command. */
2900 char *string;
2901 struct pex_obj *pex;
2902 struct command
2904 const char *prog; /* program name. */
2905 const char **argv; /* vector of args. */
2907 const char *arg;
2909 struct command *commands; /* each command buffer with above info. */
2911 gcc_assert (!processing_spec_function);
2913 if (wrapper_string)
2915 string = find_a_file (&exec_prefixes,
2916 argbuf[0], X_OK, false);
2917 if (string)
2918 argbuf[0] = string;
2919 insert_wrapper (wrapper_string);
2922 /* Count # of piped commands. */
2923 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2924 if (strcmp (arg, "|") == 0)
2925 n_commands++;
2927 /* Get storage for each command. */
2928 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2930 /* Split argbuf into its separate piped processes,
2931 and record info about each one.
2932 Also search for the programs that are to be run. */
2934 argbuf.safe_push (0);
2936 commands[0].prog = argbuf[0]; /* first command. */
2937 commands[0].argv = argbuf.address ();
2939 if (!wrapper_string)
2941 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2942 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2945 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2946 if (arg && strcmp (arg, "|") == 0)
2947 { /* each command. */
2948 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2949 fatal_error (input_location, "-pipe not supported");
2950 #endif
2951 argbuf[i] = 0; /* Termination of
2952 command args. */
2953 commands[n_commands].prog = argbuf[i + 1];
2954 commands[n_commands].argv
2955 = &(argbuf.address ())[i + 1];
2956 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2957 X_OK, false);
2958 if (string)
2959 commands[n_commands].argv[0] = string;
2960 n_commands++;
2963 /* If -v, print what we are about to do, and maybe query. */
2965 if (verbose_flag)
2967 /* For help listings, put a blank line between sub-processes. */
2968 if (print_help_list)
2969 fputc ('\n', stderr);
2971 /* Print each piped command as a separate line. */
2972 for (i = 0; i < n_commands; i++)
2974 const char *const *j;
2976 if (verbose_only_flag)
2978 for (j = commands[i].argv; *j; j++)
2980 const char *p;
2981 for (p = *j; *p; ++p)
2982 if (!ISALNUM ((unsigned char) *p)
2983 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2984 break;
2985 if (*p || !*j)
2987 fprintf (stderr, " \"");
2988 for (p = *j; *p; ++p)
2990 if (*p == '"' || *p == '\\' || *p == '$')
2991 fputc ('\\', stderr);
2992 fputc (*p, stderr);
2994 fputc ('"', stderr);
2996 /* If it's empty, print "". */
2997 else if (!**j)
2998 fprintf (stderr, " \"\"");
2999 else
3000 fprintf (stderr, " %s", *j);
3003 else
3004 for (j = commands[i].argv; *j; j++)
3005 /* If it's empty, print "". */
3006 if (!**j)
3007 fprintf (stderr, " \"\"");
3008 else
3009 fprintf (stderr, " %s", *j);
3011 /* Print a pipe symbol after all but the last command. */
3012 if (i + 1 != n_commands)
3013 fprintf (stderr, " |");
3014 fprintf (stderr, "\n");
3016 fflush (stderr);
3017 if (verbose_only_flag != 0)
3019 /* verbose_only_flag should act as if the spec was
3020 executed, so increment execution_count before
3021 returning. This prevents spurious warnings about
3022 unused linker input files, etc. */
3023 execution_count++;
3024 return 0;
3026 #ifdef DEBUG
3027 fnotice (stderr, "\nGo ahead? (y or n) ");
3028 fflush (stderr);
3029 i = getchar ();
3030 if (i != '\n')
3031 while (getchar () != '\n')
3034 if (i != 'y' && i != 'Y')
3035 return 0;
3036 #endif /* DEBUG */
3039 #ifdef ENABLE_VALGRIND_CHECKING
3040 /* Run the each command through valgrind. To simplify prepending the
3041 path to valgrind and the option "-q" (for quiet operation unless
3042 something triggers), we allocate a separate argv array. */
3044 for (i = 0; i < n_commands; i++)
3046 const char **argv;
3047 int argc;
3048 int j;
3050 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
3053 argv = XALLOCAVEC (const char *, argc + 3);
3055 argv[0] = VALGRIND_PATH;
3056 argv[1] = "-q";
3057 for (j = 2; j < argc + 2; j++)
3058 argv[j] = commands[i].argv[j - 2];
3059 argv[j] = NULL;
3061 commands[i].argv = argv;
3062 commands[i].prog = argv[0];
3064 #endif
3066 /* Run each piped subprocess. */
3068 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
3069 ? PEX_RECORD_TIMES : 0),
3070 progname, temp_filename);
3071 if (pex == NULL)
3072 fatal_error (input_location, "pex_init failed: %m");
3074 for (i = 0; i < n_commands; i++)
3076 const char *errmsg;
3077 int err;
3078 const char *string = commands[i].argv[0];
3080 errmsg = pex_run (pex,
3081 ((i + 1 == n_commands ? PEX_LAST : 0)
3082 | (string == commands[i].prog ? PEX_SEARCH : 0)),
3083 string, CONST_CAST (char **, commands[i].argv),
3084 NULL, NULL, &err);
3085 if (errmsg != NULL)
3087 if (err == 0)
3088 fatal_error (input_location, errmsg);
3089 else
3091 errno = err;
3092 pfatal_with_name (errmsg);
3096 if (i && string != commands[i].prog)
3097 free (CONST_CAST (char *, string));
3100 execution_count++;
3102 /* Wait for all the subprocesses to finish. */
3105 int *statuses;
3106 struct pex_time *times = NULL;
3107 int ret_code = 0;
3109 statuses = (int *) alloca (n_commands * sizeof (int));
3110 if (!pex_get_status (pex, n_commands, statuses))
3111 fatal_error (input_location, "failed to get exit status: %m");
3113 if (report_times || report_times_to_file)
3115 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
3116 if (!pex_get_times (pex, n_commands, times))
3117 fatal_error (input_location, "failed to get process times: %m");
3120 pex_free (pex);
3122 for (i = 0; i < n_commands; ++i)
3124 int status = statuses[i];
3126 if (WIFSIGNALED (status))
3128 #ifdef SIGPIPE
3129 /* SIGPIPE is a special case. It happens in -pipe mode
3130 when the compiler dies before the preprocessor is done,
3131 or the assembler dies before the compiler is done.
3132 There's generally been an error already, and this is
3133 just fallout. So don't generate another error unless
3134 we would otherwise have succeeded. */
3135 if (WTERMSIG (status) == SIGPIPE
3136 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
3138 signal_count++;
3139 ret_code = -1;
3141 else
3142 #endif
3143 internal_error_no_backtrace ("%s (program %s)",
3144 strsignal (WTERMSIG (status)),
3145 commands[i].prog);
3147 else if (WIFEXITED (status)
3148 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
3150 /* For ICEs in cc1, cc1obj, cc1plus see if it is
3151 reproducible or not. */
3152 const char *p;
3153 if (flag_report_bug
3154 && WEXITSTATUS (status) == ICE_EXIT_CODE
3155 && i == 0
3156 && (p = strrchr (commands[0].argv[0], DIR_SEPARATOR))
3157 && ! strncmp (p + 1, "cc1", 3))
3158 try_generate_repro (commands[0].argv);
3159 if (WEXITSTATUS (status) > greatest_status)
3160 greatest_status = WEXITSTATUS (status);
3161 ret_code = -1;
3164 if (report_times || report_times_to_file)
3166 struct pex_time *pt = &times[i];
3167 double ut, st;
3169 ut = ((double) pt->user_seconds
3170 + (double) pt->user_microseconds / 1.0e6);
3171 st = ((double) pt->system_seconds
3172 + (double) pt->system_microseconds / 1.0e6);
3174 if (ut + st != 0)
3176 if (report_times)
3177 fnotice (stderr, "# %s %.2f %.2f\n",
3178 commands[i].prog, ut, st);
3180 if (report_times_to_file)
3182 int c = 0;
3183 const char *const *j;
3185 fprintf (report_times_to_file, "%g %g", ut, st);
3187 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
3189 const char *p;
3190 for (p = *j; *p; ++p)
3191 if (*p == '"' || *p == '\\' || *p == '$'
3192 || ISSPACE (*p))
3193 break;
3195 if (*p)
3197 fprintf (report_times_to_file, " \"");
3198 for (p = *j; *p; ++p)
3200 if (*p == '"' || *p == '\\' || *p == '$')
3201 fputc ('\\', report_times_to_file);
3202 fputc (*p, report_times_to_file);
3204 fputc ('"', report_times_to_file);
3206 else
3207 fprintf (report_times_to_file, " %s", *j);
3210 fputc ('\n', report_times_to_file);
3216 if (commands[0].argv[0] != commands[0].prog)
3217 free (CONST_CAST (char *, commands[0].argv[0]));
3219 return ret_code;
3223 /* Find all the switches given to us
3224 and make a vector describing them.
3225 The elements of the vector are strings, one per switch given.
3226 If a switch uses following arguments, then the `part1' field
3227 is the switch itself and the `args' field
3228 is a null-terminated vector containing the following arguments.
3229 Bits in the `live_cond' field are:
3230 SWITCH_LIVE to indicate this switch is true in a conditional spec.
3231 SWITCH_FALSE to indicate this switch is overridden by a later switch.
3232 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
3233 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored.
3234 SWITCH_KEEP_FOR_GCC to indicate that this switch, otherwise ignored,
3235 should be included in COLLECT_GCC_OPTIONS.
3236 in all do_spec calls afterwards. Used for %<S from self specs.
3237 The `known' field describes whether this is an internal switch.
3238 The `validated' field describes whether any spec has looked at this switch;
3239 if it remains false at the end of the run, the switch must be meaningless.
3240 The `ordering' field is used to temporarily mark switches that have to be
3241 kept in a specific order. */
3243 #define SWITCH_LIVE (1 << 0)
3244 #define SWITCH_FALSE (1 << 1)
3245 #define SWITCH_IGNORE (1 << 2)
3246 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
3247 #define SWITCH_KEEP_FOR_GCC (1 << 4)
3249 struct switchstr
3251 const char *part1;
3252 const char **args;
3253 unsigned int live_cond;
3254 bool known;
3255 bool validated;
3256 bool ordering;
3259 static struct switchstr *switches;
3261 static int n_switches;
3263 static int n_switches_alloc;
3265 /* Set to zero if -fcompare-debug is disabled, positive if it's
3266 enabled and we're running the first compilation, negative if it's
3267 enabled and we're running the second compilation. For most of the
3268 time, it's in the range -1..1, but it can be temporarily set to 2
3269 or 3 to indicate that the -fcompare-debug flags didn't come from
3270 the command-line, but rather from the GCC_COMPARE_DEBUG environment
3271 variable, until a synthesized -fcompare-debug flag is added to the
3272 command line. */
3273 int compare_debug;
3275 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
3276 int compare_debug_second;
3278 /* Set to the flags that should be passed to the second compilation in
3279 a -fcompare-debug compilation. */
3280 const char *compare_debug_opt;
3282 static struct switchstr *switches_debug_check[2];
3284 static int n_switches_debug_check[2];
3286 static int n_switches_alloc_debug_check[2];
3288 static char *debug_check_temp_file[2];
3290 /* Language is one of three things:
3292 1) The name of a real programming language.
3293 2) NULL, indicating that no one has figured out
3294 what it is yet.
3295 3) '*', indicating that the file should be passed
3296 to the linker. */
3297 struct infile
3299 const char *name;
3300 const char *language;
3301 struct compiler *incompiler;
3302 bool compiled;
3303 bool preprocessed;
3306 /* Also a vector of input files specified. */
3308 static struct infile *infiles;
3310 int n_infiles;
3312 static int n_infiles_alloc;
3314 /* True if undefined environment variables encountered during spec processing
3315 are ok to ignore, typically when we're running for --help or --version. */
3317 static bool spec_undefvar_allowed;
3319 /* True if multiple input files are being compiled to a single
3320 assembly file. */
3322 static bool combine_inputs;
3324 /* This counts the number of libraries added by lang_specific_driver, so that
3325 we can tell if there were any user supplied any files or libraries. */
3327 static int added_libraries;
3329 /* And a vector of corresponding output files is made up later. */
3331 const char **outfiles;
3333 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3335 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3336 is true if we should look for an executable suffix. DO_OBJ
3337 is true if we should look for an object suffix. */
3339 static const char *
3340 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3341 int do_obj ATTRIBUTE_UNUSED)
3343 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3344 int i;
3345 #endif
3346 int len;
3348 if (name == NULL)
3349 return NULL;
3351 len = strlen (name);
3353 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3354 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3355 if (do_obj && len > 2
3356 && name[len - 2] == '.'
3357 && name[len - 1] == 'o')
3359 obstack_grow (&obstack, name, len - 2);
3360 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3361 name = XOBFINISH (&obstack, const char *);
3363 #endif
3365 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3366 /* If there is no filetype, make it the executable suffix (which includes
3367 the "."). But don't get confused if we have just "-o". */
3368 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3369 return name;
3371 for (i = len - 1; i >= 0; i--)
3372 if (IS_DIR_SEPARATOR (name[i]))
3373 break;
3375 for (i++; i < len; i++)
3376 if (name[i] == '.')
3377 return name;
3379 obstack_grow (&obstack, name, len);
3380 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3381 strlen (TARGET_EXECUTABLE_SUFFIX));
3382 name = XOBFINISH (&obstack, const char *);
3383 #endif
3385 return name;
3387 #endif
3389 /* Display the command line switches accepted by gcc. */
3390 static void
3391 display_help (void)
3393 printf (_("Usage: %s [options] file...\n"), progname);
3394 fputs (_("Options:\n"), stdout);
3396 fputs (_(" -pass-exit-codes Exit with highest error code from a phase.\n"), stdout);
3397 fputs (_(" --help Display this information.\n"), stdout);
3398 fputs (_(" --target-help Display target specific command line options.\n"), stdout);
3399 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...].\n"), stdout);
3400 fputs (_(" Display specific types of command line options.\n"), stdout);
3401 if (! verbose_flag)
3402 fputs (_(" (Use '-v --help' to display command line options of sub-processes).\n"), stdout);
3403 fputs (_(" --version Display compiler version information.\n"), stdout);
3404 fputs (_(" -dumpspecs Display all of the built in spec strings.\n"), stdout);
3405 fputs (_(" -dumpversion Display the version of the compiler.\n"), stdout);
3406 fputs (_(" -dumpmachine Display the compiler's target processor.\n"), stdout);
3407 fputs (_(" -print-search-dirs Display the directories in the compiler's search path.\n"), stdout);
3408 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library.\n"), stdout);
3409 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>.\n"), stdout);
3410 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>.\n"), stdout);
3411 fputs (_("\
3412 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3413 a component in the library path.\n"), stdout);
3414 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc.\n"), stdout);
3415 fputs (_("\
3416 -print-multi-lib Display the mapping between command line options and\n\
3417 multiple library search directories.\n"), stdout);
3418 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries.\n"), stdout);
3419 fputs (_(" -print-sysroot Display the target libraries directory.\n"), stdout);
3420 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers.\n"), stdout);
3421 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler.\n"), stdout);
3422 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor.\n"), stdout);
3423 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker.\n"), stdout);
3424 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler.\n"), stdout);
3425 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor.\n"), stdout);
3426 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker.\n"), stdout);
3427 fputs (_(" -save-temps Do not delete intermediate files.\n"), stdout);
3428 fputs (_(" -save-temps=<arg> Do not delete intermediate files.\n"), stdout);
3429 fputs (_("\
3430 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3431 prefixes to other gcc components.\n"), stdout);
3432 fputs (_(" -pipe Use pipes rather than intermediate files.\n"), stdout);
3433 fputs (_(" -time Time the execution of each subprocess.\n"), stdout);
3434 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>.\n"), stdout);
3435 fputs (_(" -std=<standard> Assume that the input sources are for <standard>.\n"), stdout);
3436 fputs (_("\
3437 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3438 and libraries.\n"), stdout);
3439 fputs (_(" -B <directory> Add <directory> to the compiler's search paths.\n"), stdout);
3440 fputs (_(" -v Display the programs invoked by the compiler.\n"), stdout);
3441 fputs (_(" -### Like -v but options quoted and commands not executed.\n"), stdout);
3442 fputs (_(" -E Preprocess only; do not compile, assemble or link.\n"), stdout);
3443 fputs (_(" -S Compile only; do not assemble or link.\n"), stdout);
3444 fputs (_(" -c Compile and assemble, but do not link.\n"), stdout);
3445 fputs (_(" -o <file> Place the output into <file>.\n"), stdout);
3446 fputs (_(" -pie Create a position independent executable.\n"), stdout);
3447 fputs (_(" -shared Create a shared library.\n"), stdout);
3448 fputs (_("\
3449 -x <language> Specify the language of the following input files.\n\
3450 Permissible languages include: c c++ assembler none\n\
3451 'none' means revert to the default behavior of\n\
3452 guessing the language based on the file's extension.\n\
3453 "), stdout);
3455 printf (_("\
3456 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3457 passed on to the various sub-processes invoked by %s. In order to pass\n\
3458 other options on to these processes the -W<letter> options must be used.\n\
3459 "), progname);
3461 /* The rest of the options are displayed by invocations of the various
3462 sub-processes. */
3465 static void
3466 add_preprocessor_option (const char *option, int len)
3468 preprocessor_options.safe_push (save_string (option, len));
3471 static void
3472 add_assembler_option (const char *option, int len)
3474 assembler_options.safe_push (save_string (option, len));
3477 static void
3478 add_linker_option (const char *option, int len)
3480 linker_options.safe_push (save_string (option, len));
3483 /* Allocate space for an input file in infiles. */
3485 static void
3486 alloc_infile (void)
3488 if (n_infiles_alloc == 0)
3490 n_infiles_alloc = 16;
3491 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3493 else if (n_infiles_alloc == n_infiles)
3495 n_infiles_alloc *= 2;
3496 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3500 /* Store an input file with the given NAME and LANGUAGE in
3501 infiles. */
3503 static void
3504 add_infile (const char *name, const char *language)
3506 alloc_infile ();
3507 infiles[n_infiles].name = name;
3508 infiles[n_infiles++].language = language;
3511 /* Allocate space for a switch in switches. */
3513 static void
3514 alloc_switch (void)
3516 if (n_switches_alloc == 0)
3518 n_switches_alloc = 16;
3519 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3521 else if (n_switches_alloc == n_switches)
3523 n_switches_alloc *= 2;
3524 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3528 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3529 as validated if VALIDATED and KNOWN if it is an internal switch. */
3531 static void
3532 save_switch (const char *opt, size_t n_args, const char *const *args,
3533 bool validated, bool known)
3535 alloc_switch ();
3536 switches[n_switches].part1 = opt + 1;
3537 if (n_args == 0)
3538 switches[n_switches].args = 0;
3539 else
3541 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3542 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3543 switches[n_switches].args[n_args] = NULL;
3546 switches[n_switches].live_cond = 0;
3547 switches[n_switches].validated = validated;
3548 switches[n_switches].known = known;
3549 switches[n_switches].ordering = 0;
3550 n_switches++;
3553 /* Set the SOURCE_DATE_EPOCH environment variable to the current time if it is
3554 not set already. */
3556 static void
3557 set_source_date_epoch_envvar ()
3559 /* Array size is 21 = ceil(log_10(2^64)) + 1 to hold string representations
3560 of 64 bit integers. */
3561 char source_date_epoch[21];
3562 time_t tt;
3564 errno = 0;
3565 tt = time (NULL);
3566 if (tt < (time_t) 0 || errno != 0)
3567 tt = (time_t) 0;
3569 snprintf (source_date_epoch, 21, "%llu", (unsigned long long) tt);
3570 /* Using setenv instead of xputenv because we want the variable to remain
3571 after finalizing so that it's still set in the second run when using
3572 -fcompare-debug. */
3573 setenv ("SOURCE_DATE_EPOCH", source_date_epoch, 0);
3576 /* Handle an option DECODED that is unknown to the option-processing
3577 machinery. */
3579 static bool
3580 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3582 const char *opt = decoded->arg;
3583 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3584 && !(decoded->errors & CL_ERR_NEGATIVE))
3586 /* Leave unknown -Wno-* options for the compiler proper, to be
3587 diagnosed only if there are warnings. */
3588 save_switch (decoded->canonical_option[0],
3589 decoded->canonical_option_num_elements - 1,
3590 &decoded->canonical_option[1], false, true);
3591 return false;
3593 if (decoded->opt_index == OPT_SPECIAL_unknown)
3595 /* Give it a chance to define it a spec file. */
3596 save_switch (decoded->canonical_option[0],
3597 decoded->canonical_option_num_elements - 1,
3598 &decoded->canonical_option[1], false, false);
3599 return false;
3601 else
3602 return true;
3605 /* Handle an option DECODED that is not marked as CL_DRIVER.
3606 LANG_MASK will always be CL_DRIVER. */
3608 static void
3609 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3610 unsigned int lang_mask ATTRIBUTE_UNUSED)
3612 /* At this point, non-driver options are accepted (and expected to
3613 be passed down by specs) unless marked to be rejected by the
3614 driver. Options to be rejected by the driver but accepted by the
3615 compilers proper are treated just like completely unknown
3616 options. */
3617 const struct cl_option *option = &cl_options[decoded->opt_index];
3619 if (option->cl_reject_driver)
3620 error ("unrecognized command line option %qs",
3621 decoded->orig_option_with_args_text);
3622 else
3623 save_switch (decoded->canonical_option[0],
3624 decoded->canonical_option_num_elements - 1,
3625 &decoded->canonical_option[1], false, true);
3628 static const char *spec_lang = 0;
3629 static int last_language_n_infiles;
3631 /* Parse -foffload option argument. */
3633 static void
3634 handle_foffload_option (const char *arg)
3636 const char *c, *cur, *n, *next, *end;
3637 char *target;
3639 /* If option argument starts with '-' then no target is specified and we
3640 do not need to parse it. */
3641 if (arg[0] == '-')
3642 return;
3644 end = strchr (arg, '=');
3645 if (end == NULL)
3646 end = strchr (arg, '\0');
3647 cur = arg;
3649 while (cur < end)
3651 next = strchr (cur, ',');
3652 if (next == NULL)
3653 next = end;
3654 next = (next > end) ? end : next;
3656 target = XNEWVEC (char, next - cur + 1);
3657 memcpy (target, cur, next - cur);
3658 target[next - cur] = '\0';
3660 /* If 'disable' is passed to the option, stop parsing the option and clean
3661 the list of offload targets. */
3662 if (strcmp (target, "disable") == 0)
3664 free (offload_targets);
3665 offload_targets = xstrdup ("");
3666 break;
3669 /* Check that GCC is configured to support the offload target. */
3670 c = OFFLOAD_TARGETS;
3671 while (c)
3673 n = strchr (c, ',');
3674 if (n == NULL)
3675 n = strchr (c, '\0');
3677 if (next - cur == n - c && strncmp (target, c, n - c) == 0)
3678 break;
3680 c = *n ? n + 1 : NULL;
3683 if (!c)
3684 fatal_error (input_location,
3685 "GCC is not configured to support %s as offload target",
3686 target);
3688 if (!offload_targets)
3690 offload_targets = target;
3691 target = NULL;
3693 else
3695 /* Check that the target hasn't already presented in the list. */
3696 c = offload_targets;
3699 n = strchr (c, ':');
3700 if (n == NULL)
3701 n = strchr (c, '\0');
3703 if (next - cur == n - c && strncmp (c, target, n - c) == 0)
3704 break;
3706 c = n + 1;
3708 while (*n);
3710 /* If duplicate is not found, append the target to the list. */
3711 if (c > n)
3713 size_t offload_targets_len = strlen (offload_targets);
3714 offload_targets
3715 = XRESIZEVEC (char, offload_targets,
3716 offload_targets_len + 1 + next - cur + 1);
3717 offload_targets[offload_targets_len++] = ':';
3718 memcpy (offload_targets + offload_targets_len, target, next - cur + 1);
3722 cur = next + 1;
3723 XDELETEVEC (target);
3727 /* Handle a driver option; arguments and return value as for
3728 handle_option. */
3730 static bool
3731 driver_handle_option (struct gcc_options *opts,
3732 struct gcc_options *opts_set,
3733 const struct cl_decoded_option *decoded,
3734 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3735 location_t loc,
3736 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3737 diagnostic_context *dc)
3739 size_t opt_index = decoded->opt_index;
3740 const char *arg = decoded->arg;
3741 const char *compare_debug_replacement_opt;
3742 int value = decoded->value;
3743 bool validated = false;
3744 bool do_save = true;
3746 gcc_assert (opts == &global_options);
3747 gcc_assert (opts_set == &global_options_set);
3748 gcc_assert (kind == DK_UNSPECIFIED);
3749 gcc_assert (loc == UNKNOWN_LOCATION);
3750 gcc_assert (dc == global_dc);
3752 switch (opt_index)
3754 case OPT_dumpspecs:
3756 struct spec_list *sl;
3757 init_spec ();
3758 for (sl = specs; sl; sl = sl->next)
3759 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3760 if (link_command_spec)
3761 printf ("*link_command:\n%s\n\n", link_command_spec);
3762 exit (0);
3765 case OPT_dumpversion:
3766 printf ("%s\n", spec_version);
3767 exit (0);
3769 case OPT_dumpmachine:
3770 printf ("%s\n", spec_machine);
3771 exit (0);
3773 case OPT__version:
3774 print_version = 1;
3776 /* CPP driver cannot obtain switch from cc1_options. */
3777 if (is_cpp_driver)
3778 add_preprocessor_option ("--version", strlen ("--version"));
3779 add_assembler_option ("--version", strlen ("--version"));
3780 add_linker_option ("--version", strlen ("--version"));
3781 break;
3783 case OPT__help:
3784 print_help_list = 1;
3786 /* CPP driver cannot obtain switch from cc1_options. */
3787 if (is_cpp_driver)
3788 add_preprocessor_option ("--help", 6);
3789 add_assembler_option ("--help", 6);
3790 add_linker_option ("--help", 6);
3791 break;
3793 case OPT__help_:
3794 print_subprocess_help = 2;
3795 break;
3797 case OPT__target_help:
3798 print_subprocess_help = 1;
3800 /* CPP driver cannot obtain switch from cc1_options. */
3801 if (is_cpp_driver)
3802 add_preprocessor_option ("--target-help", 13);
3803 add_assembler_option ("--target-help", 13);
3804 add_linker_option ("--target-help", 13);
3805 break;
3807 case OPT__no_sysroot_suffix:
3808 case OPT_pass_exit_codes:
3809 case OPT_print_search_dirs:
3810 case OPT_print_file_name_:
3811 case OPT_print_prog_name_:
3812 case OPT_print_multi_lib:
3813 case OPT_print_multi_directory:
3814 case OPT_print_sysroot:
3815 case OPT_print_multi_os_directory:
3816 case OPT_print_multiarch:
3817 case OPT_print_sysroot_headers_suffix:
3818 case OPT_time:
3819 case OPT_wrapper:
3820 /* These options set the variables specified in common.opt
3821 automatically, and do not need to be saved for spec
3822 processing. */
3823 do_save = false;
3824 break;
3826 case OPT_print_libgcc_file_name:
3827 print_file_name = "libgcc.a";
3828 do_save = false;
3829 break;
3831 case OPT_fuse_ld_bfd:
3832 use_ld = ".bfd";
3833 break;
3835 case OPT_fuse_ld_gold:
3836 use_ld = ".gold";
3837 break;
3839 case OPT_fcompare_debug_second:
3840 compare_debug_second = 1;
3841 break;
3843 case OPT_fcompare_debug:
3844 switch (value)
3846 case 0:
3847 compare_debug_replacement_opt = "-fcompare-debug=";
3848 arg = "";
3849 goto compare_debug_with_arg;
3851 case 1:
3852 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3853 arg = "-gtoggle";
3854 goto compare_debug_with_arg;
3856 default:
3857 gcc_unreachable ();
3859 break;
3861 case OPT_fcompare_debug_:
3862 compare_debug_replacement_opt = decoded->canonical_option[0];
3863 compare_debug_with_arg:
3864 gcc_assert (decoded->canonical_option_num_elements == 1);
3865 gcc_assert (arg != NULL);
3866 if (*arg)
3867 compare_debug = 1;
3868 else
3869 compare_debug = -1;
3870 if (compare_debug < 0)
3871 compare_debug_opt = NULL;
3872 else
3873 compare_debug_opt = arg;
3874 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3875 set_source_date_epoch_envvar ();
3876 return true;
3878 case OPT_fdiagnostics_color_:
3879 diagnostic_color_init (dc, value);
3880 break;
3882 case OPT_Wa_:
3884 int prev, j;
3885 /* Pass the rest of this option to the assembler. */
3887 /* Split the argument at commas. */
3888 prev = 0;
3889 for (j = 0; arg[j]; j++)
3890 if (arg[j] == ',')
3892 add_assembler_option (arg + prev, j - prev);
3893 prev = j + 1;
3896 /* Record the part after the last comma. */
3897 add_assembler_option (arg + prev, j - prev);
3899 do_save = false;
3900 break;
3902 case OPT_Wp_:
3904 int prev, j;
3905 /* Pass the rest of this option to the preprocessor. */
3907 /* Split the argument at commas. */
3908 prev = 0;
3909 for (j = 0; arg[j]; j++)
3910 if (arg[j] == ',')
3912 add_preprocessor_option (arg + prev, j - prev);
3913 prev = j + 1;
3916 /* Record the part after the last comma. */
3917 add_preprocessor_option (arg + prev, j - prev);
3919 do_save = false;
3920 break;
3922 case OPT_Wl_:
3924 int prev, j;
3925 /* Split the argument at commas. */
3926 prev = 0;
3927 for (j = 0; arg[j]; j++)
3928 if (arg[j] == ',')
3930 add_infile (save_string (arg + prev, j - prev), "*");
3931 prev = j + 1;
3933 /* Record the part after the last comma. */
3934 add_infile (arg + prev, "*");
3936 do_save = false;
3937 break;
3939 case OPT_Xlinker:
3940 add_infile (arg, "*");
3941 do_save = false;
3942 break;
3944 case OPT_Xpreprocessor:
3945 add_preprocessor_option (arg, strlen (arg));
3946 do_save = false;
3947 break;
3949 case OPT_Xassembler:
3950 add_assembler_option (arg, strlen (arg));
3951 do_save = false;
3952 break;
3954 case OPT_l:
3955 /* POSIX allows separation of -l and the lib arg; canonicalize
3956 by concatenating -l with its arg */
3957 add_infile (concat ("-l", arg, NULL), "*");
3958 do_save = false;
3959 break;
3961 case OPT_L:
3962 /* Similarly, canonicalize -L for linkers that may not accept
3963 separate arguments. */
3964 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
3965 return true;
3967 case OPT_F:
3968 /* Likewise -F. */
3969 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
3970 return true;
3972 case OPT_save_temps:
3973 save_temps_flag = SAVE_TEMPS_CWD;
3974 validated = true;
3975 break;
3977 case OPT_save_temps_:
3978 if (strcmp (arg, "cwd") == 0)
3979 save_temps_flag = SAVE_TEMPS_CWD;
3980 else if (strcmp (arg, "obj") == 0
3981 || strcmp (arg, "object") == 0)
3982 save_temps_flag = SAVE_TEMPS_OBJ;
3983 else
3984 fatal_error (input_location, "%qs is an unknown -save-temps option",
3985 decoded->orig_option_with_args_text);
3986 break;
3988 case OPT_no_canonical_prefixes:
3989 /* Already handled as a special case, so ignored here. */
3990 do_save = false;
3991 break;
3993 case OPT_pipe:
3994 validated = true;
3995 /* These options set the variables specified in common.opt
3996 automatically, but do need to be saved for spec
3997 processing. */
3998 break;
4000 case OPT_specs_:
4002 struct user_specs *user = XNEW (struct user_specs);
4004 user->next = (struct user_specs *) 0;
4005 user->filename = arg;
4006 if (user_specs_tail)
4007 user_specs_tail->next = user;
4008 else
4009 user_specs_head = user;
4010 user_specs_tail = user;
4012 validated = true;
4013 break;
4015 case OPT__sysroot_:
4016 target_system_root = arg;
4017 target_system_root_changed = 1;
4018 do_save = false;
4019 break;
4021 case OPT_time_:
4022 if (report_times_to_file)
4023 fclose (report_times_to_file);
4024 report_times_to_file = fopen (arg, "a");
4025 do_save = false;
4026 break;
4028 case OPT____:
4029 /* "-###"
4030 This is similar to -v except that there is no execution
4031 of the commands and the echoed arguments are quoted. It
4032 is intended for use in shell scripts to capture the
4033 driver-generated command line. */
4034 verbose_only_flag++;
4035 verbose_flag = 1;
4036 do_save = false;
4037 break;
4039 case OPT_B:
4041 size_t len = strlen (arg);
4043 /* Catch the case where the user has forgotten to append a
4044 directory separator to the path. Note, they may be using
4045 -B to add an executable name prefix, eg "i386-elf-", in
4046 order to distinguish between multiple installations of
4047 GCC in the same directory. Hence we must check to see
4048 if appending a directory separator actually makes a
4049 valid directory name. */
4050 if (!IS_DIR_SEPARATOR (arg[len - 1])
4051 && is_directory (arg, false))
4053 char *tmp = XNEWVEC (char, len + 2);
4054 strcpy (tmp, arg);
4055 tmp[len] = DIR_SEPARATOR;
4056 tmp[++len] = 0;
4057 arg = tmp;
4060 add_prefix (&exec_prefixes, arg, NULL,
4061 PREFIX_PRIORITY_B_OPT, 0, 0);
4062 add_prefix (&startfile_prefixes, arg, NULL,
4063 PREFIX_PRIORITY_B_OPT, 0, 0);
4064 add_prefix (&include_prefixes, arg, NULL,
4065 PREFIX_PRIORITY_B_OPT, 0, 0);
4067 validated = true;
4068 break;
4070 case OPT_x:
4071 spec_lang = arg;
4072 if (!strcmp (spec_lang, "none"))
4073 /* Suppress the warning if -xnone comes after the last input
4074 file, because alternate command interfaces like g++ might
4075 find it useful to place -xnone after each input file. */
4076 spec_lang = 0;
4077 else
4078 last_language_n_infiles = n_infiles;
4079 do_save = false;
4080 break;
4082 case OPT_o:
4083 have_o = 1;
4084 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
4085 arg = convert_filename (arg, ! have_c, 0);
4086 #endif
4087 output_file = arg;
4088 /* Save the output name in case -save-temps=obj was used. */
4089 save_temps_prefix = xstrdup (arg);
4090 /* On some systems, ld cannot handle "-o" without a space. So
4091 split the option from its argument. */
4092 save_switch ("-o", 1, &arg, validated, true);
4093 return true;
4095 #ifdef ENABLE_DEFAULT_PIE
4096 case OPT_pie:
4097 /* -pie is turned on by default. */
4098 #endif
4100 case OPT_static_libgcc:
4101 case OPT_shared_libgcc:
4102 case OPT_static_libgfortran:
4103 case OPT_static_libstdc__:
4104 /* These are always valid, since gcc.c itself understands the
4105 first two, gfortranspec.c understands -static-libgfortran and
4106 g++spec.c understands -static-libstdc++ */
4107 validated = true;
4108 break;
4110 case OPT_fwpa:
4111 flag_wpa = "";
4112 break;
4114 case OPT_foffload_:
4115 handle_foffload_option (arg);
4116 break;
4118 default:
4119 /* Various driver options need no special processing at this
4120 point, having been handled in a prescan above or being
4121 handled by specs. */
4122 break;
4125 if (do_save)
4126 save_switch (decoded->canonical_option[0],
4127 decoded->canonical_option_num_elements - 1,
4128 &decoded->canonical_option[1], validated, true);
4129 return true;
4132 /* Put the driver's standard set of option handlers in *HANDLERS. */
4134 static void
4135 set_option_handlers (struct cl_option_handlers *handlers)
4137 handlers->unknown_option_callback = driver_unknown_option_callback;
4138 handlers->wrong_lang_callback = driver_wrong_lang_callback;
4139 handlers->num_handlers = 3;
4140 handlers->handlers[0].handler = driver_handle_option;
4141 handlers->handlers[0].mask = CL_DRIVER;
4142 handlers->handlers[1].handler = common_handle_option;
4143 handlers->handlers[1].mask = CL_COMMON;
4144 handlers->handlers[2].handler = target_handle_option;
4145 handlers->handlers[2].mask = CL_TARGET;
4148 /* Create the vector `switches' and its contents.
4149 Store its length in `n_switches'. */
4151 static void
4152 process_command (unsigned int decoded_options_count,
4153 struct cl_decoded_option *decoded_options)
4155 const char *temp;
4156 char *temp1;
4157 char *tooldir_prefix, *tooldir_prefix2;
4158 char *(*get_relative_prefix) (const char *, const char *,
4159 const char *) = NULL;
4160 struct cl_option_handlers handlers;
4161 unsigned int j;
4163 gcc_exec_prefix = env.get ("GCC_EXEC_PREFIX");
4165 n_switches = 0;
4166 n_infiles = 0;
4167 added_libraries = 0;
4169 /* Figure compiler version from version string. */
4171 compiler_version = temp1 = xstrdup (version_string);
4173 for (; *temp1; ++temp1)
4175 if (*temp1 == ' ')
4177 *temp1 = '\0';
4178 break;
4182 /* Handle any -no-canonical-prefixes flag early, to assign the function
4183 that builds relative prefixes. This function creates default search
4184 paths that are needed later in normal option handling. */
4186 for (j = 1; j < decoded_options_count; j++)
4188 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
4190 get_relative_prefix = make_relative_prefix_ignore_links;
4191 break;
4194 if (! get_relative_prefix)
4195 get_relative_prefix = make_relative_prefix;
4197 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
4198 see if we can create it from the pathname specified in
4199 decoded_options[0].arg. */
4201 gcc_libexec_prefix = standard_libexec_prefix;
4202 #ifndef VMS
4203 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
4204 if (!gcc_exec_prefix)
4206 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
4207 standard_bindir_prefix,
4208 standard_exec_prefix);
4209 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
4210 standard_bindir_prefix,
4211 standard_libexec_prefix);
4212 if (gcc_exec_prefix)
4213 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
4215 else
4217 /* make_relative_prefix requires a program name, but
4218 GCC_EXEC_PREFIX is typically a directory name with a trailing
4219 / (which is ignored by make_relative_prefix), so append a
4220 program name. */
4221 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
4222 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
4223 standard_exec_prefix,
4224 standard_libexec_prefix);
4226 /* The path is unrelocated, so fallback to the original setting. */
4227 if (!gcc_libexec_prefix)
4228 gcc_libexec_prefix = standard_libexec_prefix;
4230 free (tmp_prefix);
4232 #else
4233 #endif
4234 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
4235 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
4236 or an automatically created GCC_EXEC_PREFIX from
4237 decoded_options[0].arg. */
4239 /* Do language-specific adjustment/addition of flags. */
4240 lang_specific_driver (&decoded_options, &decoded_options_count,
4241 &added_libraries);
4243 if (gcc_exec_prefix)
4245 int len = strlen (gcc_exec_prefix);
4247 if (len > (int) sizeof ("/lib/gcc/") - 1
4248 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
4250 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
4251 if (IS_DIR_SEPARATOR (*temp)
4252 && filename_ncmp (temp + 1, "lib", 3) == 0
4253 && IS_DIR_SEPARATOR (temp[4])
4254 && filename_ncmp (temp + 5, "gcc", 3) == 0)
4255 len -= sizeof ("/lib/gcc/") - 1;
4258 set_std_prefix (gcc_exec_prefix, len);
4259 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
4260 PREFIX_PRIORITY_LAST, 0, 0);
4261 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
4262 PREFIX_PRIORITY_LAST, 0, 0);
4265 /* COMPILER_PATH and LIBRARY_PATH have values
4266 that are lists of directory names with colons. */
4268 temp = env.get ("COMPILER_PATH");
4269 if (temp)
4271 const char *startp, *endp;
4272 char *nstore = (char *) alloca (strlen (temp) + 3);
4274 startp = endp = temp;
4275 while (1)
4277 if (*endp == PATH_SEPARATOR || *endp == 0)
4279 strncpy (nstore, startp, endp - startp);
4280 if (endp == startp)
4281 strcpy (nstore, concat (".", dir_separator_str, NULL));
4282 else if (!IS_DIR_SEPARATOR (endp[-1]))
4284 nstore[endp - startp] = DIR_SEPARATOR;
4285 nstore[endp - startp + 1] = 0;
4287 else
4288 nstore[endp - startp] = 0;
4289 add_prefix (&exec_prefixes, nstore, 0,
4290 PREFIX_PRIORITY_LAST, 0, 0);
4291 add_prefix (&include_prefixes, nstore, 0,
4292 PREFIX_PRIORITY_LAST, 0, 0);
4293 if (*endp == 0)
4294 break;
4295 endp = startp = endp + 1;
4297 else
4298 endp++;
4302 temp = env.get (LIBRARY_PATH_ENV);
4303 if (temp && *cross_compile == '0')
4305 const char *startp, *endp;
4306 char *nstore = (char *) alloca (strlen (temp) + 3);
4308 startp = endp = temp;
4309 while (1)
4311 if (*endp == PATH_SEPARATOR || *endp == 0)
4313 strncpy (nstore, startp, endp - startp);
4314 if (endp == startp)
4315 strcpy (nstore, concat (".", dir_separator_str, NULL));
4316 else if (!IS_DIR_SEPARATOR (endp[-1]))
4318 nstore[endp - startp] = DIR_SEPARATOR;
4319 nstore[endp - startp + 1] = 0;
4321 else
4322 nstore[endp - startp] = 0;
4323 add_prefix (&startfile_prefixes, nstore, NULL,
4324 PREFIX_PRIORITY_LAST, 0, 1);
4325 if (*endp == 0)
4326 break;
4327 endp = startp = endp + 1;
4329 else
4330 endp++;
4334 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
4335 temp = env.get ("LPATH");
4336 if (temp && *cross_compile == '0')
4338 const char *startp, *endp;
4339 char *nstore = (char *) alloca (strlen (temp) + 3);
4341 startp = endp = temp;
4342 while (1)
4344 if (*endp == PATH_SEPARATOR || *endp == 0)
4346 strncpy (nstore, startp, endp - startp);
4347 if (endp == startp)
4348 strcpy (nstore, concat (".", dir_separator_str, NULL));
4349 else if (!IS_DIR_SEPARATOR (endp[-1]))
4351 nstore[endp - startp] = DIR_SEPARATOR;
4352 nstore[endp - startp + 1] = 0;
4354 else
4355 nstore[endp - startp] = 0;
4356 add_prefix (&startfile_prefixes, nstore, NULL,
4357 PREFIX_PRIORITY_LAST, 0, 1);
4358 if (*endp == 0)
4359 break;
4360 endp = startp = endp + 1;
4362 else
4363 endp++;
4367 /* Process the options and store input files and switches in their
4368 vectors. */
4370 last_language_n_infiles = -1;
4372 set_option_handlers (&handlers);
4374 for (j = 1; j < decoded_options_count; j++)
4376 switch (decoded_options[j].opt_index)
4378 case OPT_S:
4379 case OPT_c:
4380 case OPT_E:
4381 have_c = 1;
4382 break;
4384 if (have_c)
4385 break;
4388 for (j = 1; j < decoded_options_count; j++)
4390 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
4392 const char *arg = decoded_options[j].arg;
4393 const char *p = strrchr (arg, '@');
4394 char *fname;
4395 long offset;
4396 int consumed;
4397 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4398 arg = convert_filename (arg, 0, access (arg, F_OK));
4399 #endif
4400 /* For LTO static archive support we handle input file
4401 specifications that are composed of a filename and
4402 an offset like FNAME@OFFSET. */
4403 if (p
4404 && p != arg
4405 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
4406 && strlen (p) == (unsigned int)consumed)
4408 fname = (char *)xmalloc (p - arg + 1);
4409 memcpy (fname, arg, p - arg);
4410 fname[p - arg] = '\0';
4411 /* Only accept non-stdin and existing FNAME parts, otherwise
4412 try with the full name. */
4413 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
4415 free (fname);
4416 fname = xstrdup (arg);
4419 else
4420 fname = xstrdup (arg);
4422 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
4424 if (fname[0] == '@' && access (fname + 1, F_OK) < 0)
4425 perror_with_name (fname + 1);
4426 else
4427 perror_with_name (fname);
4429 else
4430 add_infile (arg, spec_lang);
4432 free (fname);
4433 continue;
4436 read_cmdline_option (&global_options, &global_options_set,
4437 decoded_options + j, UNKNOWN_LOCATION,
4438 CL_DRIVER, &handlers, global_dc);
4441 /* If the user didn't specify any, default to all configured offload
4442 targets. */
4443 if (ENABLE_OFFLOADING && offload_targets == NULL)
4444 handle_foffload_option (OFFLOAD_TARGETS);
4446 if (output_file
4447 && strcmp (output_file, "-") != 0
4448 && strcmp (output_file, HOST_BIT_BUCKET) != 0)
4450 int i;
4451 for (i = 0; i < n_infiles; i++)
4452 if ((!infiles[i].language || infiles[i].language[0] != '*')
4453 && canonical_filename_eq (infiles[i].name, output_file))
4454 fatal_error (input_location,
4455 "input file %qs is the same as output file",
4456 output_file);
4459 /* If -save-temps=obj and -o name, create the prefix to use for %b.
4460 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
4461 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
4463 save_temps_length = strlen (save_temps_prefix);
4464 temp = strrchr (lbasename (save_temps_prefix), '.');
4465 if (temp)
4467 save_temps_length -= strlen (temp);
4468 save_temps_prefix[save_temps_length] = '\0';
4472 else if (save_temps_prefix != NULL)
4474 free (save_temps_prefix);
4475 save_temps_prefix = NULL;
4478 if (save_temps_flag && use_pipes)
4480 /* -save-temps overrides -pipe, so that temp files are produced */
4481 if (save_temps_flag)
4482 warning (0, "-pipe ignored because -save-temps specified");
4483 use_pipes = 0;
4486 if (!compare_debug)
4488 const char *gcd = env.get ("GCC_COMPARE_DEBUG");
4490 if (gcd && gcd[0] == '-')
4492 compare_debug = 2;
4493 compare_debug_opt = gcd;
4495 else if (gcd && *gcd && strcmp (gcd, "0"))
4497 compare_debug = 3;
4498 compare_debug_opt = "-gtoggle";
4501 else if (compare_debug < 0)
4503 compare_debug = 0;
4504 gcc_assert (!compare_debug_opt);
4507 /* Set up the search paths. We add directories that we expect to
4508 contain GNU Toolchain components before directories specified by
4509 the machine description so that we will find GNU components (like
4510 the GNU assembler) before those of the host system. */
4512 /* If we don't know where the toolchain has been installed, use the
4513 configured-in locations. */
4514 if (!gcc_exec_prefix)
4516 #ifndef OS2
4517 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
4518 PREFIX_PRIORITY_LAST, 1, 0);
4519 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
4520 PREFIX_PRIORITY_LAST, 2, 0);
4521 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
4522 PREFIX_PRIORITY_LAST, 2, 0);
4523 #endif
4524 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
4525 PREFIX_PRIORITY_LAST, 1, 0);
4528 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
4529 tooldir_prefix2 = concat (tooldir_base_prefix, spec_machine,
4530 dir_separator_str, NULL);
4532 /* Look for tools relative to the location from which the driver is
4533 running, or, if that is not available, the configured prefix. */
4534 tooldir_prefix
4535 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4536 spec_host_machine, dir_separator_str, spec_version,
4537 accel_dir_suffix, dir_separator_str, tooldir_prefix2, NULL);
4538 free (tooldir_prefix2);
4540 add_prefix (&exec_prefixes,
4541 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4542 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4543 add_prefix (&startfile_prefixes,
4544 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4545 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4546 free (tooldir_prefix);
4548 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4549 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4550 then consider it to relocate with the rest of the GCC installation
4551 if GCC_EXEC_PREFIX is set.
4552 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4553 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
4555 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
4556 standard_bindir_prefix,
4557 target_system_root);
4558 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4560 target_system_root = tmp_prefix;
4561 target_system_root_changed = 1;
4564 #endif
4566 /* More prefixes are enabled in main, after we read the specs file
4567 and determine whether this is cross-compilation or not. */
4569 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4570 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
4572 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
4573 environment variable. */
4574 if (compare_debug == 2 || compare_debug == 3)
4576 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
4577 save_switch (opt, 0, NULL, false, true);
4578 compare_debug = 1;
4581 /* Ensure we only invoke each subprocess once. */
4582 if (print_subprocess_help || print_help_list || print_version)
4584 n_infiles = 0;
4586 /* Create a dummy input file, so that we can pass
4587 the help option on to the various sub-processes. */
4588 add_infile ("help-dummy", "c");
4591 /* Decide if undefined variable references are allowed in specs. */
4593 /* --version and --help alone or together are safe. Note that -v would
4594 make them unsafe, as they'd then be run for subprocesses as well, the
4595 location of which might depend on variables possibly coming from
4596 self-specs.
4598 Count the number of options we have for which undefined variables
4599 are harmless for sure, and check that nothing else is set. */
4601 unsigned n_varsafe_options = 0;
4603 if (print_version)
4604 n_varsafe_options++;
4606 if (print_help_list)
4607 n_varsafe_options++;
4609 spec_undefvar_allowed = (n_varsafe_options == decoded_options_count - 1);
4611 alloc_switch ();
4612 switches[n_switches].part1 = 0;
4613 alloc_infile ();
4614 infiles[n_infiles].name = 0;
4617 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4618 and place that in the environment. */
4620 static void
4621 set_collect_gcc_options (void)
4623 int i;
4624 int first_time;
4626 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4627 the compiler. */
4628 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4629 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4631 first_time = TRUE;
4632 for (i = 0; (int) i < n_switches; i++)
4634 const char *const *args;
4635 const char *p, *q;
4636 if (!first_time)
4637 obstack_grow (&collect_obstack, " ", 1);
4639 first_time = FALSE;
4641 /* Ignore elided switches. */
4642 if ((switches[i].live_cond
4643 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4644 == SWITCH_IGNORE)
4645 continue;
4647 obstack_grow (&collect_obstack, "'-", 2);
4648 q = switches[i].part1;
4649 while ((p = strchr (q, '\'')))
4651 obstack_grow (&collect_obstack, q, p - q);
4652 obstack_grow (&collect_obstack, "'\\''", 4);
4653 q = ++p;
4655 obstack_grow (&collect_obstack, q, strlen (q));
4656 obstack_grow (&collect_obstack, "'", 1);
4658 for (args = switches[i].args; args && *args; args++)
4660 obstack_grow (&collect_obstack, " '", 2);
4661 q = *args;
4662 while ((p = strchr (q, '\'')))
4664 obstack_grow (&collect_obstack, q, p - q);
4665 obstack_grow (&collect_obstack, "'\\''", 4);
4666 q = ++p;
4668 obstack_grow (&collect_obstack, q, strlen (q));
4669 obstack_grow (&collect_obstack, "'", 1);
4672 obstack_grow (&collect_obstack, "\0", 1);
4673 xputenv (XOBFINISH (&collect_obstack, char *));
4676 /* Process a spec string, accumulating and running commands. */
4678 /* These variables describe the input file name.
4679 input_file_number is the index on outfiles of this file,
4680 so that the output file name can be stored for later use by %o.
4681 input_basename is the start of the part of the input file
4682 sans all directory names, and basename_length is the number
4683 of characters starting there excluding the suffix .c or whatever. */
4685 static const char *gcc_input_filename;
4686 static int input_file_number;
4687 size_t input_filename_length;
4688 static int basename_length;
4689 static int suffixed_basename_length;
4690 static const char *input_basename;
4691 static const char *input_suffix;
4692 #ifndef HOST_LACKS_INODE_NUMBERS
4693 static struct stat input_stat;
4694 #endif
4695 static int input_stat_set;
4697 /* The compiler used to process the current input file. */
4698 static struct compiler *input_file_compiler;
4700 /* These are variables used within do_spec and do_spec_1. */
4702 /* Nonzero if an arg has been started and not yet terminated
4703 (with space, tab or newline). */
4704 static int arg_going;
4706 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4707 is a temporary file name. */
4708 static int delete_this_arg;
4710 /* Nonzero means %w has been seen; the next arg to be terminated
4711 is the output file name of this compilation. */
4712 static int this_is_output_file;
4714 /* Nonzero means %s has been seen; the next arg to be terminated
4715 is the name of a library file and we should try the standard
4716 search dirs for it. */
4717 static int this_is_library_file;
4719 /* Nonzero means %T has been seen; the next arg to be terminated
4720 is the name of a linker script and we should try all of the
4721 standard search dirs for it. If it is found insert a --script
4722 command line switch and then substitute the full path in place,
4723 otherwise generate an error message. */
4724 static int this_is_linker_script;
4726 /* Nonzero means that the input of this command is coming from a pipe. */
4727 static int input_from_pipe;
4729 /* Nonnull means substitute this for any suffix when outputting a switches
4730 arguments. */
4731 static const char *suffix_subst;
4733 /* If there is an argument being accumulated, terminate it and store it. */
4735 static void
4736 end_going_arg (void)
4738 if (arg_going)
4740 const char *string;
4742 obstack_1grow (&obstack, 0);
4743 string = XOBFINISH (&obstack, const char *);
4744 if (this_is_library_file)
4745 string = find_file (string);
4746 if (this_is_linker_script)
4748 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4750 if (full_script_path == NULL)
4752 error ("unable to locate default linker script %qs in the library search paths", string);
4753 /* Script was not found on search path. */
4754 return;
4756 store_arg ("--script", false, false);
4757 string = full_script_path;
4759 store_arg (string, delete_this_arg, this_is_output_file);
4760 if (this_is_output_file)
4761 outfiles[input_file_number] = string;
4762 arg_going = 0;
4767 /* Parse the WRAPPER string which is a comma separated list of the command line
4768 and insert them into the beginning of argbuf. */
4770 static void
4771 insert_wrapper (const char *wrapper)
4773 int n = 0;
4774 int i;
4775 char *buf = xstrdup (wrapper);
4776 char *p = buf;
4777 unsigned int old_length = argbuf.length ();
4781 n++;
4782 while (*p == ',')
4783 p++;
4785 while ((p = strchr (p, ',')) != NULL);
4787 argbuf.safe_grow (old_length + n);
4788 memmove (argbuf.address () + n,
4789 argbuf.address (),
4790 old_length * sizeof (const_char_p));
4792 i = 0;
4793 p = buf;
4796 while (*p == ',')
4798 *p = 0;
4799 p++;
4801 argbuf[i] = p;
4802 i++;
4804 while ((p = strchr (p, ',')) != NULL);
4805 gcc_assert (i == n);
4808 /* Process the spec SPEC and run the commands specified therein.
4809 Returns 0 if the spec is successfully processed; -1 if failed. */
4812 do_spec (const char *spec)
4814 int value;
4816 value = do_spec_2 (spec);
4818 /* Force out any unfinished command.
4819 If -pipe, this forces out the last command if it ended in `|'. */
4820 if (value == 0)
4822 if (argbuf.length () > 0
4823 && !strcmp (argbuf.last (), "|"))
4824 argbuf.pop ();
4826 set_collect_gcc_options ();
4828 if (argbuf.length () > 0)
4829 value = execute ();
4832 return value;
4835 static int
4836 do_spec_2 (const char *spec)
4838 int result;
4840 clear_args ();
4841 arg_going = 0;
4842 delete_this_arg = 0;
4843 this_is_output_file = 0;
4844 this_is_library_file = 0;
4845 this_is_linker_script = 0;
4846 input_from_pipe = 0;
4847 suffix_subst = NULL;
4849 result = do_spec_1 (spec, 0, NULL);
4851 end_going_arg ();
4853 return result;
4857 /* Process the given spec string and add any new options to the end
4858 of the switches/n_switches array. */
4860 static void
4861 do_option_spec (const char *name, const char *spec)
4863 unsigned int i, value_count, value_len;
4864 const char *p, *q, *value;
4865 char *tmp_spec, *tmp_spec_p;
4867 if (configure_default_options[0].name == NULL)
4868 return;
4870 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4871 if (strcmp (configure_default_options[i].name, name) == 0)
4872 break;
4873 if (i == ARRAY_SIZE (configure_default_options))
4874 return;
4876 value = configure_default_options[i].value;
4877 value_len = strlen (value);
4879 /* Compute the size of the final spec. */
4880 value_count = 0;
4881 p = spec;
4882 while ((p = strstr (p, "%(VALUE)")) != NULL)
4884 p ++;
4885 value_count ++;
4888 /* Replace each %(VALUE) by the specified value. */
4889 tmp_spec = (char *) alloca (strlen (spec) + 1
4890 + value_count * (value_len - strlen ("%(VALUE)")));
4891 tmp_spec_p = tmp_spec;
4892 q = spec;
4893 while ((p = strstr (q, "%(VALUE)")) != NULL)
4895 memcpy (tmp_spec_p, q, p - q);
4896 tmp_spec_p = tmp_spec_p + (p - q);
4897 memcpy (tmp_spec_p, value, value_len);
4898 tmp_spec_p += value_len;
4899 q = p + strlen ("%(VALUE)");
4901 strcpy (tmp_spec_p, q);
4903 do_self_spec (tmp_spec);
4906 /* Process the given spec string and add any new options to the end
4907 of the switches/n_switches array. */
4909 static void
4910 do_self_spec (const char *spec)
4912 int i;
4914 do_spec_2 (spec);
4915 do_spec_1 (" ", 0, NULL);
4917 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4918 do_self_specs adds the replacements to switches array, so it shouldn't
4919 be processed afterwards. */
4920 for (i = 0; i < n_switches; i++)
4921 if ((switches[i].live_cond & SWITCH_IGNORE))
4922 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4924 if (argbuf.length () > 0)
4926 const char **argbuf_copy;
4927 struct cl_decoded_option *decoded_options;
4928 struct cl_option_handlers handlers;
4929 unsigned int decoded_options_count;
4930 unsigned int j;
4932 /* Create a copy of argbuf with a dummy argv[0] entry for
4933 decode_cmdline_options_to_array. */
4934 argbuf_copy = XNEWVEC (const char *,
4935 argbuf.length () + 1);
4936 argbuf_copy[0] = "";
4937 memcpy (argbuf_copy + 1, argbuf.address (),
4938 argbuf.length () * sizeof (const char *));
4940 decode_cmdline_options_to_array (argbuf.length () + 1,
4941 argbuf_copy,
4942 CL_DRIVER, &decoded_options,
4943 &decoded_options_count);
4944 free (argbuf_copy);
4946 set_option_handlers (&handlers);
4948 for (j = 1; j < decoded_options_count; j++)
4950 switch (decoded_options[j].opt_index)
4952 case OPT_SPECIAL_input_file:
4953 /* Specs should only generate options, not input
4954 files. */
4955 if (strcmp (decoded_options[j].arg, "-") != 0)
4956 fatal_error (input_location,
4957 "switch %qs does not start with %<-%>",
4958 decoded_options[j].arg);
4959 else
4960 fatal_error (input_location,
4961 "spec-generated switch is just %<-%>");
4962 break;
4964 case OPT_fcompare_debug_second:
4965 case OPT_fcompare_debug:
4966 case OPT_fcompare_debug_:
4967 case OPT_o:
4968 /* Avoid duplicate processing of some options from
4969 compare-debug specs; just save them here. */
4970 save_switch (decoded_options[j].canonical_option[0],
4971 (decoded_options[j].canonical_option_num_elements
4972 - 1),
4973 &decoded_options[j].canonical_option[1], false, true);
4974 break;
4976 default:
4977 read_cmdline_option (&global_options, &global_options_set,
4978 decoded_options + j, UNKNOWN_LOCATION,
4979 CL_DRIVER, &handlers, global_dc);
4980 break;
4984 free (decoded_options);
4986 alloc_switch ();
4987 switches[n_switches].part1 = 0;
4991 /* Callback for processing %D and %I specs. */
4993 struct spec_path_info {
4994 const char *option;
4995 const char *append;
4996 size_t append_len;
4997 bool omit_relative;
4998 bool separate_options;
5001 static void *
5002 spec_path (char *path, void *data)
5004 struct spec_path_info *info = (struct spec_path_info *) data;
5005 size_t len = 0;
5006 char save = 0;
5008 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
5009 return NULL;
5011 if (info->append_len != 0)
5013 len = strlen (path);
5014 memcpy (path + len, info->append, info->append_len + 1);
5017 if (!is_directory (path, true))
5018 return NULL;
5020 do_spec_1 (info->option, 1, NULL);
5021 if (info->separate_options)
5022 do_spec_1 (" ", 0, NULL);
5024 if (info->append_len == 0)
5026 len = strlen (path);
5027 save = path[len - 1];
5028 if (IS_DIR_SEPARATOR (path[len - 1]))
5029 path[len - 1] = '\0';
5032 do_spec_1 (path, 1, NULL);
5033 do_spec_1 (" ", 0, NULL);
5035 /* Must not damage the original path. */
5036 if (info->append_len == 0)
5037 path[len - 1] = save;
5039 return NULL;
5042 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
5043 argument list. */
5045 static void
5046 create_at_file (char **argv)
5048 char *temp_file = make_temp_file ("");
5049 char *at_argument = concat ("@", temp_file, NULL);
5050 FILE *f = fopen (temp_file, "w");
5051 int status;
5053 if (f == NULL)
5054 fatal_error (input_location, "could not open temporary response file %s",
5055 temp_file);
5057 status = writeargv (argv, f);
5059 if (status)
5060 fatal_error (input_location,
5061 "could not write to temporary response file %s",
5062 temp_file);
5064 status = fclose (f);
5066 if (EOF == status)
5067 fatal_error (input_location, "could not close temporary response file %s",
5068 temp_file);
5070 store_arg (at_argument, 0, 0);
5072 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
5075 /* True if we should compile INFILE. */
5077 static bool
5078 compile_input_file_p (struct infile *infile)
5080 if ((!infile->language) || (infile->language[0] != '*'))
5081 if (infile->incompiler == input_file_compiler)
5082 return true;
5083 return false;
5086 /* Process each member of VEC as a spec. */
5088 static void
5089 do_specs_vec (vec<char_p> vec)
5091 unsigned ix;
5092 char *opt;
5094 FOR_EACH_VEC_ELT (vec, ix, opt)
5096 do_spec_1 (opt, 1, NULL);
5097 /* Make each accumulated option a separate argument. */
5098 do_spec_1 (" ", 0, NULL);
5102 /* Process the sub-spec SPEC as a portion of a larger spec.
5103 This is like processing a whole spec except that we do
5104 not initialize at the beginning and we do not supply a
5105 newline by default at the end.
5106 INSWITCH nonzero means don't process %-sequences in SPEC;
5107 in this case, % is treated as an ordinary character.
5108 This is used while substituting switches.
5109 INSWITCH nonzero also causes SPC not to terminate an argument.
5111 Value is zero unless a line was finished
5112 and the command on that line reported an error. */
5114 static int
5115 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
5117 const char *p = spec;
5118 int c;
5119 int i;
5120 int value;
5122 /* If it's an empty string argument to a switch, keep it as is. */
5123 if (inswitch && !*p)
5124 arg_going = 1;
5126 while ((c = *p++))
5127 /* If substituting a switch, treat all chars like letters.
5128 Otherwise, NL, SPC, TAB and % are special. */
5129 switch (inswitch ? 'a' : c)
5131 case '\n':
5132 end_going_arg ();
5134 if (argbuf.length () > 0
5135 && !strcmp (argbuf.last (), "|"))
5137 /* A `|' before the newline means use a pipe here,
5138 but only if -pipe was specified.
5139 Otherwise, execute now and don't pass the `|' as an arg. */
5140 if (use_pipes)
5142 input_from_pipe = 1;
5143 break;
5145 else
5146 argbuf.pop ();
5149 set_collect_gcc_options ();
5151 if (argbuf.length () > 0)
5153 value = execute ();
5154 if (value)
5155 return value;
5157 /* Reinitialize for a new command, and for a new argument. */
5158 clear_args ();
5159 arg_going = 0;
5160 delete_this_arg = 0;
5161 this_is_output_file = 0;
5162 this_is_library_file = 0;
5163 this_is_linker_script = 0;
5164 input_from_pipe = 0;
5165 break;
5167 case '|':
5168 end_going_arg ();
5170 /* Use pipe */
5171 obstack_1grow (&obstack, c);
5172 arg_going = 1;
5173 break;
5175 case '\t':
5176 case ' ':
5177 end_going_arg ();
5179 /* Reinitialize for a new argument. */
5180 delete_this_arg = 0;
5181 this_is_output_file = 0;
5182 this_is_library_file = 0;
5183 this_is_linker_script = 0;
5184 break;
5186 case '%':
5187 switch (c = *p++)
5189 case 0:
5190 fatal_error (input_location, "spec %qs invalid", spec);
5192 case 'b':
5193 if (save_temps_length)
5194 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
5195 else
5196 obstack_grow (&obstack, input_basename, basename_length);
5197 if (compare_debug < 0)
5198 obstack_grow (&obstack, ".gk", 3);
5199 arg_going = 1;
5200 break;
5202 case 'B':
5203 if (save_temps_length)
5204 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
5205 else
5206 obstack_grow (&obstack, input_basename, suffixed_basename_length);
5207 if (compare_debug < 0)
5208 obstack_grow (&obstack, ".gk", 3);
5209 arg_going = 1;
5210 break;
5212 case 'd':
5213 delete_this_arg = 2;
5214 break;
5216 /* Dump out the directories specified with LIBRARY_PATH,
5217 followed by the absolute directories
5218 that we search for startfiles. */
5219 case 'D':
5221 struct spec_path_info info;
5223 info.option = "-L";
5224 info.append_len = 0;
5225 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
5226 /* Used on systems which record the specified -L dirs
5227 and use them to search for dynamic linking.
5228 Relative directories always come from -B,
5229 and it is better not to use them for searching
5230 at run time. In particular, stage1 loses. */
5231 info.omit_relative = true;
5232 #else
5233 info.omit_relative = false;
5234 #endif
5235 info.separate_options = false;
5237 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
5239 break;
5241 case 'e':
5242 /* %efoo means report an error with `foo' as error message
5243 and don't execute any more commands for this file. */
5245 const char *q = p;
5246 char *buf;
5247 while (*p != 0 && *p != '\n')
5248 p++;
5249 buf = (char *) alloca (p - q + 1);
5250 strncpy (buf, q, p - q);
5251 buf[p - q] = 0;
5252 error ("%s", _(buf));
5253 return -1;
5255 break;
5256 case 'n':
5257 /* %nfoo means report a notice with `foo' on stderr. */
5259 const char *q = p;
5260 char *buf;
5261 while (*p != 0 && *p != '\n')
5262 p++;
5263 buf = (char *) alloca (p - q + 1);
5264 strncpy (buf, q, p - q);
5265 buf[p - q] = 0;
5266 inform (0, "%s", _(buf));
5267 if (*p)
5268 p++;
5270 break;
5272 case 'j':
5274 struct stat st;
5276 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
5277 defined, and it is not a directory, and it is
5278 writable, use it. Otherwise, treat this like any
5279 other temporary file. */
5281 if ((!save_temps_flag)
5282 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
5283 && (access (HOST_BIT_BUCKET, W_OK) == 0))
5285 obstack_grow (&obstack, HOST_BIT_BUCKET,
5286 strlen (HOST_BIT_BUCKET));
5287 delete_this_arg = 0;
5288 arg_going = 1;
5289 break;
5292 goto create_temp_file;
5293 case '|':
5294 if (use_pipes)
5296 obstack_1grow (&obstack, '-');
5297 delete_this_arg = 0;
5298 arg_going = 1;
5300 /* consume suffix */
5301 while (*p == '.' || ISALNUM ((unsigned char) *p))
5302 p++;
5303 if (p[0] == '%' && p[1] == 'O')
5304 p += 2;
5306 break;
5308 goto create_temp_file;
5309 case 'm':
5310 if (use_pipes)
5312 /* consume suffix */
5313 while (*p == '.' || ISALNUM ((unsigned char) *p))
5314 p++;
5315 if (p[0] == '%' && p[1] == 'O')
5316 p += 2;
5318 break;
5320 goto create_temp_file;
5321 case 'g':
5322 case 'u':
5323 case 'U':
5324 create_temp_file:
5326 struct temp_name *t;
5327 int suffix_length;
5328 const char *suffix = p;
5329 char *saved_suffix = NULL;
5331 while (*p == '.' || ISALNUM ((unsigned char) *p))
5332 p++;
5333 suffix_length = p - suffix;
5334 if (p[0] == '%' && p[1] == 'O')
5336 p += 2;
5337 /* We don't support extra suffix characters after %O. */
5338 if (*p == '.' || ISALNUM ((unsigned char) *p))
5339 fatal_error (input_location,
5340 "spec %qs has invalid %<%%0%c%>", spec, *p);
5341 if (suffix_length == 0)
5342 suffix = TARGET_OBJECT_SUFFIX;
5343 else
5345 saved_suffix
5346 = XNEWVEC (char, suffix_length
5347 + strlen (TARGET_OBJECT_SUFFIX) + 1);
5348 strncpy (saved_suffix, suffix, suffix_length);
5349 strcpy (saved_suffix + suffix_length,
5350 TARGET_OBJECT_SUFFIX);
5352 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
5355 if (compare_debug < 0)
5357 suffix = concat (".gk", suffix, NULL);
5358 suffix_length += 3;
5361 /* If -save-temps=obj and -o were specified, use that for the
5362 temp file. */
5363 if (save_temps_length)
5365 char *tmp;
5366 temp_filename_length
5367 = save_temps_length + suffix_length + 1;
5368 tmp = (char *) alloca (temp_filename_length);
5369 memcpy (tmp, save_temps_prefix, save_temps_length);
5370 memcpy (tmp + save_temps_length, suffix, suffix_length);
5371 tmp[save_temps_length + suffix_length] = '\0';
5372 temp_filename = save_string (tmp, save_temps_length
5373 + suffix_length);
5374 obstack_grow (&obstack, temp_filename,
5375 temp_filename_length);
5376 arg_going = 1;
5377 delete_this_arg = 0;
5378 break;
5381 /* If the gcc_input_filename has the same suffix specified
5382 for the %g, %u, or %U, and -save-temps is specified,
5383 we could end up using that file as an intermediate
5384 thus clobbering the user's source file (.e.g.,
5385 gcc -save-temps foo.s would clobber foo.s with the
5386 output of cpp0). So check for this condition and
5387 generate a temp file as the intermediate. */
5389 if (save_temps_flag)
5391 char *tmp;
5392 temp_filename_length = basename_length + suffix_length + 1;
5393 tmp = (char *) alloca (temp_filename_length);
5394 memcpy (tmp, input_basename, basename_length);
5395 memcpy (tmp + basename_length, suffix, suffix_length);
5396 tmp[basename_length + suffix_length] = '\0';
5397 temp_filename = tmp;
5399 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
5401 #ifndef HOST_LACKS_INODE_NUMBERS
5402 struct stat st_temp;
5404 /* Note, set_input() resets input_stat_set to 0. */
5405 if (input_stat_set == 0)
5407 input_stat_set = stat (gcc_input_filename,
5408 &input_stat);
5409 if (input_stat_set >= 0)
5410 input_stat_set = 1;
5413 /* If we have the stat for the gcc_input_filename
5414 and we can do the stat for the temp_filename
5415 then the they could still refer to the same
5416 file if st_dev/st_ino's are the same. */
5417 if (input_stat_set != 1
5418 || stat (temp_filename, &st_temp) < 0
5419 || input_stat.st_dev != st_temp.st_dev
5420 || input_stat.st_ino != st_temp.st_ino)
5421 #else
5422 /* Just compare canonical pathnames. */
5423 char* input_realname = lrealpath (gcc_input_filename);
5424 char* temp_realname = lrealpath (temp_filename);
5425 bool files_differ = filename_cmp (input_realname, temp_realname);
5426 free (input_realname);
5427 free (temp_realname);
5428 if (files_differ)
5429 #endif
5431 temp_filename
5432 = save_string (temp_filename,
5433 temp_filename_length - 1);
5434 obstack_grow (&obstack, temp_filename,
5435 temp_filename_length);
5436 arg_going = 1;
5437 delete_this_arg = 0;
5438 break;
5443 /* See if we already have an association of %g/%u/%U and
5444 suffix. */
5445 for (t = temp_names; t; t = t->next)
5446 if (t->length == suffix_length
5447 && strncmp (t->suffix, suffix, suffix_length) == 0
5448 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
5449 break;
5451 /* Make a new association if needed. %u and %j
5452 require one. */
5453 if (t == 0 || c == 'u' || c == 'j')
5455 if (t == 0)
5457 t = XNEW (struct temp_name);
5458 t->next = temp_names;
5459 temp_names = t;
5461 t->length = suffix_length;
5462 if (saved_suffix)
5464 t->suffix = saved_suffix;
5465 saved_suffix = NULL;
5467 else
5468 t->suffix = save_string (suffix, suffix_length);
5469 t->unique = (c == 'u' || c == 'U' || c == 'j');
5470 temp_filename = make_temp_file (t->suffix);
5471 temp_filename_length = strlen (temp_filename);
5472 t->filename = temp_filename;
5473 t->filename_length = temp_filename_length;
5476 free (saved_suffix);
5478 obstack_grow (&obstack, t->filename, t->filename_length);
5479 delete_this_arg = 1;
5481 arg_going = 1;
5482 break;
5484 case 'i':
5485 if (combine_inputs)
5487 if (at_file_supplied)
5489 /* We are going to expand `%i' to `@FILE', where FILE
5490 is a newly-created temporary filename. The filenames
5491 that would usually be expanded in place of %o will be
5492 written to the temporary file. */
5493 char **argv;
5494 int n_files = 0;
5495 int j;
5497 for (i = 0; i < n_infiles; i++)
5498 if (compile_input_file_p (&infiles[i]))
5499 n_files++;
5501 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5503 /* Copy the strings over. */
5504 for (i = 0, j = 0; i < n_infiles; i++)
5505 if (compile_input_file_p (&infiles[i]))
5507 argv[j] = CONST_CAST (char *, infiles[i].name);
5508 infiles[i].compiled = true;
5509 j++;
5511 argv[j] = NULL;
5513 create_at_file (argv);
5515 else
5516 for (i = 0; (int) i < n_infiles; i++)
5517 if (compile_input_file_p (&infiles[i]))
5519 store_arg (infiles[i].name, 0, 0);
5520 infiles[i].compiled = true;
5523 else
5525 obstack_grow (&obstack, gcc_input_filename,
5526 input_filename_length);
5527 arg_going = 1;
5529 break;
5531 case 'I':
5533 struct spec_path_info info;
5535 if (multilib_dir)
5537 do_spec_1 ("-imultilib", 1, NULL);
5538 /* Make this a separate argument. */
5539 do_spec_1 (" ", 0, NULL);
5540 do_spec_1 (multilib_dir, 1, NULL);
5541 do_spec_1 (" ", 0, NULL);
5544 if (multiarch_dir)
5546 do_spec_1 ("-imultiarch", 1, NULL);
5547 /* Make this a separate argument. */
5548 do_spec_1 (" ", 0, NULL);
5549 do_spec_1 (multiarch_dir, 1, NULL);
5550 do_spec_1 (" ", 0, NULL);
5553 if (gcc_exec_prefix)
5555 do_spec_1 ("-iprefix", 1, NULL);
5556 /* Make this a separate argument. */
5557 do_spec_1 (" ", 0, NULL);
5558 do_spec_1 (gcc_exec_prefix, 1, NULL);
5559 do_spec_1 (" ", 0, NULL);
5562 if (target_system_root_changed ||
5563 (target_system_root && target_sysroot_hdrs_suffix))
5565 do_spec_1 ("-isysroot", 1, NULL);
5566 /* Make this a separate argument. */
5567 do_spec_1 (" ", 0, NULL);
5568 do_spec_1 (target_system_root, 1, NULL);
5569 if (target_sysroot_hdrs_suffix)
5570 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
5571 do_spec_1 (" ", 0, NULL);
5574 info.option = "-isystem";
5575 info.append = "include";
5576 info.append_len = strlen (info.append);
5577 info.omit_relative = false;
5578 info.separate_options = true;
5580 for_each_path (&include_prefixes, false, info.append_len,
5581 spec_path, &info);
5583 info.append = "include-fixed";
5584 if (*sysroot_hdrs_suffix_spec)
5585 info.append = concat (info.append, dir_separator_str,
5586 multilib_dir, NULL);
5587 info.append_len = strlen (info.append);
5588 for_each_path (&include_prefixes, false, info.append_len,
5589 spec_path, &info);
5591 break;
5593 case 'o':
5595 int max = n_infiles;
5596 max += lang_specific_extra_outfiles;
5598 if (HAVE_GNU_LD && at_file_supplied)
5600 /* We are going to expand `%o' to `@FILE', where FILE
5601 is a newly-created temporary filename. The filenames
5602 that would usually be expanded in place of %o will be
5603 written to the temporary file. */
5605 char **argv;
5606 int n_files, j;
5608 /* Convert OUTFILES into a form suitable for writeargv. */
5610 /* Determine how many are non-NULL. */
5611 for (n_files = 0, i = 0; i < max; i++)
5612 n_files += outfiles[i] != NULL;
5614 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5616 /* Copy the strings over. */
5617 for (i = 0, j = 0; i < max; i++)
5618 if (outfiles[i])
5620 argv[j] = CONST_CAST (char *, outfiles[i]);
5621 j++;
5623 argv[j] = NULL;
5625 create_at_file (argv);
5627 else
5628 for (i = 0; i < max; i++)
5629 if (outfiles[i])
5630 store_arg (outfiles[i], 0, 0);
5631 break;
5634 case 'O':
5635 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5636 arg_going = 1;
5637 break;
5639 case 's':
5640 this_is_library_file = 1;
5641 break;
5643 case 'T':
5644 this_is_linker_script = 1;
5645 break;
5647 case 'V':
5648 outfiles[input_file_number] = NULL;
5649 break;
5651 case 'w':
5652 this_is_output_file = 1;
5653 break;
5655 case 'W':
5657 unsigned int cur_index = argbuf.length ();
5658 /* Handle the {...} following the %W. */
5659 if (*p != '{')
5660 fatal_error (input_location,
5661 "spec %qs has invalid %<%%W%c%>", spec, *p);
5662 p = handle_braces (p + 1);
5663 if (p == 0)
5664 return -1;
5665 end_going_arg ();
5666 /* If any args were output, mark the last one for deletion
5667 on failure. */
5668 if (argbuf.length () != cur_index)
5669 record_temp_file (argbuf.last (), 0, 1);
5670 break;
5673 /* %x{OPTION} records OPTION for %X to output. */
5674 case 'x':
5676 const char *p1 = p;
5677 char *string;
5678 char *opt;
5679 unsigned ix;
5681 /* Skip past the option value and make a copy. */
5682 if (*p != '{')
5683 fatal_error (input_location,
5684 "spec %qs has invalid %<%%x%c%>", spec, *p);
5685 while (*p++ != '}')
5687 string = save_string (p1 + 1, p - p1 - 2);
5689 /* See if we already recorded this option. */
5690 FOR_EACH_VEC_ELT (linker_options, ix, opt)
5691 if (! strcmp (string, opt))
5693 free (string);
5694 return 0;
5697 /* This option is new; add it. */
5698 add_linker_option (string, strlen (string));
5699 free (string);
5701 break;
5703 /* Dump out the options accumulated previously using %x. */
5704 case 'X':
5705 do_specs_vec (linker_options);
5706 break;
5708 /* Dump out the options accumulated previously using -Wa,. */
5709 case 'Y':
5710 do_specs_vec (assembler_options);
5711 break;
5713 /* Dump out the options accumulated previously using -Wp,. */
5714 case 'Z':
5715 do_specs_vec (preprocessor_options);
5716 break;
5718 /* Here are digits and numbers that just process
5719 a certain constant string as a spec. */
5721 case '1':
5722 value = do_spec_1 (cc1_spec, 0, NULL);
5723 if (value != 0)
5724 return value;
5725 break;
5727 case '2':
5728 value = do_spec_1 (cc1plus_spec, 0, NULL);
5729 if (value != 0)
5730 return value;
5731 break;
5733 case 'a':
5734 value = do_spec_1 (asm_spec, 0, NULL);
5735 if (value != 0)
5736 return value;
5737 break;
5739 case 'A':
5740 value = do_spec_1 (asm_final_spec, 0, NULL);
5741 if (value != 0)
5742 return value;
5743 break;
5745 case 'C':
5747 const char *const spec
5748 = (input_file_compiler->cpp_spec
5749 ? input_file_compiler->cpp_spec
5750 : cpp_spec);
5751 value = do_spec_1 (spec, 0, NULL);
5752 if (value != 0)
5753 return value;
5755 break;
5757 case 'E':
5758 value = do_spec_1 (endfile_spec, 0, NULL);
5759 if (value != 0)
5760 return value;
5761 break;
5763 case 'l':
5764 value = do_spec_1 (link_spec, 0, NULL);
5765 if (value != 0)
5766 return value;
5767 break;
5769 case 'L':
5770 value = do_spec_1 (lib_spec, 0, NULL);
5771 if (value != 0)
5772 return value;
5773 break;
5775 case 'M':
5776 if (multilib_os_dir == NULL)
5777 obstack_1grow (&obstack, '.');
5778 else
5779 obstack_grow (&obstack, multilib_os_dir,
5780 strlen (multilib_os_dir));
5781 break;
5783 case 'G':
5784 value = do_spec_1 (libgcc_spec, 0, NULL);
5785 if (value != 0)
5786 return value;
5787 break;
5789 case 'R':
5790 /* We assume there is a directory
5791 separator at the end of this string. */
5792 if (target_system_root)
5794 obstack_grow (&obstack, target_system_root,
5795 strlen (target_system_root));
5796 if (target_sysroot_suffix)
5797 obstack_grow (&obstack, target_sysroot_suffix,
5798 strlen (target_sysroot_suffix));
5800 break;
5802 case 'S':
5803 value = do_spec_1 (startfile_spec, 0, NULL);
5804 if (value != 0)
5805 return value;
5806 break;
5808 /* Here we define characters other than letters and digits. */
5810 case '{':
5811 p = handle_braces (p);
5812 if (p == 0)
5813 return -1;
5814 break;
5816 case ':':
5817 p = handle_spec_function (p, NULL);
5818 if (p == 0)
5819 return -1;
5820 break;
5822 case '%':
5823 obstack_1grow (&obstack, '%');
5824 break;
5826 case '.':
5828 unsigned len = 0;
5830 while (p[len] && p[len] != ' ' && p[len] != '%')
5831 len++;
5832 suffix_subst = save_string (p - 1, len + 1);
5833 p += len;
5835 break;
5837 /* Henceforth ignore the option(s) matching the pattern
5838 after the %<. */
5839 case '<':
5840 case '>':
5842 unsigned len = 0;
5843 int have_wildcard = 0;
5844 int i;
5845 int switch_option;
5847 if (c == '>')
5848 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5849 else
5850 switch_option = SWITCH_IGNORE;
5852 while (p[len] && p[len] != ' ' && p[len] != '\t')
5853 len++;
5855 if (p[len-1] == '*')
5856 have_wildcard = 1;
5858 for (i = 0; i < n_switches; i++)
5859 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5860 && (have_wildcard || switches[i].part1[len] == '\0'))
5862 switches[i].live_cond |= switch_option;
5863 /* User switch be validated from validate_all_switches.
5864 when the definition is seen from the spec file.
5865 If not defined anywhere, will be rejected. */
5866 if (switches[i].known)
5867 switches[i].validated = true;
5870 p += len;
5872 break;
5874 case '*':
5875 if (soft_matched_part)
5877 if (soft_matched_part[0])
5878 do_spec_1 (soft_matched_part, 1, NULL);
5879 /* Only insert a space after the substitution if it is at the
5880 end of the current sequence. So if:
5882 "%{foo=*:bar%*}%{foo=*:one%*two}"
5884 matches -foo=hello then it will produce:
5886 barhello onehellotwo
5888 if (*p == 0 || *p == '}')
5889 do_spec_1 (" ", 0, NULL);
5891 else
5892 /* Catch the case where a spec string contains something like
5893 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5894 hand side of the :. */
5895 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5896 break;
5898 /* Process a string found as the value of a spec given by name.
5899 This feature allows individual machine descriptions
5900 to add and use their own specs. */
5901 case '(':
5903 const char *name = p;
5904 struct spec_list *sl;
5905 int len;
5907 /* The string after the S/P is the name of a spec that is to be
5908 processed. */
5909 while (*p && *p != ')')
5910 p++;
5912 /* See if it's in the list. */
5913 for (len = p - name, sl = specs; sl; sl = sl->next)
5914 if (sl->name_len == len && !strncmp (sl->name, name, len))
5916 name = *(sl->ptr_spec);
5917 #ifdef DEBUG_SPECS
5918 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5919 sl->name, name);
5920 #endif
5921 break;
5924 if (sl)
5926 value = do_spec_1 (name, 0, NULL);
5927 if (value != 0)
5928 return value;
5931 /* Discard the closing paren. */
5932 if (*p)
5933 p++;
5935 break;
5937 default:
5938 error ("spec failure: unrecognized spec option %qc", c);
5939 break;
5941 break;
5943 case '\\':
5944 /* Backslash: treat next character as ordinary. */
5945 c = *p++;
5947 /* Fall through. */
5948 default:
5949 /* Ordinary character: put it into the current argument. */
5950 obstack_1grow (&obstack, c);
5951 arg_going = 1;
5954 /* End of string. If we are processing a spec function, we need to
5955 end any pending argument. */
5956 if (processing_spec_function)
5957 end_going_arg ();
5959 return 0;
5962 /* Look up a spec function. */
5964 static const struct spec_function *
5965 lookup_spec_function (const char *name)
5967 const struct spec_function *sf;
5969 for (sf = static_spec_functions; sf->name != NULL; sf++)
5970 if (strcmp (sf->name, name) == 0)
5971 return sf;
5973 return NULL;
5976 /* Evaluate a spec function. */
5978 static const char *
5979 eval_spec_function (const char *func, const char *args)
5981 const struct spec_function *sf;
5982 const char *funcval;
5984 /* Saved spec processing context. */
5985 vec<const_char_p> save_argbuf;
5987 int save_arg_going;
5988 int save_delete_this_arg;
5989 int save_this_is_output_file;
5990 int save_this_is_library_file;
5991 int save_input_from_pipe;
5992 int save_this_is_linker_script;
5993 const char *save_suffix_subst;
5995 int save_growing_size;
5996 void *save_growing_value = NULL;
5998 sf = lookup_spec_function (func);
5999 if (sf == NULL)
6000 fatal_error (input_location, "unknown spec function %qs", func);
6002 /* Push the spec processing context. */
6003 save_argbuf = argbuf;
6005 save_arg_going = arg_going;
6006 save_delete_this_arg = delete_this_arg;
6007 save_this_is_output_file = this_is_output_file;
6008 save_this_is_library_file = this_is_library_file;
6009 save_this_is_linker_script = this_is_linker_script;
6010 save_input_from_pipe = input_from_pipe;
6011 save_suffix_subst = suffix_subst;
6013 /* If we have some object growing now, finalize it so the args and function
6014 eval proceed from a cleared context. This is needed to prevent the first
6015 constructed arg from mistakenly including the growing value. We'll push
6016 this value back on the obstack once the function evaluation is done, to
6017 restore a consistent processing context for our caller. This is fine as
6018 the address of growing objects isn't guaranteed to remain stable until
6019 they are finalized, and we expect this situation to be rare enough for
6020 the extra copy not to be an issue. */
6021 save_growing_size = obstack_object_size (&obstack);
6022 if (save_growing_size > 0)
6023 save_growing_value = obstack_finish (&obstack);
6025 /* Create a new spec processing context, and build the function
6026 arguments. */
6028 alloc_args ();
6029 if (do_spec_2 (args) < 0)
6030 fatal_error (input_location, "error in args to spec function %qs", func);
6032 /* argbuf_index is an index for the next argument to be inserted, and
6033 so contains the count of the args already inserted. */
6035 funcval = (*sf->func) (argbuf.length (),
6036 argbuf.address ());
6038 /* Pop the spec processing context. */
6039 argbuf.release ();
6040 argbuf = save_argbuf;
6042 arg_going = save_arg_going;
6043 delete_this_arg = save_delete_this_arg;
6044 this_is_output_file = save_this_is_output_file;
6045 this_is_library_file = save_this_is_library_file;
6046 this_is_linker_script = save_this_is_linker_script;
6047 input_from_pipe = save_input_from_pipe;
6048 suffix_subst = save_suffix_subst;
6050 if (save_growing_size > 0)
6051 obstack_grow (&obstack, save_growing_value, save_growing_size);
6053 return funcval;
6056 /* Handle a spec function call of the form:
6058 %:function(args)
6060 ARGS is processed as a spec in a separate context and split into an
6061 argument vector in the normal fashion. The function returns a string
6062 containing a spec which we then process in the caller's context, or
6063 NULL if no processing is required.
6065 If RETVAL_NONNULL is not NULL, then store a bool whether function
6066 returned non-NULL. */
6068 static const char *
6069 handle_spec_function (const char *p, bool *retval_nonnull)
6071 char *func, *args;
6072 const char *endp, *funcval;
6073 int count;
6075 processing_spec_function++;
6077 /* Get the function name. */
6078 for (endp = p; *endp != '\0'; endp++)
6080 if (*endp == '(') /* ) */
6081 break;
6082 /* Only allow [A-Za-z0-9], -, and _ in function names. */
6083 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
6084 fatal_error (input_location, "malformed spec function name");
6086 if (*endp != '(') /* ) */
6087 fatal_error (input_location, "no arguments for spec function");
6088 func = save_string (p, endp - p);
6089 p = ++endp;
6091 /* Get the arguments. */
6092 for (count = 0; *endp != '\0'; endp++)
6094 /* ( */
6095 if (*endp == ')')
6097 if (count == 0)
6098 break;
6099 count--;
6101 else if (*endp == '(') /* ) */
6102 count++;
6104 /* ( */
6105 if (*endp != ')')
6106 fatal_error (input_location, "malformed spec function arguments");
6107 args = save_string (p, endp - p);
6108 p = ++endp;
6110 /* p now points to just past the end of the spec function expression. */
6112 funcval = eval_spec_function (func, args);
6113 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
6114 p = NULL;
6115 if (retval_nonnull)
6116 *retval_nonnull = funcval != NULL;
6118 free (func);
6119 free (args);
6121 processing_spec_function--;
6123 return p;
6126 /* Inline subroutine of handle_braces. Returns true if the current
6127 input suffix matches the atom bracketed by ATOM and END_ATOM. */
6128 static inline bool
6129 input_suffix_matches (const char *atom, const char *end_atom)
6131 return (input_suffix
6132 && !strncmp (input_suffix, atom, end_atom - atom)
6133 && input_suffix[end_atom - atom] == '\0');
6136 /* Subroutine of handle_braces. Returns true if the current
6137 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
6138 static bool
6139 input_spec_matches (const char *atom, const char *end_atom)
6141 return (input_file_compiler
6142 && input_file_compiler->suffix
6143 && input_file_compiler->suffix[0] != '\0'
6144 && !strncmp (input_file_compiler->suffix + 1, atom,
6145 end_atom - atom)
6146 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
6149 /* Subroutine of handle_braces. Returns true if a switch
6150 matching the atom bracketed by ATOM and END_ATOM appeared on the
6151 command line. */
6152 static bool
6153 switch_matches (const char *atom, const char *end_atom, int starred)
6155 int i;
6156 int len = end_atom - atom;
6157 int plen = starred ? len : -1;
6159 for (i = 0; i < n_switches; i++)
6160 if (!strncmp (switches[i].part1, atom, len)
6161 && (starred || switches[i].part1[len] == '\0')
6162 && check_live_switch (i, plen))
6163 return true;
6165 /* Check if a switch with separated form matching the atom.
6166 We check -D and -U switches. */
6167 else if (switches[i].args != 0)
6169 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
6170 && *switches[i].part1 == atom[0])
6172 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
6173 && (starred || (switches[i].part1[1] == '\0'
6174 && switches[i].args[0][len - 1] == '\0'))
6175 && check_live_switch (i, (starred ? 1 : -1)))
6176 return true;
6180 return false;
6183 /* Inline subroutine of handle_braces. Mark all of the switches which
6184 match ATOM (extends to END_ATOM; STARRED indicates whether there
6185 was a star after the atom) for later processing. */
6186 static inline void
6187 mark_matching_switches (const char *atom, const char *end_atom, int starred)
6189 int i;
6190 int len = end_atom - atom;
6191 int plen = starred ? len : -1;
6193 for (i = 0; i < n_switches; i++)
6194 if (!strncmp (switches[i].part1, atom, len)
6195 && (starred || switches[i].part1[len] == '\0')
6196 && check_live_switch (i, plen))
6197 switches[i].ordering = 1;
6200 /* Inline subroutine of handle_braces. Process all the currently
6201 marked switches through give_switch, and clear the marks. */
6202 static inline void
6203 process_marked_switches (void)
6205 int i;
6207 for (i = 0; i < n_switches; i++)
6208 if (switches[i].ordering == 1)
6210 switches[i].ordering = 0;
6211 give_switch (i, 0);
6215 /* Handle a %{ ... } construct. P points just inside the leading {.
6216 Returns a pointer one past the end of the brace block, or 0
6217 if we call do_spec_1 and that returns -1. */
6219 static const char *
6220 handle_braces (const char *p)
6222 const char *atom, *end_atom;
6223 const char *d_atom = NULL, *d_end_atom = NULL;
6224 const char *orig = p;
6226 bool a_is_suffix;
6227 bool a_is_spectype;
6228 bool a_is_starred;
6229 bool a_is_negated;
6230 bool a_matched;
6232 bool a_must_be_last = false;
6233 bool ordered_set = false;
6234 bool disjunct_set = false;
6235 bool disj_matched = false;
6236 bool disj_starred = true;
6237 bool n_way_choice = false;
6238 bool n_way_matched = false;
6240 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
6244 if (a_must_be_last)
6245 goto invalid;
6247 /* Scan one "atom" (S in the description above of %{}, possibly
6248 with '!', '.', '@', ',', or '*' modifiers). */
6249 a_matched = false;
6250 a_is_suffix = false;
6251 a_is_starred = false;
6252 a_is_negated = false;
6253 a_is_spectype = false;
6255 SKIP_WHITE ();
6256 if (*p == '!')
6257 p++, a_is_negated = true;
6259 SKIP_WHITE ();
6260 if (*p == '%' && p[1] == ':')
6262 atom = NULL;
6263 end_atom = NULL;
6264 p = handle_spec_function (p + 2, &a_matched);
6266 else
6268 if (*p == '.')
6269 p++, a_is_suffix = true;
6270 else if (*p == ',')
6271 p++, a_is_spectype = true;
6273 atom = p;
6274 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
6275 || *p == ',' || *p == '.' || *p == '@')
6276 p++;
6277 end_atom = p;
6279 if (*p == '*')
6280 p++, a_is_starred = 1;
6283 SKIP_WHITE ();
6284 switch (*p)
6286 case '&': case '}':
6287 /* Substitute the switch(es) indicated by the current atom. */
6288 ordered_set = true;
6289 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
6290 || a_is_spectype || atom == end_atom)
6291 goto invalid;
6293 mark_matching_switches (atom, end_atom, a_is_starred);
6295 if (*p == '}')
6296 process_marked_switches ();
6297 break;
6299 case '|': case ':':
6300 /* Substitute some text if the current atom appears as a switch
6301 or suffix. */
6302 disjunct_set = true;
6303 if (ordered_set)
6304 goto invalid;
6306 if (atom && atom == end_atom)
6308 if (!n_way_choice || disj_matched || *p == '|'
6309 || a_is_negated || a_is_suffix || a_is_spectype
6310 || a_is_starred)
6311 goto invalid;
6313 /* An empty term may appear as the last choice of an
6314 N-way choice set; it means "otherwise". */
6315 a_must_be_last = true;
6316 disj_matched = !n_way_matched;
6317 disj_starred = false;
6319 else
6321 if ((a_is_suffix || a_is_spectype) && a_is_starred)
6322 goto invalid;
6324 if (!a_is_starred)
6325 disj_starred = false;
6327 /* Don't bother testing this atom if we already have a
6328 match. */
6329 if (!disj_matched && !n_way_matched)
6331 if (atom == NULL)
6332 /* a_matched is already set by handle_spec_function. */;
6333 else if (a_is_suffix)
6334 a_matched = input_suffix_matches (atom, end_atom);
6335 else if (a_is_spectype)
6336 a_matched = input_spec_matches (atom, end_atom);
6337 else
6338 a_matched = switch_matches (atom, end_atom, a_is_starred);
6340 if (a_matched != a_is_negated)
6342 disj_matched = true;
6343 d_atom = atom;
6344 d_end_atom = end_atom;
6349 if (*p == ':')
6351 /* Found the body, that is, the text to substitute if the
6352 current disjunction matches. */
6353 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
6354 disj_matched && !n_way_matched);
6355 if (p == 0)
6356 return 0;
6358 /* If we have an N-way choice, reset state for the next
6359 disjunction. */
6360 if (*p == ';')
6362 n_way_choice = true;
6363 n_way_matched |= disj_matched;
6364 disj_matched = false;
6365 disj_starred = true;
6366 d_atom = d_end_atom = NULL;
6369 break;
6371 default:
6372 goto invalid;
6375 while (*p++ != '}');
6377 return p;
6379 invalid:
6380 fatal_error (input_location, "braced spec %qs is invalid at %qc", orig, *p);
6382 #undef SKIP_WHITE
6385 /* Subroutine of handle_braces. Scan and process a brace substitution body
6386 (X in the description of %{} syntax). P points one past the colon;
6387 ATOM and END_ATOM bracket the first atom which was found to be true
6388 (present) in the current disjunction; STARRED indicates whether all
6389 the atoms in the current disjunction were starred (for syntax validation);
6390 MATCHED indicates whether the disjunction matched or not, and therefore
6391 whether or not the body is to be processed through do_spec_1 or just
6392 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
6393 returns -1. */
6395 static const char *
6396 process_brace_body (const char *p, const char *atom, const char *end_atom,
6397 int starred, int matched)
6399 const char *body, *end_body;
6400 unsigned int nesting_level;
6401 bool have_subst = false;
6403 /* Locate the closing } or ;, honoring nested braces.
6404 Trim trailing whitespace. */
6405 body = p;
6406 nesting_level = 1;
6407 for (;;)
6409 if (*p == '{')
6410 nesting_level++;
6411 else if (*p == '}')
6413 if (!--nesting_level)
6414 break;
6416 else if (*p == ';' && nesting_level == 1)
6417 break;
6418 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
6419 have_subst = true;
6420 else if (*p == '\0')
6421 goto invalid;
6422 p++;
6425 end_body = p;
6426 while (end_body[-1] == ' ' || end_body[-1] == '\t')
6427 end_body--;
6429 if (have_subst && !starred)
6430 goto invalid;
6432 if (matched)
6434 /* Copy the substitution body to permanent storage and execute it.
6435 If have_subst is false, this is a simple matter of running the
6436 body through do_spec_1... */
6437 char *string = save_string (body, end_body - body);
6438 if (!have_subst)
6440 if (do_spec_1 (string, 0, NULL) < 0)
6442 free (string);
6443 return 0;
6446 else
6448 /* ... but if have_subst is true, we have to process the
6449 body once for each matching switch, with %* set to the
6450 variant part of the switch. */
6451 unsigned int hard_match_len = end_atom - atom;
6452 int i;
6454 for (i = 0; i < n_switches; i++)
6455 if (!strncmp (switches[i].part1, atom, hard_match_len)
6456 && check_live_switch (i, hard_match_len))
6458 if (do_spec_1 (string, 0,
6459 &switches[i].part1[hard_match_len]) < 0)
6461 free (string);
6462 return 0;
6464 /* Pass any arguments this switch has. */
6465 give_switch (i, 1);
6466 suffix_subst = NULL;
6469 free (string);
6472 return p;
6474 invalid:
6475 fatal_error (input_location, "braced spec body %qs is invalid", body);
6478 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
6479 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
6480 spec, or -1 if either exact match or %* is used.
6482 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
6483 whose value does not begin with "no-" is obsoleted by the same value
6484 with the "no-", similarly for a switch with the "no-" prefix. */
6486 static int
6487 check_live_switch (int switchnum, int prefix_length)
6489 const char *name = switches[switchnum].part1;
6490 int i;
6492 /* If we already processed this switch and determined if it was
6493 live or not, return our past determination. */
6494 if (switches[switchnum].live_cond != 0)
6495 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
6496 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
6497 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
6498 == 0);
6500 /* In the common case of {<at-most-one-letter>*}, a negating
6501 switch would always match, so ignore that case. We will just
6502 send the conflicting switches to the compiler phase. */
6503 if (prefix_length >= 0 && prefix_length <= 1)
6504 return 1;
6506 /* Now search for duplicate in a manner that depends on the name. */
6507 switch (*name)
6509 case 'O':
6510 for (i = switchnum + 1; i < n_switches; i++)
6511 if (switches[i].part1[0] == 'O')
6513 switches[switchnum].validated = true;
6514 switches[switchnum].live_cond = SWITCH_FALSE;
6515 return 0;
6517 break;
6519 case 'W': case 'f': case 'm': case 'g':
6520 if (! strncmp (name + 1, "no-", 3))
6522 /* We have Xno-YYY, search for XYYY. */
6523 for (i = switchnum + 1; i < n_switches; i++)
6524 if (switches[i].part1[0] == name[0]
6525 && ! strcmp (&switches[i].part1[1], &name[4]))
6527 /* --specs are validated with the validate_switches mechanism. */
6528 if (switches[switchnum].known)
6529 switches[switchnum].validated = true;
6530 switches[switchnum].live_cond = SWITCH_FALSE;
6531 return 0;
6534 else
6536 /* We have XYYY, search for Xno-YYY. */
6537 for (i = switchnum + 1; i < n_switches; i++)
6538 if (switches[i].part1[0] == name[0]
6539 && switches[i].part1[1] == 'n'
6540 && switches[i].part1[2] == 'o'
6541 && switches[i].part1[3] == '-'
6542 && !strcmp (&switches[i].part1[4], &name[1]))
6544 /* --specs are validated with the validate_switches mechanism. */
6545 if (switches[switchnum].known)
6546 switches[switchnum].validated = true;
6547 switches[switchnum].live_cond = SWITCH_FALSE;
6548 return 0;
6551 break;
6554 /* Otherwise the switch is live. */
6555 switches[switchnum].live_cond |= SWITCH_LIVE;
6556 return 1;
6559 /* Pass a switch to the current accumulating command
6560 in the same form that we received it.
6561 SWITCHNUM identifies the switch; it is an index into
6562 the vector of switches gcc received, which is `switches'.
6563 This cannot fail since it never finishes a command line.
6565 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
6567 static void
6568 give_switch (int switchnum, int omit_first_word)
6570 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
6571 return;
6573 if (!omit_first_word)
6575 do_spec_1 ("-", 0, NULL);
6576 do_spec_1 (switches[switchnum].part1, 1, NULL);
6579 if (switches[switchnum].args != 0)
6581 const char **p;
6582 for (p = switches[switchnum].args; *p; p++)
6584 const char *arg = *p;
6586 do_spec_1 (" ", 0, NULL);
6587 if (suffix_subst)
6589 unsigned length = strlen (arg);
6590 int dot = 0;
6592 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
6593 if (arg[length] == '.')
6595 (CONST_CAST (char *, arg))[length] = 0;
6596 dot = 1;
6597 break;
6599 do_spec_1 (arg, 1, NULL);
6600 if (dot)
6601 (CONST_CAST (char *, arg))[length] = '.';
6602 do_spec_1 (suffix_subst, 1, NULL);
6604 else
6605 do_spec_1 (arg, 1, NULL);
6609 do_spec_1 (" ", 0, NULL);
6610 switches[switchnum].validated = true;
6613 /* Print GCC configuration (e.g. version, thread model, target,
6614 configuration_arguments) to a given FILE. */
6616 static void
6617 print_configuration (FILE *file)
6619 int n;
6620 const char *thrmod;
6622 fnotice (file, "Target: %s\n", spec_machine);
6623 fnotice (file, "Configured with: %s\n", configuration_arguments);
6625 #ifdef THREAD_MODEL_SPEC
6626 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6627 but there's no point in doing all this processing just to get
6628 thread_model back. */
6629 obstack_init (&obstack);
6630 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6631 obstack_1grow (&obstack, '\0');
6632 thrmod = XOBFINISH (&obstack, const char *);
6633 #else
6634 thrmod = thread_model;
6635 #endif
6637 fnotice (file, "Thread model: %s\n", thrmod);
6639 /* compiler_version is truncated at the first space when initialized
6640 from version string, so truncate version_string at the first space
6641 before comparing. */
6642 for (n = 0; version_string[n]; n++)
6643 if (version_string[n] == ' ')
6644 break;
6646 if (! strncmp (version_string, compiler_version, n)
6647 && compiler_version[n] == 0)
6648 fnotice (file, "gcc version %s %s\n", version_string,
6649 pkgversion_string);
6650 else
6651 fnotice (file, "gcc driver version %s %sexecuting gcc version %s\n",
6652 version_string, pkgversion_string, compiler_version);
6656 #define RETRY_ICE_ATTEMPTS 3
6658 /* Returns true if FILE1 and FILE2 contain equivalent data, 0 otherwise. */
6660 static bool
6661 files_equal_p (char *file1, char *file2)
6663 struct stat st1, st2;
6664 off_t n, len;
6665 int fd1, fd2;
6666 const int bufsize = 8192;
6667 char *buf = XNEWVEC (char, bufsize);
6669 fd1 = open (file1, O_RDONLY);
6670 fd2 = open (file2, O_RDONLY);
6672 if (fd1 < 0 || fd2 < 0)
6673 goto error;
6675 if (fstat (fd1, &st1) < 0 || fstat (fd2, &st2) < 0)
6676 goto error;
6678 if (st1.st_size != st2.st_size)
6679 goto error;
6681 for (n = st1.st_size; n; n -= len)
6683 len = n;
6684 if ((int) len > bufsize / 2)
6685 len = bufsize / 2;
6687 if (read (fd1, buf, len) != (int) len
6688 || read (fd2, buf + bufsize / 2, len) != (int) len)
6690 goto error;
6693 if (memcmp (buf, buf + bufsize / 2, len) != 0)
6694 goto error;
6697 free (buf);
6698 close (fd1);
6699 close (fd2);
6701 return 1;
6703 error:
6704 free (buf);
6705 close (fd1);
6706 close (fd2);
6707 return 0;
6710 /* Check that compiler's output doesn't differ across runs.
6711 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are arrays of files, containing
6712 stdout and stderr for each compiler run. Return true if all of
6713 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are equivalent. */
6715 static bool
6716 check_repro (char **temp_stdout_files, char **temp_stderr_files)
6718 int i;
6719 for (i = 0; i < RETRY_ICE_ATTEMPTS - 2; ++i)
6721 if (!files_equal_p (temp_stdout_files[i], temp_stdout_files[i + 1])
6722 || !files_equal_p (temp_stderr_files[i], temp_stderr_files[i + 1]))
6724 fnotice (stderr, "The bug is not reproducible, so it is"
6725 " likely a hardware or OS problem.\n");
6726 break;
6729 return i == RETRY_ICE_ATTEMPTS - 2;
6732 enum attempt_status {
6733 ATTEMPT_STATUS_FAIL_TO_RUN,
6734 ATTEMPT_STATUS_SUCCESS,
6735 ATTEMPT_STATUS_ICE
6739 /* Run compiler with arguments NEW_ARGV to reproduce the ICE, storing stdout
6740 to OUT_TEMP and stderr to ERR_TEMP. If APPEND is TRUE, append to OUT_TEMP
6741 and ERR_TEMP instead of truncating. If EMIT_SYSTEM_INFO is TRUE, also write
6742 GCC configuration into to ERR_TEMP. Return ATTEMPT_STATUS_FAIL_TO_RUN if
6743 compiler failed to run, ATTEMPT_STATUS_ICE if compiled ICE-ed and
6744 ATTEMPT_STATUS_SUCCESS otherwise. */
6746 static enum attempt_status
6747 run_attempt (const char **new_argv, const char *out_temp,
6748 const char *err_temp, int emit_system_info, int append)
6751 if (emit_system_info)
6753 FILE *file_out = fopen (err_temp, "a");
6754 print_configuration (file_out);
6755 fputs ("\n", file_out);
6756 fclose (file_out);
6759 int exit_status;
6760 const char *errmsg;
6761 struct pex_obj *pex;
6762 int err;
6763 int pex_flags = PEX_USE_PIPES | PEX_LAST;
6764 enum attempt_status status = ATTEMPT_STATUS_FAIL_TO_RUN;
6766 if (append)
6767 pex_flags |= PEX_STDOUT_APPEND | PEX_STDERR_APPEND;
6769 pex = pex_init (PEX_USE_PIPES, new_argv[0], NULL);
6770 if (!pex)
6771 fatal_error (input_location, "pex_init failed: %m");
6773 errmsg = pex_run (pex, pex_flags, new_argv[0],
6774 CONST_CAST2 (char *const *, const char **, &new_argv[1]), out_temp,
6775 err_temp, &err);
6776 if (errmsg != NULL)
6778 if (err == 0)
6779 fatal_error (input_location, errmsg);
6780 else
6782 errno = err;
6783 pfatal_with_name (errmsg);
6787 if (!pex_get_status (pex, 1, &exit_status))
6788 goto out;
6790 switch (WEXITSTATUS (exit_status))
6792 case ICE_EXIT_CODE:
6793 status = ATTEMPT_STATUS_ICE;
6794 break;
6796 case SUCCESS_EXIT_CODE:
6797 status = ATTEMPT_STATUS_SUCCESS;
6798 break;
6800 default:
6804 out:
6805 pex_free (pex);
6806 return status;
6809 /* This routine reads lines from IN file, adds C++ style comments
6810 at the begining of each line and writes result into OUT. */
6812 static void
6813 insert_comments (const char *file_in, const char *file_out)
6815 FILE *in = fopen (file_in, "rb");
6816 FILE *out = fopen (file_out, "wb");
6817 char line[256];
6819 bool add_comment = true;
6820 while (fgets (line, sizeof (line), in))
6822 if (add_comment)
6823 fputs ("// ", out);
6824 fputs (line, out);
6825 add_comment = strchr (line, '\n') != NULL;
6828 fclose (in);
6829 fclose (out);
6832 /* This routine adds preprocessed source code into the given ERR_FILE.
6833 To do this, it adds "-E" to NEW_ARGV and execute RUN_ATTEMPT routine to
6834 add information in report file. RUN_ATTEMPT should return
6835 ATTEMPT_STATUS_SUCCESS, in other case we cannot generate the report. */
6837 static void
6838 do_report_bug (const char **new_argv, const int nargs,
6839 char **out_file, char **err_file)
6841 int i, status;
6842 int fd = open (*out_file, O_RDWR | O_APPEND);
6843 if (fd < 0)
6844 return;
6845 write (fd, "\n//", 3);
6846 for (i = 0; i < nargs; i++)
6848 write (fd, " ", 1);
6849 write (fd, new_argv[i], strlen (new_argv[i]));
6851 write (fd, "\n\n", 2);
6852 close (fd);
6853 new_argv[nargs] = "-E";
6854 new_argv[nargs + 1] = NULL;
6856 status = run_attempt (new_argv, *out_file, *err_file, 0, 1);
6858 if (status == ATTEMPT_STATUS_SUCCESS)
6860 fnotice (stderr, "Preprocessed source stored into %s file,"
6861 " please attach this to your bugreport.\n", *out_file);
6862 /* Make sure it is not deleted. */
6863 free (*out_file);
6864 *out_file = NULL;
6868 /* Try to reproduce ICE. If bug is reproducible, generate report .err file
6869 containing GCC configuration, backtrace, compiler's command line options
6870 and preprocessed source code. */
6872 static void
6873 try_generate_repro (const char **argv)
6875 int i, nargs, out_arg = -1, quiet = 0, attempt;
6876 const char **new_argv;
6877 char *temp_files[RETRY_ICE_ATTEMPTS * 2];
6878 char **temp_stdout_files = &temp_files[0];
6879 char **temp_stderr_files = &temp_files[RETRY_ICE_ATTEMPTS];
6881 if (gcc_input_filename == NULL || ! strcmp (gcc_input_filename, "-"))
6882 return;
6884 for (nargs = 0; argv[nargs] != NULL; ++nargs)
6885 /* Only retry compiler ICEs, not preprocessor ones. */
6886 if (! strcmp (argv[nargs], "-E"))
6887 return;
6888 else if (argv[nargs][0] == '-' && argv[nargs][1] == 'o')
6890 if (out_arg == -1)
6891 out_arg = nargs;
6892 else
6893 return;
6895 /* If the compiler is going to output any time information,
6896 it might varry between invocations. */
6897 else if (! strcmp (argv[nargs], "-quiet"))
6898 quiet = 1;
6899 else if (! strcmp (argv[nargs], "-ftime-report"))
6900 return;
6902 if (out_arg == -1 || !quiet)
6903 return;
6905 memset (temp_files, '\0', sizeof (temp_files));
6906 new_argv = XALLOCAVEC (const char *, nargs + 4);
6907 memcpy (new_argv, argv, (nargs + 1) * sizeof (const char *));
6908 new_argv[nargs++] = "-frandom-seed=0";
6909 new_argv[nargs++] = "-fdump-noaddr";
6910 new_argv[nargs] = NULL;
6911 if (new_argv[out_arg][2] == '\0')
6912 new_argv[out_arg + 1] = "-";
6913 else
6914 new_argv[out_arg] = "-o-";
6916 int status;
6917 for (attempt = 0; attempt < RETRY_ICE_ATTEMPTS; ++attempt)
6919 int emit_system_info = 0;
6920 int append = 0;
6921 temp_stdout_files[attempt] = make_temp_file (".out");
6922 temp_stderr_files[attempt] = make_temp_file (".err");
6924 if (attempt == RETRY_ICE_ATTEMPTS - 1)
6926 append = 1;
6927 emit_system_info = 1;
6930 status = run_attempt (new_argv, temp_stdout_files[attempt],
6931 temp_stderr_files[attempt], emit_system_info,
6932 append);
6934 if (status != ATTEMPT_STATUS_ICE)
6936 fnotice (stderr, "The bug is not reproducible, so it is"
6937 " likely a hardware or OS problem.\n");
6938 goto out;
6942 if (!check_repro (temp_stdout_files, temp_stderr_files))
6943 goto out;
6946 /* Insert commented out backtrace into report file. */
6947 char **stderr_commented = &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1];
6948 insert_comments (temp_stderr_files[RETRY_ICE_ATTEMPTS - 1],
6949 *stderr_commented);
6951 /* In final attempt we append compiler options and preprocesssed code to last
6952 generated .out file with configuration and backtrace. */
6953 char **output = &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1];
6954 do_report_bug (new_argv, nargs, stderr_commented, output);
6957 out:
6958 for (i = 0; i < RETRY_ICE_ATTEMPTS * 2; i++)
6959 if (temp_files[i])
6961 unlink (temp_stdout_files[i]);
6962 free (temp_stdout_files[i]);
6966 /* Search for a file named NAME trying various prefixes including the
6967 user's -B prefix and some standard ones.
6968 Return the absolute file name found. If nothing is found, return NAME. */
6970 static const char *
6971 find_file (const char *name)
6973 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
6974 return newname ? newname : name;
6977 /* Determine whether a directory exists. If LINKER, return 0 for
6978 certain fixed names not needed by the linker. */
6980 static int
6981 is_directory (const char *path1, bool linker)
6983 int len1;
6984 char *path;
6985 char *cp;
6986 struct stat st;
6988 /* Ensure the string ends with "/.". The resulting path will be a
6989 directory even if the given path is a symbolic link. */
6990 len1 = strlen (path1);
6991 path = (char *) alloca (3 + len1);
6992 memcpy (path, path1, len1);
6993 cp = path + len1;
6994 if (!IS_DIR_SEPARATOR (cp[-1]))
6995 *cp++ = DIR_SEPARATOR;
6996 *cp++ = '.';
6997 *cp = '\0';
6999 /* Exclude directories that the linker is known to search. */
7000 if (linker
7001 && IS_DIR_SEPARATOR (path[0])
7002 && ((cp - path == 6
7003 && filename_ncmp (path + 1, "lib", 3) == 0)
7004 || (cp - path == 10
7005 && filename_ncmp (path + 1, "usr", 3) == 0
7006 && IS_DIR_SEPARATOR (path[4])
7007 && filename_ncmp (path + 5, "lib", 3) == 0)))
7008 return 0;
7010 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
7013 /* Set up the various global variables to indicate that we're processing
7014 the input file named FILENAME. */
7016 void
7017 set_input (const char *filename)
7019 const char *p;
7021 gcc_input_filename = filename;
7022 input_filename_length = strlen (gcc_input_filename);
7023 input_basename = lbasename (gcc_input_filename);
7025 /* Find a suffix starting with the last period,
7026 and set basename_length to exclude that suffix. */
7027 basename_length = strlen (input_basename);
7028 suffixed_basename_length = basename_length;
7029 p = input_basename + basename_length;
7030 while (p != input_basename && *p != '.')
7031 --p;
7032 if (*p == '.' && p != input_basename)
7034 basename_length = p - input_basename;
7035 input_suffix = p + 1;
7037 else
7038 input_suffix = "";
7040 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
7041 we will need to do a stat on the gcc_input_filename. The
7042 INPUT_STAT_SET signals that the stat is needed. */
7043 input_stat_set = 0;
7046 /* On fatal signals, delete all the temporary files. */
7048 static void
7049 fatal_signal (int signum)
7051 signal (signum, SIG_DFL);
7052 delete_failure_queue ();
7053 delete_temp_files ();
7054 /* Get the same signal again, this time not handled,
7055 so its normal effect occurs. */
7056 kill (getpid (), signum);
7059 /* Compare the contents of the two files named CMPFILE[0] and
7060 CMPFILE[1]. Return zero if they're identical, nonzero
7061 otherwise. */
7063 static int
7064 compare_files (char *cmpfile[])
7066 int ret = 0;
7067 FILE *temp[2] = { NULL, NULL };
7068 int i;
7070 #if HAVE_MMAP_FILE
7072 size_t length[2];
7073 void *map[2] = { NULL, NULL };
7075 for (i = 0; i < 2; i++)
7077 struct stat st;
7079 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
7081 error ("%s: could not determine length of compare-debug file %s",
7082 gcc_input_filename, cmpfile[i]);
7083 ret = 1;
7084 break;
7087 length[i] = st.st_size;
7090 if (!ret && length[0] != length[1])
7092 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
7093 ret = 1;
7096 if (!ret)
7097 for (i = 0; i < 2; i++)
7099 int fd = open (cmpfile[i], O_RDONLY);
7100 if (fd < 0)
7102 error ("%s: could not open compare-debug file %s",
7103 gcc_input_filename, cmpfile[i]);
7104 ret = 1;
7105 break;
7108 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
7109 close (fd);
7111 if (map[i] == (void *) MAP_FAILED)
7113 ret = -1;
7114 break;
7118 if (!ret)
7120 if (memcmp (map[0], map[1], length[0]) != 0)
7122 error ("%s: -fcompare-debug failure", gcc_input_filename);
7123 ret = 1;
7127 for (i = 0; i < 2; i++)
7128 if (map[i])
7129 munmap ((caddr_t) map[i], length[i]);
7131 if (ret >= 0)
7132 return ret;
7134 ret = 0;
7136 #endif
7138 for (i = 0; i < 2; i++)
7140 temp[i] = fopen (cmpfile[i], "r");
7141 if (!temp[i])
7143 error ("%s: could not open compare-debug file %s",
7144 gcc_input_filename, cmpfile[i]);
7145 ret = 1;
7146 break;
7150 if (!ret && temp[0] && temp[1])
7151 for (;;)
7153 int c0, c1;
7154 c0 = fgetc (temp[0]);
7155 c1 = fgetc (temp[1]);
7157 if (c0 != c1)
7159 error ("%s: -fcompare-debug failure",
7160 gcc_input_filename);
7161 ret = 1;
7162 break;
7165 if (c0 == EOF)
7166 break;
7169 for (i = 1; i >= 0; i--)
7171 if (temp[i])
7172 fclose (temp[i]);
7175 return ret;
7178 driver::driver (bool can_finalize, bool debug) :
7179 explicit_link_files (NULL),
7180 decoded_options (NULL),
7181 m_option_suggestions (NULL)
7183 env.init (can_finalize, debug);
7186 driver::~driver ()
7188 XDELETEVEC (explicit_link_files);
7189 XDELETEVEC (decoded_options);
7190 if (m_option_suggestions)
7192 int i;
7193 char *str;
7194 FOR_EACH_VEC_ELT (*m_option_suggestions, i, str)
7195 free (str);
7196 delete m_option_suggestions;
7200 /* driver::main is implemented as a series of driver:: method calls. */
7203 driver::main (int argc, char **argv)
7205 bool early_exit;
7207 set_progname (argv[0]);
7208 expand_at_files (&argc, &argv);
7209 decode_argv (argc, const_cast <const char **> (argv));
7210 global_initializations ();
7211 build_multilib_strings ();
7212 set_up_specs ();
7213 putenv_COLLECT_GCC (argv[0]);
7214 maybe_putenv_COLLECT_LTO_WRAPPER ();
7215 maybe_putenv_OFFLOAD_TARGETS ();
7216 handle_unrecognized_options ();
7218 if (!maybe_print_and_exit ())
7219 return 0;
7221 early_exit = prepare_infiles ();
7222 if (early_exit)
7223 return get_exit_code ();
7225 do_spec_on_infiles ();
7226 maybe_run_linker (argv[0]);
7227 final_actions ();
7228 return get_exit_code ();
7231 /* Locate the final component of argv[0] after any leading path, and set
7232 the program name accordingly. */
7234 void
7235 driver::set_progname (const char *argv0) const
7237 const char *p = argv0 + strlen (argv0);
7238 while (p != argv0 && !IS_DIR_SEPARATOR (p[-1]))
7239 --p;
7240 progname = p;
7242 xmalloc_set_program_name (progname);
7245 /* Expand any @ files within the command-line args,
7246 setting at_file_supplied if any were expanded. */
7248 void
7249 driver::expand_at_files (int *argc, char ***argv) const
7251 char **old_argv = *argv;
7253 expandargv (argc, argv);
7255 /* Determine if any expansions were made. */
7256 if (*argv != old_argv)
7257 at_file_supplied = true;
7260 /* Decode the command-line arguments from argc/argv into the
7261 decoded_options array. */
7263 void
7264 driver::decode_argv (int argc, const char **argv)
7266 /* Register the language-independent parameters. */
7267 global_init_params ();
7268 finish_params ();
7270 init_opts_obstack ();
7271 init_options_struct (&global_options, &global_options_set);
7273 decode_cmdline_options_to_array (argc, argv,
7274 CL_DRIVER,
7275 &decoded_options, &decoded_options_count);
7278 /* Perform various initializations and setup. */
7280 void
7281 driver::global_initializations ()
7283 /* Unlock the stdio streams. */
7284 unlock_std_streams ();
7286 gcc_init_libintl ();
7288 diagnostic_initialize (global_dc, 0);
7289 diagnostic_color_init (global_dc);
7291 #ifdef GCC_DRIVER_HOST_INITIALIZATION
7292 /* Perform host dependent initialization when needed. */
7293 GCC_DRIVER_HOST_INITIALIZATION;
7294 #endif
7296 if (atexit (delete_temp_files) != 0)
7297 fatal_error (input_location, "atexit failed");
7299 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
7300 signal (SIGINT, fatal_signal);
7301 #ifdef SIGHUP
7302 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
7303 signal (SIGHUP, fatal_signal);
7304 #endif
7305 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
7306 signal (SIGTERM, fatal_signal);
7307 #ifdef SIGPIPE
7308 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
7309 signal (SIGPIPE, fatal_signal);
7310 #endif
7311 #ifdef SIGCHLD
7312 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
7313 receive the signal. A different setting is inheritable */
7314 signal (SIGCHLD, SIG_DFL);
7315 #endif
7317 /* Parsing and gimplification sometimes need quite large stack.
7318 Increase stack size limits if possible. */
7319 stack_limit_increase (64 * 1024 * 1024);
7321 /* Allocate the argument vector. */
7322 alloc_args ();
7324 obstack_init (&obstack);
7327 /* Build multilib_select, et. al from the separate lines that make up each
7328 multilib selection. */
7330 void
7331 driver::build_multilib_strings () const
7334 const char *p;
7335 const char *const *q = multilib_raw;
7336 int need_space;
7338 obstack_init (&multilib_obstack);
7339 while ((p = *q++) != (char *) 0)
7340 obstack_grow (&multilib_obstack, p, strlen (p));
7342 obstack_1grow (&multilib_obstack, 0);
7343 multilib_select = XOBFINISH (&multilib_obstack, const char *);
7345 q = multilib_matches_raw;
7346 while ((p = *q++) != (char *) 0)
7347 obstack_grow (&multilib_obstack, p, strlen (p));
7349 obstack_1grow (&multilib_obstack, 0);
7350 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
7352 q = multilib_exclusions_raw;
7353 while ((p = *q++) != (char *) 0)
7354 obstack_grow (&multilib_obstack, p, strlen (p));
7356 obstack_1grow (&multilib_obstack, 0);
7357 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
7359 q = multilib_reuse_raw;
7360 while ((p = *q++) != (char *) 0)
7361 obstack_grow (&multilib_obstack, p, strlen (p));
7363 obstack_1grow (&multilib_obstack, 0);
7364 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
7366 need_space = FALSE;
7367 for (size_t i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
7369 if (need_space)
7370 obstack_1grow (&multilib_obstack, ' ');
7371 obstack_grow (&multilib_obstack,
7372 multilib_defaults_raw[i],
7373 strlen (multilib_defaults_raw[i]));
7374 need_space = TRUE;
7377 obstack_1grow (&multilib_obstack, 0);
7378 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
7382 /* Set up the spec-handling machinery. */
7384 void
7385 driver::set_up_specs () const
7387 const char *spec_machine_suffix;
7388 char *specs_file;
7389 size_t i;
7391 #ifdef INIT_ENVIRONMENT
7392 /* Set up any other necessary machine specific environment variables. */
7393 xputenv (INIT_ENVIRONMENT);
7394 #endif
7396 /* Make a table of what switches there are (switches, n_switches).
7397 Make a table of specified input files (infiles, n_infiles).
7398 Decode switches that are handled locally. */
7400 process_command (decoded_options_count, decoded_options);
7402 /* Initialize the vector of specs to just the default.
7403 This means one element containing 0s, as a terminator. */
7405 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
7406 memcpy (compilers, default_compilers, sizeof default_compilers);
7407 n_compilers = n_default_compilers;
7409 /* Read specs from a file if there is one. */
7411 machine_suffix = concat (spec_host_machine, dir_separator_str, spec_version,
7412 accel_dir_suffix, dir_separator_str, NULL);
7413 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
7415 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
7416 /* Read the specs file unless it is a default one. */
7417 if (specs_file != 0 && strcmp (specs_file, "specs"))
7418 read_specs (specs_file, true, false);
7419 else
7420 init_spec ();
7422 #ifdef ACCEL_COMPILER
7423 spec_machine_suffix = machine_suffix;
7424 #else
7425 spec_machine_suffix = just_machine_suffix;
7426 #endif
7428 /* We need to check standard_exec_prefix/spec_machine_suffix/specs
7429 for any override of as, ld and libraries. */
7430 specs_file = (char *) alloca (strlen (standard_exec_prefix)
7431 + strlen (spec_machine_suffix) + sizeof ("specs"));
7432 strcpy (specs_file, standard_exec_prefix);
7433 strcat (specs_file, spec_machine_suffix);
7434 strcat (specs_file, "specs");
7435 if (access (specs_file, R_OK) == 0)
7436 read_specs (specs_file, true, false);
7438 /* Process any configure-time defaults specified for the command line
7439 options, via OPTION_DEFAULT_SPECS. */
7440 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
7441 do_option_spec (option_default_specs[i].name,
7442 option_default_specs[i].spec);
7444 /* Process DRIVER_SELF_SPECS, adding any new options to the end
7445 of the command line. */
7447 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
7448 do_self_spec (driver_self_specs[i]);
7450 /* If not cross-compiling, look for executables in the standard
7451 places. */
7452 if (*cross_compile == '0')
7454 if (*md_exec_prefix)
7456 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
7457 PREFIX_PRIORITY_LAST, 0, 0);
7461 /* Process sysroot_suffix_spec. */
7462 if (*sysroot_suffix_spec != 0
7463 && !no_sysroot_suffix
7464 && do_spec_2 (sysroot_suffix_spec) == 0)
7466 if (argbuf.length () > 1)
7467 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
7468 else if (argbuf.length () == 1)
7469 target_sysroot_suffix = xstrdup (argbuf.last ());
7472 #ifdef HAVE_LD_SYSROOT
7473 /* Pass the --sysroot option to the linker, if it supports that. If
7474 there is a sysroot_suffix_spec, it has already been processed by
7475 this point, so target_system_root really is the system root we
7476 should be using. */
7477 if (target_system_root)
7479 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
7480 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
7481 set_spec ("link", XOBFINISH (&obstack, const char *), false);
7483 #endif
7485 /* Process sysroot_hdrs_suffix_spec. */
7486 if (*sysroot_hdrs_suffix_spec != 0
7487 && !no_sysroot_suffix
7488 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
7490 if (argbuf.length () > 1)
7491 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
7492 else if (argbuf.length () == 1)
7493 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
7496 /* Look for startfiles in the standard places. */
7497 if (*startfile_prefix_spec != 0
7498 && do_spec_2 (startfile_prefix_spec) == 0
7499 && do_spec_1 (" ", 0, NULL) == 0)
7501 const char *arg;
7502 int ndx;
7503 FOR_EACH_VEC_ELT (argbuf, ndx, arg)
7504 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
7505 PREFIX_PRIORITY_LAST, 0, 1);
7507 /* We should eventually get rid of all these and stick to
7508 startfile_prefix_spec exclusively. */
7509 else if (*cross_compile == '0' || target_system_root)
7511 if (*md_startfile_prefix)
7512 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
7513 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7515 if (*md_startfile_prefix_1)
7516 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
7517 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7519 /* If standard_startfile_prefix is relative, base it on
7520 standard_exec_prefix. This lets us move the installed tree
7521 as a unit. If GCC_EXEC_PREFIX is defined, base
7522 standard_startfile_prefix on that as well.
7524 If the prefix is relative, only search it for native compilers;
7525 otherwise we will search a directory containing host libraries. */
7526 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
7527 add_sysrooted_prefix (&startfile_prefixes,
7528 standard_startfile_prefix, "BINUTILS",
7529 PREFIX_PRIORITY_LAST, 0, 1);
7530 else if (*cross_compile == '0')
7532 add_prefix (&startfile_prefixes,
7533 concat (gcc_exec_prefix
7534 ? gcc_exec_prefix : standard_exec_prefix,
7535 machine_suffix,
7536 standard_startfile_prefix, NULL),
7537 NULL, PREFIX_PRIORITY_LAST, 0, 1);
7540 /* Sysrooted prefixes are relocated because target_system_root is
7541 also relocated by gcc_exec_prefix. */
7542 if (*standard_startfile_prefix_1)
7543 add_sysrooted_prefix (&startfile_prefixes,
7544 standard_startfile_prefix_1, "BINUTILS",
7545 PREFIX_PRIORITY_LAST, 0, 1);
7546 if (*standard_startfile_prefix_2)
7547 add_sysrooted_prefix (&startfile_prefixes,
7548 standard_startfile_prefix_2, "BINUTILS",
7549 PREFIX_PRIORITY_LAST, 0, 1);
7552 /* Process any user specified specs in the order given on the command
7553 line. */
7554 for (struct user_specs *uptr = user_specs_head; uptr; uptr = uptr->next)
7556 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
7557 R_OK, true);
7558 read_specs (filename ? filename : uptr->filename, false, true);
7561 /* Process any user self specs. */
7563 struct spec_list *sl;
7564 for (sl = specs; sl; sl = sl->next)
7565 if (sl->name_len == sizeof "self_spec" - 1
7566 && !strcmp (sl->name, "self_spec"))
7567 do_self_spec (*sl->ptr_spec);
7570 if (compare_debug)
7572 enum save_temps save;
7574 if (!compare_debug_second)
7576 n_switches_debug_check[1] = n_switches;
7577 n_switches_alloc_debug_check[1] = n_switches_alloc;
7578 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
7579 n_switches_alloc);
7581 do_self_spec ("%:compare-debug-self-opt()");
7582 n_switches_debug_check[0] = n_switches;
7583 n_switches_alloc_debug_check[0] = n_switches_alloc;
7584 switches_debug_check[0] = switches;
7586 n_switches = n_switches_debug_check[1];
7587 n_switches_alloc = n_switches_alloc_debug_check[1];
7588 switches = switches_debug_check[1];
7591 /* Avoid crash when computing %j in this early. */
7592 save = save_temps_flag;
7593 save_temps_flag = SAVE_TEMPS_NONE;
7595 compare_debug = -compare_debug;
7596 do_self_spec ("%:compare-debug-self-opt()");
7598 save_temps_flag = save;
7600 if (!compare_debug_second)
7602 n_switches_debug_check[1] = n_switches;
7603 n_switches_alloc_debug_check[1] = n_switches_alloc;
7604 switches_debug_check[1] = switches;
7605 compare_debug = -compare_debug;
7606 n_switches = n_switches_debug_check[0];
7607 n_switches_alloc = n_switches_debug_check[0];
7608 switches = switches_debug_check[0];
7613 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
7614 if (gcc_exec_prefix)
7615 gcc_exec_prefix = concat (gcc_exec_prefix, spec_host_machine,
7616 dir_separator_str, spec_version,
7617 accel_dir_suffix, dir_separator_str, NULL);
7619 /* Now we have the specs.
7620 Set the `valid' bits for switches that match anything in any spec. */
7622 validate_all_switches ();
7624 /* Now that we have the switches and the specs, set
7625 the subdirectory based on the options. */
7626 set_multilib_dir ();
7629 /* Set up to remember the pathname of gcc and any options
7630 needed for collect. We use argv[0] instead of progname because
7631 we need the complete pathname. */
7633 void
7634 driver::putenv_COLLECT_GCC (const char *argv0) const
7636 obstack_init (&collect_obstack);
7637 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
7638 obstack_grow (&collect_obstack, argv0, strlen (argv0) + 1);
7639 xputenv (XOBFINISH (&collect_obstack, char *));
7642 /* Set up to remember the pathname of the lto wrapper. */
7644 void
7645 driver::maybe_putenv_COLLECT_LTO_WRAPPER () const
7647 char *lto_wrapper_file;
7649 if (have_c)
7650 lto_wrapper_file = NULL;
7651 else
7652 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
7653 X_OK, false);
7654 if (lto_wrapper_file)
7656 lto_wrapper_file = convert_white_space (lto_wrapper_file);
7657 lto_wrapper_spec = lto_wrapper_file;
7658 obstack_init (&collect_obstack);
7659 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
7660 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
7661 obstack_grow (&collect_obstack, lto_wrapper_spec,
7662 strlen (lto_wrapper_spec) + 1);
7663 xputenv (XOBFINISH (&collect_obstack, char *));
7668 /* Set up to remember the names of offload targets. */
7670 void
7671 driver::maybe_putenv_OFFLOAD_TARGETS () const
7673 if (offload_targets && offload_targets[0] != '\0')
7675 obstack_grow (&collect_obstack, "OFFLOAD_TARGET_NAMES=",
7676 sizeof ("OFFLOAD_TARGET_NAMES=") - 1);
7677 obstack_grow (&collect_obstack, offload_targets,
7678 strlen (offload_targets) + 1);
7679 xputenv (XOBFINISH (&collect_obstack, char *));
7682 free (offload_targets);
7683 offload_targets = NULL;
7686 /* Helper function for driver::suggest_option. Populate
7687 m_option_suggestions with candidate strings for misspelled options.
7688 The strings will be freed by the driver's dtor. */
7690 void
7691 driver::build_option_suggestions (void)
7693 gcc_assert (m_option_suggestions == NULL);
7694 m_option_suggestions = new auto_vec <char *> ();
7696 /* We build a vec of m_option_suggestions, using add_misspelling_candidates
7697 to add copies of strings, without a leading dash. */
7699 for (unsigned int i = 0; i < cl_options_count; i++)
7701 const struct cl_option *option = &cl_options[i];
7702 const char *opt_text = option->opt_text;
7703 switch (i)
7705 default:
7706 if (option->var_type == CLVC_ENUM)
7708 const struct cl_enum *e = &cl_enums[option->var_enum];
7709 for (unsigned j = 0; e->values[j].arg != NULL; j++)
7711 char *with_arg = concat (opt_text, e->values[j].arg, NULL);
7712 add_misspelling_candidates (m_option_suggestions, option,
7713 with_arg);
7714 free (with_arg);
7717 else
7718 add_misspelling_candidates (m_option_suggestions, option,
7719 opt_text);
7720 break;
7722 case OPT_fsanitize_:
7723 case OPT_fsanitize_recover_:
7724 /* -fsanitize= and -fsanitize-recover= can take
7725 a comma-separated list of arguments. Given that combinations
7726 are supported, we can't add all potential candidates to the
7727 vec, but if we at least add them individually without commas,
7728 we should do a better job e.g. correcting
7729 "-sanitize=address"
7731 "-fsanitize=address"
7732 rather than to "-Wframe-address" (PR driver/69265). */
7734 for (int j = 0; sanitizer_opts[j].name != NULL; ++j)
7736 /* Get one arg at a time e.g. "-fsanitize=address". */
7737 char *with_arg = concat (opt_text,
7738 sanitizer_opts[j].name,
7739 NULL);
7740 /* Add with_arg and all of its variant spellings e.g.
7741 "-fno-sanitize=address" to candidates (albeit without
7742 leading dashes). */
7743 add_misspelling_candidates (m_option_suggestions, option,
7744 with_arg);
7745 free (with_arg);
7748 break;
7753 /* Helper function for driver::handle_unrecognized_options.
7755 Given an unrecognized option BAD_OPT (without the leading dash),
7756 locate the closest reasonable matching option (again, without the
7757 leading dash), or NULL.
7759 The returned string is owned by the driver instance. */
7761 const char *
7762 driver::suggest_option (const char *bad_opt)
7764 /* Lazily populate m_option_suggestions. */
7765 if (!m_option_suggestions)
7766 build_option_suggestions ();
7767 gcc_assert (m_option_suggestions);
7769 /* "m_option_suggestions" is now populated. Use it. */
7770 return find_closest_string
7771 (bad_opt,
7772 (auto_vec <const char *> *) m_option_suggestions);
7775 /* Reject switches that no pass was interested in. */
7777 void
7778 driver::handle_unrecognized_options ()
7780 for (size_t i = 0; (int) i < n_switches; i++)
7781 if (! switches[i].validated)
7783 const char *hint = suggest_option (switches[i].part1);
7784 if (hint)
7785 error ("unrecognized command line option %<-%s%>;"
7786 " did you mean %<-%s%>?",
7787 switches[i].part1, hint);
7788 else
7789 error ("unrecognized command line option %<-%s%>",
7790 switches[i].part1);
7794 /* Handle the various -print-* options, returning 0 if the driver
7795 should exit, or nonzero if the driver should continue. */
7798 driver::maybe_print_and_exit () const
7800 if (print_search_dirs)
7802 printf (_("install: %s%s\n"),
7803 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
7804 gcc_exec_prefix ? "" : machine_suffix);
7805 printf (_("programs: %s\n"),
7806 build_search_list (&exec_prefixes, "", false, false));
7807 printf (_("libraries: %s\n"),
7808 build_search_list (&startfile_prefixes, "", false, true));
7809 return (0);
7812 if (print_file_name)
7814 printf ("%s\n", find_file (print_file_name));
7815 return (0);
7818 if (print_prog_name)
7820 if (use_ld != NULL && ! strcmp (print_prog_name, "ld"))
7822 /* Append USE_LD to the default linker. */
7823 #ifdef DEFAULT_LINKER
7824 char *ld;
7825 # ifdef HAVE_HOST_EXECUTABLE_SUFFIX
7826 int len = (sizeof (DEFAULT_LINKER)
7827 - sizeof (HOST_EXECUTABLE_SUFFIX));
7828 ld = NULL;
7829 if (len > 0)
7831 char *default_linker = xstrdup (DEFAULT_LINKER);
7832 /* Strip HOST_EXECUTABLE_SUFFIX if DEFAULT_LINKER contains
7833 HOST_EXECUTABLE_SUFFIX. */
7834 if (! strcmp (&default_linker[len], HOST_EXECUTABLE_SUFFIX))
7836 default_linker[len] = '\0';
7837 ld = concat (default_linker, use_ld,
7838 HOST_EXECUTABLE_SUFFIX, NULL);
7841 if (ld == NULL)
7842 # endif
7843 ld = concat (DEFAULT_LINKER, use_ld, NULL);
7844 if (access (ld, X_OK) == 0)
7846 printf ("%s\n", ld);
7847 return (0);
7849 #endif
7850 print_prog_name = concat (print_prog_name, use_ld, NULL);
7852 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
7853 printf ("%s\n", (newname ? newname : print_prog_name));
7854 return (0);
7857 if (print_multi_lib)
7859 print_multilib_info ();
7860 return (0);
7863 if (print_multi_directory)
7865 if (multilib_dir == NULL)
7866 printf (".\n");
7867 else
7868 printf ("%s\n", multilib_dir);
7869 return (0);
7872 if (print_multiarch)
7874 if (multiarch_dir == NULL)
7875 printf ("\n");
7876 else
7877 printf ("%s\n", multiarch_dir);
7878 return (0);
7881 if (print_sysroot)
7883 if (target_system_root)
7885 if (target_sysroot_suffix)
7886 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
7887 else
7888 printf ("%s\n", target_system_root);
7890 return (0);
7893 if (print_multi_os_directory)
7895 if (multilib_os_dir == NULL)
7896 printf (".\n");
7897 else
7898 printf ("%s\n", multilib_os_dir);
7899 return (0);
7902 if (print_sysroot_headers_suffix)
7904 if (*sysroot_hdrs_suffix_spec)
7906 printf("%s\n", (target_sysroot_hdrs_suffix
7907 ? target_sysroot_hdrs_suffix
7908 : ""));
7909 return (0);
7911 else
7912 /* The error status indicates that only one set of fixed
7913 headers should be built. */
7914 fatal_error (input_location,
7915 "not configured with sysroot headers suffix");
7918 if (print_help_list)
7920 display_help ();
7922 if (! verbose_flag)
7924 printf (_("\nFor bug reporting instructions, please see:\n"));
7925 printf ("%s.\n", bug_report_url);
7927 return (0);
7930 /* We do not exit here. Instead we have created a fake input file
7931 called 'help-dummy' which needs to be compiled, and we pass this
7932 on the various sub-processes, along with the --help switch.
7933 Ensure their output appears after ours. */
7934 fputc ('\n', stdout);
7935 fflush (stdout);
7938 if (print_version)
7940 printf (_("%s %s%s\n"), progname, pkgversion_string,
7941 version_string);
7942 printf ("Copyright %s 2016 Free Software Foundation, Inc.\n",
7943 _("(C)"));
7944 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
7945 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
7946 stdout);
7947 if (! verbose_flag)
7948 return 0;
7950 /* We do not exit here. We use the same mechanism of --help to print
7951 the version of the sub-processes. */
7952 fputc ('\n', stdout);
7953 fflush (stdout);
7956 if (verbose_flag)
7958 print_configuration (stderr);
7959 if (n_infiles == 0)
7960 return (0);
7963 return 1;
7966 /* Figure out what to do with each input file.
7967 Return true if we need to exit early from "main", false otherwise. */
7969 bool
7970 driver::prepare_infiles ()
7972 size_t i;
7973 int lang_n_infiles = 0;
7975 if (n_infiles == added_libraries)
7976 fatal_error (input_location, "no input files");
7978 if (seen_error ())
7979 /* Early exit needed from main. */
7980 return true;
7982 /* Make a place to record the compiler output file names
7983 that correspond to the input files. */
7985 i = n_infiles;
7986 i += lang_specific_extra_outfiles;
7987 outfiles = XCNEWVEC (const char *, i);
7989 /* Record which files were specified explicitly as link input. */
7991 explicit_link_files = XCNEWVEC (char, n_infiles);
7993 combine_inputs = have_o || flag_wpa;
7995 for (i = 0; (int) i < n_infiles; i++)
7997 const char *name = infiles[i].name;
7998 struct compiler *compiler = lookup_compiler (name,
7999 strlen (name),
8000 infiles[i].language);
8002 if (compiler && !(compiler->combinable))
8003 combine_inputs = false;
8005 if (lang_n_infiles > 0 && compiler != input_file_compiler
8006 && infiles[i].language && infiles[i].language[0] != '*')
8007 infiles[i].incompiler = compiler;
8008 else if (compiler)
8010 lang_n_infiles++;
8011 input_file_compiler = compiler;
8012 infiles[i].incompiler = compiler;
8014 else
8016 /* Since there is no compiler for this input file, assume it is a
8017 linker file. */
8018 explicit_link_files[i] = 1;
8019 infiles[i].incompiler = NULL;
8021 infiles[i].compiled = false;
8022 infiles[i].preprocessed = false;
8025 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
8026 fatal_error (input_location,
8027 "cannot specify -o with -c, -S or -E with multiple files");
8029 /* No early exit needed from main; we can continue. */
8030 return false;
8033 /* Run the spec machinery on each input file. */
8035 void
8036 driver::do_spec_on_infiles () const
8038 size_t i;
8040 for (i = 0; (int) i < n_infiles; i++)
8042 int this_file_error = 0;
8044 /* Tell do_spec what to substitute for %i. */
8046 input_file_number = i;
8047 set_input (infiles[i].name);
8049 if (infiles[i].compiled)
8050 continue;
8052 /* Use the same thing in %o, unless cp->spec says otherwise. */
8054 outfiles[i] = gcc_input_filename;
8056 /* Figure out which compiler from the file's suffix. */
8058 input_file_compiler
8059 = lookup_compiler (infiles[i].name, input_filename_length,
8060 infiles[i].language);
8062 if (input_file_compiler)
8064 /* Ok, we found an applicable compiler. Run its spec. */
8066 if (input_file_compiler->spec[0] == '#')
8068 error ("%s: %s compiler not installed on this system",
8069 gcc_input_filename, &input_file_compiler->spec[1]);
8070 this_file_error = 1;
8072 else
8074 int value;
8076 if (compare_debug)
8078 free (debug_check_temp_file[0]);
8079 debug_check_temp_file[0] = NULL;
8081 free (debug_check_temp_file[1]);
8082 debug_check_temp_file[1] = NULL;
8085 value = do_spec (input_file_compiler->spec);
8086 infiles[i].compiled = true;
8087 if (value < 0)
8088 this_file_error = 1;
8089 else if (compare_debug && debug_check_temp_file[0])
8091 if (verbose_flag)
8092 inform (0, "recompiling with -fcompare-debug");
8094 compare_debug = -compare_debug;
8095 n_switches = n_switches_debug_check[1];
8096 n_switches_alloc = n_switches_alloc_debug_check[1];
8097 switches = switches_debug_check[1];
8099 value = do_spec (input_file_compiler->spec);
8101 compare_debug = -compare_debug;
8102 n_switches = n_switches_debug_check[0];
8103 n_switches_alloc = n_switches_alloc_debug_check[0];
8104 switches = switches_debug_check[0];
8106 if (value < 0)
8108 error ("during -fcompare-debug recompilation");
8109 this_file_error = 1;
8112 gcc_assert (debug_check_temp_file[1]
8113 && filename_cmp (debug_check_temp_file[0],
8114 debug_check_temp_file[1]));
8116 if (verbose_flag)
8117 inform (0, "comparing final insns dumps");
8119 if (compare_files (debug_check_temp_file))
8120 this_file_error = 1;
8123 if (compare_debug)
8125 free (debug_check_temp_file[0]);
8126 debug_check_temp_file[0] = NULL;
8128 free (debug_check_temp_file[1]);
8129 debug_check_temp_file[1] = NULL;
8134 /* If this file's name does not contain a recognized suffix,
8135 record it as explicit linker input. */
8137 else
8138 explicit_link_files[i] = 1;
8140 /* Clear the delete-on-failure queue, deleting the files in it
8141 if this compilation failed. */
8143 if (this_file_error)
8145 delete_failure_queue ();
8146 errorcount++;
8148 /* If this compilation succeeded, don't delete those files later. */
8149 clear_failure_queue ();
8152 /* Reset the input file name to the first compile/object file name, for use
8153 with %b in LINK_SPEC. We use the first input file that we can find
8154 a compiler to compile it instead of using infiles.language since for
8155 languages other than C we use aliases that we then lookup later. */
8156 if (n_infiles > 0)
8158 int i;
8160 for (i = 0; i < n_infiles ; i++)
8161 if (infiles[i].incompiler
8162 || (infiles[i].language && infiles[i].language[0] != '*'))
8164 set_input (infiles[i].name);
8165 break;
8169 if (!seen_error ())
8171 /* Make sure INPUT_FILE_NUMBER points to first available open
8172 slot. */
8173 input_file_number = n_infiles;
8174 if (lang_specific_pre_link ())
8175 errorcount++;
8179 /* If we have to run the linker, do it now. */
8181 void
8182 driver::maybe_run_linker (const char *argv0) const
8184 size_t i;
8185 int linker_was_run = 0;
8186 int num_linker_inputs;
8188 /* Determine if there are any linker input files. */
8189 num_linker_inputs = 0;
8190 for (i = 0; (int) i < n_infiles; i++)
8191 if (explicit_link_files[i] || outfiles[i] != NULL)
8192 num_linker_inputs++;
8194 /* Run ld to link all the compiler output files. */
8196 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
8198 int tmp = execution_count;
8200 if (! have_c)
8202 #if HAVE_LTO_PLUGIN > 0
8203 #if HAVE_LTO_PLUGIN == 2
8204 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
8205 #else
8206 const char *fuse_linker_plugin = "fuse-linker-plugin";
8207 #endif
8208 #endif
8210 /* We'll use ld if we can't find collect2. */
8211 if (! strcmp (linker_name_spec, "collect2"))
8213 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
8214 if (s == NULL)
8215 linker_name_spec = "ld";
8218 #if HAVE_LTO_PLUGIN > 0
8219 #if HAVE_LTO_PLUGIN == 2
8220 if (!switch_matches (fno_use_linker_plugin,
8221 fno_use_linker_plugin
8222 + strlen (fno_use_linker_plugin), 0))
8223 #else
8224 if (switch_matches (fuse_linker_plugin,
8225 fuse_linker_plugin
8226 + strlen (fuse_linker_plugin), 0))
8227 #endif
8229 char *temp_spec = find_a_file (&exec_prefixes,
8230 LTOPLUGINSONAME, R_OK,
8231 false);
8232 if (!temp_spec)
8233 fatal_error (input_location,
8234 "-fuse-linker-plugin, but %s not found",
8235 LTOPLUGINSONAME);
8236 linker_plugin_file_spec = convert_white_space (temp_spec);
8238 #endif
8239 lto_gcc_spec = argv0;
8242 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
8243 for collect. */
8244 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
8245 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
8247 if (print_subprocess_help == 1)
8249 printf (_("\nLinker options\n==============\n\n"));
8250 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
8251 " to the linker.\n\n"));
8252 fflush (stdout);
8254 int value = do_spec (link_command_spec);
8255 if (value < 0)
8256 errorcount = 1;
8257 linker_was_run = (tmp != execution_count);
8260 /* If options said don't run linker,
8261 complain about input files to be given to the linker. */
8263 if (! linker_was_run && !seen_error ())
8264 for (i = 0; (int) i < n_infiles; i++)
8265 if (explicit_link_files[i]
8266 && !(infiles[i].language && infiles[i].language[0] == '*'))
8267 warning (0, "%s: linker input file unused because linking not done",
8268 outfiles[i]);
8271 /* The end of "main". */
8273 void
8274 driver::final_actions () const
8276 /* Delete some or all of the temporary files we made. */
8278 if (seen_error ())
8279 delete_failure_queue ();
8280 delete_temp_files ();
8282 if (print_help_list)
8284 printf (("\nFor bug reporting instructions, please see:\n"));
8285 printf ("%s\n", bug_report_url);
8289 /* Determine what the exit code of the driver should be. */
8292 driver::get_exit_code () const
8294 return (signal_count != 0 ? 2
8295 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
8296 : 0);
8299 /* Find the proper compilation spec for the file name NAME,
8300 whose length is LENGTH. LANGUAGE is the specified language,
8301 or 0 if this file is to be passed to the linker. */
8303 static struct compiler *
8304 lookup_compiler (const char *name, size_t length, const char *language)
8306 struct compiler *cp;
8308 /* If this was specified by the user to be a linker input, indicate that. */
8309 if (language != 0 && language[0] == '*')
8310 return 0;
8312 /* Otherwise, look for the language, if one is spec'd. */
8313 if (language != 0)
8315 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8316 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
8317 return cp;
8319 error ("language %s not recognized", language);
8320 return 0;
8323 /* Look for a suffix. */
8324 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8326 if (/* The suffix `-' matches only the file name `-'. */
8327 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
8328 || (strlen (cp->suffix) < length
8329 /* See if the suffix matches the end of NAME. */
8330 && !strcmp (cp->suffix,
8331 name + length - strlen (cp->suffix))
8333 break;
8336 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
8337 /* Look again, but case-insensitively this time. */
8338 if (cp < compilers)
8339 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8341 if (/* The suffix `-' matches only the file name `-'. */
8342 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
8343 || (strlen (cp->suffix) < length
8344 /* See if the suffix matches the end of NAME. */
8345 && ((!strcmp (cp->suffix,
8346 name + length - strlen (cp->suffix))
8347 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
8348 && !strcasecmp (cp->suffix,
8349 name + length - strlen (cp->suffix)))
8351 break;
8353 #endif
8355 if (cp >= compilers)
8357 if (cp->spec[0] != '@')
8358 /* A non-alias entry: return it. */
8359 return cp;
8361 /* An alias entry maps a suffix to a language.
8362 Search for the language; pass 0 for NAME and LENGTH
8363 to avoid infinite recursion if language not found. */
8364 return lookup_compiler (NULL, 0, cp->spec + 1);
8366 return 0;
8369 static char *
8370 save_string (const char *s, int len)
8372 char *result = XNEWVEC (char, len + 1);
8374 gcc_checking_assert (strlen (s) >= (unsigned int) len);
8375 memcpy (result, s, len);
8376 result[len] = 0;
8377 return result;
8380 void
8381 pfatal_with_name (const char *name)
8383 perror_with_name (name);
8384 delete_temp_files ();
8385 exit (1);
8388 static void
8389 perror_with_name (const char *name)
8391 error ("%s: %m", name);
8394 static inline void
8395 validate_switches_from_spec (const char *spec, bool user)
8397 const char *p = spec;
8398 char c;
8399 while ((c = *p++))
8400 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
8401 /* We have a switch spec. */
8402 p = validate_switches (p + 1, user);
8405 static void
8406 validate_all_switches (void)
8408 struct compiler *comp;
8409 struct spec_list *spec;
8411 for (comp = compilers; comp->spec; comp++)
8412 validate_switches_from_spec (comp->spec, false);
8414 /* Look through the linked list of specs read from the specs file. */
8415 for (spec = specs; spec; spec = spec->next)
8416 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
8418 validate_switches_from_spec (link_command_spec, false);
8421 /* Look at the switch-name that comes after START
8422 and mark as valid all supplied switches that match it. */
8424 static const char *
8425 validate_switches (const char *start, bool user_spec)
8427 const char *p = start;
8428 const char *atom;
8429 size_t len;
8430 int i;
8431 bool suffix = false;
8432 bool starred = false;
8434 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
8436 next_member:
8437 SKIP_WHITE ();
8439 if (*p == '!')
8440 p++;
8442 SKIP_WHITE ();
8443 if (*p == '.' || *p == ',')
8444 suffix = true, p++;
8446 atom = p;
8447 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
8448 || *p == ',' || *p == '.' || *p == '@')
8449 p++;
8450 len = p - atom;
8452 if (*p == '*')
8453 starred = true, p++;
8455 SKIP_WHITE ();
8457 if (!suffix)
8459 /* Mark all matching switches as valid. */
8460 for (i = 0; i < n_switches; i++)
8461 if (!strncmp (switches[i].part1, atom, len)
8462 && (starred || switches[i].part1[len] == '\0')
8463 && (switches[i].known || user_spec))
8464 switches[i].validated = true;
8467 if (*p) p++;
8468 if (*p && (p[-1] == '|' || p[-1] == '&'))
8469 goto next_member;
8471 if (*p && p[-1] == ':')
8473 while (*p && *p != ';' && *p != '}')
8475 if (*p == '%')
8477 p++;
8478 if (*p == '{' || *p == '<')
8479 p = validate_switches (p+1, user_spec);
8480 else if (p[0] == 'W' && p[1] == '{')
8481 p = validate_switches (p+2, user_spec);
8483 else
8484 p++;
8487 if (*p) p++;
8488 if (*p && p[-1] == ';')
8489 goto next_member;
8492 return p;
8493 #undef SKIP_WHITE
8496 struct mdswitchstr
8498 const char *str;
8499 int len;
8502 static struct mdswitchstr *mdswitches;
8503 static int n_mdswitches;
8505 /* Check whether a particular argument was used. The first time we
8506 canonicalize the switches to keep only the ones we care about. */
8508 class used_arg_t
8510 public:
8511 int operator () (const char *p, int len);
8512 void finalize ();
8514 private:
8515 struct mswitchstr
8517 const char *str;
8518 const char *replace;
8519 int len;
8520 int rep_len;
8523 mswitchstr *mswitches;
8524 int n_mswitches;
8528 used_arg_t used_arg;
8531 used_arg_t::operator () (const char *p, int len)
8533 int i, j;
8535 if (!mswitches)
8537 struct mswitchstr *matches;
8538 const char *q;
8539 int cnt = 0;
8541 /* Break multilib_matches into the component strings of string
8542 and replacement string. */
8543 for (q = multilib_matches; *q != '\0'; q++)
8544 if (*q == ';')
8545 cnt++;
8547 matches
8548 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
8549 i = 0;
8550 q = multilib_matches;
8551 while (*q != '\0')
8553 matches[i].str = q;
8554 while (*q != ' ')
8556 if (*q == '\0')
8558 invalid_matches:
8559 fatal_error (input_location, "multilib spec %qs is invalid",
8560 multilib_matches);
8562 q++;
8564 matches[i].len = q - matches[i].str;
8566 matches[i].replace = ++q;
8567 while (*q != ';' && *q != '\0')
8569 if (*q == ' ')
8570 goto invalid_matches;
8571 q++;
8573 matches[i].rep_len = q - matches[i].replace;
8574 i++;
8575 if (*q == ';')
8576 q++;
8579 /* Now build a list of the replacement string for switches that we care
8580 about. Make sure we allocate at least one entry. This prevents
8581 xmalloc from calling fatal, and prevents us from re-executing this
8582 block of code. */
8583 mswitches
8584 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
8585 for (i = 0; i < n_switches; i++)
8586 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
8588 int xlen = strlen (switches[i].part1);
8589 for (j = 0; j < cnt; j++)
8590 if (xlen == matches[j].len
8591 && ! strncmp (switches[i].part1, matches[j].str, xlen))
8593 mswitches[n_mswitches].str = matches[j].replace;
8594 mswitches[n_mswitches].len = matches[j].rep_len;
8595 mswitches[n_mswitches].replace = (char *) 0;
8596 mswitches[n_mswitches].rep_len = 0;
8597 n_mswitches++;
8598 break;
8602 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
8603 on the command line nor any options mutually incompatible with
8604 them. */
8605 for (i = 0; i < n_mdswitches; i++)
8607 const char *r;
8609 for (q = multilib_options; *q != '\0'; *q && q++)
8611 while (*q == ' ')
8612 q++;
8614 r = q;
8615 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
8616 || strchr (" /", q[mdswitches[i].len]) == NULL)
8618 while (*q != ' ' && *q != '/' && *q != '\0')
8619 q++;
8620 if (*q != '/')
8621 break;
8622 q++;
8625 if (*q != ' ' && *q != '\0')
8627 while (*r != ' ' && *r != '\0')
8629 q = r;
8630 while (*q != ' ' && *q != '/' && *q != '\0')
8631 q++;
8633 if (used_arg (r, q - r))
8634 break;
8636 if (*q != '/')
8638 mswitches[n_mswitches].str = mdswitches[i].str;
8639 mswitches[n_mswitches].len = mdswitches[i].len;
8640 mswitches[n_mswitches].replace = (char *) 0;
8641 mswitches[n_mswitches].rep_len = 0;
8642 n_mswitches++;
8643 break;
8646 r = q + 1;
8648 break;
8654 for (i = 0; i < n_mswitches; i++)
8655 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
8656 return 1;
8658 return 0;
8661 void used_arg_t::finalize ()
8663 XDELETEVEC (mswitches);
8664 mswitches = NULL;
8665 n_mswitches = 0;
8669 static int
8670 default_arg (const char *p, int len)
8672 int i;
8674 for (i = 0; i < n_mdswitches; i++)
8675 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
8676 return 1;
8678 return 0;
8681 /* Work out the subdirectory to use based on the options. The format of
8682 multilib_select is a list of elements. Each element is a subdirectory
8683 name followed by a list of options followed by a semicolon. The format
8684 of multilib_exclusions is the same, but without the preceding
8685 directory. First gcc will check the exclusions, if none of the options
8686 beginning with an exclamation point are present, and all of the other
8687 options are present, then we will ignore this completely. Passing
8688 that, gcc will consider each multilib_select in turn using the same
8689 rules for matching the options. If a match is found, that subdirectory
8690 will be used.
8691 A subdirectory name is optionally followed by a colon and the corresponding
8692 multiarch name. */
8694 static void
8695 set_multilib_dir (void)
8697 const char *p;
8698 unsigned int this_path_len;
8699 const char *this_path, *this_arg;
8700 const char *start, *end;
8701 int not_arg;
8702 int ok, ndfltok, first;
8704 n_mdswitches = 0;
8705 start = multilib_defaults;
8706 while (*start == ' ' || *start == '\t')
8707 start++;
8708 while (*start != '\0')
8710 n_mdswitches++;
8711 while (*start != ' ' && *start != '\t' && *start != '\0')
8712 start++;
8713 while (*start == ' ' || *start == '\t')
8714 start++;
8717 if (n_mdswitches)
8719 int i = 0;
8721 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
8722 for (start = multilib_defaults; *start != '\0'; start = end + 1)
8724 while (*start == ' ' || *start == '\t')
8725 start++;
8727 if (*start == '\0')
8728 break;
8730 for (end = start + 1;
8731 *end != ' ' && *end != '\t' && *end != '\0'; end++)
8734 obstack_grow (&multilib_obstack, start, end - start);
8735 obstack_1grow (&multilib_obstack, 0);
8736 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
8737 mdswitches[i++].len = end - start;
8739 if (*end == '\0')
8740 break;
8744 p = multilib_exclusions;
8745 while (*p != '\0')
8747 /* Ignore newlines. */
8748 if (*p == '\n')
8750 ++p;
8751 continue;
8754 /* Check the arguments. */
8755 ok = 1;
8756 while (*p != ';')
8758 if (*p == '\0')
8760 invalid_exclusions:
8761 fatal_error (input_location, "multilib exclusions %qs is invalid",
8762 multilib_exclusions);
8765 if (! ok)
8767 ++p;
8768 continue;
8771 this_arg = p;
8772 while (*p != ' ' && *p != ';')
8774 if (*p == '\0')
8775 goto invalid_exclusions;
8776 ++p;
8779 if (*this_arg != '!')
8780 not_arg = 0;
8781 else
8783 not_arg = 1;
8784 ++this_arg;
8787 ok = used_arg (this_arg, p - this_arg);
8788 if (not_arg)
8789 ok = ! ok;
8791 if (*p == ' ')
8792 ++p;
8795 if (ok)
8796 return;
8798 ++p;
8801 first = 1;
8802 p = multilib_select;
8804 /* Append multilib reuse rules if any. With those rules, we can reuse
8805 one multilib for certain different options sets. */
8806 if (strlen (multilib_reuse) > 0)
8807 p = concat (p, multilib_reuse, NULL);
8809 while (*p != '\0')
8811 /* Ignore newlines. */
8812 if (*p == '\n')
8814 ++p;
8815 continue;
8818 /* Get the initial path. */
8819 this_path = p;
8820 while (*p != ' ')
8822 if (*p == '\0')
8824 invalid_select:
8825 fatal_error (input_location, "multilib select %qs %qs is invalid",
8826 multilib_select, multilib_reuse);
8828 ++p;
8830 this_path_len = p - this_path;
8832 /* Check the arguments. */
8833 ok = 1;
8834 ndfltok = 1;
8835 ++p;
8836 while (*p != ';')
8838 if (*p == '\0')
8839 goto invalid_select;
8841 if (! ok)
8843 ++p;
8844 continue;
8847 this_arg = p;
8848 while (*p != ' ' && *p != ';')
8850 if (*p == '\0')
8851 goto invalid_select;
8852 ++p;
8855 if (*this_arg != '!')
8856 not_arg = 0;
8857 else
8859 not_arg = 1;
8860 ++this_arg;
8863 /* If this is a default argument, we can just ignore it.
8864 This is true even if this_arg begins with '!'. Beginning
8865 with '!' does not mean that this argument is necessarily
8866 inappropriate for this library: it merely means that
8867 there is a more specific library which uses this
8868 argument. If this argument is a default, we need not
8869 consider that more specific library. */
8870 ok = used_arg (this_arg, p - this_arg);
8871 if (not_arg)
8872 ok = ! ok;
8874 if (! ok)
8875 ndfltok = 0;
8877 if (default_arg (this_arg, p - this_arg))
8878 ok = 1;
8880 if (*p == ' ')
8881 ++p;
8884 if (ok && first)
8886 if (this_path_len != 1
8887 || this_path[0] != '.')
8889 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
8890 char *q;
8892 strncpy (new_multilib_dir, this_path, this_path_len);
8893 new_multilib_dir[this_path_len] = '\0';
8894 q = strchr (new_multilib_dir, ':');
8895 if (q != NULL)
8896 *q = '\0';
8897 multilib_dir = new_multilib_dir;
8899 first = 0;
8902 if (ndfltok)
8904 const char *q = this_path, *end = this_path + this_path_len;
8906 while (q < end && *q != ':')
8907 q++;
8908 if (q < end)
8910 const char *q2 = q + 1, *ml_end = end;
8911 char *new_multilib_os_dir;
8913 while (q2 < end && *q2 != ':')
8914 q2++;
8915 if (*q2 == ':')
8916 ml_end = q2;
8917 if (ml_end - q == 1)
8918 multilib_os_dir = xstrdup (".");
8919 else
8921 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
8922 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
8923 new_multilib_os_dir[ml_end - q - 1] = '\0';
8924 multilib_os_dir = new_multilib_os_dir;
8927 if (q2 < end && *q2 == ':')
8929 char *new_multiarch_dir = XNEWVEC (char, end - q2);
8930 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
8931 new_multiarch_dir[end - q2 - 1] = '\0';
8932 multiarch_dir = new_multiarch_dir;
8934 break;
8938 ++p;
8941 if (multilib_dir == NULL && multilib_os_dir != NULL
8942 && strcmp (multilib_os_dir, ".") == 0)
8944 free (CONST_CAST (char *, multilib_os_dir));
8945 multilib_os_dir = NULL;
8947 else if (multilib_dir != NULL && multilib_os_dir == NULL)
8948 multilib_os_dir = multilib_dir;
8951 /* Print out the multiple library subdirectory selection
8952 information. This prints out a series of lines. Each line looks
8953 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
8954 required. Only the desired options are printed out, the negative
8955 matches. The options are print without a leading dash. There are
8956 no spaces to make it easy to use the information in the shell.
8957 Each subdirectory is printed only once. This assumes the ordering
8958 generated by the genmultilib script. Also, we leave out ones that match
8959 the exclusions. */
8961 static void
8962 print_multilib_info (void)
8964 const char *p = multilib_select;
8965 const char *last_path = 0, *this_path;
8966 int skip;
8967 unsigned int last_path_len = 0;
8969 while (*p != '\0')
8971 skip = 0;
8972 /* Ignore newlines. */
8973 if (*p == '\n')
8975 ++p;
8976 continue;
8979 /* Get the initial path. */
8980 this_path = p;
8981 while (*p != ' ')
8983 if (*p == '\0')
8985 invalid_select:
8986 fatal_error (input_location,
8987 "multilib select %qs is invalid", multilib_select);
8990 ++p;
8993 /* When --disable-multilib was used but target defines
8994 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
8995 with .:: for multiarch configurations) are there just to find
8996 multilib_os_dir, so skip them from output. */
8997 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
8998 skip = 1;
9000 /* Check for matches with the multilib_exclusions. We don't bother
9001 with the '!' in either list. If any of the exclusion rules match
9002 all of its options with the select rule, we skip it. */
9004 const char *e = multilib_exclusions;
9005 const char *this_arg;
9007 while (*e != '\0')
9009 int m = 1;
9010 /* Ignore newlines. */
9011 if (*e == '\n')
9013 ++e;
9014 continue;
9017 /* Check the arguments. */
9018 while (*e != ';')
9020 const char *q;
9021 int mp = 0;
9023 if (*e == '\0')
9025 invalid_exclusion:
9026 fatal_error (input_location,
9027 "multilib exclusion %qs is invalid",
9028 multilib_exclusions);
9031 if (! m)
9033 ++e;
9034 continue;
9037 this_arg = e;
9039 while (*e != ' ' && *e != ';')
9041 if (*e == '\0')
9042 goto invalid_exclusion;
9043 ++e;
9046 q = p + 1;
9047 while (*q != ';')
9049 const char *arg;
9050 int len = e - this_arg;
9052 if (*q == '\0')
9053 goto invalid_select;
9055 arg = q;
9057 while (*q != ' ' && *q != ';')
9059 if (*q == '\0')
9060 goto invalid_select;
9061 ++q;
9064 if (! strncmp (arg, this_arg,
9065 (len < q - arg) ? q - arg : len)
9066 || default_arg (this_arg, e - this_arg))
9068 mp = 1;
9069 break;
9072 if (*q == ' ')
9073 ++q;
9076 if (! mp)
9077 m = 0;
9079 if (*e == ' ')
9080 ++e;
9083 if (m)
9085 skip = 1;
9086 break;
9089 if (*e != '\0')
9090 ++e;
9094 if (! skip)
9096 /* If this is a duplicate, skip it. */
9097 skip = (last_path != 0
9098 && (unsigned int) (p - this_path) == last_path_len
9099 && ! filename_ncmp (last_path, this_path, last_path_len));
9101 last_path = this_path;
9102 last_path_len = p - this_path;
9105 /* If this directory requires any default arguments, we can skip
9106 it. We will already have printed a directory identical to
9107 this one which does not require that default argument. */
9108 if (! skip)
9110 const char *q;
9112 q = p + 1;
9113 while (*q != ';')
9115 const char *arg;
9117 if (*q == '\0')
9118 goto invalid_select;
9120 if (*q == '!')
9121 arg = NULL;
9122 else
9123 arg = q;
9125 while (*q != ' ' && *q != ';')
9127 if (*q == '\0')
9128 goto invalid_select;
9129 ++q;
9132 if (arg != NULL
9133 && default_arg (arg, q - arg))
9135 skip = 1;
9136 break;
9139 if (*q == ' ')
9140 ++q;
9144 if (! skip)
9146 const char *p1;
9148 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
9149 putchar (*p1);
9150 putchar (';');
9153 ++p;
9154 while (*p != ';')
9156 int use_arg;
9158 if (*p == '\0')
9159 goto invalid_select;
9161 if (skip)
9163 ++p;
9164 continue;
9167 use_arg = *p != '!';
9169 if (use_arg)
9170 putchar ('@');
9172 while (*p != ' ' && *p != ';')
9174 if (*p == '\0')
9175 goto invalid_select;
9176 if (use_arg)
9177 putchar (*p);
9178 ++p;
9181 if (*p == ' ')
9182 ++p;
9185 if (! skip)
9187 /* If there are extra options, print them now. */
9188 if (multilib_extra && *multilib_extra)
9190 int print_at = TRUE;
9191 const char *q;
9193 for (q = multilib_extra; *q != '\0'; q++)
9195 if (*q == ' ')
9196 print_at = TRUE;
9197 else
9199 if (print_at)
9200 putchar ('@');
9201 putchar (*q);
9202 print_at = FALSE;
9207 putchar ('\n');
9210 ++p;
9214 /* getenv built-in spec function.
9216 Returns the value of the environment variable given by its first argument,
9217 concatenated with the second argument. If the variable is not defined, a
9218 fatal error is issued unless such undefs are internally allowed, in which
9219 case the variable name is used as the variable value. */
9221 static const char *
9222 getenv_spec_function (int argc, const char **argv)
9224 const char *value;
9225 const char *varname;
9227 char *result;
9228 char *ptr;
9229 size_t len;
9231 if (argc != 2)
9232 return NULL;
9234 varname = argv[0];
9235 value = env.get (varname);
9237 if (!value && spec_undefvar_allowed)
9238 value = varname;
9240 if (!value)
9241 fatal_error (input_location,
9242 "environment variable %qs not defined", varname);
9244 /* We have to escape every character of the environment variable so
9245 they are not interpreted as active spec characters. A
9246 particularly painful case is when we are reading a variable
9247 holding a windows path complete with \ separators. */
9248 len = strlen (value) * 2 + strlen (argv[1]) + 1;
9249 result = XNEWVAR (char, len);
9250 for (ptr = result; *value; ptr += 2)
9252 ptr[0] = '\\';
9253 ptr[1] = *value++;
9256 strcpy (ptr, argv[1]);
9258 return result;
9261 /* if-exists built-in spec function.
9263 Checks to see if the file specified by the absolute pathname in
9264 ARGS exists. Returns that pathname if found.
9266 The usual use for this function is to check for a library file
9267 (whose name has been expanded with %s). */
9269 static const char *
9270 if_exists_spec_function (int argc, const char **argv)
9272 /* Must have only one argument. */
9273 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
9274 return argv[0];
9276 return NULL;
9279 /* if-exists-else built-in spec function.
9281 This is like if-exists, but takes an additional argument which
9282 is returned if the first argument does not exist. */
9284 static const char *
9285 if_exists_else_spec_function (int argc, const char **argv)
9287 /* Must have exactly two arguments. */
9288 if (argc != 2)
9289 return NULL;
9291 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
9292 return argv[0];
9294 return argv[1];
9297 /* sanitize built-in spec function.
9299 This returns non-NULL, if sanitizing address, thread or
9300 any of the undefined behavior sanitizers. */
9302 static const char *
9303 sanitize_spec_function (int argc, const char **argv)
9305 if (argc != 1)
9306 return NULL;
9308 if (strcmp (argv[0], "address") == 0)
9309 return (flag_sanitize & SANITIZE_USER_ADDRESS) ? "" : NULL;
9310 if (strcmp (argv[0], "kernel-address") == 0)
9311 return (flag_sanitize & SANITIZE_KERNEL_ADDRESS) ? "" : NULL;
9312 if (strcmp (argv[0], "thread") == 0)
9313 return (flag_sanitize & SANITIZE_THREAD) ? "" : NULL;
9314 if (strcmp (argv[0], "undefined") == 0)
9315 return ((flag_sanitize & (SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT))
9316 && !flag_sanitize_undefined_trap_on_error) ? "" : NULL;
9317 if (strcmp (argv[0], "leak") == 0)
9318 return ((flag_sanitize
9319 & (SANITIZE_ADDRESS | SANITIZE_LEAK | SANITIZE_THREAD))
9320 == SANITIZE_LEAK) ? "" : NULL;
9321 return NULL;
9324 /* replace-outfile built-in spec function.
9326 This looks for the first argument in the outfiles array's name and
9327 replaces it with the second argument. */
9329 static const char *
9330 replace_outfile_spec_function (int argc, const char **argv)
9332 int i;
9333 /* Must have exactly two arguments. */
9334 if (argc != 2)
9335 abort ();
9337 for (i = 0; i < n_infiles; i++)
9339 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
9340 outfiles[i] = xstrdup (argv[1]);
9342 return NULL;
9345 /* remove-outfile built-in spec function.
9347 * This looks for the first argument in the outfiles array's name and
9348 * removes it. */
9350 static const char *
9351 remove_outfile_spec_function (int argc, const char **argv)
9353 int i;
9354 /* Must have exactly one argument. */
9355 if (argc != 1)
9356 abort ();
9358 for (i = 0; i < n_infiles; i++)
9360 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
9361 outfiles[i] = NULL;
9363 return NULL;
9366 /* Given two version numbers, compares the two numbers.
9367 A version number must match the regular expression
9368 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
9370 static int
9371 compare_version_strings (const char *v1, const char *v2)
9373 int rresult;
9374 regex_t r;
9376 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
9377 REG_EXTENDED | REG_NOSUB) != 0)
9378 abort ();
9379 rresult = regexec (&r, v1, 0, NULL, 0);
9380 if (rresult == REG_NOMATCH)
9381 fatal_error (input_location, "invalid version number %qs", v1);
9382 else if (rresult != 0)
9383 abort ();
9384 rresult = regexec (&r, v2, 0, NULL, 0);
9385 if (rresult == REG_NOMATCH)
9386 fatal_error (input_location, "invalid version number %qs", v2);
9387 else if (rresult != 0)
9388 abort ();
9390 return strverscmp (v1, v2);
9394 /* version_compare built-in spec function.
9396 This takes an argument of the following form:
9398 <comparison-op> <arg1> [<arg2>] <switch> <result>
9400 and produces "result" if the comparison evaluates to true,
9401 and nothing if it doesn't.
9403 The supported <comparison-op> values are:
9405 >= true if switch is a later (or same) version than arg1
9406 !> opposite of >=
9407 < true if switch is an earlier version than arg1
9408 !< opposite of <
9409 >< true if switch is arg1 or later, and earlier than arg2
9410 <> true if switch is earlier than arg1 or is arg2 or later
9412 If the switch is not present, the condition is false unless
9413 the first character of the <comparison-op> is '!'.
9415 For example,
9416 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
9417 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
9419 static const char *
9420 version_compare_spec_function (int argc, const char **argv)
9422 int comp1, comp2;
9423 size_t switch_len;
9424 const char *switch_value = NULL;
9425 int nargs = 1, i;
9426 bool result;
9428 if (argc < 3)
9429 fatal_error (input_location, "too few arguments to %%:version-compare");
9430 if (argv[0][0] == '\0')
9431 abort ();
9432 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
9433 nargs = 2;
9434 if (argc != nargs + 3)
9435 fatal_error (input_location, "too many arguments to %%:version-compare");
9437 switch_len = strlen (argv[nargs + 1]);
9438 for (i = 0; i < n_switches; i++)
9439 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
9440 && check_live_switch (i, switch_len))
9441 switch_value = switches[i].part1 + switch_len;
9443 if (switch_value == NULL)
9444 comp1 = comp2 = -1;
9445 else
9447 comp1 = compare_version_strings (switch_value, argv[1]);
9448 if (nargs == 2)
9449 comp2 = compare_version_strings (switch_value, argv[2]);
9450 else
9451 comp2 = -1; /* This value unused. */
9454 switch (argv[0][0] << 8 | argv[0][1])
9456 case '>' << 8 | '=':
9457 result = comp1 >= 0;
9458 break;
9459 case '!' << 8 | '<':
9460 result = comp1 >= 0 || switch_value == NULL;
9461 break;
9462 case '<' << 8:
9463 result = comp1 < 0;
9464 break;
9465 case '!' << 8 | '>':
9466 result = comp1 < 0 || switch_value == NULL;
9467 break;
9468 case '>' << 8 | '<':
9469 result = comp1 >= 0 && comp2 < 0;
9470 break;
9471 case '<' << 8 | '>':
9472 result = comp1 < 0 || comp2 >= 0;
9473 break;
9475 default:
9476 fatal_error (input_location,
9477 "unknown operator %qs in %%:version-compare", argv[0]);
9479 if (! result)
9480 return NULL;
9482 return argv[nargs + 2];
9485 /* %:include builtin spec function. This differs from %include in that it
9486 can be nested inside a spec, and thus be conditionalized. It takes
9487 one argument, the filename, and looks for it in the startfile path.
9488 The result is always NULL, i.e. an empty expansion. */
9490 static const char *
9491 include_spec_function (int argc, const char **argv)
9493 char *file;
9495 if (argc != 1)
9496 abort ();
9498 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
9499 read_specs (file ? file : argv[0], false, false);
9501 return NULL;
9504 /* %:find-file spec function. This function replaces its argument by
9505 the file found through find_file, that is the -print-file-name gcc
9506 program option. */
9507 static const char *
9508 find_file_spec_function (int argc, const char **argv)
9510 const char *file;
9512 if (argc != 1)
9513 abort ();
9515 file = find_file (argv[0]);
9516 return file;
9520 /* %:find-plugindir spec function. This function replaces its argument
9521 by the -iplugindir=<dir> option. `dir' is found through find_file, that
9522 is the -print-file-name gcc program option. */
9523 static const char *
9524 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
9526 const char *option;
9528 if (argc != 0)
9529 abort ();
9531 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
9532 return option;
9536 /* %:print-asm-header spec function. Print a banner to say that the
9537 following output is from the assembler. */
9539 static const char *
9540 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
9541 const char **argv ATTRIBUTE_UNUSED)
9543 printf (_("Assembler options\n=================\n\n"));
9544 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
9545 fflush (stdout);
9546 return NULL;
9549 /* Get a random number for -frandom-seed */
9551 static unsigned HOST_WIDE_INT
9552 get_random_number (void)
9554 unsigned HOST_WIDE_INT ret = 0;
9555 int fd;
9557 fd = open ("/dev/urandom", O_RDONLY);
9558 if (fd >= 0)
9560 read (fd, &ret, sizeof (HOST_WIDE_INT));
9561 close (fd);
9562 if (ret)
9563 return ret;
9566 /* Get some more or less random data. */
9567 #ifdef HAVE_GETTIMEOFDAY
9569 struct timeval tv;
9571 gettimeofday (&tv, NULL);
9572 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
9574 #else
9576 time_t now = time (NULL);
9578 if (now != (time_t)-1)
9579 ret = (unsigned) now;
9581 #endif
9583 return ret ^ getpid ();
9586 /* %:compare-debug-dump-opt spec function. Save the last argument,
9587 expected to be the last -fdump-final-insns option, or generate a
9588 temporary. */
9590 static const char *
9591 compare_debug_dump_opt_spec_function (int arg,
9592 const char **argv ATTRIBUTE_UNUSED)
9594 char *ret;
9595 char *name;
9596 int which;
9597 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
9599 if (arg != 0)
9600 fatal_error (input_location,
9601 "too many arguments to %%:compare-debug-dump-opt");
9603 do_spec_2 ("%{fdump-final-insns=*:%*}");
9604 do_spec_1 (" ", 0, NULL);
9606 if (argbuf.length () > 0
9607 && strcmp (argv[argbuf.length () - 1], "."))
9609 if (!compare_debug)
9610 return NULL;
9612 name = xstrdup (argv[argbuf.length () - 1]);
9613 ret = NULL;
9615 else
9617 const char *ext = NULL;
9619 if (argbuf.length () > 0)
9621 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
9622 ext = ".gkd";
9624 else if (!compare_debug)
9625 return NULL;
9626 else
9627 do_spec_2 ("%g.gkd");
9629 do_spec_1 (" ", 0, NULL);
9631 gcc_assert (argbuf.length () > 0);
9633 name = concat (argbuf.last (), ext, NULL);
9635 ret = concat ("-fdump-final-insns=", name, NULL);
9638 which = compare_debug < 0;
9639 debug_check_temp_file[which] = name;
9641 if (!which)
9643 unsigned HOST_WIDE_INT value = get_random_number ();
9645 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
9648 if (*random_seed)
9650 char *tmp = ret;
9651 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
9652 ret, NULL);
9653 free (tmp);
9656 if (which)
9657 *random_seed = 0;
9659 return ret;
9662 static const char *debug_auxbase_opt;
9664 /* %:compare-debug-self-opt spec function. Expands to the options
9665 that are to be passed in the second compilation of
9666 compare-debug. */
9668 static const char *
9669 compare_debug_self_opt_spec_function (int arg,
9670 const char **argv ATTRIBUTE_UNUSED)
9672 if (arg != 0)
9673 fatal_error (input_location,
9674 "too many arguments to %%:compare-debug-self-opt");
9676 if (compare_debug >= 0)
9677 return NULL;
9679 do_spec_2 ("%{c|S:%{o*:%*}}");
9680 do_spec_1 (" ", 0, NULL);
9682 if (argbuf.length () > 0)
9683 debug_auxbase_opt = concat ("-auxbase-strip ",
9684 argbuf.last (),
9685 NULL);
9686 else
9687 debug_auxbase_opt = NULL;
9689 return concat ("\
9690 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
9691 %<fdump-final-insns=* -w -S -o %j \
9692 %{!fcompare-debug-second:-fcompare-debug-second} \
9693 ", compare_debug_opt, NULL);
9696 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
9697 options that are to be passed in the second compilation of
9698 compare-debug. It expects, as an argument, the basename of the
9699 current input file name, with the .gk suffix appended to it. */
9701 static const char *
9702 compare_debug_auxbase_opt_spec_function (int arg,
9703 const char **argv)
9705 char *name;
9706 int len;
9708 if (arg == 0)
9709 fatal_error (input_location,
9710 "too few arguments to %%:compare-debug-auxbase-opt");
9712 if (arg != 1)
9713 fatal_error (input_location,
9714 "too many arguments to %%:compare-debug-auxbase-opt");
9716 if (compare_debug >= 0)
9717 return NULL;
9719 len = strlen (argv[0]);
9720 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
9721 fatal_error (input_location, "argument to %%:compare-debug-auxbase-opt "
9722 "does not end in .gk");
9724 if (debug_auxbase_opt)
9725 return debug_auxbase_opt;
9727 #define OPT "-auxbase "
9729 len -= 3;
9730 name = (char*) xmalloc (sizeof (OPT) + len);
9731 memcpy (name, OPT, sizeof (OPT) - 1);
9732 memcpy (name + sizeof (OPT) - 1, argv[0], len);
9733 name[sizeof (OPT) - 1 + len] = '\0';
9735 #undef OPT
9737 return name;
9740 /* %:pass-through-libs spec function. Finds all -l options and input
9741 file names in the lib spec passed to it, and makes a list of them
9742 prepended with the plugin option to cause them to be passed through
9743 to the final link after all the new object files have been added. */
9745 const char *
9746 pass_through_libs_spec_func (int argc, const char **argv)
9748 char *prepended = xstrdup (" ");
9749 int n;
9750 /* Shlemiel the painter's algorithm. Innately horrible, but at least
9751 we know that there will never be more than a handful of strings to
9752 concat, and it's only once per run, so it's not worth optimising. */
9753 for (n = 0; n < argc; n++)
9755 char *old = prepended;
9756 /* Anything that isn't an option is a full path to an output
9757 file; pass it through if it ends in '.a'. Among options,
9758 pass only -l. */
9759 if (argv[n][0] == '-' && argv[n][1] == 'l')
9761 const char *lopt = argv[n] + 2;
9762 /* Handle both joined and non-joined -l options. If for any
9763 reason there's a trailing -l with no joined or following
9764 arg just discard it. */
9765 if (!*lopt && ++n >= argc)
9766 break;
9767 else if (!*lopt)
9768 lopt = argv[n];
9769 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
9770 lopt, " ", NULL);
9772 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
9774 prepended = concat (prepended, "-plugin-opt=-pass-through=",
9775 argv[n], " ", NULL);
9777 if (prepended != old)
9778 free (old);
9780 return prepended;
9783 /* %:replace-extension spec function. Replaces the extension of the
9784 first argument with the second argument. */
9786 const char *
9787 replace_extension_spec_func (int argc, const char **argv)
9789 char *name;
9790 char *p;
9791 char *result;
9792 int i;
9794 if (argc != 2)
9795 fatal_error (input_location, "too few arguments to %%:replace-extension");
9797 name = xstrdup (argv[0]);
9799 for (i = strlen (name) - 1; i >= 0; i--)
9800 if (IS_DIR_SEPARATOR (name[i]))
9801 break;
9803 p = strrchr (name + i + 1, '.');
9804 if (p != NULL)
9805 *p = '\0';
9807 result = concat (name, argv[1], NULL);
9809 free (name);
9810 return result;
9813 /* Returns "" if ARGV[ARGC - 2] is greater than ARGV[ARGC-1].
9814 Otherwise, return NULL. */
9816 static const char *
9817 greater_than_spec_func (int argc, const char **argv)
9819 char *converted;
9821 if (argc == 1)
9822 return NULL;
9824 gcc_assert (argc >= 2);
9826 long arg = strtol (argv[argc - 2], &converted, 10);
9827 gcc_assert (converted != argv[argc - 2]);
9829 long lim = strtol (argv[argc - 1], &converted, 10);
9830 gcc_assert (converted != argv[argc - 1]);
9832 if (arg > lim)
9833 return "";
9835 return NULL;
9838 /* Insert backslash before spaces in ORIG (usually a file path), to
9839 avoid being broken by spec parser.
9841 This function is needed as do_spec_1 treats white space (' ' and '\t')
9842 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
9843 the file name should be treated as a single argument rather than being
9844 broken into multiple. Solution is to insert '\\' before the space in a
9845 file name.
9847 This function converts and only converts all occurrence of ' '
9848 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
9849 "a b" -> "a\\ b"
9850 "a b" -> "a\\ \\ b"
9851 "a\tb" -> "a\\\tb"
9852 "a\\ b" -> "a\\\\ b"
9854 orig: input null-terminating string that was allocated by xalloc. The
9855 memory it points to might be freed in this function. Behavior undefined
9856 if ORIG wasn't xalloced or was freed already at entry.
9858 Return: ORIG if no conversion needed. Otherwise a newly allocated string
9859 that was converted from ORIG. */
9861 static char *
9862 convert_white_space (char *orig)
9864 int len, number_of_space = 0;
9866 for (len = 0; orig[len]; len++)
9867 if (orig[len] == ' ' || orig[len] == '\t') number_of_space++;
9869 if (number_of_space)
9871 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
9872 int j, k;
9873 for (j = 0, k = 0; j <= len; j++, k++)
9875 if (orig[j] == ' ' || orig[j] == '\t')
9876 new_spec[k++] = '\\';
9877 new_spec[k] = orig[j];
9879 free (orig);
9880 return new_spec;
9882 else
9883 return orig;
9886 static void
9887 path_prefix_reset (path_prefix *prefix)
9889 struct prefix_list *iter, *next;
9890 iter = prefix->plist;
9891 while (iter)
9893 next = iter->next;
9894 free (const_cast <char *> (iter->prefix));
9895 XDELETE (iter);
9896 iter = next;
9898 prefix->plist = 0;
9899 prefix->max_len = 0;
9902 /* Restore all state within gcc.c to the initial state, so that the driver
9903 code can be safely re-run in-process.
9905 Many const char * variables are referenced by static specs (see
9906 INIT_STATIC_SPEC above). These variables are restored to their default
9907 values by a simple loop over the static specs.
9909 For other variables, we directly restore them all to their initial
9910 values (often implicitly 0).
9912 Free the various obstacks in this file, along with "opts_obstack"
9913 from opts.c.
9915 This function also restores any environment variables that were changed. */
9917 void
9918 driver::finalize ()
9920 env.restore ();
9921 params_c_finalize ();
9922 diagnostic_finish (global_dc);
9924 is_cpp_driver = 0;
9925 at_file_supplied = 0;
9926 print_help_list = 0;
9927 print_version = 0;
9928 verbose_only_flag = 0;
9929 print_subprocess_help = 0;
9930 use_ld = NULL;
9931 report_times_to_file = NULL;
9932 target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
9933 target_system_root_changed = 0;
9934 target_sysroot_suffix = 0;
9935 target_sysroot_hdrs_suffix = 0;
9936 save_temps_flag = SAVE_TEMPS_NONE;
9937 save_temps_prefix = 0;
9938 save_temps_length = 0;
9939 spec_machine = DEFAULT_TARGET_MACHINE;
9940 greatest_status = 1;
9942 finalize_options_struct (&global_options);
9943 finalize_options_struct (&global_options_set);
9945 obstack_free (&obstack, NULL);
9946 obstack_free (&opts_obstack, NULL); /* in opts.c */
9947 obstack_free (&collect_obstack, NULL);
9949 link_command_spec = LINK_COMMAND_SPEC;
9951 obstack_free (&multilib_obstack, NULL);
9953 user_specs_head = NULL;
9954 user_specs_tail = NULL;
9956 /* Within the "compilers" vec, the fields "suffix" and "spec" were
9957 statically allocated for the default compilers, but dynamically
9958 allocated for additional compilers. Delete them for the latter. */
9959 for (int i = n_default_compilers; i < n_compilers; i++)
9961 free (const_cast <char *> (compilers[i].suffix));
9962 free (const_cast <char *> (compilers[i].spec));
9964 XDELETEVEC (compilers);
9965 compilers = NULL;
9966 n_compilers = 0;
9968 linker_options.truncate (0);
9969 assembler_options.truncate (0);
9970 preprocessor_options.truncate (0);
9972 path_prefix_reset (&exec_prefixes);
9973 path_prefix_reset (&startfile_prefixes);
9974 path_prefix_reset (&include_prefixes);
9976 machine_suffix = 0;
9977 just_machine_suffix = 0;
9978 gcc_exec_prefix = 0;
9979 gcc_libexec_prefix = 0;
9980 md_exec_prefix = MD_EXEC_PREFIX;
9981 md_startfile_prefix = MD_STARTFILE_PREFIX;
9982 md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
9983 multilib_dir = 0;
9984 multilib_os_dir = 0;
9985 multiarch_dir = 0;
9987 /* Free any specs dynamically-allocated by set_spec.
9988 These will be at the head of the list, before the
9989 statically-allocated ones. */
9990 if (specs)
9992 while (specs != static_specs)
9994 spec_list *next = specs->next;
9995 free (const_cast <char *> (specs->name));
9996 XDELETE (specs);
9997 specs = next;
9999 specs = 0;
10001 for (unsigned i = 0; i < ARRAY_SIZE (static_specs); i++)
10003 spec_list *sl = &static_specs[i];
10004 if (sl->alloc_p)
10006 if (0)
10007 free (const_cast <char *> (*(sl->ptr_spec)));
10008 sl->alloc_p = false;
10010 *(sl->ptr_spec) = sl->default_ptr;
10012 #ifdef EXTRA_SPECS
10013 extra_specs = NULL;
10014 #endif
10016 processing_spec_function = 0;
10018 argbuf.truncate (0);
10020 have_c = 0;
10021 have_o = 0;
10023 temp_names = NULL;
10024 execution_count = 0;
10025 signal_count = 0;
10027 temp_filename = NULL;
10028 temp_filename_length = 0;
10029 always_delete_queue = NULL;
10030 failure_delete_queue = NULL;
10032 XDELETEVEC (switches);
10033 switches = NULL;
10034 n_switches = 0;
10035 n_switches_alloc = 0;
10037 compare_debug = 0;
10038 compare_debug_second = 0;
10039 compare_debug_opt = NULL;
10040 for (int i = 0; i < 2; i++)
10042 switches_debug_check[i] = NULL;
10043 n_switches_debug_check[i] = 0;
10044 n_switches_alloc_debug_check[i] = 0;
10045 debug_check_temp_file[i] = NULL;
10048 XDELETEVEC (infiles);
10049 infiles = NULL;
10050 n_infiles = 0;
10051 n_infiles_alloc = 0;
10053 combine_inputs = false;
10054 added_libraries = 0;
10055 XDELETEVEC (outfiles);
10056 outfiles = NULL;
10057 spec_lang = 0;
10058 last_language_n_infiles = 0;
10059 gcc_input_filename = NULL;
10060 input_file_number = 0;
10061 input_filename_length = 0;
10062 basename_length = 0;
10063 suffixed_basename_length = 0;
10064 input_basename = NULL;
10065 input_suffix = NULL;
10066 /* We don't need to purge "input_stat", just to unset "input_stat_set". */
10067 input_stat_set = 0;
10068 input_file_compiler = NULL;
10069 arg_going = 0;
10070 delete_this_arg = 0;
10071 this_is_output_file = 0;
10072 this_is_library_file = 0;
10073 this_is_linker_script = 0;
10074 input_from_pipe = 0;
10075 suffix_subst = NULL;
10077 mdswitches = NULL;
10078 n_mdswitches = 0;
10080 debug_auxbase_opt = NULL;
10082 used_arg.finalize ();
10085 /* PR jit/64810.
10086 Targets can provide configure-time default options in
10087 OPTION_DEFAULT_SPECS. The jit needs to access these, but
10088 they are expressed in the spec language.
10090 Run just enough of the driver to be able to expand these
10091 specs, and then call the callback CB on each
10092 such option. The options strings are *without* a leading
10093 '-' character e.g. ("march=x86-64"). Finally, clean up. */
10095 void
10096 driver_get_configure_time_options (void (*cb) (const char *option,
10097 void *user_data),
10098 void *user_data)
10100 size_t i;
10102 obstack_init (&obstack);
10103 init_opts_obstack ();
10104 n_switches = 0;
10106 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
10107 do_option_spec (option_default_specs[i].name,
10108 option_default_specs[i].spec);
10110 for (i = 0; (int) i < n_switches; i++)
10112 gcc_assert (switches[i].part1);
10113 (*cb) (switches[i].part1, user_data);
10116 obstack_free (&opts_obstack, NULL);
10117 obstack_free (&obstack, NULL);
10118 n_switches = 0;