Fix spawned function with lambda function
[official-gcc.git] / gcc / gcc.c
blob757bfc988eb041dba723068ed06e5bfd68030f22
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987-2015 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"
48 /* Manage the manipulation of env vars.
50 We poison "getenv" and "putenv", so that all enviroment-handling is
51 done through this class. Note that poisoning happens in the
52 preprocessor at the identifier level, and doesn't distinguish between
53 env.getenv ();
54 and
55 getenv ();
56 Hence we need to use "get" for the accessor method, not "getenv". */
58 class env_manager
60 public:
61 void init (bool can_restore, bool debug);
62 const char *get (const char *name);
63 void xput (const char *string);
64 void restore ();
66 private:
67 bool m_can_restore;
68 bool m_debug;
69 struct kv
71 char *m_key;
72 char *m_value;
74 vec<kv> m_keys;
78 /* The singleton instance of class env_manager. */
80 static env_manager env;
82 /* Initializer for class env_manager.
84 We can't do this as a constructor since we have a statically
85 allocated instance ("env" above). */
87 void
88 env_manager::init (bool can_restore, bool debug)
90 m_can_restore = can_restore;
91 m_debug = debug;
94 /* Get the value of NAME within the environment. Essentially
95 a wrapper for ::getenv, but adding logging, and the possibility
96 of caching results. */
98 const char *
99 env_manager::get (const char *name)
101 const char *result = ::getenv (name);
102 if (m_debug)
103 fprintf (stderr, "env_manager::getenv (%s) -> %s\n", name, result);
104 return result;
107 /* Put the given KEY=VALUE entry STRING into the environment.
108 If the env_manager was initialized with CAN_RESTORE set, then
109 also record the old value of KEY within the environment, so that it
110 can be later restored. */
112 void
113 env_manager::xput (const char *string)
115 if (m_debug)
116 fprintf (stderr, "env_manager::xput (%s)\n", string);
117 if (verbose_flag)
118 fnotice (stderr, "%s\n", string);
120 if (m_can_restore)
122 char *equals = strchr (const_cast <char *> (string), '=');
123 gcc_assert (equals);
125 struct kv kv;
126 kv.m_key = xstrndup (string, equals - string);
127 const char *cur_value = ::getenv (kv.m_key);
128 if (m_debug)
129 fprintf (stderr, "saving old value: %s\n",cur_value);
130 kv.m_value = cur_value ? xstrdup (cur_value) : NULL;
131 m_keys.safe_push (kv);
134 ::putenv (CONST_CAST (char *, string));
137 /* Undo any xputenv changes made since last restore.
138 Can only be called if the env_manager was initialized with
139 CAN_RESTORE enabled. */
141 void
142 env_manager::restore ()
144 unsigned int i;
145 struct kv *item;
147 gcc_assert (m_can_restore);
149 FOR_EACH_VEC_ELT_REVERSE (m_keys, i, item)
151 if (m_debug)
152 printf ("restoring saved key: %s value: %s\n", item->m_key, item->m_value);
153 if (item->m_value)
154 ::setenv (item->m_key, item->m_value, 1);
155 else
156 ::unsetenv (item->m_key);
157 free (item->m_key);
158 free (item->m_value);
161 m_keys.truncate (0);
164 /* Forbid other uses of getenv and putenv. */
165 #if (GCC_VERSION >= 3000)
166 #pragma GCC poison getenv putenv
167 #endif
171 /* By default there is no special suffix for target executables. */
172 /* FIXME: when autoconf is fixed, remove the host check - dj */
173 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
174 #define HAVE_TARGET_EXECUTABLE_SUFFIX
175 #endif
177 /* By default there is no special suffix for host executables. */
178 #ifdef HOST_EXECUTABLE_SUFFIX
179 #define HAVE_HOST_EXECUTABLE_SUFFIX
180 #else
181 #define HOST_EXECUTABLE_SUFFIX ""
182 #endif
184 /* By default, the suffix for target object files is ".o". */
185 #ifdef TARGET_OBJECT_SUFFIX
186 #define HAVE_TARGET_OBJECT_SUFFIX
187 #else
188 #define TARGET_OBJECT_SUFFIX ".o"
189 #endif
191 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
193 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
194 #ifndef LIBRARY_PATH_ENV
195 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
196 #endif
198 /* If a stage of compilation returns an exit status >= 1,
199 compilation of that file ceases. */
201 #define MIN_FATAL_STATUS 1
203 /* Flag set by cppspec.c to 1. */
204 int is_cpp_driver;
206 /* Flag set to nonzero if an @file argument has been supplied to gcc. */
207 static bool at_file_supplied;
209 /* Definition of string containing the arguments given to configure. */
210 #include "configargs.h"
212 /* Flag saying to print the command line options understood by gcc and its
213 sub-processes. */
215 static int print_help_list;
217 /* Flag saying to print the version of gcc and its sub-processes. */
219 static int print_version;
221 /* Flag indicating whether we should ONLY print the command and
222 arguments (like verbose_flag) without executing the command.
223 Displayed arguments are quoted so that the generated command
224 line is suitable for execution. This is intended for use in
225 shell scripts to capture the driver-generated command line. */
226 static int verbose_only_flag;
228 /* Flag indicating how to print command line options of sub-processes. */
230 static int print_subprocess_help;
232 /* Linker suffix passed to -fuse-ld=... */
233 static const char *use_ld;
235 /* Whether we should report subprocess execution times to a file. */
237 FILE *report_times_to_file = NULL;
239 /* Nonzero means place this string before uses of /, so that include
240 and library files can be found in an alternate location. */
242 #ifdef TARGET_SYSTEM_ROOT
243 #define DEFAULT_TARGET_SYSTEM_ROOT (TARGET_SYSTEM_ROOT)
244 #else
245 #define DEFAULT_TARGET_SYSTEM_ROOT (0)
246 #endif
247 static const char *target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
249 /* Nonzero means pass the updated target_system_root to the compiler. */
251 static int target_system_root_changed;
253 /* Nonzero means append this string to target_system_root. */
255 static const char *target_sysroot_suffix = 0;
257 /* Nonzero means append this string to target_system_root for headers. */
259 static const char *target_sysroot_hdrs_suffix = 0;
261 /* Nonzero means write "temp" files in source directory
262 and use the source file's name in them, and don't delete them. */
264 static enum save_temps {
265 SAVE_TEMPS_NONE, /* no -save-temps */
266 SAVE_TEMPS_CWD, /* -save-temps in current directory */
267 SAVE_TEMPS_OBJ /* -save-temps in object directory */
268 } save_temps_flag;
270 /* Output file to use to get the object directory for -save-temps=obj */
271 static char *save_temps_prefix = 0;
272 static size_t save_temps_length = 0;
274 /* The compiler version. */
276 static const char *compiler_version;
278 /* The target version. */
280 static const char *const spec_version = DEFAULT_TARGET_VERSION;
282 /* The target machine. */
284 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
285 static const char *spec_host_machine = DEFAULT_REAL_TARGET_MACHINE;
287 /* List of offload targets. */
289 static char *offload_targets = NULL;
291 /* Nonzero if cross-compiling.
292 When -b is used, the value comes from the `specs' file. */
294 #ifdef CROSS_DIRECTORY_STRUCTURE
295 static const char *cross_compile = "1";
296 #else
297 static const char *cross_compile = "0";
298 #endif
300 /* Greatest exit code of sub-processes that has been encountered up to
301 now. */
302 static int greatest_status = 1;
304 /* This is the obstack which we use to allocate many strings. */
306 static struct obstack obstack;
308 /* This is the obstack to build an environment variable to pass to
309 collect2 that describes all of the relevant switches of what to
310 pass the compiler in building the list of pointers to constructors
311 and destructors. */
313 static struct obstack collect_obstack;
315 /* Forward declaration for prototypes. */
316 struct path_prefix;
317 struct prefix_list;
319 static void init_spec (void);
320 static void store_arg (const char *, int, int);
321 static void insert_wrapper (const char *);
322 static char *load_specs (const char *);
323 static void read_specs (const char *, bool, bool);
324 static void set_spec (const char *, const char *, bool);
325 static struct compiler *lookup_compiler (const char *, size_t, const char *);
326 static char *build_search_list (const struct path_prefix *, const char *,
327 bool, bool);
328 static void xputenv (const char *);
329 static void putenv_from_prefixes (const struct path_prefix *, const char *,
330 bool);
331 static int access_check (const char *, int);
332 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
333 static void add_prefix (struct path_prefix *, const char *, const char *,
334 int, int, int);
335 static void add_sysrooted_prefix (struct path_prefix *, const char *,
336 const char *, int, int, int);
337 static char *skip_whitespace (char *);
338 static void delete_if_ordinary (const char *);
339 static void delete_temp_files (void);
340 static void delete_failure_queue (void);
341 static void clear_failure_queue (void);
342 static int check_live_switch (int, int);
343 static const char *handle_braces (const char *);
344 static inline bool input_suffix_matches (const char *, const char *);
345 static inline bool switch_matches (const char *, const char *, int);
346 static inline void mark_matching_switches (const char *, const char *, int);
347 static inline void process_marked_switches (void);
348 static const char *process_brace_body (const char *, const char *, const char *, int, int);
349 static const struct spec_function *lookup_spec_function (const char *);
350 static const char *eval_spec_function (const char *, const char *);
351 static const char *handle_spec_function (const char *, bool *);
352 static char *save_string (const char *, int);
353 static void set_collect_gcc_options (void);
354 static int do_spec_1 (const char *, int, const char *);
355 static int do_spec_2 (const char *);
356 static void do_option_spec (const char *, const char *);
357 static void do_self_spec (const char *);
358 static const char *find_file (const char *);
359 static int is_directory (const char *, bool);
360 static const char *validate_switches (const char *, bool);
361 static void validate_all_switches (void);
362 static inline void validate_switches_from_spec (const char *, bool);
363 static void give_switch (int, int);
364 static int default_arg (const char *, int);
365 static void set_multilib_dir (void);
366 static void print_multilib_info (void);
367 static void perror_with_name (const char *);
368 static void display_help (void);
369 static void add_preprocessor_option (const char *, int);
370 static void add_assembler_option (const char *, int);
371 static void add_linker_option (const char *, int);
372 static void process_command (unsigned int, struct cl_decoded_option *);
373 static int execute (void);
374 static void alloc_args (void);
375 static void clear_args (void);
376 static void fatal_signal (int);
377 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
378 static void init_gcc_specs (struct obstack *, const char *, const char *,
379 const char *);
380 #endif
381 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
382 static const char *convert_filename (const char *, int, int);
383 #endif
385 static void try_generate_repro (const char **argv);
386 static const char *getenv_spec_function (int, const char **);
387 static const char *if_exists_spec_function (int, const char **);
388 static const char *if_exists_else_spec_function (int, const char **);
389 static const char *sanitize_spec_function (int, const char **);
390 static const char *replace_outfile_spec_function (int, const char **);
391 static const char *remove_outfile_spec_function (int, const char **);
392 static const char *version_compare_spec_function (int, const char **);
393 static const char *include_spec_function (int, const char **);
394 static const char *find_file_spec_function (int, const char **);
395 static const char *find_plugindir_spec_function (int, const char **);
396 static const char *print_asm_header_spec_function (int, const char **);
397 static const char *compare_debug_dump_opt_spec_function (int, const char **);
398 static const char *compare_debug_self_opt_spec_function (int, const char **);
399 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
400 static const char *pass_through_libs_spec_func (int, const char **);
401 static const char *replace_extension_spec_func (int, const char **);
402 static const char *greater_than_spec_func (int, const char **);
403 static char *convert_white_space (char *);
405 /* The Specs Language
407 Specs are strings containing lines, each of which (if not blank)
408 is made up of a program name, and arguments separated by spaces.
409 The program name must be exact and start from root, since no path
410 is searched and it is unreliable to depend on the current working directory.
411 Redirection of input or output is not supported; the subprograms must
412 accept filenames saying what files to read and write.
414 In addition, the specs can contain %-sequences to substitute variable text
415 or for conditional text. Here is a table of all defined %-sequences.
416 Note that spaces are not generated automatically around the results of
417 expanding these sequences; therefore, you can concatenate them together
418 or with constant text in a single argument.
420 %% substitute one % into the program name or argument.
421 %i substitute the name of the input file being processed.
422 %b substitute the basename of the input file being processed.
423 This is the substring up to (and not including) the last period
424 and not including the directory unless -save-temps was specified
425 to put temporaries in a different location.
426 %B same as %b, but include the file suffix (text after the last period).
427 %gSUFFIX
428 substitute a file name that has suffix SUFFIX and is chosen
429 once per compilation, and mark the argument a la %d. To reduce
430 exposure to denial-of-service attacks, the file name is now
431 chosen in a way that is hard to predict even when previously
432 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
433 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
434 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
435 had been pre-processed. Previously, %g was simply substituted
436 with a file name chosen once per compilation, without regard
437 to any appended suffix (which was therefore treated just like
438 ordinary text), making such attacks more likely to succeed.
439 %|SUFFIX
440 like %g, but if -pipe is in effect, expands simply to "-".
441 %mSUFFIX
442 like %g, but if -pipe is in effect, expands to nothing. (We have both
443 %| and %m to accommodate differences between system assemblers; see
444 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
445 %uSUFFIX
446 like %g, but generates a new temporary file name even if %uSUFFIX
447 was already seen.
448 %USUFFIX
449 substitutes the last file name generated with %uSUFFIX, generating a
450 new one if there is no such last file name. In the absence of any
451 %uSUFFIX, this is just like %gSUFFIX, except they don't share
452 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
453 would involve the generation of two distinct file names, one
454 for each `%g.s' and another for each `%U.s'. Previously, %U was
455 simply substituted with a file name chosen for the previous %u,
456 without regard to any appended suffix.
457 %jSUFFIX
458 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
459 writable, and if save-temps is off; otherwise, substitute the name
460 of a temporary file, just like %u. This temporary file is not
461 meant for communication between processes, but rather as a junk
462 disposal mechanism.
463 %.SUFFIX
464 substitutes .SUFFIX for the suffixes of a matched switch's args when
465 it is subsequently output with %*. SUFFIX is terminated by the next
466 space or %.
467 %d marks the argument containing or following the %d as a
468 temporary file name, so that file will be deleted if GCC exits
469 successfully. Unlike %g, this contributes no text to the argument.
470 %w marks the argument containing or following the %w as the
471 "output file" of this compilation. This puts the argument
472 into the sequence of arguments that %o will substitute later.
473 %V indicates that this compilation produces no "output file".
474 %W{...}
475 like %{...} but mark last argument supplied within
476 as a file to be deleted on failure.
477 %o substitutes the names of all the output files, with spaces
478 automatically placed around them. You should write spaces
479 around the %o as well or the results are undefined.
480 %o is for use in the specs for running the linker.
481 Input files whose names have no recognized suffix are not compiled
482 at all, but they are included among the output files, so they will
483 be linked.
484 %O substitutes the suffix for object files. Note that this is
485 handled specially when it immediately follows %g, %u, or %U
486 (with or without a suffix argument) because of the need for
487 those to form complete file names. The handling is such that
488 %O is treated exactly as if it had already been substituted,
489 except that %g, %u, and %U do not currently support additional
490 SUFFIX characters following %O as they would following, for
491 example, `.o'.
492 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
493 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
494 and -B options) and -imultilib as necessary.
495 %s current argument is the name of a library or startup file of some sort.
496 Search for that file in a standard list of directories
497 and substitute the full name found.
498 %eSTR Print STR as an error message. STR is terminated by a newline.
499 Use this when inconsistent options are detected.
500 %nSTR Print STR as a notice. STR is terminated by a newline.
501 %x{OPTION} Accumulate an option for %X.
502 %X Output the accumulated linker options specified by compilations.
503 %Y Output the accumulated assembler options specified by compilations.
504 %Z Output the accumulated preprocessor options specified by compilations.
505 %a process ASM_SPEC as a spec.
506 This allows config.h to specify part of the spec for running as.
507 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
508 used here. This can be used to run a post-processor after the
509 assembler has done its job.
510 %D Dump out a -L option for each directory in startfile_prefixes.
511 If multilib_dir is set, extra entries are generated with it affixed.
512 %l process LINK_SPEC as a spec.
513 %L process LIB_SPEC as a spec.
514 %M Output multilib_os_dir.
515 %G process LIBGCC_SPEC as a spec.
516 %R Output the concatenation of target_system_root and
517 target_sysroot_suffix.
518 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
519 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
520 %C process CPP_SPEC as a spec.
521 %1 process CC1_SPEC as a spec.
522 %2 process CC1PLUS_SPEC as a spec.
523 %* substitute the variable part of a matched option. (See below.)
524 Note that each comma in the substituted string is replaced by
525 a single space. A space is appended after the last substition
526 unless there is more text in current sequence.
527 %<S remove all occurrences of -S from the command line.
528 Note - this command is position dependent. % commands in the
529 spec string before this one will see -S, % commands in the
530 spec string after this one will not.
531 %>S Similar to "%<S", but keep it in the GCC command line.
532 %<S* remove all occurrences of all switches beginning with -S from the
533 command line.
534 %:function(args)
535 Call the named function FUNCTION, passing it ARGS. ARGS is
536 first processed as a nested spec string, then split into an
537 argument vector in the usual fashion. The function returns
538 a string which is processed as if it had appeared literally
539 as part of the current spec.
540 %{S} substitutes the -S switch, if that switch was given to GCC.
541 If that switch was not specified, this substitutes nothing.
542 Here S is a metasyntactic variable.
543 %{S*} substitutes all the switches specified to GCC whose names start
544 with -S. This is used for -o, -I, etc; switches that take
545 arguments. GCC considers `-o foo' as being one switch whose
546 name starts with `o'. %{o*} would substitute this text,
547 including the space; thus, two arguments would be generated.
548 %{S*&T*} likewise, but preserve order of S and T options (the order
549 of S and T in the spec is not significant). Can be any number
550 of ampersand-separated variables; for each the wild card is
551 optional. Useful for CPP as %{D*&U*&A*}.
553 %{S:X} substitutes X, if the -S switch was given to GCC.
554 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
555 %{S*:X} substitutes X if one or more switches whose names start
556 with -S was given to GCC. Normally X is substituted only
557 once, no matter how many such switches appeared. However,
558 if %* appears somewhere in X, then X will be substituted
559 once for each matching switch, with the %* replaced by the
560 part of that switch that matched the '*'. A space will be
561 appended after the last substition unless there is more
562 text in current sequence.
563 %{.S:X} substitutes X, if processing a file with suffix S.
564 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
565 %{,S:X} substitutes X, if processing a file which will use spec S.
566 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
568 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
569 combined with '!', '.', ',', and '*' as above binding stronger
570 than the OR.
571 If %* appears in X, all of the alternatives must be starred, and
572 only the first matching alternative is substituted.
573 %{%:function(args):X}
574 Call function named FUNCTION with args ARGS. If the function
575 returns non-NULL, then X is substituted, if it returns
576 NULL, it isn't substituted.
577 %{S:X; if S was given to GCC, substitutes X;
578 T:Y; else if T was given to GCC, substitutes Y;
579 :D} else substitutes D. There can be as many clauses as you need.
580 This may be combined with '.', '!', ',', '|', and '*' as above.
582 %(Spec) processes a specification defined in a specs file as *Spec:
584 The conditional text X in a %{S:X} or similar construct may contain
585 other nested % constructs or spaces, or even newlines. They are
586 processed as usual, as described above. Trailing white space in X is
587 ignored. White space may also appear anywhere on the left side of the
588 colon in these constructs, except between . or * and the corresponding
589 word.
591 The -O, -f, -g, -m, and -W switches are handled specifically in these
592 constructs. If another value of -O or the negated form of a -f, -m, or
593 -W switch is found later in the command line, the earlier switch
594 value is ignored, except with {S*} where S is just one letter; this
595 passes all matching options.
597 The character | at the beginning of the predicate text is used to indicate
598 that a command should be piped to the following command, but only if -pipe
599 is specified.
601 Note that it is built into GCC which switches take arguments and which
602 do not. You might think it would be useful to generalize this to
603 allow each compiler's spec to say which switches take arguments. But
604 this cannot be done in a consistent fashion. GCC cannot even decide
605 which input files have been specified without knowing which switches
606 take arguments, and it must know which input files to compile in order
607 to tell which compilers to run.
609 GCC also knows implicitly that arguments starting in `-l' are to be
610 treated as compiler output files, and passed to the linker in their
611 proper position among the other output files. */
613 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
615 /* config.h can define ASM_SPEC to provide extra args to the assembler
616 or extra switch-translations. */
617 #ifndef ASM_SPEC
618 #define ASM_SPEC ""
619 #endif
621 /* config.h can define ASM_FINAL_SPEC to run a post processor after
622 the assembler has run. */
623 #ifndef ASM_FINAL_SPEC
624 #define ASM_FINAL_SPEC \
625 "%{gsplit-dwarf: \n\
626 objcopy --extract-dwo \
627 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
628 %{c:%{o*:%:replace-extension(%{o*:%*} .dwo)}%{!o*:%b.dwo}}%{!c:%b.dwo} \n\
629 objcopy --strip-dwo \
630 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
632 #endif
634 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
635 or extra switch-translations. */
636 #ifndef CPP_SPEC
637 #define CPP_SPEC ""
638 #endif
640 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
641 or extra switch-translations. */
642 #ifndef CC1_SPEC
643 #define CC1_SPEC ""
644 #endif
646 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
647 or extra switch-translations. */
648 #ifndef CC1PLUS_SPEC
649 #define CC1PLUS_SPEC ""
650 #endif
652 /* config.h can define LINK_SPEC to provide extra args to the linker
653 or extra switch-translations. */
654 #ifndef LINK_SPEC
655 #define LINK_SPEC ""
656 #endif
658 /* config.h can define LIB_SPEC to override the default libraries. */
659 #ifndef LIB_SPEC
660 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
661 #endif
663 /* When using -fsplit-stack we need to wrap pthread_create, in order
664 to initialize the stack guard. We always use wrapping, rather than
665 shared library ordering, and we keep the wrapper function in
666 libgcc. This is not yet a real spec, though it could become one;
667 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
668 only works with GNU ld and gold. */
669 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
671 #ifndef LIBASAN_SPEC
672 #define STATIC_LIBASAN_LIBS \
673 " %{static-libasan:%:include(libsanitizer.spec)%(link_libasan)}"
674 #ifdef LIBASAN_EARLY_SPEC
675 #define LIBASAN_SPEC STATIC_LIBASAN_LIBS
676 #elif defined(HAVE_LD_STATIC_DYNAMIC)
677 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
678 "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
679 STATIC_LIBASAN_LIBS
680 #else
681 #define LIBASAN_SPEC "-lasan" STATIC_LIBASAN_LIBS
682 #endif
683 #endif
685 #ifndef LIBASAN_EARLY_SPEC
686 #define LIBASAN_EARLY_SPEC ""
687 #endif
689 #ifndef LIBTSAN_SPEC
690 #define STATIC_LIBTSAN_LIBS \
691 " %{static-libtsan:%:include(libsanitizer.spec)%(link_libtsan)}"
692 #ifdef LIBTSAN_EARLY_SPEC
693 #define LIBTSAN_SPEC STATIC_LIBTSAN_LIBS
694 #elif defined(HAVE_LD_STATIC_DYNAMIC)
695 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
696 "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}" \
697 STATIC_LIBTSAN_LIBS
698 #else
699 #define LIBTSAN_SPEC "-ltsan" STATIC_LIBTSAN_LIBS
700 #endif
701 #endif
703 #ifndef LIBTSAN_EARLY_SPEC
704 #define LIBTSAN_EARLY_SPEC ""
705 #endif
707 #ifndef LIBLSAN_SPEC
708 #define STATIC_LIBLSAN_LIBS \
709 " %{static-liblsan:%:include(libsanitizer.spec)%(link_liblsan)}"
710 #ifdef LIBLSAN_EARLY_SPEC
711 #define LIBLSAN_SPEC STATIC_LIBLSAN_LIBS
712 #elif defined(HAVE_LD_STATIC_DYNAMIC)
713 #define LIBLSAN_SPEC "%{static-liblsan:" LD_STATIC_OPTION \
714 "} -llsan %{static-liblsan:" LD_DYNAMIC_OPTION "}" \
715 STATIC_LIBLSAN_LIBS
716 #else
717 #define LIBLSAN_SPEC "-llsan" STATIC_LIBLSAN_LIBS
718 #endif
719 #endif
721 #ifndef LIBLSAN_EARLY_SPEC
722 #define LIBLSAN_EARLY_SPEC ""
723 #endif
725 #ifndef LIBUBSAN_SPEC
726 #define STATIC_LIBUBSAN_LIBS \
727 " %{static-libubsan:%:include(libsanitizer.spec)%(link_libubsan)}"
728 #ifdef HAVE_LD_STATIC_DYNAMIC
729 #define LIBUBSAN_SPEC "%{static-libubsan:" LD_STATIC_OPTION \
730 "} -lubsan %{static-libubsan:" LD_DYNAMIC_OPTION "}" \
731 STATIC_LIBUBSAN_LIBS
732 #else
733 #define LIBUBSAN_SPEC "-lubsan" STATIC_LIBUBSAN_LIBS
734 #endif
735 #endif
737 /* Linker options for compressed debug sections. */
738 #if HAVE_LD_COMPRESS_DEBUG == 0
739 /* No linker support. */
740 #define LINK_COMPRESS_DEBUG_SPEC \
741 " %{gz*:%e-gz is not supported in this configuration} "
742 #elif HAVE_LD_COMPRESS_DEBUG == 1
743 /* GNU style on input, GNU ld options. Reject, not useful. */
744 #define LINK_COMPRESS_DEBUG_SPEC \
745 " %{gz*:%e-gz is not supported in this configuration} "
746 #elif HAVE_LD_COMPRESS_DEBUG == 2
747 /* GNU style, GNU gold options. */
748 #define LINK_COMPRESS_DEBUG_SPEC \
749 " %{gz|gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
750 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
751 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
752 #elif HAVE_LD_COMPRESS_DEBUG == 3
753 /* ELF gABI style. */
754 #define LINK_COMPRESS_DEBUG_SPEC \
755 " %{gz|gz=zlib:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
756 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
757 " %{gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
758 #else
759 #error Unknown value for HAVE_LD_COMPRESS_DEBUG.
760 #endif
762 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
763 included. */
764 #ifndef LIBGCC_SPEC
765 #if defined(REAL_LIBGCC_SPEC)
766 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
767 #elif defined(LINK_LIBGCC_SPECIAL_1)
768 /* Have gcc do the search for libgcc.a. */
769 #define LIBGCC_SPEC "libgcc.a%s"
770 #else
771 #define LIBGCC_SPEC "-lgcc"
772 #endif
773 #endif
775 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
776 #ifndef STARTFILE_SPEC
777 #define STARTFILE_SPEC \
778 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
779 #endif
781 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
782 #ifndef ENDFILE_SPEC
783 #define ENDFILE_SPEC ""
784 #endif
786 #ifndef LINKER_NAME
787 #define LINKER_NAME "collect2"
788 #endif
790 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
791 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
792 #else
793 #define ASM_MAP ""
794 #endif
796 /* Assembler options for compressed debug sections. */
797 #if HAVE_LD_COMPRESS_DEBUG < 2
798 /* Reject if the linker cannot write compressed debug sections. */
799 #define ASM_COMPRESS_DEBUG_SPEC \
800 " %{gz*:%e-gz is not supported in this configuration} "
801 #else /* HAVE_LD_COMPRESS_DEBUG >= 2 */
802 #if HAVE_AS_COMPRESS_DEBUG == 0
803 /* No assembler support. Ignore silently. */
804 #define ASM_COMPRESS_DEBUG_SPEC \
805 " %{gz*:} "
806 #elif HAVE_AS_COMPRESS_DEBUG == 1
807 /* GNU style, GNU as options. */
808 #define ASM_COMPRESS_DEBUG_SPEC \
809 " %{gz|gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "}" \
810 " %{gz=none:" AS_NO_COMPRESS_DEBUG_OPTION "}" \
811 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
812 #elif HAVE_AS_COMPRESS_DEBUG == 2
813 /* ELF gABI style. */
814 #define ASM_COMPRESS_DEBUG_SPEC \
815 " %{gz|gz=zlib:" AS_COMPRESS_DEBUG_OPTION "=zlib}" \
816 " %{gz=none:" AS_COMPRESS_DEBUG_OPTION "=none}" \
817 " %{gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
818 #else
819 #error Unknown value for HAVE_AS_COMPRESS_DEBUG.
820 #endif
821 #endif /* HAVE_LD_COMPRESS_DEBUG >= 2 */
823 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
824 to the assembler. */
825 #ifndef ASM_DEBUG_SPEC
826 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
827 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
828 # define ASM_DEBUG_SPEC \
829 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
830 ? "%{!g0:%{gdwarf*:--gdwarf2}%{!gdwarf*:%{g*:--gstabs}}}" ASM_MAP \
831 : "%{!g0:%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
832 # else
833 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
834 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gstabs}}" ASM_MAP
835 # endif
836 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
837 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gdwarf2}}" ASM_MAP
838 # endif
839 # endif
840 #endif
841 #ifndef ASM_DEBUG_SPEC
842 # define ASM_DEBUG_SPEC ""
843 #endif
845 /* Here is the spec for running the linker, after compiling all files. */
847 /* This is overridable by the target in case they need to specify the
848 -lgcc and -lc order specially, yet not require them to override all
849 of LINK_COMMAND_SPEC. */
850 #ifndef LINK_GCC_C_SEQUENCE_SPEC
851 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
852 #endif
854 #ifndef LINK_SSP_SPEC
855 #ifdef TARGET_LIBC_PROVIDES_SSP
856 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
857 "|fstack-protector-strong|fstack-protector-explicit:}"
858 #else
859 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
860 "|fstack-protector-strong|fstack-protector-explicit" \
861 ":-lssp_nonshared -lssp}"
862 #endif
863 #endif
865 #ifdef ENABLE_DEFAULT_PIE
866 #define NO_PIE_SPEC "no-pie|static"
867 #define PIE_SPEC NO_PIE_SPEC "|r|shared:;"
868 #define NO_FPIE1_SPEC "fno-pie"
869 #define FPIE1_SPEC NO_FPIE1_SPEC ":;"
870 #define NO_FPIE2_SPEC "fno-PIE"
871 #define FPIE2_SPEC NO_FPIE2_SPEC ":;"
872 #define NO_FPIE_SPEC NO_FPIE1_SPEC "|" NO_FPIE2_SPEC
873 #define FPIE_SPEC NO_FPIE_SPEC ":;"
874 #define NO_FPIC1_SPEC "fno-pic"
875 #define FPIC1_SPEC NO_FPIC1_SPEC ":;"
876 #define NO_FPIC2_SPEC "fno-PIC"
877 #define FPIC2_SPEC NO_FPIC2_SPEC ":;"
878 #define NO_FPIC_SPEC NO_FPIC1_SPEC "|" NO_FPIC2_SPEC
879 #define FPIC_SPEC NO_FPIC_SPEC ":;"
880 #define NO_FPIE1_AND_FPIC1_SPEC NO_FPIE1_SPEC "|" NO_FPIC1_SPEC
881 #define FPIE1_OR_FPIC1_SPEC NO_FPIE1_AND_FPIC1_SPEC ":;"
882 #define NO_FPIE2_AND_FPIC2_SPEC NO_FPIE2_SPEC "|" NO_FPIC2_SPEC
883 #define FPIE2_OR_FPIC2_SPEC NO_FPIE2_AND_FPIC2_SPEC ":;"
884 #define NO_FPIE_AND_FPIC_SPEC NO_FPIE_SPEC "|" NO_FPIC_SPEC
885 #define FPIE_OR_FPIC_SPEC NO_FPIE_AND_FPIC_SPEC ":;"
886 #else
887 #define PIE_SPEC "pie"
888 #define NO_PIE_SPEC PIE_SPEC "|r|shared:;"
889 #define FPIE1_SPEC "fpie"
890 #define NO_FPIE1_SPEC FPIE1_SPEC ":;"
891 #define FPIE2_SPEC "fPIE"
892 #define NO_FPIE2_SPEC FPIE2_SPEC ":;"
893 #define FPIE_SPEC FPIE1_SPEC "|" FPIE2_SPEC
894 #define NO_FPIE_SPEC FPIE_SPEC ":;"
895 #define FPIC1_SPEC "fpic"
896 #define NO_FPIC1_SPEC FPIC1_SPEC ":;"
897 #define FPIC2_SPEC "fPIC"
898 #define NO_FPIC2_SPEC FPIC2_SPEC ":;"
899 #define FPIC_SPEC FPIC1_SPEC "|" FPIC2_SPEC
900 #define NO_FPIC_SPEC FPIC_SPEC ":;"
901 #define FPIE1_OR_FPIC1_SPEC FPIE1_SPEC "|" FPIC1_SPEC
902 #define NO_FPIE1_AND_FPIC1_SPEC FPIE1_OR_FPIC1_SPEC ":;"
903 #define FPIE2_OR_FPIC2_SPEC FPIE2_SPEC "|" FPIC2_SPEC
904 #define NO_FPIE2_AND_FPIC2_SPEC FPIE1_OR_FPIC2_SPEC ":;"
905 #define FPIE_OR_FPIC_SPEC FPIE_SPEC "|" FPIC_SPEC
906 #define NO_FPIE_AND_FPIC_SPEC FPIE_OR_FPIC_SPEC ":;"
907 #endif
909 #ifndef LINK_PIE_SPEC
910 #ifdef HAVE_LD_PIE
911 #define LD_PIE_SPEC "-pie"
912 #else
913 #define LD_PIE_SPEC ""
914 #endif
915 #define LINK_PIE_SPEC "%{no-pie:} " "%{" PIE_SPEC ":" LD_PIE_SPEC "} "
916 #endif
918 #ifndef LINK_BUILDID_SPEC
919 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
920 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
921 # endif
922 #endif
924 /* Conditional to test whether the LTO plugin is used or not.
925 FIXME: For slim LTO we will need to enable plugin unconditionally. This
926 still cause problems with PLUGIN_LD != LD and when plugin is built but
927 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
928 plugin only when LTO is enabled. We still honor explicit
929 -fuse-linker-plugin if the linker used understands -plugin. */
931 /* The linker has some plugin support. */
932 #if HAVE_LTO_PLUGIN > 0
933 /* The linker used has full plugin support, use LTO plugin by default. */
934 #if HAVE_LTO_PLUGIN == 2
935 #define PLUGIN_COND "!fno-use-linker-plugin:%{!fno-lto"
936 #define PLUGIN_COND_CLOSE "}"
937 #else
938 /* The linker used has limited plugin support, use LTO plugin with explicit
939 -fuse-linker-plugin. */
940 #define PLUGIN_COND "fuse-linker-plugin"
941 #define PLUGIN_COND_CLOSE ""
942 #endif
943 #define LINK_PLUGIN_SPEC \
944 "%{" PLUGIN_COND": \
945 -plugin %(linker_plugin_file) \
946 -plugin-opt=%(lto_wrapper) \
947 -plugin-opt=-fresolution=%u.res \
948 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
949 }" PLUGIN_COND_CLOSE
950 #else
951 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
952 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
953 %e-fuse-linker-plugin is not supported in this configuration}"
954 #endif
956 /* Linker command line options for -fsanitize= early on the command line. */
957 #ifndef SANITIZER_EARLY_SPEC
958 #define SANITIZER_EARLY_SPEC "\
959 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_EARLY_SPEC "} \
960 %{%:sanitize(thread):" LIBTSAN_EARLY_SPEC "} \
961 %{%:sanitize(leak):" LIBLSAN_EARLY_SPEC "}}}"
962 #endif
964 /* Linker command line options for -fsanitize= late on the command line. */
965 #ifndef SANITIZER_SPEC
966 #define SANITIZER_SPEC "\
967 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_SPEC "\
968 %{static:%ecannot specify -static with -fsanitize=address}}\
969 %{%:sanitize(thread):" LIBTSAN_SPEC "\
970 %{static:%ecannot specify -static with -fsanitize=thread}}\
971 %{%:sanitize(undefined):" LIBUBSAN_SPEC "}\
972 %{%:sanitize(leak):" LIBLSAN_SPEC "}}}"
973 #endif
975 /* This is the spec to use, once the code for creating the vtable
976 verification runtime library, libvtv.so, has been created. Currently
977 the vtable verification runtime functions are in libstdc++, so we use
978 the spec just below this one. */
979 #ifndef VTABLE_VERIFICATION_SPEC
980 #define VTABLE_VERIFICATION_SPEC "\
981 %{!nostdlib:%{fvtable-verify=std: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}\
982 %{fvtable-verify=preinit: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}}"
983 #endif
985 #ifndef CHKP_SPEC
986 #define CHKP_SPEC ""
987 #endif
989 /* -u* was put back because both BSD and SysV seem to support it. */
990 /* %{static:} simply prevents an error message if the target machine
991 doesn't handle -static. */
992 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
993 scripts which exist in user specified directories, or in standard
994 directories. */
995 /* We pass any -flto flags on to the linker, which is expected
996 to understand them. In practice, this means it had better be collect2. */
997 /* %{e*} includes -export-dynamic; see comment in common.opt. */
998 #ifndef LINK_COMMAND_SPEC
999 #define LINK_COMMAND_SPEC "\
1000 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
1001 %(linker) " \
1002 LINK_PLUGIN_SPEC \
1003 "%{flto|flto=*:%<fcompare-debug*} \
1004 %{flto} %{fno-lto} %{flto=*} %l " LINK_PIE_SPEC \
1005 "%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
1006 "%X %{o*} %{e*} %{N} %{n} %{r}\
1007 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}} " VTABLE_VERIFICATION_SPEC " \
1008 %{static:} %{L*} %(mfwrap) %(link_libgcc) " SANITIZER_EARLY_SPEC " %o\
1009 " CHKP_SPEC " \
1010 %{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*} 1):\
1011 %:include(libgomp.spec)%(link_gomp)}\
1012 %{fcilkplus:%:include(libcilkrts.spec)%(link_cilkrts)}\
1013 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
1014 %(mflib) " STACK_SPLIT_SPEC "\
1015 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
1016 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
1017 %{!nostdlib:%{!nostartfiles:%E}} %{T*} }}}}}}"
1018 #endif
1020 #ifndef LINK_LIBGCC_SPEC
1021 /* Generate -L options for startfile prefix list. */
1022 # define LINK_LIBGCC_SPEC "%D"
1023 #endif
1025 #ifndef STARTFILE_PREFIX_SPEC
1026 # define STARTFILE_PREFIX_SPEC ""
1027 #endif
1029 #ifndef SYSROOT_SPEC
1030 # define SYSROOT_SPEC "--sysroot=%R"
1031 #endif
1033 #ifndef SYSROOT_SUFFIX_SPEC
1034 # define SYSROOT_SUFFIX_SPEC ""
1035 #endif
1037 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
1038 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
1039 #endif
1041 static const char *asm_debug = ASM_DEBUG_SPEC;
1042 static const char *cpp_spec = CPP_SPEC;
1043 static const char *cc1_spec = CC1_SPEC;
1044 static const char *cc1plus_spec = CC1PLUS_SPEC;
1045 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
1046 static const char *link_ssp_spec = LINK_SSP_SPEC;
1047 static const char *asm_spec = ASM_SPEC;
1048 static const char *asm_final_spec = ASM_FINAL_SPEC;
1049 static const char *link_spec = LINK_SPEC;
1050 static const char *lib_spec = LIB_SPEC;
1051 static const char *link_gomp_spec = "";
1052 static const char *libgcc_spec = LIBGCC_SPEC;
1053 static const char *endfile_spec = ENDFILE_SPEC;
1054 static const char *startfile_spec = STARTFILE_SPEC;
1055 static const char *linker_name_spec = LINKER_NAME;
1056 static const char *linker_plugin_file_spec = "";
1057 static const char *lto_wrapper_spec = "";
1058 static const char *lto_gcc_spec = "";
1059 static const char *link_command_spec = LINK_COMMAND_SPEC;
1060 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
1061 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
1062 static const char *sysroot_spec = SYSROOT_SPEC;
1063 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
1064 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
1065 static const char *self_spec = "";
1067 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
1068 There should be no need to override these in target dependent files,
1069 but we need to copy them to the specs file so that newer versions
1070 of the GCC driver can correctly drive older tool chains with the
1071 appropriate -B options. */
1073 /* When cpplib handles traditional preprocessing, get rid of this, and
1074 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
1075 that we default the front end language better. */
1076 static const char *trad_capable_cpp =
1077 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
1079 /* We don't wrap .d files in %W{} since a missing .d file, and
1080 therefore no dependency entry, confuses make into thinking a .o
1081 file that happens to exist is up-to-date. */
1082 static const char *cpp_unique_options =
1083 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
1084 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
1085 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
1086 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
1087 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
1088 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
1089 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1090 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
1091 %{E|M|MM:%W{o*}}";
1093 /* This contains cpp options which are common with cc1_options and are passed
1094 only when preprocessing only to avoid duplication. We pass the cc1 spec
1095 options to the preprocessor so that it the cc1 spec may manipulate
1096 options used to set target flags. Those special target flags settings may
1097 in turn cause preprocessor symbols to be defined specially. */
1098 static const char *cpp_options =
1099 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
1100 %{f*} %{g*:%{!g0:%{g*} %{!fno-working-directory:-fworking-directory}}} %{O*}\
1101 %{undef} %{save-temps*:-fpch-preprocess}";
1103 /* This contains cpp options which are not passed when the preprocessor
1104 output will be used by another program. */
1105 static const char *cpp_debug_options = "%{d*}";
1107 /* NB: This is shared amongst all front-ends, except for Ada. */
1108 static const char *cc1_options =
1109 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
1110 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1111 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
1112 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
1113 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
1114 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
1115 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
1116 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
1117 %{-target-help:--target-help}\
1118 %{-version:--version}\
1119 %{-help=*:--help=%*}\
1120 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
1121 %{fsyntax-only:-o %j} %{-param*}\
1122 %{coverage:-fprofile-arcs -ftest-coverage}";
1124 static const char *asm_options =
1125 "%{-target-help:%:print-asm-header()} "
1126 #if HAVE_GNU_AS
1127 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
1128 to the assembler equivalents. */
1129 "%{v} %{w:-W} %{I*} "
1130 #endif
1131 ASM_COMPRESS_DEBUG_SPEC
1132 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
1134 static const char *invoke_as =
1135 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1136 "%{!fwpa*:\
1137 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1138 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
1140 #else
1141 "%{!fwpa*:\
1142 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1143 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
1145 #endif
1147 /* Some compilers have limits on line lengths, and the multilib_select
1148 and/or multilib_matches strings can be very long, so we build them at
1149 run time. */
1150 static struct obstack multilib_obstack;
1151 static const char *multilib_select;
1152 static const char *multilib_matches;
1153 static const char *multilib_defaults;
1154 static const char *multilib_exclusions;
1155 static const char *multilib_reuse;
1157 /* Check whether a particular argument is a default argument. */
1159 #ifndef MULTILIB_DEFAULTS
1160 #define MULTILIB_DEFAULTS { "" }
1161 #endif
1163 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
1165 #ifndef DRIVER_SELF_SPECS
1166 #define DRIVER_SELF_SPECS ""
1167 #endif
1169 /* Linking to libgomp implies pthreads. This is particularly important
1170 for targets that use different start files and suchlike. */
1171 #ifndef GOMP_SELF_SPECS
1172 #define GOMP_SELF_SPECS \
1173 "%{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*} 1): " \
1174 "-pthread}"
1175 #endif
1177 /* Likewise for -fgnu-tm. */
1178 #ifndef GTM_SELF_SPECS
1179 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
1180 #endif
1182 /* Likewise for -fcilkplus. */
1183 #ifndef CILK_SELF_SPECS
1184 #define CILK_SELF_SPECS "%{fcilkplus: -pthread}"
1185 #endif
1187 static const char *const driver_self_specs[] = {
1188 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
1189 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS,
1190 CILK_SELF_SPECS
1193 #ifndef OPTION_DEFAULT_SPECS
1194 #define OPTION_DEFAULT_SPECS { "", "" }
1195 #endif
1197 struct default_spec
1199 const char *name;
1200 const char *spec;
1203 static const struct default_spec
1204 option_default_specs[] = { OPTION_DEFAULT_SPECS };
1206 struct user_specs
1208 struct user_specs *next;
1209 const char *filename;
1212 static struct user_specs *user_specs_head, *user_specs_tail;
1215 /* Record the mapping from file suffixes for compilation specs. */
1217 struct compiler
1219 const char *suffix; /* Use this compiler for input files
1220 whose names end in this suffix. */
1222 const char *spec; /* To use this compiler, run this spec. */
1224 const char *cpp_spec; /* If non-NULL, substitute this spec
1225 for `%C', rather than the usual
1226 cpp_spec. */
1227 const int combinable; /* If nonzero, compiler can deal with
1228 multiple source files at once (IMA). */
1229 const int needs_preprocessing; /* If nonzero, source files need to
1230 be run through a preprocessor. */
1233 /* Pointer to a vector of `struct compiler' that gives the spec for
1234 compiling a file, based on its suffix.
1235 A file that does not end in any of these suffixes will be passed
1236 unchanged to the loader and nothing else will be done to it.
1238 An entry containing two 0s is used to terminate the vector.
1240 If multiple entries match a file, the last matching one is used. */
1242 static struct compiler *compilers;
1244 /* Number of entries in `compilers', not counting the null terminator. */
1246 static int n_compilers;
1248 /* The default list of file name suffixes and their compilation specs. */
1250 static const struct compiler default_compilers[] =
1252 /* Add lists of suffixes of known languages here. If those languages
1253 were not present when we built the driver, we will hit these copies
1254 and be given a more meaningful error than "file not used since
1255 linking is not done". */
1256 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
1257 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
1258 {".mii", "#Objective-C++", 0, 0, 0},
1259 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
1260 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
1261 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
1262 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
1263 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
1264 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
1265 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
1266 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
1267 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
1268 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
1269 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
1270 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1271 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1272 {".r", "#Ratfor", 0, 0, 0},
1273 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
1274 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
1275 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
1276 {".go", "#Go", 0, 1, 0},
1277 /* Next come the entries for C. */
1278 {".c", "@c", 0, 0, 1},
1279 {"@c",
1280 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1281 external preprocessor if -save-temps is given. */
1282 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1283 %{!E:%{!M:%{!MM:\
1284 %{traditional:\
1285 %eGNU C no longer supports -traditional without -E}\
1286 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1287 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1288 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1289 %(cc1_options)}\
1290 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1291 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1292 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1293 {"-",
1294 "%{!E:%e-E or -x required when input is from standard input}\
1295 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1296 {".h", "@c-header", 0, 0, 0},
1297 {"@c-header",
1298 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1299 external preprocessor if -save-temps is given. */
1300 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1301 %{!E:%{!M:%{!MM:\
1302 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1303 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1304 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1305 %(cc1_options)\
1306 %{!fsyntax-only:-o %g.s \
1307 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1308 %W{o*:--output-pch=%*}}%V}}\
1309 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1310 cc1 %(cpp_unique_options) %(cc1_options)\
1311 %{!fsyntax-only:-o %g.s \
1312 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1313 %W{o*:--output-pch=%*}}%V}}}}}}}", 0, 0, 0},
1314 {".i", "@cpp-output", 0, 0, 0},
1315 {"@cpp-output",
1316 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1317 {".s", "@assembler", 0, 0, 0},
1318 {"@assembler",
1319 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1320 {".sx", "@assembler-with-cpp", 0, 0, 0},
1321 {".S", "@assembler-with-cpp", 0, 0, 0},
1322 {"@assembler-with-cpp",
1323 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1324 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1325 %{E|M|MM:%(cpp_debug_options)}\
1326 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1327 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1328 #else
1329 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1330 %{E|M|MM:%(cpp_debug_options)}\
1331 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1332 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1333 #endif
1334 , 0, 0, 0},
1336 #include "specs.h"
1337 /* Mark end of table. */
1338 {0, 0, 0, 0, 0}
1341 /* Number of elements in default_compilers, not counting the terminator. */
1343 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1345 typedef char *char_p; /* For DEF_VEC_P. */
1347 /* A vector of options to give to the linker.
1348 These options are accumulated by %x,
1349 and substituted into the linker command with %X. */
1350 static vec<char_p> linker_options;
1352 /* A vector of options to give to the assembler.
1353 These options are accumulated by -Wa,
1354 and substituted into the assembler command with %Y. */
1355 static vec<char_p> assembler_options;
1357 /* A vector of options to give to the preprocessor.
1358 These options are accumulated by -Wp,
1359 and substituted into the preprocessor command with %Z. */
1360 static vec<char_p> preprocessor_options;
1362 static char *
1363 skip_whitespace (char *p)
1365 while (1)
1367 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1368 be considered whitespace. */
1369 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1370 return p + 1;
1371 else if (*p == '\n' || *p == ' ' || *p == '\t')
1372 p++;
1373 else if (*p == '#')
1375 while (*p != '\n')
1376 p++;
1377 p++;
1379 else
1380 break;
1383 return p;
1385 /* Structures to keep track of prefixes to try when looking for files. */
1387 struct prefix_list
1389 const char *prefix; /* String to prepend to the path. */
1390 struct prefix_list *next; /* Next in linked list. */
1391 int require_machine_suffix; /* Don't use without machine_suffix. */
1392 /* 2 means try both machine_suffix and just_machine_suffix. */
1393 int priority; /* Sort key - priority within list. */
1394 int os_multilib; /* 1 if OS multilib scheme should be used,
1395 0 for GCC multilib scheme. */
1398 struct path_prefix
1400 struct prefix_list *plist; /* List of prefixes to try */
1401 int max_len; /* Max length of a prefix in PLIST */
1402 const char *name; /* Name of this list (used in config stuff) */
1405 /* List of prefixes to try when looking for executables. */
1407 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1409 /* List of prefixes to try when looking for startup (crt0) files. */
1411 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1413 /* List of prefixes to try when looking for include files. */
1415 static struct path_prefix include_prefixes = { 0, 0, "include" };
1417 /* Suffix to attach to directories searched for commands.
1418 This looks like `MACHINE/VERSION/'. */
1420 static const char *machine_suffix = 0;
1422 /* Suffix to attach to directories searched for commands.
1423 This is just `MACHINE/'. */
1425 static const char *just_machine_suffix = 0;
1427 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1429 static const char *gcc_exec_prefix;
1431 /* Adjusted value of standard_libexec_prefix. */
1433 static const char *gcc_libexec_prefix;
1435 /* Default prefixes to attach to command names. */
1437 #ifndef STANDARD_STARTFILE_PREFIX_1
1438 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1439 #endif
1440 #ifndef STANDARD_STARTFILE_PREFIX_2
1441 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1442 #endif
1444 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1445 #undef MD_EXEC_PREFIX
1446 #undef MD_STARTFILE_PREFIX
1447 #undef MD_STARTFILE_PREFIX_1
1448 #endif
1450 /* If no prefixes defined, use the null string, which will disable them. */
1451 #ifndef MD_EXEC_PREFIX
1452 #define MD_EXEC_PREFIX ""
1453 #endif
1454 #ifndef MD_STARTFILE_PREFIX
1455 #define MD_STARTFILE_PREFIX ""
1456 #endif
1457 #ifndef MD_STARTFILE_PREFIX_1
1458 #define MD_STARTFILE_PREFIX_1 ""
1459 #endif
1461 /* These directories are locations set at configure-time based on the
1462 --prefix option provided to configure. Their initializers are
1463 defined in Makefile.in. These paths are not *directly* used when
1464 gcc_exec_prefix is set because, in that case, we know where the
1465 compiler has been installed, and use paths relative to that
1466 location instead. */
1467 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1468 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1469 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1470 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1472 /* For native compilers, these are well-known paths containing
1473 components that may be provided by the system. For cross
1474 compilers, these paths are not used. */
1475 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1476 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1477 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1478 static const char *const standard_startfile_prefix_1
1479 = STANDARD_STARTFILE_PREFIX_1;
1480 static const char *const standard_startfile_prefix_2
1481 = STANDARD_STARTFILE_PREFIX_2;
1483 /* A relative path to be used in finding the location of tools
1484 relative to the driver. */
1485 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1487 /* A prefix to be used when this is an accelerator compiler. */
1488 static const char *const accel_dir_suffix = ACCEL_DIR_SUFFIX;
1490 /* Subdirectory to use for locating libraries. Set by
1491 set_multilib_dir based on the compilation options. */
1493 static const char *multilib_dir;
1495 /* Subdirectory to use for locating libraries in OS conventions. Set by
1496 set_multilib_dir based on the compilation options. */
1498 static const char *multilib_os_dir;
1500 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1501 set_multilib_dir based on the compilation options. */
1503 static const char *multiarch_dir;
1505 /* Structure to keep track of the specs that have been defined so far.
1506 These are accessed using %(specname) in a compiler or link
1507 spec. */
1509 struct spec_list
1511 /* The following 2 fields must be first */
1512 /* to allow EXTRA_SPECS to be initialized */
1513 const char *name; /* name of the spec. */
1514 const char *ptr; /* available ptr if no static pointer */
1516 /* The following fields are not initialized */
1517 /* by EXTRA_SPECS */
1518 const char **ptr_spec; /* pointer to the spec itself. */
1519 struct spec_list *next; /* Next spec in linked list. */
1520 int name_len; /* length of the name */
1521 bool user_p; /* whether string come from file spec. */
1522 bool alloc_p; /* whether string was allocated */
1523 const char *default_ptr; /* The default value of *ptr_spec. */
1526 #define INIT_STATIC_SPEC(NAME,PTR) \
1527 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false, \
1528 *PTR }
1530 /* List of statically defined specs. */
1531 static struct spec_list static_specs[] =
1533 INIT_STATIC_SPEC ("asm", &asm_spec),
1534 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1535 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1536 INIT_STATIC_SPEC ("asm_options", &asm_options),
1537 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1538 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1539 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1540 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1541 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1542 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1543 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1544 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1545 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1546 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1547 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1548 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1549 INIT_STATIC_SPEC ("link", &link_spec),
1550 INIT_STATIC_SPEC ("lib", &lib_spec),
1551 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1552 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1553 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1554 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1555 INIT_STATIC_SPEC ("version", &compiler_version),
1556 INIT_STATIC_SPEC ("multilib", &multilib_select),
1557 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1558 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1559 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1560 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1561 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1562 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1563 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1564 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1565 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1566 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1567 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1568 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1569 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1570 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1571 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1572 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1573 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1574 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1575 INIT_STATIC_SPEC ("self_spec", &self_spec),
1578 #ifdef EXTRA_SPECS /* additional specs needed */
1579 /* Structure to keep track of just the first two args of a spec_list.
1580 That is all that the EXTRA_SPECS macro gives us. */
1581 struct spec_list_1
1583 const char *const name;
1584 const char *const ptr;
1587 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1588 static struct spec_list *extra_specs = (struct spec_list *) 0;
1589 #endif
1591 /* List of dynamically allocates specs that have been defined so far. */
1593 static struct spec_list *specs = (struct spec_list *) 0;
1595 /* List of static spec functions. */
1597 static const struct spec_function static_spec_functions[] =
1599 { "getenv", getenv_spec_function },
1600 { "if-exists", if_exists_spec_function },
1601 { "if-exists-else", if_exists_else_spec_function },
1602 { "sanitize", sanitize_spec_function },
1603 { "replace-outfile", replace_outfile_spec_function },
1604 { "remove-outfile", remove_outfile_spec_function },
1605 { "version-compare", version_compare_spec_function },
1606 { "include", include_spec_function },
1607 { "find-file", find_file_spec_function },
1608 { "find-plugindir", find_plugindir_spec_function },
1609 { "print-asm-header", print_asm_header_spec_function },
1610 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1611 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1612 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1613 { "pass-through-libs", pass_through_libs_spec_func },
1614 { "replace-extension", replace_extension_spec_func },
1615 { "gt", greater_than_spec_func },
1616 #ifdef EXTRA_SPEC_FUNCTIONS
1617 EXTRA_SPEC_FUNCTIONS
1618 #endif
1619 { 0, 0 }
1622 static int processing_spec_function;
1624 /* Add appropriate libgcc specs to OBSTACK, taking into account
1625 various permutations of -shared-libgcc, -shared, and such. */
1627 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1629 #ifndef USE_LD_AS_NEEDED
1630 #define USE_LD_AS_NEEDED 0
1631 #endif
1633 static void
1634 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1635 const char *static_name, const char *eh_name)
1637 char *buf;
1639 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1640 "%{!static:%{!static-libgcc:"
1641 #if USE_LD_AS_NEEDED
1642 "%{!shared-libgcc:",
1643 static_name, " " LD_AS_NEEDED_OPTION " ",
1644 shared_name, " " LD_NO_AS_NEEDED_OPTION
1646 "%{shared-libgcc:",
1647 shared_name, "%{!shared: ", static_name, "}"
1649 #else
1650 "%{!shared:"
1651 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1652 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1654 #ifdef LINK_EH_SPEC
1655 "%{shared:"
1656 "%{shared-libgcc:", shared_name, "}"
1657 "%{!shared-libgcc:", static_name, "}"
1659 #else
1660 "%{shared:", shared_name, "}"
1661 #endif
1662 #endif
1663 "}}", NULL);
1665 obstack_grow (obstack, buf, strlen (buf));
1666 free (buf);
1668 #endif /* ENABLE_SHARED_LIBGCC */
1670 /* Initialize the specs lookup routines. */
1672 static void
1673 init_spec (void)
1675 struct spec_list *next = (struct spec_list *) 0;
1676 struct spec_list *sl = (struct spec_list *) 0;
1677 int i;
1679 if (specs)
1680 return; /* Already initialized. */
1682 if (verbose_flag)
1683 fnotice (stderr, "Using built-in specs.\n");
1685 #ifdef EXTRA_SPECS
1686 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1688 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1690 sl = &extra_specs[i];
1691 sl->name = extra_specs_1[i].name;
1692 sl->ptr = extra_specs_1[i].ptr;
1693 sl->next = next;
1694 sl->name_len = strlen (sl->name);
1695 sl->ptr_spec = &sl->ptr;
1696 gcc_assert (sl->ptr_spec != NULL);
1697 sl->default_ptr = sl->ptr;
1698 next = sl;
1700 #endif
1702 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1704 sl = &static_specs[i];
1705 sl->next = next;
1706 next = sl;
1709 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1710 /* ??? If neither -shared-libgcc nor --static-libgcc was
1711 seen, then we should be making an educated guess. Some proposed
1712 heuristics for ELF include:
1714 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1715 program will be doing dynamic loading, which will likely
1716 need the shared libgcc.
1718 (2) If "-ldl", then it's also a fair bet that we're doing
1719 dynamic loading.
1721 (3) For each ET_DYN we're linking against (either through -lfoo
1722 or /some/path/foo.so), check to see whether it or one of
1723 its dependencies depends on a shared libgcc.
1725 (4) If "-shared"
1727 If the runtime is fixed to look for program headers instead
1728 of calling __register_frame_info at all, for each object,
1729 use the shared libgcc if any EH symbol referenced.
1731 If crtstuff is fixed to not invoke __register_frame_info
1732 automatically, for each object, use the shared libgcc if
1733 any non-empty unwind section found.
1735 Doing any of this probably requires invoking an external program to
1736 do the actual object file scanning. */
1738 const char *p = libgcc_spec;
1739 int in_sep = 1;
1741 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1742 when given the proper command line arguments. */
1743 while (*p)
1745 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1747 init_gcc_specs (&obstack,
1748 "-lgcc_s"
1749 #ifdef USE_LIBUNWIND_EXCEPTIONS
1750 " -lunwind"
1751 #endif
1753 "-lgcc",
1754 "-lgcc_eh"
1755 #ifdef USE_LIBUNWIND_EXCEPTIONS
1756 # ifdef HAVE_LD_STATIC_DYNAMIC
1757 " %{!static:" LD_STATIC_OPTION "} -lunwind"
1758 " %{!static:" LD_DYNAMIC_OPTION "}"
1759 # else
1760 " -lunwind"
1761 # endif
1762 #endif
1765 p += 5;
1766 in_sep = 0;
1768 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1770 /* Ug. We don't know shared library extensions. Hope that
1771 systems that use this form don't do shared libraries. */
1772 init_gcc_specs (&obstack,
1773 "-lgcc_s",
1774 "libgcc.a%s",
1775 "libgcc_eh.a%s"
1776 #ifdef USE_LIBUNWIND_EXCEPTIONS
1777 " -lunwind"
1778 #endif
1780 p += 10;
1781 in_sep = 0;
1783 else
1785 obstack_1grow (&obstack, *p);
1786 in_sep = (*p == ' ');
1787 p += 1;
1791 obstack_1grow (&obstack, '\0');
1792 libgcc_spec = XOBFINISH (&obstack, const char *);
1794 #endif
1795 #ifdef USE_AS_TRADITIONAL_FORMAT
1796 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1798 static const char tf[] = "--traditional-format ";
1799 obstack_grow (&obstack, tf, sizeof (tf) - 1);
1800 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1801 asm_spec = XOBFINISH (&obstack, const char *);
1803 #endif
1805 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1806 defined LINKER_HASH_STYLE
1807 # ifdef LINK_BUILDID_SPEC
1808 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1809 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof (LINK_BUILDID_SPEC) - 1);
1810 # endif
1811 # ifdef LINK_EH_SPEC
1812 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1813 obstack_grow (&obstack, LINK_EH_SPEC, sizeof (LINK_EH_SPEC) - 1);
1814 # endif
1815 # ifdef LINKER_HASH_STYLE
1816 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1817 before. */
1819 static const char hash_style[] = "--hash-style=";
1820 obstack_grow (&obstack, hash_style, sizeof (hash_style) - 1);
1821 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof (LINKER_HASH_STYLE) - 1);
1822 obstack_1grow (&obstack, ' ');
1824 # endif
1825 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1826 link_spec = XOBFINISH (&obstack, const char *);
1827 #endif
1829 specs = sl;
1832 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1833 removed; If the spec starts with a + then SPEC is added to the end of the
1834 current spec. */
1836 static void
1837 set_spec (const char *name, const char *spec, bool user_p)
1839 struct spec_list *sl;
1840 const char *old_spec;
1841 int name_len = strlen (name);
1842 int i;
1844 /* If this is the first call, initialize the statically allocated specs. */
1845 if (!specs)
1847 struct spec_list *next = (struct spec_list *) 0;
1848 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1850 sl = &static_specs[i];
1851 sl->next = next;
1852 next = sl;
1854 specs = sl;
1857 /* See if the spec already exists. */
1858 for (sl = specs; sl; sl = sl->next)
1859 if (name_len == sl->name_len && !strcmp (sl->name, name))
1860 break;
1862 if (!sl)
1864 /* Not found - make it. */
1865 sl = XNEW (struct spec_list);
1866 sl->name = xstrdup (name);
1867 sl->name_len = name_len;
1868 sl->ptr_spec = &sl->ptr;
1869 sl->alloc_p = 0;
1870 *(sl->ptr_spec) = "";
1871 sl->next = specs;
1872 sl->default_ptr = NULL;
1873 specs = sl;
1876 old_spec = *(sl->ptr_spec);
1877 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1878 ? concat (old_spec, spec + 1, NULL)
1879 : xstrdup (spec));
1881 #ifdef DEBUG_SPECS
1882 if (verbose_flag)
1883 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1884 #endif
1886 /* Free the old spec. */
1887 if (old_spec && sl->alloc_p)
1888 free (CONST_CAST (char *, old_spec));
1890 sl->user_p = user_p;
1891 sl->alloc_p = true;
1894 /* Accumulate a command (program name and args), and run it. */
1896 typedef const char *const_char_p; /* For DEF_VEC_P. */
1898 /* Vector of pointers to arguments in the current line of specifications. */
1900 static vec<const_char_p> argbuf;
1902 /* Were the options -c, -S or -E passed. */
1903 static int have_c = 0;
1905 /* Was the option -o passed. */
1906 static int have_o = 0;
1908 /* Pointer to output file name passed in with -o. */
1909 static const char *output_file = 0;
1911 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1912 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1913 it here. */
1915 static struct temp_name {
1916 const char *suffix; /* suffix associated with the code. */
1917 int length; /* strlen (suffix). */
1918 int unique; /* Indicates whether %g or %u/%U was used. */
1919 const char *filename; /* associated filename. */
1920 int filename_length; /* strlen (filename). */
1921 struct temp_name *next;
1922 } *temp_names;
1924 /* Number of commands executed so far. */
1926 static int execution_count;
1928 /* Number of commands that exited with a signal. */
1930 static int signal_count;
1932 /* Allocate the argument vector. */
1934 static void
1935 alloc_args (void)
1937 argbuf.create (10);
1940 /* Clear out the vector of arguments (after a command is executed). */
1942 static void
1943 clear_args (void)
1945 argbuf.truncate (0);
1948 /* Add one argument to the vector at the end.
1949 This is done when a space is seen or at the end of the line.
1950 If DELETE_ALWAYS is nonzero, the arg is a filename
1951 and the file should be deleted eventually.
1952 If DELETE_FAILURE is nonzero, the arg is a filename
1953 and the file should be deleted if this compilation fails. */
1955 static void
1956 store_arg (const char *arg, int delete_always, int delete_failure)
1958 argbuf.safe_push (arg);
1960 if (delete_always || delete_failure)
1962 const char *p;
1963 /* If the temporary file we should delete is specified as
1964 part of a joined argument extract the filename. */
1965 if (arg[0] == '-'
1966 && (p = strrchr (arg, '=')))
1967 arg = p + 1;
1968 record_temp_file (arg, delete_always, delete_failure);
1972 /* Load specs from a file name named FILENAME, replacing occurrences of
1973 various different types of line-endings, \r\n, \n\r and just \r, with
1974 a single \n. */
1976 static char *
1977 load_specs (const char *filename)
1979 int desc;
1980 int readlen;
1981 struct stat statbuf;
1982 char *buffer;
1983 char *buffer_p;
1984 char *specs;
1985 char *specs_p;
1987 if (verbose_flag)
1988 fnotice (stderr, "Reading specs from %s\n", filename);
1990 /* Open and stat the file. */
1991 desc = open (filename, O_RDONLY, 0);
1992 if (desc < 0)
1993 pfatal_with_name (filename);
1994 if (stat (filename, &statbuf) < 0)
1995 pfatal_with_name (filename);
1997 /* Read contents of file into BUFFER. */
1998 buffer = XNEWVEC (char, statbuf.st_size + 1);
1999 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
2000 if (readlen < 0)
2001 pfatal_with_name (filename);
2002 buffer[readlen] = 0;
2003 close (desc);
2005 specs = XNEWVEC (char, readlen + 1);
2006 specs_p = specs;
2007 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
2009 int skip = 0;
2010 char c = *buffer_p;
2011 if (c == '\r')
2013 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
2014 skip = 1;
2015 else if (*(buffer_p + 1) == '\n') /* \r\n */
2016 skip = 1;
2017 else /* \r */
2018 c = '\n';
2020 if (! skip)
2021 *specs_p++ = c;
2023 *specs_p = '\0';
2025 free (buffer);
2026 return (specs);
2029 /* Read compilation specs from a file named FILENAME,
2030 replacing the default ones.
2032 A suffix which starts with `*' is a definition for
2033 one of the machine-specific sub-specs. The "suffix" should be
2034 *asm, *cc1, *cpp, *link, *startfile, etc.
2035 The corresponding spec is stored in asm_spec, etc.,
2036 rather than in the `compilers' vector.
2038 Anything invalid in the file is a fatal error. */
2040 static void
2041 read_specs (const char *filename, bool main_p, bool user_p)
2043 char *buffer;
2044 char *p;
2046 buffer = load_specs (filename);
2048 /* Scan BUFFER for specs, putting them in the vector. */
2049 p = buffer;
2050 while (1)
2052 char *suffix;
2053 char *spec;
2054 char *in, *out, *p1, *p2, *p3;
2056 /* Advance P in BUFFER to the next nonblank nocomment line. */
2057 p = skip_whitespace (p);
2058 if (*p == 0)
2059 break;
2061 /* Is this a special command that starts with '%'? */
2062 /* Don't allow this for the main specs file, since it would
2063 encourage people to overwrite it. */
2064 if (*p == '%' && !main_p)
2066 p1 = p;
2067 while (*p && *p != '\n')
2068 p++;
2070 /* Skip '\n'. */
2071 p++;
2073 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
2074 && (p1[sizeof "%include" - 1] == ' '
2075 || p1[sizeof "%include" - 1] == '\t'))
2077 char *new_filename;
2079 p1 += sizeof ("%include");
2080 while (*p1 == ' ' || *p1 == '\t')
2081 p1++;
2083 if (*p1++ != '<' || p[-2] != '>')
2084 fatal_error (input_location,
2085 "specs %%include syntax malformed after "
2086 "%ld characters",
2087 (long) (p1 - buffer + 1));
2089 p[-2] = '\0';
2090 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2091 read_specs (new_filename ? new_filename : p1, false, user_p);
2092 continue;
2094 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
2095 && (p1[sizeof "%include_noerr" - 1] == ' '
2096 || p1[sizeof "%include_noerr" - 1] == '\t'))
2098 char *new_filename;
2100 p1 += sizeof "%include_noerr";
2101 while (*p1 == ' ' || *p1 == '\t')
2102 p1++;
2104 if (*p1++ != '<' || p[-2] != '>')
2105 fatal_error (input_location,
2106 "specs %%include syntax malformed after "
2107 "%ld characters",
2108 (long) (p1 - buffer + 1));
2110 p[-2] = '\0';
2111 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2112 if (new_filename)
2113 read_specs (new_filename, false, user_p);
2114 else if (verbose_flag)
2115 fnotice (stderr, "could not find specs file %s\n", p1);
2116 continue;
2118 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
2119 && (p1[sizeof "%rename" - 1] == ' '
2120 || p1[sizeof "%rename" - 1] == '\t'))
2122 int name_len;
2123 struct spec_list *sl;
2124 struct spec_list *newsl;
2126 /* Get original name. */
2127 p1 += sizeof "%rename";
2128 while (*p1 == ' ' || *p1 == '\t')
2129 p1++;
2131 if (! ISALPHA ((unsigned char) *p1))
2132 fatal_error (input_location,
2133 "specs %%rename syntax malformed after "
2134 "%ld characters",
2135 (long) (p1 - buffer));
2137 p2 = p1;
2138 while (*p2 && !ISSPACE ((unsigned char) *p2))
2139 p2++;
2141 if (*p2 != ' ' && *p2 != '\t')
2142 fatal_error (input_location,
2143 "specs %%rename syntax malformed after "
2144 "%ld characters",
2145 (long) (p2 - buffer));
2147 name_len = p2 - p1;
2148 *p2++ = '\0';
2149 while (*p2 == ' ' || *p2 == '\t')
2150 p2++;
2152 if (! ISALPHA ((unsigned char) *p2))
2153 fatal_error (input_location,
2154 "specs %%rename syntax malformed after "
2155 "%ld characters",
2156 (long) (p2 - buffer));
2158 /* Get new spec name. */
2159 p3 = p2;
2160 while (*p3 && !ISSPACE ((unsigned char) *p3))
2161 p3++;
2163 if (p3 != p - 1)
2164 fatal_error (input_location,
2165 "specs %%rename syntax malformed after "
2166 "%ld characters",
2167 (long) (p3 - buffer));
2168 *p3 = '\0';
2170 for (sl = specs; sl; sl = sl->next)
2171 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2172 break;
2174 if (!sl)
2175 fatal_error (input_location,
2176 "specs %s spec was not found to be renamed", p1);
2178 if (strcmp (p1, p2) == 0)
2179 continue;
2181 for (newsl = specs; newsl; newsl = newsl->next)
2182 if (strcmp (newsl->name, p2) == 0)
2183 fatal_error (input_location,
2184 "%s: attempt to rename spec %qs to "
2185 "already defined spec %qs",
2186 filename, p1, p2);
2188 if (verbose_flag)
2190 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
2191 #ifdef DEBUG_SPECS
2192 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
2193 #endif
2196 set_spec (p2, *(sl->ptr_spec), user_p);
2197 if (sl->alloc_p)
2198 free (CONST_CAST (char *, *(sl->ptr_spec)));
2200 *(sl->ptr_spec) = "";
2201 sl->alloc_p = 0;
2202 continue;
2204 else
2205 fatal_error (input_location,
2206 "specs unknown %% command after %ld characters",
2207 (long) (p1 - buffer));
2210 /* Find the colon that should end the suffix. */
2211 p1 = p;
2212 while (*p1 && *p1 != ':' && *p1 != '\n')
2213 p1++;
2215 /* The colon shouldn't be missing. */
2216 if (*p1 != ':')
2217 fatal_error (input_location,
2218 "specs file malformed after %ld characters",
2219 (long) (p1 - buffer));
2221 /* Skip back over trailing whitespace. */
2222 p2 = p1;
2223 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2224 p2--;
2226 /* Copy the suffix to a string. */
2227 suffix = save_string (p, p2 - p);
2228 /* Find the next line. */
2229 p = skip_whitespace (p1 + 1);
2230 if (p[1] == 0)
2231 fatal_error (input_location,
2232 "specs file malformed after %ld characters",
2233 (long) (p - buffer));
2235 p1 = p;
2236 /* Find next blank line or end of string. */
2237 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2238 p1++;
2240 /* Specs end at the blank line and do not include the newline. */
2241 spec = save_string (p, p1 - p);
2242 p = p1;
2244 /* Delete backslash-newline sequences from the spec. */
2245 in = spec;
2246 out = spec;
2247 while (*in != 0)
2249 if (in[0] == '\\' && in[1] == '\n')
2250 in += 2;
2251 else if (in[0] == '#')
2252 while (*in && *in != '\n')
2253 in++;
2255 else
2256 *out++ = *in++;
2258 *out = 0;
2260 if (suffix[0] == '*')
2262 if (! strcmp (suffix, "*link_command"))
2263 link_command_spec = spec;
2264 else
2266 set_spec (suffix + 1, spec, user_p);
2267 free (spec);
2270 else
2272 /* Add this pair to the vector. */
2273 compilers
2274 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
2276 compilers[n_compilers].suffix = suffix;
2277 compilers[n_compilers].spec = spec;
2278 n_compilers++;
2279 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2282 if (*suffix == 0)
2283 link_command_spec = spec;
2286 if (link_command_spec == 0)
2287 fatal_error (input_location, "spec file has no spec for linking");
2289 XDELETEVEC (buffer);
2292 /* Record the names of temporary files we tell compilers to write,
2293 and delete them at the end of the run. */
2295 /* This is the common prefix we use to make temp file names.
2296 It is chosen once for each run of this program.
2297 It is substituted into a spec by %g or %j.
2298 Thus, all temp file names contain this prefix.
2299 In practice, all temp file names start with this prefix.
2301 This prefix comes from the envvar TMPDIR if it is defined;
2302 otherwise, from the P_tmpdir macro if that is defined;
2303 otherwise, in /usr/tmp or /tmp;
2304 or finally the current directory if all else fails. */
2306 static const char *temp_filename;
2308 /* Length of the prefix. */
2310 static int temp_filename_length;
2312 /* Define the list of temporary files to delete. */
2314 struct temp_file
2316 const char *name;
2317 struct temp_file *next;
2320 /* Queue of files to delete on success or failure of compilation. */
2321 static struct temp_file *always_delete_queue;
2322 /* Queue of files to delete on failure of compilation. */
2323 static struct temp_file *failure_delete_queue;
2325 /* Record FILENAME as a file to be deleted automatically.
2326 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2327 otherwise delete it in any case.
2328 FAIL_DELETE nonzero means delete it if a compilation step fails;
2329 otherwise delete it in any case. */
2331 void
2332 record_temp_file (const char *filename, int always_delete, int fail_delete)
2334 char *const name = xstrdup (filename);
2336 if (always_delete)
2338 struct temp_file *temp;
2339 for (temp = always_delete_queue; temp; temp = temp->next)
2340 if (! filename_cmp (name, temp->name))
2341 goto already1;
2343 temp = XNEW (struct temp_file);
2344 temp->next = always_delete_queue;
2345 temp->name = name;
2346 always_delete_queue = temp;
2348 already1:;
2351 if (fail_delete)
2353 struct temp_file *temp;
2354 for (temp = failure_delete_queue; temp; temp = temp->next)
2355 if (! filename_cmp (name, temp->name))
2357 free (name);
2358 goto already2;
2361 temp = XNEW (struct temp_file);
2362 temp->next = failure_delete_queue;
2363 temp->name = name;
2364 failure_delete_queue = temp;
2366 already2:;
2370 /* Delete all the temporary files whose names we previously recorded. */
2372 #ifndef DELETE_IF_ORDINARY
2373 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2374 do \
2376 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2377 if (unlink (NAME) < 0) \
2378 if (VERBOSE_FLAG) \
2379 perror_with_name (NAME); \
2380 } while (0)
2381 #endif
2383 static void
2384 delete_if_ordinary (const char *name)
2386 struct stat st;
2387 #ifdef DEBUG
2388 int i, c;
2390 printf ("Delete %s? (y or n) ", name);
2391 fflush (stdout);
2392 i = getchar ();
2393 if (i != '\n')
2394 while ((c = getchar ()) != '\n' && c != EOF)
2397 if (i == 'y' || i == 'Y')
2398 #endif /* DEBUG */
2399 DELETE_IF_ORDINARY (name, st, verbose_flag);
2402 static void
2403 delete_temp_files (void)
2405 struct temp_file *temp;
2407 for (temp = always_delete_queue; temp; temp = temp->next)
2408 delete_if_ordinary (temp->name);
2409 always_delete_queue = 0;
2412 /* Delete all the files to be deleted on error. */
2414 static void
2415 delete_failure_queue (void)
2417 struct temp_file *temp;
2419 for (temp = failure_delete_queue; temp; temp = temp->next)
2420 delete_if_ordinary (temp->name);
2423 static void
2424 clear_failure_queue (void)
2426 failure_delete_queue = 0;
2429 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2430 returns non-NULL.
2431 If DO_MULTI is true iterate over the paths twice, first with multilib
2432 suffix then without, otherwise iterate over the paths once without
2433 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2434 to avoid visiting the same path twice, but we could do better. For
2435 instance, /usr/lib/../lib is considered different from /usr/lib.
2436 At least EXTRA_SPACE chars past the end of the path passed to
2437 CALLBACK are available for use by the callback.
2438 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2440 Returns the value returned by CALLBACK. */
2442 static void *
2443 for_each_path (const struct path_prefix *paths,
2444 bool do_multi,
2445 size_t extra_space,
2446 void *(*callback) (char *, void *),
2447 void *callback_info)
2449 struct prefix_list *pl;
2450 const char *multi_dir = NULL;
2451 const char *multi_os_dir = NULL;
2452 const char *multiarch_suffix = NULL;
2453 const char *multi_suffix;
2454 const char *just_multi_suffix;
2455 char *path = NULL;
2456 void *ret = NULL;
2457 bool skip_multi_dir = false;
2458 bool skip_multi_os_dir = false;
2460 multi_suffix = machine_suffix;
2461 just_multi_suffix = just_machine_suffix;
2462 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2464 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2465 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2466 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2468 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2469 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2470 if (multiarch_dir)
2471 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2473 while (1)
2475 size_t multi_dir_len = 0;
2476 size_t multi_os_dir_len = 0;
2477 size_t multiarch_len = 0;
2478 size_t suffix_len;
2479 size_t just_suffix_len;
2480 size_t len;
2482 if (multi_dir)
2483 multi_dir_len = strlen (multi_dir);
2484 if (multi_os_dir)
2485 multi_os_dir_len = strlen (multi_os_dir);
2486 if (multiarch_suffix)
2487 multiarch_len = strlen (multiarch_suffix);
2488 suffix_len = strlen (multi_suffix);
2489 just_suffix_len = strlen (just_multi_suffix);
2491 if (path == NULL)
2493 len = paths->max_len + extra_space + 1;
2494 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2495 path = XNEWVEC (char, len);
2498 for (pl = paths->plist; pl != 0; pl = pl->next)
2500 len = strlen (pl->prefix);
2501 memcpy (path, pl->prefix, len);
2503 /* Look first in MACHINE/VERSION subdirectory. */
2504 if (!skip_multi_dir)
2506 memcpy (path + len, multi_suffix, suffix_len + 1);
2507 ret = callback (path, callback_info);
2508 if (ret)
2509 break;
2512 /* Some paths are tried with just the machine (ie. target)
2513 subdir. This is used for finding as, ld, etc. */
2514 if (!skip_multi_dir
2515 && pl->require_machine_suffix == 2)
2517 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2518 ret = callback (path, callback_info);
2519 if (ret)
2520 break;
2523 /* Now try the multiarch path. */
2524 if (!skip_multi_dir
2525 && !pl->require_machine_suffix && multiarch_dir)
2527 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2528 ret = callback (path, callback_info);
2529 if (ret)
2530 break;
2533 /* Now try the base path. */
2534 if (!pl->require_machine_suffix
2535 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2537 const char *this_multi;
2538 size_t this_multi_len;
2540 if (pl->os_multilib)
2542 this_multi = multi_os_dir;
2543 this_multi_len = multi_os_dir_len;
2545 else
2547 this_multi = multi_dir;
2548 this_multi_len = multi_dir_len;
2551 if (this_multi_len)
2552 memcpy (path + len, this_multi, this_multi_len + 1);
2553 else
2554 path[len] = '\0';
2556 ret = callback (path, callback_info);
2557 if (ret)
2558 break;
2561 if (pl)
2562 break;
2564 if (multi_dir == NULL && multi_os_dir == NULL)
2565 break;
2567 /* Run through the paths again, this time without multilibs.
2568 Don't repeat any we have already seen. */
2569 if (multi_dir)
2571 free (CONST_CAST (char *, multi_dir));
2572 multi_dir = NULL;
2573 free (CONST_CAST (char *, multi_suffix));
2574 multi_suffix = machine_suffix;
2575 free (CONST_CAST (char *, just_multi_suffix));
2576 just_multi_suffix = just_machine_suffix;
2578 else
2579 skip_multi_dir = true;
2580 if (multi_os_dir)
2582 free (CONST_CAST (char *, multi_os_dir));
2583 multi_os_dir = NULL;
2585 else
2586 skip_multi_os_dir = true;
2589 if (multi_dir)
2591 free (CONST_CAST (char *, multi_dir));
2592 free (CONST_CAST (char *, multi_suffix));
2593 free (CONST_CAST (char *, just_multi_suffix));
2595 if (multi_os_dir)
2596 free (CONST_CAST (char *, multi_os_dir));
2597 if (ret != path)
2598 free (path);
2599 return ret;
2602 /* Callback for build_search_list. Adds path to obstack being built. */
2604 struct add_to_obstack_info {
2605 struct obstack *ob;
2606 bool check_dir;
2607 bool first_time;
2610 static void *
2611 add_to_obstack (char *path, void *data)
2613 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2615 if (info->check_dir && !is_directory (path, false))
2616 return NULL;
2618 if (!info->first_time)
2619 obstack_1grow (info->ob, PATH_SEPARATOR);
2621 obstack_grow (info->ob, path, strlen (path));
2623 info->first_time = false;
2624 return NULL;
2627 /* Add or change the value of an environment variable, outputting the
2628 change to standard error if in verbose mode. */
2629 static void
2630 xputenv (const char *string)
2632 env.xput (string);
2635 /* Build a list of search directories from PATHS.
2636 PREFIX is a string to prepend to the list.
2637 If CHECK_DIR_P is true we ensure the directory exists.
2638 If DO_MULTI is true, multilib paths are output first, then
2639 non-multilib paths.
2640 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2641 It is also used by the --print-search-dirs flag. */
2643 static char *
2644 build_search_list (const struct path_prefix *paths, const char *prefix,
2645 bool check_dir, bool do_multi)
2647 struct add_to_obstack_info info;
2649 info.ob = &collect_obstack;
2650 info.check_dir = check_dir;
2651 info.first_time = true;
2653 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2654 obstack_1grow (&collect_obstack, '=');
2656 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2658 obstack_1grow (&collect_obstack, '\0');
2659 return XOBFINISH (&collect_obstack, char *);
2662 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2663 for collect. */
2665 static void
2666 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2667 bool do_multi)
2669 xputenv (build_search_list (paths, env_var, true, do_multi));
2672 /* Check whether NAME can be accessed in MODE. This is like access,
2673 except that it never considers directories to be executable. */
2675 static int
2676 access_check (const char *name, int mode)
2678 if (mode == X_OK)
2680 struct stat st;
2682 if (stat (name, &st) < 0
2683 || S_ISDIR (st.st_mode))
2684 return -1;
2687 return access (name, mode);
2690 /* Callback for find_a_file. Appends the file name to the directory
2691 path. If the resulting file exists in the right mode, return the
2692 full pathname to the file. */
2694 struct file_at_path_info {
2695 const char *name;
2696 const char *suffix;
2697 int name_len;
2698 int suffix_len;
2699 int mode;
2702 static void *
2703 file_at_path (char *path, void *data)
2705 struct file_at_path_info *info = (struct file_at_path_info *) data;
2706 size_t len = strlen (path);
2708 memcpy (path + len, info->name, info->name_len);
2709 len += info->name_len;
2711 /* Some systems have a suffix for executable files.
2712 So try appending that first. */
2713 if (info->suffix_len)
2715 memcpy (path + len, info->suffix, info->suffix_len + 1);
2716 if (access_check (path, info->mode) == 0)
2717 return path;
2720 path[len] = '\0';
2721 if (access_check (path, info->mode) == 0)
2722 return path;
2724 return NULL;
2727 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2728 access to check permissions. If DO_MULTI is true, search multilib
2729 paths then non-multilib paths, otherwise do not search multilib paths.
2730 Return 0 if not found, otherwise return its name, allocated with malloc. */
2732 static char *
2733 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2734 bool do_multi)
2736 struct file_at_path_info info;
2738 #ifdef DEFAULT_ASSEMBLER
2739 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2740 return xstrdup (DEFAULT_ASSEMBLER);
2741 #endif
2743 #ifdef DEFAULT_LINKER
2744 if (! strcmp (name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2745 return xstrdup (DEFAULT_LINKER);
2746 #endif
2748 /* Determine the filename to execute (special case for absolute paths). */
2750 if (IS_ABSOLUTE_PATH (name))
2752 if (access (name, mode) == 0)
2753 return xstrdup (name);
2755 return NULL;
2758 info.name = name;
2759 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2760 info.name_len = strlen (info.name);
2761 info.suffix_len = strlen (info.suffix);
2762 info.mode = mode;
2764 return (char*) for_each_path (pprefix, do_multi,
2765 info.name_len + info.suffix_len,
2766 file_at_path, &info);
2769 /* Ranking of prefixes in the sort list. -B prefixes are put before
2770 all others. */
2772 enum path_prefix_priority
2774 PREFIX_PRIORITY_B_OPT,
2775 PREFIX_PRIORITY_LAST
2778 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2779 order according to PRIORITY. Within each PRIORITY, new entries are
2780 appended.
2782 If WARN is nonzero, we will warn if no file is found
2783 through this prefix. WARN should point to an int
2784 which will be set to 1 if this entry is used.
2786 COMPONENT is the value to be passed to update_path.
2788 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2789 the complete value of machine_suffix.
2790 2 means try both machine_suffix and just_machine_suffix. */
2792 static void
2793 add_prefix (struct path_prefix *pprefix, const char *prefix,
2794 const char *component, /* enum prefix_priority */ int priority,
2795 int require_machine_suffix, int os_multilib)
2797 struct prefix_list *pl, **prev;
2798 int len;
2800 for (prev = &pprefix->plist;
2801 (*prev) != NULL && (*prev)->priority <= priority;
2802 prev = &(*prev)->next)
2805 /* Keep track of the longest prefix. */
2807 prefix = update_path (prefix, component);
2808 len = strlen (prefix);
2809 if (len > pprefix->max_len)
2810 pprefix->max_len = len;
2812 pl = XNEW (struct prefix_list);
2813 pl->prefix = prefix;
2814 pl->require_machine_suffix = require_machine_suffix;
2815 pl->priority = priority;
2816 pl->os_multilib = os_multilib;
2818 /* Insert after PREV. */
2819 pl->next = (*prev);
2820 (*prev) = pl;
2823 /* Same as add_prefix, but prepending target_system_root to prefix. */
2824 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2825 static void
2826 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2827 const char *component,
2828 /* enum prefix_priority */ int priority,
2829 int require_machine_suffix, int os_multilib)
2831 if (!IS_ABSOLUTE_PATH (prefix))
2832 fatal_error (input_location, "system path %qs is not absolute", prefix);
2834 if (target_system_root)
2836 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2837 size_t sysroot_len = strlen (target_system_root);
2839 if (sysroot_len > 0
2840 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2841 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2843 if (target_sysroot_suffix)
2844 prefix = concat (sysroot_no_trailing_dir_separator,
2845 target_sysroot_suffix, prefix, NULL);
2846 else
2847 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2849 free (sysroot_no_trailing_dir_separator);
2851 /* We have to override this because GCC's notion of sysroot
2852 moves along with GCC. */
2853 component = "GCC";
2856 add_prefix (pprefix, prefix, component, priority,
2857 require_machine_suffix, os_multilib);
2860 /* Execute the command specified by the arguments on the current line of spec.
2861 When using pipes, this includes several piped-together commands
2862 with `|' between them.
2864 Return 0 if successful, -1 if failed. */
2866 static int
2867 execute (void)
2869 int i;
2870 int n_commands; /* # of command. */
2871 char *string;
2872 struct pex_obj *pex;
2873 struct command
2875 const char *prog; /* program name. */
2876 const char **argv; /* vector of args. */
2878 const char *arg;
2880 struct command *commands; /* each command buffer with above info. */
2882 gcc_assert (!processing_spec_function);
2884 if (wrapper_string)
2886 string = find_a_file (&exec_prefixes,
2887 argbuf[0], X_OK, false);
2888 if (string)
2889 argbuf[0] = string;
2890 insert_wrapper (wrapper_string);
2893 /* Count # of piped commands. */
2894 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2895 if (strcmp (arg, "|") == 0)
2896 n_commands++;
2898 /* Get storage for each command. */
2899 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2901 /* Split argbuf into its separate piped processes,
2902 and record info about each one.
2903 Also search for the programs that are to be run. */
2905 argbuf.safe_push (0);
2907 commands[0].prog = argbuf[0]; /* first command. */
2908 commands[0].argv = argbuf.address ();
2910 if (!wrapper_string)
2912 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2913 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2916 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2917 if (arg && strcmp (arg, "|") == 0)
2918 { /* each command. */
2919 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2920 fatal_error (input_location, "-pipe not supported");
2921 #endif
2922 argbuf[i] = 0; /* Termination of
2923 command args. */
2924 commands[n_commands].prog = argbuf[i + 1];
2925 commands[n_commands].argv
2926 = &(argbuf.address ())[i + 1];
2927 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2928 X_OK, false);
2929 if (string)
2930 commands[n_commands].argv[0] = string;
2931 n_commands++;
2934 /* If -v, print what we are about to do, and maybe query. */
2936 if (verbose_flag)
2938 /* For help listings, put a blank line between sub-processes. */
2939 if (print_help_list)
2940 fputc ('\n', stderr);
2942 /* Print each piped command as a separate line. */
2943 for (i = 0; i < n_commands; i++)
2945 const char *const *j;
2947 if (verbose_only_flag)
2949 for (j = commands[i].argv; *j; j++)
2951 const char *p;
2952 for (p = *j; *p; ++p)
2953 if (!ISALNUM ((unsigned char) *p)
2954 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2955 break;
2956 if (*p || !*j)
2958 fprintf (stderr, " \"");
2959 for (p = *j; *p; ++p)
2961 if (*p == '"' || *p == '\\' || *p == '$')
2962 fputc ('\\', stderr);
2963 fputc (*p, stderr);
2965 fputc ('"', stderr);
2967 /* If it's empty, print "". */
2968 else if (!**j)
2969 fprintf (stderr, " \"\"");
2970 else
2971 fprintf (stderr, " %s", *j);
2974 else
2975 for (j = commands[i].argv; *j; j++)
2976 /* If it's empty, print "". */
2977 if (!**j)
2978 fprintf (stderr, " \"\"");
2979 else
2980 fprintf (stderr, " %s", *j);
2982 /* Print a pipe symbol after all but the last command. */
2983 if (i + 1 != n_commands)
2984 fprintf (stderr, " |");
2985 fprintf (stderr, "\n");
2987 fflush (stderr);
2988 if (verbose_only_flag != 0)
2990 /* verbose_only_flag should act as if the spec was
2991 executed, so increment execution_count before
2992 returning. This prevents spurious warnings about
2993 unused linker input files, etc. */
2994 execution_count++;
2995 return 0;
2997 #ifdef DEBUG
2998 fnotice (stderr, "\nGo ahead? (y or n) ");
2999 fflush (stderr);
3000 i = getchar ();
3001 if (i != '\n')
3002 while (getchar () != '\n')
3005 if (i != 'y' && i != 'Y')
3006 return 0;
3007 #endif /* DEBUG */
3010 #ifdef ENABLE_VALGRIND_CHECKING
3011 /* Run the each command through valgrind. To simplify prepending the
3012 path to valgrind and the option "-q" (for quiet operation unless
3013 something triggers), we allocate a separate argv array. */
3015 for (i = 0; i < n_commands; i++)
3017 const char **argv;
3018 int argc;
3019 int j;
3021 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
3024 argv = XALLOCAVEC (const char *, argc + 3);
3026 argv[0] = VALGRIND_PATH;
3027 argv[1] = "-q";
3028 for (j = 2; j < argc + 2; j++)
3029 argv[j] = commands[i].argv[j - 2];
3030 argv[j] = NULL;
3032 commands[i].argv = argv;
3033 commands[i].prog = argv[0];
3035 #endif
3037 /* Run each piped subprocess. */
3039 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
3040 ? PEX_RECORD_TIMES : 0),
3041 progname, temp_filename);
3042 if (pex == NULL)
3043 fatal_error (input_location, "pex_init failed: %m");
3045 for (i = 0; i < n_commands; i++)
3047 const char *errmsg;
3048 int err;
3049 const char *string = commands[i].argv[0];
3051 errmsg = pex_run (pex,
3052 ((i + 1 == n_commands ? PEX_LAST : 0)
3053 | (string == commands[i].prog ? PEX_SEARCH : 0)),
3054 string, CONST_CAST (char **, commands[i].argv),
3055 NULL, NULL, &err);
3056 if (errmsg != NULL)
3058 if (err == 0)
3059 fatal_error (input_location, errmsg);
3060 else
3062 errno = err;
3063 pfatal_with_name (errmsg);
3067 if (i && string != commands[i].prog)
3068 free (CONST_CAST (char *, string));
3071 execution_count++;
3073 /* Wait for all the subprocesses to finish. */
3076 int *statuses;
3077 struct pex_time *times = NULL;
3078 int ret_code = 0;
3080 statuses = (int *) alloca (n_commands * sizeof (int));
3081 if (!pex_get_status (pex, n_commands, statuses))
3082 fatal_error (input_location, "failed to get exit status: %m");
3084 if (report_times || report_times_to_file)
3086 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
3087 if (!pex_get_times (pex, n_commands, times))
3088 fatal_error (input_location, "failed to get process times: %m");
3091 pex_free (pex);
3093 for (i = 0; i < n_commands; ++i)
3095 int status = statuses[i];
3097 if (WIFSIGNALED (status))
3099 #ifdef SIGPIPE
3100 /* SIGPIPE is a special case. It happens in -pipe mode
3101 when the compiler dies before the preprocessor is done,
3102 or the assembler dies before the compiler is done.
3103 There's generally been an error already, and this is
3104 just fallout. So don't generate another error unless
3105 we would otherwise have succeeded. */
3106 if (WTERMSIG (status) == SIGPIPE
3107 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
3109 signal_count++;
3110 ret_code = -1;
3112 else
3113 #endif
3114 internal_error_no_backtrace ("%s (program %s)",
3115 strsignal (WTERMSIG (status)),
3116 commands[i].prog);
3118 else if (WIFEXITED (status)
3119 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
3121 /* For ICEs in cc1, cc1obj, cc1plus see if it is
3122 reproducible or not. */
3123 const char *p;
3124 if (flag_report_bug
3125 && WEXITSTATUS (status) == ICE_EXIT_CODE
3126 && i == 0
3127 && (p = strrchr (commands[0].argv[0], DIR_SEPARATOR))
3128 && ! strncmp (p + 1, "cc1", 3))
3129 try_generate_repro (commands[0].argv);
3130 if (WEXITSTATUS (status) > greatest_status)
3131 greatest_status = WEXITSTATUS (status);
3132 ret_code = -1;
3135 if (report_times || report_times_to_file)
3137 struct pex_time *pt = &times[i];
3138 double ut, st;
3140 ut = ((double) pt->user_seconds
3141 + (double) pt->user_microseconds / 1.0e6);
3142 st = ((double) pt->system_seconds
3143 + (double) pt->system_microseconds / 1.0e6);
3145 if (ut + st != 0)
3147 if (report_times)
3148 fnotice (stderr, "# %s %.2f %.2f\n",
3149 commands[i].prog, ut, st);
3151 if (report_times_to_file)
3153 int c = 0;
3154 const char *const *j;
3156 fprintf (report_times_to_file, "%g %g", ut, st);
3158 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
3160 const char *p;
3161 for (p = *j; *p; ++p)
3162 if (*p == '"' || *p == '\\' || *p == '$'
3163 || ISSPACE (*p))
3164 break;
3166 if (*p)
3168 fprintf (report_times_to_file, " \"");
3169 for (p = *j; *p; ++p)
3171 if (*p == '"' || *p == '\\' || *p == '$')
3172 fputc ('\\', report_times_to_file);
3173 fputc (*p, report_times_to_file);
3175 fputc ('"', report_times_to_file);
3177 else
3178 fprintf (report_times_to_file, " %s", *j);
3181 fputc ('\n', report_times_to_file);
3187 if (commands[0].argv[0] != commands[0].prog)
3188 free (CONST_CAST (char *, commands[0].argv[0]));
3190 return ret_code;
3194 /* Find all the switches given to us
3195 and make a vector describing them.
3196 The elements of the vector are strings, one per switch given.
3197 If a switch uses following arguments, then the `part1' field
3198 is the switch itself and the `args' field
3199 is a null-terminated vector containing the following arguments.
3200 Bits in the `live_cond' field are:
3201 SWITCH_LIVE to indicate this switch is true in a conditional spec.
3202 SWITCH_FALSE to indicate this switch is overridden by a later switch.
3203 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
3204 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored.
3205 SWITCH_KEEP_FOR_GCC to indicate that this switch, otherwise ignored,
3206 should be included in COLLECT_GCC_OPTIONS.
3207 in all do_spec calls afterwards. Used for %<S from self specs.
3208 The `known' field describes whether this is an internal switch.
3209 The `validated' field describes whether any spec has looked at this switch;
3210 if it remains false at the end of the run, the switch must be meaningless.
3211 The `ordering' field is used to temporarily mark switches that have to be
3212 kept in a specific order. */
3214 #define SWITCH_LIVE (1 << 0)
3215 #define SWITCH_FALSE (1 << 1)
3216 #define SWITCH_IGNORE (1 << 2)
3217 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
3218 #define SWITCH_KEEP_FOR_GCC (1 << 4)
3220 struct switchstr
3222 const char *part1;
3223 const char **args;
3224 unsigned int live_cond;
3225 bool known;
3226 bool validated;
3227 bool ordering;
3230 static struct switchstr *switches;
3232 static int n_switches;
3234 static int n_switches_alloc;
3236 /* Set to zero if -fcompare-debug is disabled, positive if it's
3237 enabled and we're running the first compilation, negative if it's
3238 enabled and we're running the second compilation. For most of the
3239 time, it's in the range -1..1, but it can be temporarily set to 2
3240 or 3 to indicate that the -fcompare-debug flags didn't come from
3241 the command-line, but rather from the GCC_COMPARE_DEBUG environment
3242 variable, until a synthesized -fcompare-debug flag is added to the
3243 command line. */
3244 int compare_debug;
3246 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
3247 int compare_debug_second;
3249 /* Set to the flags that should be passed to the second compilation in
3250 a -fcompare-debug compilation. */
3251 const char *compare_debug_opt;
3253 static struct switchstr *switches_debug_check[2];
3255 static int n_switches_debug_check[2];
3257 static int n_switches_alloc_debug_check[2];
3259 static char *debug_check_temp_file[2];
3261 /* Language is one of three things:
3263 1) The name of a real programming language.
3264 2) NULL, indicating that no one has figured out
3265 what it is yet.
3266 3) '*', indicating that the file should be passed
3267 to the linker. */
3268 struct infile
3270 const char *name;
3271 const char *language;
3272 struct compiler *incompiler;
3273 bool compiled;
3274 bool preprocessed;
3277 /* Also a vector of input files specified. */
3279 static struct infile *infiles;
3281 int n_infiles;
3283 static int n_infiles_alloc;
3285 /* True if multiple input files are being compiled to a single
3286 assembly file. */
3288 static bool combine_inputs;
3290 /* This counts the number of libraries added by lang_specific_driver, so that
3291 we can tell if there were any user supplied any files or libraries. */
3293 static int added_libraries;
3295 /* And a vector of corresponding output files is made up later. */
3297 const char **outfiles;
3299 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3301 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3302 is true if we should look for an executable suffix. DO_OBJ
3303 is true if we should look for an object suffix. */
3305 static const char *
3306 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3307 int do_obj ATTRIBUTE_UNUSED)
3309 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3310 int i;
3311 #endif
3312 int len;
3314 if (name == NULL)
3315 return NULL;
3317 len = strlen (name);
3319 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3320 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3321 if (do_obj && len > 2
3322 && name[len - 2] == '.'
3323 && name[len - 1] == 'o')
3325 obstack_grow (&obstack, name, len - 2);
3326 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3327 name = XOBFINISH (&obstack, const char *);
3329 #endif
3331 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3332 /* If there is no filetype, make it the executable suffix (which includes
3333 the "."). But don't get confused if we have just "-o". */
3334 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3335 return name;
3337 for (i = len - 1; i >= 0; i--)
3338 if (IS_DIR_SEPARATOR (name[i]))
3339 break;
3341 for (i++; i < len; i++)
3342 if (name[i] == '.')
3343 return name;
3345 obstack_grow (&obstack, name, len);
3346 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3347 strlen (TARGET_EXECUTABLE_SUFFIX));
3348 name = XOBFINISH (&obstack, const char *);
3349 #endif
3351 return name;
3353 #endif
3355 /* Display the command line switches accepted by gcc. */
3356 static void
3357 display_help (void)
3359 printf (_("Usage: %s [options] file...\n"), progname);
3360 fputs (_("Options:\n"), stdout);
3362 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3363 fputs (_(" --help Display this information\n"), stdout);
3364 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3365 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...]\n"), stdout);
3366 fputs (_(" Display specific types of command line options\n"), stdout);
3367 if (! verbose_flag)
3368 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3369 fputs (_(" --version Display compiler version information\n"), stdout);
3370 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3371 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3372 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3373 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3374 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3375 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3376 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3377 fputs (_("\
3378 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3379 a component in the library path\n"), stdout);
3380 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3381 fputs (_("\
3382 -print-multi-lib Display the mapping between command line options and\n\
3383 multiple library search directories\n"), stdout);
3384 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3385 fputs (_(" -print-sysroot Display the target libraries directory\n"), stdout);
3386 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
3387 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3388 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3389 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3390 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3391 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3392 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3393 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3394 fputs (_(" -save-temps=<arg> Do not delete intermediate files\n"), stdout);
3395 fputs (_("\
3396 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3397 prefixes to other gcc components\n"), stdout);
3398 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3399 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3400 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3401 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3402 fputs (_("\
3403 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3404 and libraries\n"), stdout);
3405 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3406 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3407 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3408 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3409 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3410 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3411 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3412 fputs (_(" -pie Create a position independent executable\n"), stdout);
3413 fputs (_(" -shared Create a shared library\n"), stdout);
3414 fputs (_("\
3415 -x <language> Specify the language of the following input files\n\
3416 Permissible languages include: c c++ assembler none\n\
3417 'none' means revert to the default behavior of\n\
3418 guessing the language based on the file's extension\n\
3419 "), stdout);
3421 printf (_("\
3422 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3423 passed on to the various sub-processes invoked by %s. In order to pass\n\
3424 other options on to these processes the -W<letter> options must be used.\n\
3425 "), progname);
3427 /* The rest of the options are displayed by invocations of the various
3428 sub-processes. */
3431 static void
3432 add_preprocessor_option (const char *option, int len)
3434 preprocessor_options.safe_push (save_string (option, len));
3437 static void
3438 add_assembler_option (const char *option, int len)
3440 assembler_options.safe_push (save_string (option, len));
3443 static void
3444 add_linker_option (const char *option, int len)
3446 linker_options.safe_push (save_string (option, len));
3449 /* Allocate space for an input file in infiles. */
3451 static void
3452 alloc_infile (void)
3454 if (n_infiles_alloc == 0)
3456 n_infiles_alloc = 16;
3457 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3459 else if (n_infiles_alloc == n_infiles)
3461 n_infiles_alloc *= 2;
3462 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3466 /* Store an input file with the given NAME and LANGUAGE in
3467 infiles. */
3469 static void
3470 add_infile (const char *name, const char *language)
3472 alloc_infile ();
3473 infiles[n_infiles].name = name;
3474 infiles[n_infiles++].language = language;
3477 /* Allocate space for a switch in switches. */
3479 static void
3480 alloc_switch (void)
3482 if (n_switches_alloc == 0)
3484 n_switches_alloc = 16;
3485 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3487 else if (n_switches_alloc == n_switches)
3489 n_switches_alloc *= 2;
3490 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3494 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3495 as validated if VALIDATED and KNOWN if it is an internal switch. */
3497 static void
3498 save_switch (const char *opt, size_t n_args, const char *const *args,
3499 bool validated, bool known)
3501 alloc_switch ();
3502 switches[n_switches].part1 = opt + 1;
3503 if (n_args == 0)
3504 switches[n_switches].args = 0;
3505 else
3507 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3508 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3509 switches[n_switches].args[n_args] = NULL;
3512 switches[n_switches].live_cond = 0;
3513 switches[n_switches].validated = validated;
3514 switches[n_switches].known = known;
3515 switches[n_switches].ordering = 0;
3516 n_switches++;
3519 /* Handle an option DECODED that is unknown to the option-processing
3520 machinery. */
3522 static bool
3523 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3525 const char *opt = decoded->arg;
3526 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3527 && !(decoded->errors & CL_ERR_NEGATIVE))
3529 /* Leave unknown -Wno-* options for the compiler proper, to be
3530 diagnosed only if there are warnings. */
3531 save_switch (decoded->canonical_option[0],
3532 decoded->canonical_option_num_elements - 1,
3533 &decoded->canonical_option[1], false, true);
3534 return false;
3536 if (decoded->opt_index == OPT_SPECIAL_unknown)
3538 /* Give it a chance to define it a spec file. */
3539 save_switch (decoded->canonical_option[0],
3540 decoded->canonical_option_num_elements - 1,
3541 &decoded->canonical_option[1], false, false);
3542 return false;
3544 else
3545 return true;
3548 /* Handle an option DECODED that is not marked as CL_DRIVER.
3549 LANG_MASK will always be CL_DRIVER. */
3551 static void
3552 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3553 unsigned int lang_mask ATTRIBUTE_UNUSED)
3555 /* At this point, non-driver options are accepted (and expected to
3556 be passed down by specs) unless marked to be rejected by the
3557 driver. Options to be rejected by the driver but accepted by the
3558 compilers proper are treated just like completely unknown
3559 options. */
3560 const struct cl_option *option = &cl_options[decoded->opt_index];
3562 if (option->cl_reject_driver)
3563 error ("unrecognized command line option %qs",
3564 decoded->orig_option_with_args_text);
3565 else
3566 save_switch (decoded->canonical_option[0],
3567 decoded->canonical_option_num_elements - 1,
3568 &decoded->canonical_option[1], false, true);
3571 static const char *spec_lang = 0;
3572 static int last_language_n_infiles;
3574 /* Parse -foffload option argument. */
3576 static void
3577 handle_foffload_option (const char *arg)
3579 const char *c, *cur, *n, *next, *end;
3580 char *target;
3582 /* If option argument starts with '-' then no target is specified and we
3583 do not need to parse it. */
3584 if (arg[0] == '-')
3585 return;
3587 end = strchr (arg, '=');
3588 if (end == NULL)
3589 end = strchr (arg, '\0');
3590 cur = arg;
3592 while (cur < end)
3594 next = strchr (cur, ',');
3595 if (next == NULL)
3596 next = end;
3597 next = (next > end) ? end : next;
3599 target = XNEWVEC (char, next - cur + 1);
3600 memcpy (target, cur, next - cur);
3601 target[next - cur] = '\0';
3603 /* If 'disable' is passed to the option, stop parsing the option and clean
3604 the list of offload targets. */
3605 if (strcmp (target, "disable") == 0)
3607 free (offload_targets);
3608 offload_targets = xstrdup ("");
3609 break;
3612 /* Check that GCC is configured to support the offload target. */
3613 c = OFFLOAD_TARGETS;
3614 while (c)
3616 n = strchr (c, ',');
3617 if (n == NULL)
3618 n = strchr (c, '\0');
3620 if (next - cur == n - c && strncmp (target, c, n - c) == 0)
3621 break;
3623 c = *n ? n + 1 : NULL;
3626 if (!c)
3627 fatal_error (input_location,
3628 "GCC is not configured to support %s as offload target",
3629 target);
3631 if (!offload_targets)
3633 offload_targets = target;
3634 target = NULL;
3636 else
3638 /* Check that the target hasn't already presented in the list. */
3639 c = offload_targets;
3642 n = strchr (c, ':');
3643 if (n == NULL)
3644 n = strchr (c, '\0');
3646 if (next - cur == n - c && strncmp (c, target, n - c) == 0)
3647 break;
3649 c = n + 1;
3651 while (*n);
3653 /* If duplicate is not found, append the target to the list. */
3654 if (c > n)
3656 size_t offload_targets_len = strlen (offload_targets);
3657 offload_targets
3658 = XRESIZEVEC (char, offload_targets,
3659 offload_targets_len + next - cur + 2);
3660 if (offload_targets_len)
3661 offload_targets[offload_targets_len++] = ':';
3662 memcpy (offload_targets + offload_targets_len, target, next - cur);
3666 cur = next + 1;
3667 XDELETEVEC (target);
3671 /* Handle a driver option; arguments and return value as for
3672 handle_option. */
3674 static bool
3675 driver_handle_option (struct gcc_options *opts,
3676 struct gcc_options *opts_set,
3677 const struct cl_decoded_option *decoded,
3678 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3679 location_t loc,
3680 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3681 diagnostic_context *dc)
3683 size_t opt_index = decoded->opt_index;
3684 const char *arg = decoded->arg;
3685 const char *compare_debug_replacement_opt;
3686 int value = decoded->value;
3687 bool validated = false;
3688 bool do_save = true;
3690 gcc_assert (opts == &global_options);
3691 gcc_assert (opts_set == &global_options_set);
3692 gcc_assert (kind == DK_UNSPECIFIED);
3693 gcc_assert (loc == UNKNOWN_LOCATION);
3694 gcc_assert (dc == global_dc);
3696 switch (opt_index)
3698 case OPT_dumpspecs:
3700 struct spec_list *sl;
3701 init_spec ();
3702 for (sl = specs; sl; sl = sl->next)
3703 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3704 if (link_command_spec)
3705 printf ("*link_command:\n%s\n\n", link_command_spec);
3706 exit (0);
3709 case OPT_dumpversion:
3710 printf ("%s\n", spec_version);
3711 exit (0);
3713 case OPT_dumpmachine:
3714 printf ("%s\n", spec_machine);
3715 exit (0);
3717 case OPT__version:
3718 print_version = 1;
3720 /* CPP driver cannot obtain switch from cc1_options. */
3721 if (is_cpp_driver)
3722 add_preprocessor_option ("--version", strlen ("--version"));
3723 add_assembler_option ("--version", strlen ("--version"));
3724 add_linker_option ("--version", strlen ("--version"));
3725 break;
3727 case OPT__help:
3728 print_help_list = 1;
3730 /* CPP driver cannot obtain switch from cc1_options. */
3731 if (is_cpp_driver)
3732 add_preprocessor_option ("--help", 6);
3733 add_assembler_option ("--help", 6);
3734 add_linker_option ("--help", 6);
3735 break;
3737 case OPT__help_:
3738 print_subprocess_help = 2;
3739 break;
3741 case OPT__target_help:
3742 print_subprocess_help = 1;
3744 /* CPP driver cannot obtain switch from cc1_options. */
3745 if (is_cpp_driver)
3746 add_preprocessor_option ("--target-help", 13);
3747 add_assembler_option ("--target-help", 13);
3748 add_linker_option ("--target-help", 13);
3749 break;
3751 case OPT__no_sysroot_suffix:
3752 case OPT_pass_exit_codes:
3753 case OPT_print_search_dirs:
3754 case OPT_print_file_name_:
3755 case OPT_print_prog_name_:
3756 case OPT_print_multi_lib:
3757 case OPT_print_multi_directory:
3758 case OPT_print_sysroot:
3759 case OPT_print_multi_os_directory:
3760 case OPT_print_multiarch:
3761 case OPT_print_sysroot_headers_suffix:
3762 case OPT_time:
3763 case OPT_wrapper:
3764 /* These options set the variables specified in common.opt
3765 automatically, and do not need to be saved for spec
3766 processing. */
3767 do_save = false;
3768 break;
3770 case OPT_print_libgcc_file_name:
3771 print_file_name = "libgcc.a";
3772 do_save = false;
3773 break;
3775 case OPT_fuse_ld_bfd:
3776 use_ld = ".bfd";
3777 break;
3779 case OPT_fuse_ld_gold:
3780 use_ld = ".gold";
3781 break;
3783 case OPT_fcompare_debug_second:
3784 compare_debug_second = 1;
3785 break;
3787 case OPT_fcompare_debug:
3788 switch (value)
3790 case 0:
3791 compare_debug_replacement_opt = "-fcompare-debug=";
3792 arg = "";
3793 goto compare_debug_with_arg;
3795 case 1:
3796 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3797 arg = "-gtoggle";
3798 goto compare_debug_with_arg;
3800 default:
3801 gcc_unreachable ();
3803 break;
3805 case OPT_fcompare_debug_:
3806 compare_debug_replacement_opt = decoded->canonical_option[0];
3807 compare_debug_with_arg:
3808 gcc_assert (decoded->canonical_option_num_elements == 1);
3809 gcc_assert (arg != NULL);
3810 if (*arg)
3811 compare_debug = 1;
3812 else
3813 compare_debug = -1;
3814 if (compare_debug < 0)
3815 compare_debug_opt = NULL;
3816 else
3817 compare_debug_opt = arg;
3818 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3819 return true;
3821 case OPT_fdiagnostics_color_:
3822 diagnostic_color_init (dc, value);
3823 break;
3825 case OPT_Wa_:
3827 int prev, j;
3828 /* Pass the rest of this option to the assembler. */
3830 /* Split the argument at commas. */
3831 prev = 0;
3832 for (j = 0; arg[j]; j++)
3833 if (arg[j] == ',')
3835 add_assembler_option (arg + prev, j - prev);
3836 prev = j + 1;
3839 /* Record the part after the last comma. */
3840 add_assembler_option (arg + prev, j - prev);
3842 do_save = false;
3843 break;
3845 case OPT_Wp_:
3847 int prev, j;
3848 /* Pass the rest of this option to the preprocessor. */
3850 /* Split the argument at commas. */
3851 prev = 0;
3852 for (j = 0; arg[j]; j++)
3853 if (arg[j] == ',')
3855 add_preprocessor_option (arg + prev, j - prev);
3856 prev = j + 1;
3859 /* Record the part after the last comma. */
3860 add_preprocessor_option (arg + prev, j - prev);
3862 do_save = false;
3863 break;
3865 case OPT_Wl_:
3867 int prev, j;
3868 /* Split the argument at commas. */
3869 prev = 0;
3870 for (j = 0; arg[j]; j++)
3871 if (arg[j] == ',')
3873 add_infile (save_string (arg + prev, j - prev), "*");
3874 prev = j + 1;
3876 /* Record the part after the last comma. */
3877 add_infile (arg + prev, "*");
3879 do_save = false;
3880 break;
3882 case OPT_Xlinker:
3883 add_infile (arg, "*");
3884 do_save = false;
3885 break;
3887 case OPT_Xpreprocessor:
3888 add_preprocessor_option (arg, strlen (arg));
3889 do_save = false;
3890 break;
3892 case OPT_Xassembler:
3893 add_assembler_option (arg, strlen (arg));
3894 do_save = false;
3895 break;
3897 case OPT_l:
3898 /* POSIX allows separation of -l and the lib arg; canonicalize
3899 by concatenating -l with its arg */
3900 add_infile (concat ("-l", arg, NULL), "*");
3901 do_save = false;
3902 break;
3904 case OPT_L:
3905 /* Similarly, canonicalize -L for linkers that may not accept
3906 separate arguments. */
3907 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
3908 return true;
3910 case OPT_F:
3911 /* Likewise -F. */
3912 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
3913 return true;
3915 case OPT_save_temps:
3916 save_temps_flag = SAVE_TEMPS_CWD;
3917 validated = true;
3918 break;
3920 case OPT_save_temps_:
3921 if (strcmp (arg, "cwd") == 0)
3922 save_temps_flag = SAVE_TEMPS_CWD;
3923 else if (strcmp (arg, "obj") == 0
3924 || strcmp (arg, "object") == 0)
3925 save_temps_flag = SAVE_TEMPS_OBJ;
3926 else
3927 fatal_error (input_location, "%qs is an unknown -save-temps option",
3928 decoded->orig_option_with_args_text);
3929 break;
3931 case OPT_no_canonical_prefixes:
3932 /* Already handled as a special case, so ignored here. */
3933 do_save = false;
3934 break;
3936 case OPT_pipe:
3937 validated = true;
3938 /* These options set the variables specified in common.opt
3939 automatically, but do need to be saved for spec
3940 processing. */
3941 break;
3943 case OPT_specs_:
3945 struct user_specs *user = XNEW (struct user_specs);
3947 user->next = (struct user_specs *) 0;
3948 user->filename = arg;
3949 if (user_specs_tail)
3950 user_specs_tail->next = user;
3951 else
3952 user_specs_head = user;
3953 user_specs_tail = user;
3955 validated = true;
3956 break;
3958 case OPT__sysroot_:
3959 target_system_root = arg;
3960 target_system_root_changed = 1;
3961 do_save = false;
3962 break;
3964 case OPT_time_:
3965 if (report_times_to_file)
3966 fclose (report_times_to_file);
3967 report_times_to_file = fopen (arg, "a");
3968 do_save = false;
3969 break;
3971 case OPT____:
3972 /* "-###"
3973 This is similar to -v except that there is no execution
3974 of the commands and the echoed arguments are quoted. It
3975 is intended for use in shell scripts to capture the
3976 driver-generated command line. */
3977 verbose_only_flag++;
3978 verbose_flag = 1;
3979 do_save = false;
3980 break;
3982 case OPT_B:
3984 size_t len = strlen (arg);
3986 /* Catch the case where the user has forgotten to append a
3987 directory separator to the path. Note, they may be using
3988 -B to add an executable name prefix, eg "i386-elf-", in
3989 order to distinguish between multiple installations of
3990 GCC in the same directory. Hence we must check to see
3991 if appending a directory separator actually makes a
3992 valid directory name. */
3993 if (!IS_DIR_SEPARATOR (arg[len - 1])
3994 && is_directory (arg, false))
3996 char *tmp = XNEWVEC (char, len + 2);
3997 strcpy (tmp, arg);
3998 tmp[len] = DIR_SEPARATOR;
3999 tmp[++len] = 0;
4000 arg = tmp;
4003 add_prefix (&exec_prefixes, arg, NULL,
4004 PREFIX_PRIORITY_B_OPT, 0, 0);
4005 add_prefix (&startfile_prefixes, arg, NULL,
4006 PREFIX_PRIORITY_B_OPT, 0, 0);
4007 add_prefix (&include_prefixes, arg, NULL,
4008 PREFIX_PRIORITY_B_OPT, 0, 0);
4010 validated = true;
4011 break;
4013 case OPT_x:
4014 spec_lang = arg;
4015 if (!strcmp (spec_lang, "none"))
4016 /* Suppress the warning if -xnone comes after the last input
4017 file, because alternate command interfaces like g++ might
4018 find it useful to place -xnone after each input file. */
4019 spec_lang = 0;
4020 else
4021 last_language_n_infiles = n_infiles;
4022 do_save = false;
4023 break;
4025 case OPT_o:
4026 have_o = 1;
4027 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
4028 arg = convert_filename (arg, ! have_c, 0);
4029 #endif
4030 output_file = arg;
4031 /* Save the output name in case -save-temps=obj was used. */
4032 save_temps_prefix = xstrdup (arg);
4033 /* On some systems, ld cannot handle "-o" without a space. So
4034 split the option from its argument. */
4035 save_switch ("-o", 1, &arg, validated, true);
4036 return true;
4038 #ifdef ENABLE_DEFAULT_PIE
4039 case OPT_pie:
4040 /* -pie is turned on by default. */
4041 #endif
4043 case OPT_static_libgcc:
4044 case OPT_shared_libgcc:
4045 case OPT_static_libgfortran:
4046 case OPT_static_libstdc__:
4047 /* These are always valid, since gcc.c itself understands the
4048 first two, gfortranspec.c understands -static-libgfortran and
4049 g++spec.c understands -static-libstdc++ */
4050 validated = true;
4051 break;
4053 case OPT_fwpa:
4054 flag_wpa = "";
4055 break;
4057 case OPT_foffload_:
4058 handle_foffload_option (arg);
4059 break;
4061 default:
4062 /* Various driver options need no special processing at this
4063 point, having been handled in a prescan above or being
4064 handled by specs. */
4065 break;
4068 if (do_save)
4069 save_switch (decoded->canonical_option[0],
4070 decoded->canonical_option_num_elements - 1,
4071 &decoded->canonical_option[1], validated, true);
4072 return true;
4075 /* Put the driver's standard set of option handlers in *HANDLERS. */
4077 static void
4078 set_option_handlers (struct cl_option_handlers *handlers)
4080 handlers->unknown_option_callback = driver_unknown_option_callback;
4081 handlers->wrong_lang_callback = driver_wrong_lang_callback;
4082 handlers->num_handlers = 3;
4083 handlers->handlers[0].handler = driver_handle_option;
4084 handlers->handlers[0].mask = CL_DRIVER;
4085 handlers->handlers[1].handler = common_handle_option;
4086 handlers->handlers[1].mask = CL_COMMON;
4087 handlers->handlers[2].handler = target_handle_option;
4088 handlers->handlers[2].mask = CL_TARGET;
4091 /* Create the vector `switches' and its contents.
4092 Store its length in `n_switches'. */
4094 static void
4095 process_command (unsigned int decoded_options_count,
4096 struct cl_decoded_option *decoded_options)
4098 const char *temp;
4099 char *temp1;
4100 char *tooldir_prefix, *tooldir_prefix2;
4101 char *(*get_relative_prefix) (const char *, const char *,
4102 const char *) = NULL;
4103 struct cl_option_handlers handlers;
4104 unsigned int j;
4106 gcc_exec_prefix = env.get ("GCC_EXEC_PREFIX");
4108 n_switches = 0;
4109 n_infiles = 0;
4110 added_libraries = 0;
4112 /* Figure compiler version from version string. */
4114 compiler_version = temp1 = xstrdup (version_string);
4116 for (; *temp1; ++temp1)
4118 if (*temp1 == ' ')
4120 *temp1 = '\0';
4121 break;
4125 /* Handle any -no-canonical-prefixes flag early, to assign the function
4126 that builds relative prefixes. This function creates default search
4127 paths that are needed later in normal option handling. */
4129 for (j = 1; j < decoded_options_count; j++)
4131 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
4133 get_relative_prefix = make_relative_prefix_ignore_links;
4134 break;
4137 if (! get_relative_prefix)
4138 get_relative_prefix = make_relative_prefix;
4140 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
4141 see if we can create it from the pathname specified in
4142 decoded_options[0].arg. */
4144 gcc_libexec_prefix = standard_libexec_prefix;
4145 #ifndef VMS
4146 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
4147 if (!gcc_exec_prefix)
4149 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
4150 standard_bindir_prefix,
4151 standard_exec_prefix);
4152 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
4153 standard_bindir_prefix,
4154 standard_libexec_prefix);
4155 if (gcc_exec_prefix)
4156 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
4158 else
4160 /* make_relative_prefix requires a program name, but
4161 GCC_EXEC_PREFIX is typically a directory name with a trailing
4162 / (which is ignored by make_relative_prefix), so append a
4163 program name. */
4164 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
4165 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
4166 standard_exec_prefix,
4167 standard_libexec_prefix);
4169 /* The path is unrelocated, so fallback to the original setting. */
4170 if (!gcc_libexec_prefix)
4171 gcc_libexec_prefix = standard_libexec_prefix;
4173 free (tmp_prefix);
4175 #else
4176 #endif
4177 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
4178 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
4179 or an automatically created GCC_EXEC_PREFIX from
4180 decoded_options[0].arg. */
4182 /* Do language-specific adjustment/addition of flags. */
4183 lang_specific_driver (&decoded_options, &decoded_options_count,
4184 &added_libraries);
4186 if (gcc_exec_prefix)
4188 int len = strlen (gcc_exec_prefix);
4190 if (len > (int) sizeof ("/lib/gcc/") - 1
4191 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
4193 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
4194 if (IS_DIR_SEPARATOR (*temp)
4195 && filename_ncmp (temp + 1, "lib", 3) == 0
4196 && IS_DIR_SEPARATOR (temp[4])
4197 && filename_ncmp (temp + 5, "gcc", 3) == 0)
4198 len -= sizeof ("/lib/gcc/") - 1;
4201 set_std_prefix (gcc_exec_prefix, len);
4202 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
4203 PREFIX_PRIORITY_LAST, 0, 0);
4204 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
4205 PREFIX_PRIORITY_LAST, 0, 0);
4208 /* COMPILER_PATH and LIBRARY_PATH have values
4209 that are lists of directory names with colons. */
4211 temp = env.get ("COMPILER_PATH");
4212 if (temp)
4214 const char *startp, *endp;
4215 char *nstore = (char *) alloca (strlen (temp) + 3);
4217 startp = endp = temp;
4218 while (1)
4220 if (*endp == PATH_SEPARATOR || *endp == 0)
4222 strncpy (nstore, startp, endp - startp);
4223 if (endp == startp)
4224 strcpy (nstore, concat (".", dir_separator_str, NULL));
4225 else if (!IS_DIR_SEPARATOR (endp[-1]))
4227 nstore[endp - startp] = DIR_SEPARATOR;
4228 nstore[endp - startp + 1] = 0;
4230 else
4231 nstore[endp - startp] = 0;
4232 add_prefix (&exec_prefixes, nstore, 0,
4233 PREFIX_PRIORITY_LAST, 0, 0);
4234 add_prefix (&include_prefixes, nstore, 0,
4235 PREFIX_PRIORITY_LAST, 0, 0);
4236 if (*endp == 0)
4237 break;
4238 endp = startp = endp + 1;
4240 else
4241 endp++;
4245 temp = env.get (LIBRARY_PATH_ENV);
4246 if (temp && *cross_compile == '0')
4248 const char *startp, *endp;
4249 char *nstore = (char *) alloca (strlen (temp) + 3);
4251 startp = endp = temp;
4252 while (1)
4254 if (*endp == PATH_SEPARATOR || *endp == 0)
4256 strncpy (nstore, startp, endp - startp);
4257 if (endp == startp)
4258 strcpy (nstore, concat (".", dir_separator_str, NULL));
4259 else if (!IS_DIR_SEPARATOR (endp[-1]))
4261 nstore[endp - startp] = DIR_SEPARATOR;
4262 nstore[endp - startp + 1] = 0;
4264 else
4265 nstore[endp - startp] = 0;
4266 add_prefix (&startfile_prefixes, nstore, NULL,
4267 PREFIX_PRIORITY_LAST, 0, 1);
4268 if (*endp == 0)
4269 break;
4270 endp = startp = endp + 1;
4272 else
4273 endp++;
4277 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
4278 temp = env.get ("LPATH");
4279 if (temp && *cross_compile == '0')
4281 const char *startp, *endp;
4282 char *nstore = (char *) alloca (strlen (temp) + 3);
4284 startp = endp = temp;
4285 while (1)
4287 if (*endp == PATH_SEPARATOR || *endp == 0)
4289 strncpy (nstore, startp, endp - startp);
4290 if (endp == startp)
4291 strcpy (nstore, concat (".", dir_separator_str, NULL));
4292 else if (!IS_DIR_SEPARATOR (endp[-1]))
4294 nstore[endp - startp] = DIR_SEPARATOR;
4295 nstore[endp - startp + 1] = 0;
4297 else
4298 nstore[endp - startp] = 0;
4299 add_prefix (&startfile_prefixes, nstore, NULL,
4300 PREFIX_PRIORITY_LAST, 0, 1);
4301 if (*endp == 0)
4302 break;
4303 endp = startp = endp + 1;
4305 else
4306 endp++;
4310 /* Process the options and store input files and switches in their
4311 vectors. */
4313 last_language_n_infiles = -1;
4315 set_option_handlers (&handlers);
4317 for (j = 1; j < decoded_options_count; j++)
4319 switch (decoded_options[j].opt_index)
4321 case OPT_S:
4322 case OPT_c:
4323 case OPT_E:
4324 have_c = 1;
4325 break;
4327 if (have_c)
4328 break;
4331 for (j = 1; j < decoded_options_count; j++)
4333 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
4335 const char *arg = decoded_options[j].arg;
4336 const char *p = strrchr (arg, '@');
4337 char *fname;
4338 long offset;
4339 int consumed;
4340 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4341 arg = convert_filename (arg, 0, access (arg, F_OK));
4342 #endif
4343 /* For LTO static archive support we handle input file
4344 specifications that are composed of a filename and
4345 an offset like FNAME@OFFSET. */
4346 if (p
4347 && p != arg
4348 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
4349 && strlen (p) == (unsigned int)consumed)
4351 fname = (char *)xmalloc (p - arg + 1);
4352 memcpy (fname, arg, p - arg);
4353 fname[p - arg] = '\0';
4354 /* Only accept non-stdin and existing FNAME parts, otherwise
4355 try with the full name. */
4356 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
4358 free (fname);
4359 fname = xstrdup (arg);
4362 else
4363 fname = xstrdup (arg);
4365 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
4366 perror_with_name (fname);
4367 else
4368 add_infile (arg, spec_lang);
4370 free (fname);
4371 continue;
4374 read_cmdline_option (&global_options, &global_options_set,
4375 decoded_options + j, UNKNOWN_LOCATION,
4376 CL_DRIVER, &handlers, global_dc);
4379 if (output_file
4380 && strcmp (output_file, "-") != 0
4381 && strcmp (output_file, HOST_BIT_BUCKET) != 0)
4383 int i;
4384 for (i = 0; i < n_infiles; i++)
4385 if ((!infiles[i].language || infiles[i].language[0] != '*')
4386 && canonical_filename_eq (infiles[i].name, output_file))
4387 fatal_error (input_location,
4388 "input file %qs is the same as output file",
4389 output_file);
4392 /* If -save-temps=obj and -o name, create the prefix to use for %b.
4393 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
4394 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
4396 save_temps_length = strlen (save_temps_prefix);
4397 temp = strrchr (lbasename (save_temps_prefix), '.');
4398 if (temp)
4400 save_temps_length -= strlen (temp);
4401 save_temps_prefix[save_temps_length] = '\0';
4405 else if (save_temps_prefix != NULL)
4407 free (save_temps_prefix);
4408 save_temps_prefix = NULL;
4411 if (save_temps_flag && use_pipes)
4413 /* -save-temps overrides -pipe, so that temp files are produced */
4414 if (save_temps_flag)
4415 warning (0, "-pipe ignored because -save-temps specified");
4416 use_pipes = 0;
4419 if (!compare_debug)
4421 const char *gcd = env.get ("GCC_COMPARE_DEBUG");
4423 if (gcd && gcd[0] == '-')
4425 compare_debug = 2;
4426 compare_debug_opt = gcd;
4428 else if (gcd && *gcd && strcmp (gcd, "0"))
4430 compare_debug = 3;
4431 compare_debug_opt = "-gtoggle";
4434 else if (compare_debug < 0)
4436 compare_debug = 0;
4437 gcc_assert (!compare_debug_opt);
4440 /* Set up the search paths. We add directories that we expect to
4441 contain GNU Toolchain components before directories specified by
4442 the machine description so that we will find GNU components (like
4443 the GNU assembler) before those of the host system. */
4445 /* If we don't know where the toolchain has been installed, use the
4446 configured-in locations. */
4447 if (!gcc_exec_prefix)
4449 #ifndef OS2
4450 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
4451 PREFIX_PRIORITY_LAST, 1, 0);
4452 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
4453 PREFIX_PRIORITY_LAST, 2, 0);
4454 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
4455 PREFIX_PRIORITY_LAST, 2, 0);
4456 #endif
4457 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
4458 PREFIX_PRIORITY_LAST, 1, 0);
4461 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
4462 tooldir_prefix2 = concat (tooldir_base_prefix, spec_host_machine,
4463 dir_separator_str, NULL);
4465 /* Look for tools relative to the location from which the driver is
4466 running, or, if that is not available, the configured prefix. */
4467 tooldir_prefix
4468 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4469 spec_host_machine, dir_separator_str, spec_version,
4470 accel_dir_suffix, dir_separator_str, tooldir_prefix2, NULL);
4471 free (tooldir_prefix2);
4473 add_prefix (&exec_prefixes,
4474 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4475 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4476 add_prefix (&startfile_prefixes,
4477 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4478 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4479 free (tooldir_prefix);
4481 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4482 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4483 then consider it to relocate with the rest of the GCC installation
4484 if GCC_EXEC_PREFIX is set.
4485 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4486 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
4488 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
4489 standard_bindir_prefix,
4490 target_system_root);
4491 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4493 target_system_root = tmp_prefix;
4494 target_system_root_changed = 1;
4497 #endif
4499 /* More prefixes are enabled in main, after we read the specs file
4500 and determine whether this is cross-compilation or not. */
4502 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4503 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
4505 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
4506 environment variable. */
4507 if (compare_debug == 2 || compare_debug == 3)
4509 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
4510 save_switch (opt, 0, NULL, false, true);
4511 compare_debug = 1;
4514 /* Ensure we only invoke each subprocess once. */
4515 if (print_subprocess_help || print_help_list || print_version)
4517 n_infiles = 0;
4519 /* Create a dummy input file, so that we can pass
4520 the help option on to the various sub-processes. */
4521 add_infile ("help-dummy", "c");
4524 alloc_switch ();
4525 switches[n_switches].part1 = 0;
4526 alloc_infile ();
4527 infiles[n_infiles].name = 0;
4530 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4531 and place that in the environment. */
4533 static void
4534 set_collect_gcc_options (void)
4536 int i;
4537 int first_time;
4539 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4540 the compiler. */
4541 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4542 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4544 first_time = TRUE;
4545 for (i = 0; (int) i < n_switches; i++)
4547 const char *const *args;
4548 const char *p, *q;
4549 if (!first_time)
4550 obstack_grow (&collect_obstack, " ", 1);
4552 first_time = FALSE;
4554 /* Ignore elided switches. */
4555 if ((switches[i].live_cond
4556 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4557 == SWITCH_IGNORE)
4558 continue;
4560 obstack_grow (&collect_obstack, "'-", 2);
4561 q = switches[i].part1;
4562 while ((p = strchr (q, '\'')))
4564 obstack_grow (&collect_obstack, q, p - q);
4565 obstack_grow (&collect_obstack, "'\\''", 4);
4566 q = ++p;
4568 obstack_grow (&collect_obstack, q, strlen (q));
4569 obstack_grow (&collect_obstack, "'", 1);
4571 for (args = switches[i].args; args && *args; args++)
4573 obstack_grow (&collect_obstack, " '", 2);
4574 q = *args;
4575 while ((p = strchr (q, '\'')))
4577 obstack_grow (&collect_obstack, q, p - q);
4578 obstack_grow (&collect_obstack, "'\\''", 4);
4579 q = ++p;
4581 obstack_grow (&collect_obstack, q, strlen (q));
4582 obstack_grow (&collect_obstack, "'", 1);
4585 obstack_grow (&collect_obstack, "\0", 1);
4586 xputenv (XOBFINISH (&collect_obstack, char *));
4589 /* Process a spec string, accumulating and running commands. */
4591 /* These variables describe the input file name.
4592 input_file_number is the index on outfiles of this file,
4593 so that the output file name can be stored for later use by %o.
4594 input_basename is the start of the part of the input file
4595 sans all directory names, and basename_length is the number
4596 of characters starting there excluding the suffix .c or whatever. */
4598 static const char *gcc_input_filename;
4599 static int input_file_number;
4600 size_t input_filename_length;
4601 static int basename_length;
4602 static int suffixed_basename_length;
4603 static const char *input_basename;
4604 static const char *input_suffix;
4605 #ifndef HOST_LACKS_INODE_NUMBERS
4606 static struct stat input_stat;
4607 #endif
4608 static int input_stat_set;
4610 /* The compiler used to process the current input file. */
4611 static struct compiler *input_file_compiler;
4613 /* These are variables used within do_spec and do_spec_1. */
4615 /* Nonzero if an arg has been started and not yet terminated
4616 (with space, tab or newline). */
4617 static int arg_going;
4619 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4620 is a temporary file name. */
4621 static int delete_this_arg;
4623 /* Nonzero means %w has been seen; the next arg to be terminated
4624 is the output file name of this compilation. */
4625 static int this_is_output_file;
4627 /* Nonzero means %s has been seen; the next arg to be terminated
4628 is the name of a library file and we should try the standard
4629 search dirs for it. */
4630 static int this_is_library_file;
4632 /* Nonzero means %T has been seen; the next arg to be terminated
4633 is the name of a linker script and we should try all of the
4634 standard search dirs for it. If it is found insert a --script
4635 command line switch and then substitute the full path in place,
4636 otherwise generate an error message. */
4637 static int this_is_linker_script;
4639 /* Nonzero means that the input of this command is coming from a pipe. */
4640 static int input_from_pipe;
4642 /* Nonnull means substitute this for any suffix when outputting a switches
4643 arguments. */
4644 static const char *suffix_subst;
4646 /* If there is an argument being accumulated, terminate it and store it. */
4648 static void
4649 end_going_arg (void)
4651 if (arg_going)
4653 const char *string;
4655 obstack_1grow (&obstack, 0);
4656 string = XOBFINISH (&obstack, const char *);
4657 if (this_is_library_file)
4658 string = find_file (string);
4659 if (this_is_linker_script)
4661 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4663 if (full_script_path == NULL)
4665 error ("unable to locate default linker script %qs in the library search paths", string);
4666 /* Script was not found on search path. */
4667 return;
4669 store_arg ("--script", false, false);
4670 string = full_script_path;
4672 store_arg (string, delete_this_arg, this_is_output_file);
4673 if (this_is_output_file)
4674 outfiles[input_file_number] = string;
4675 arg_going = 0;
4680 /* Parse the WRAPPER string which is a comma separated list of the command line
4681 and insert them into the beginning of argbuf. */
4683 static void
4684 insert_wrapper (const char *wrapper)
4686 int n = 0;
4687 int i;
4688 char *buf = xstrdup (wrapper);
4689 char *p = buf;
4690 unsigned int old_length = argbuf.length ();
4694 n++;
4695 while (*p == ',')
4696 p++;
4698 while ((p = strchr (p, ',')) != NULL);
4700 argbuf.safe_grow (old_length + n);
4701 memmove (argbuf.address () + n,
4702 argbuf.address (),
4703 old_length * sizeof (const_char_p));
4705 i = 0;
4706 p = buf;
4709 while (*p == ',')
4711 *p = 0;
4712 p++;
4714 argbuf[i] = p;
4715 i++;
4717 while ((p = strchr (p, ',')) != NULL);
4718 gcc_assert (i == n);
4721 /* Process the spec SPEC and run the commands specified therein.
4722 Returns 0 if the spec is successfully processed; -1 if failed. */
4725 do_spec (const char *spec)
4727 int value;
4729 value = do_spec_2 (spec);
4731 /* Force out any unfinished command.
4732 If -pipe, this forces out the last command if it ended in `|'. */
4733 if (value == 0)
4735 if (argbuf.length () > 0
4736 && !strcmp (argbuf.last (), "|"))
4737 argbuf.pop ();
4739 set_collect_gcc_options ();
4741 if (argbuf.length () > 0)
4742 value = execute ();
4745 return value;
4748 static int
4749 do_spec_2 (const char *spec)
4751 int result;
4753 clear_args ();
4754 arg_going = 0;
4755 delete_this_arg = 0;
4756 this_is_output_file = 0;
4757 this_is_library_file = 0;
4758 this_is_linker_script = 0;
4759 input_from_pipe = 0;
4760 suffix_subst = NULL;
4762 result = do_spec_1 (spec, 0, NULL);
4764 end_going_arg ();
4766 return result;
4770 /* Process the given spec string and add any new options to the end
4771 of the switches/n_switches array. */
4773 static void
4774 do_option_spec (const char *name, const char *spec)
4776 unsigned int i, value_count, value_len;
4777 const char *p, *q, *value;
4778 char *tmp_spec, *tmp_spec_p;
4780 if (configure_default_options[0].name == NULL)
4781 return;
4783 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4784 if (strcmp (configure_default_options[i].name, name) == 0)
4785 break;
4786 if (i == ARRAY_SIZE (configure_default_options))
4787 return;
4789 value = configure_default_options[i].value;
4790 value_len = strlen (value);
4792 /* Compute the size of the final spec. */
4793 value_count = 0;
4794 p = spec;
4795 while ((p = strstr (p, "%(VALUE)")) != NULL)
4797 p ++;
4798 value_count ++;
4801 /* Replace each %(VALUE) by the specified value. */
4802 tmp_spec = (char *) alloca (strlen (spec) + 1
4803 + value_count * (value_len - strlen ("%(VALUE)")));
4804 tmp_spec_p = tmp_spec;
4805 q = spec;
4806 while ((p = strstr (q, "%(VALUE)")) != NULL)
4808 memcpy (tmp_spec_p, q, p - q);
4809 tmp_spec_p = tmp_spec_p + (p - q);
4810 memcpy (tmp_spec_p, value, value_len);
4811 tmp_spec_p += value_len;
4812 q = p + strlen ("%(VALUE)");
4814 strcpy (tmp_spec_p, q);
4816 do_self_spec (tmp_spec);
4819 /* Process the given spec string and add any new options to the end
4820 of the switches/n_switches array. */
4822 static void
4823 do_self_spec (const char *spec)
4825 int i;
4827 do_spec_2 (spec);
4828 do_spec_1 (" ", 0, NULL);
4830 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4831 do_self_specs adds the replacements to switches array, so it shouldn't
4832 be processed afterwards. */
4833 for (i = 0; i < n_switches; i++)
4834 if ((switches[i].live_cond & SWITCH_IGNORE))
4835 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4837 if (argbuf.length () > 0)
4839 const char **argbuf_copy;
4840 struct cl_decoded_option *decoded_options;
4841 struct cl_option_handlers handlers;
4842 unsigned int decoded_options_count;
4843 unsigned int j;
4845 /* Create a copy of argbuf with a dummy argv[0] entry for
4846 decode_cmdline_options_to_array. */
4847 argbuf_copy = XNEWVEC (const char *,
4848 argbuf.length () + 1);
4849 argbuf_copy[0] = "";
4850 memcpy (argbuf_copy + 1, argbuf.address (),
4851 argbuf.length () * sizeof (const char *));
4853 decode_cmdline_options_to_array (argbuf.length () + 1,
4854 argbuf_copy,
4855 CL_DRIVER, &decoded_options,
4856 &decoded_options_count);
4857 free (argbuf_copy);
4859 set_option_handlers (&handlers);
4861 for (j = 1; j < decoded_options_count; j++)
4863 switch (decoded_options[j].opt_index)
4865 case OPT_SPECIAL_input_file:
4866 /* Specs should only generate options, not input
4867 files. */
4868 if (strcmp (decoded_options[j].arg, "-") != 0)
4869 fatal_error (input_location,
4870 "switch %qs does not start with %<-%>",
4871 decoded_options[j].arg);
4872 else
4873 fatal_error (input_location,
4874 "spec-generated switch is just %<-%>");
4875 break;
4877 case OPT_fcompare_debug_second:
4878 case OPT_fcompare_debug:
4879 case OPT_fcompare_debug_:
4880 case OPT_o:
4881 /* Avoid duplicate processing of some options from
4882 compare-debug specs; just save them here. */
4883 save_switch (decoded_options[j].canonical_option[0],
4884 (decoded_options[j].canonical_option_num_elements
4885 - 1),
4886 &decoded_options[j].canonical_option[1], false, true);
4887 break;
4889 default:
4890 read_cmdline_option (&global_options, &global_options_set,
4891 decoded_options + j, UNKNOWN_LOCATION,
4892 CL_DRIVER, &handlers, global_dc);
4893 break;
4897 free (decoded_options);
4899 alloc_switch ();
4900 switches[n_switches].part1 = 0;
4904 /* Callback for processing %D and %I specs. */
4906 struct spec_path_info {
4907 const char *option;
4908 const char *append;
4909 size_t append_len;
4910 bool omit_relative;
4911 bool separate_options;
4914 static void *
4915 spec_path (char *path, void *data)
4917 struct spec_path_info *info = (struct spec_path_info *) data;
4918 size_t len = 0;
4919 char save = 0;
4921 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4922 return NULL;
4924 if (info->append_len != 0)
4926 len = strlen (path);
4927 memcpy (path + len, info->append, info->append_len + 1);
4930 if (!is_directory (path, true))
4931 return NULL;
4933 do_spec_1 (info->option, 1, NULL);
4934 if (info->separate_options)
4935 do_spec_1 (" ", 0, NULL);
4937 if (info->append_len == 0)
4939 len = strlen (path);
4940 save = path[len - 1];
4941 if (IS_DIR_SEPARATOR (path[len - 1]))
4942 path[len - 1] = '\0';
4945 do_spec_1 (path, 1, NULL);
4946 do_spec_1 (" ", 0, NULL);
4948 /* Must not damage the original path. */
4949 if (info->append_len == 0)
4950 path[len - 1] = save;
4952 return NULL;
4955 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
4956 argument list. */
4958 static void
4959 create_at_file (char **argv)
4961 char *temp_file = make_temp_file ("");
4962 char *at_argument = concat ("@", temp_file, NULL);
4963 FILE *f = fopen (temp_file, "w");
4964 int status;
4966 if (f == NULL)
4967 fatal_error (input_location, "could not open temporary response file %s",
4968 temp_file);
4970 status = writeargv (argv, f);
4972 if (status)
4973 fatal_error (input_location,
4974 "could not write to temporary response file %s",
4975 temp_file);
4977 status = fclose (f);
4979 if (EOF == status)
4980 fatal_error (input_location, "could not close temporary response file %s",
4981 temp_file);
4983 store_arg (at_argument, 0, 0);
4985 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
4988 /* True if we should compile INFILE. */
4990 static bool
4991 compile_input_file_p (struct infile *infile)
4993 if ((!infile->language) || (infile->language[0] != '*'))
4994 if (infile->incompiler == input_file_compiler)
4995 return true;
4996 return false;
4999 /* Process each member of VEC as a spec. */
5001 static void
5002 do_specs_vec (vec<char_p> vec)
5004 unsigned ix;
5005 char *opt;
5007 FOR_EACH_VEC_ELT (vec, ix, opt)
5009 do_spec_1 (opt, 1, NULL);
5010 /* Make each accumulated option a separate argument. */
5011 do_spec_1 (" ", 0, NULL);
5015 /* Process the sub-spec SPEC as a portion of a larger spec.
5016 This is like processing a whole spec except that we do
5017 not initialize at the beginning and we do not supply a
5018 newline by default at the end.
5019 INSWITCH nonzero means don't process %-sequences in SPEC;
5020 in this case, % is treated as an ordinary character.
5021 This is used while substituting switches.
5022 INSWITCH nonzero also causes SPC not to terminate an argument.
5024 Value is zero unless a line was finished
5025 and the command on that line reported an error. */
5027 static int
5028 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
5030 const char *p = spec;
5031 int c;
5032 int i;
5033 int value;
5035 /* If it's an empty string argument to a switch, keep it as is. */
5036 if (inswitch && !*p)
5037 arg_going = 1;
5039 while ((c = *p++))
5040 /* If substituting a switch, treat all chars like letters.
5041 Otherwise, NL, SPC, TAB and % are special. */
5042 switch (inswitch ? 'a' : c)
5044 case '\n':
5045 end_going_arg ();
5047 if (argbuf.length () > 0
5048 && !strcmp (argbuf.last (), "|"))
5050 /* A `|' before the newline means use a pipe here,
5051 but only if -pipe was specified.
5052 Otherwise, execute now and don't pass the `|' as an arg. */
5053 if (use_pipes)
5055 input_from_pipe = 1;
5056 break;
5058 else
5059 argbuf.pop ();
5062 set_collect_gcc_options ();
5064 if (argbuf.length () > 0)
5066 value = execute ();
5067 if (value)
5068 return value;
5070 /* Reinitialize for a new command, and for a new argument. */
5071 clear_args ();
5072 arg_going = 0;
5073 delete_this_arg = 0;
5074 this_is_output_file = 0;
5075 this_is_library_file = 0;
5076 this_is_linker_script = 0;
5077 input_from_pipe = 0;
5078 break;
5080 case '|':
5081 end_going_arg ();
5083 /* Use pipe */
5084 obstack_1grow (&obstack, c);
5085 arg_going = 1;
5086 break;
5088 case '\t':
5089 case ' ':
5090 end_going_arg ();
5092 /* Reinitialize for a new argument. */
5093 delete_this_arg = 0;
5094 this_is_output_file = 0;
5095 this_is_library_file = 0;
5096 this_is_linker_script = 0;
5097 break;
5099 case '%':
5100 switch (c = *p++)
5102 case 0:
5103 fatal_error (input_location, "spec %qs invalid", spec);
5105 case 'b':
5106 if (save_temps_length)
5107 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
5108 else
5109 obstack_grow (&obstack, input_basename, basename_length);
5110 if (compare_debug < 0)
5111 obstack_grow (&obstack, ".gk", 3);
5112 arg_going = 1;
5113 break;
5115 case 'B':
5116 if (save_temps_length)
5117 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
5118 else
5119 obstack_grow (&obstack, input_basename, suffixed_basename_length);
5120 if (compare_debug < 0)
5121 obstack_grow (&obstack, ".gk", 3);
5122 arg_going = 1;
5123 break;
5125 case 'd':
5126 delete_this_arg = 2;
5127 break;
5129 /* Dump out the directories specified with LIBRARY_PATH,
5130 followed by the absolute directories
5131 that we search for startfiles. */
5132 case 'D':
5134 struct spec_path_info info;
5136 info.option = "-L";
5137 info.append_len = 0;
5138 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
5139 /* Used on systems which record the specified -L dirs
5140 and use them to search for dynamic linking.
5141 Relative directories always come from -B,
5142 and it is better not to use them for searching
5143 at run time. In particular, stage1 loses. */
5144 info.omit_relative = true;
5145 #else
5146 info.omit_relative = false;
5147 #endif
5148 info.separate_options = false;
5150 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
5152 break;
5154 case 'e':
5155 /* %efoo means report an error with `foo' as error message
5156 and don't execute any more commands for this file. */
5158 const char *q = p;
5159 char *buf;
5160 while (*p != 0 && *p != '\n')
5161 p++;
5162 buf = (char *) alloca (p - q + 1);
5163 strncpy (buf, q, p - q);
5164 buf[p - q] = 0;
5165 error ("%s", _(buf));
5166 return -1;
5168 break;
5169 case 'n':
5170 /* %nfoo means report a notice with `foo' on stderr. */
5172 const char *q = p;
5173 char *buf;
5174 while (*p != 0 && *p != '\n')
5175 p++;
5176 buf = (char *) alloca (p - q + 1);
5177 strncpy (buf, q, p - q);
5178 buf[p - q] = 0;
5179 inform (0, "%s", _(buf));
5180 if (*p)
5181 p++;
5183 break;
5185 case 'j':
5187 struct stat st;
5189 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
5190 defined, and it is not a directory, and it is
5191 writable, use it. Otherwise, treat this like any
5192 other temporary file. */
5194 if ((!save_temps_flag)
5195 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
5196 && (access (HOST_BIT_BUCKET, W_OK) == 0))
5198 obstack_grow (&obstack, HOST_BIT_BUCKET,
5199 strlen (HOST_BIT_BUCKET));
5200 delete_this_arg = 0;
5201 arg_going = 1;
5202 break;
5205 goto create_temp_file;
5206 case '|':
5207 if (use_pipes)
5209 obstack_1grow (&obstack, '-');
5210 delete_this_arg = 0;
5211 arg_going = 1;
5213 /* consume suffix */
5214 while (*p == '.' || ISALNUM ((unsigned char) *p))
5215 p++;
5216 if (p[0] == '%' && p[1] == 'O')
5217 p += 2;
5219 break;
5221 goto create_temp_file;
5222 case 'm':
5223 if (use_pipes)
5225 /* consume suffix */
5226 while (*p == '.' || ISALNUM ((unsigned char) *p))
5227 p++;
5228 if (p[0] == '%' && p[1] == 'O')
5229 p += 2;
5231 break;
5233 goto create_temp_file;
5234 case 'g':
5235 case 'u':
5236 case 'U':
5237 create_temp_file:
5239 struct temp_name *t;
5240 int suffix_length;
5241 const char *suffix = p;
5242 char *saved_suffix = NULL;
5244 while (*p == '.' || ISALNUM ((unsigned char) *p))
5245 p++;
5246 suffix_length = p - suffix;
5247 if (p[0] == '%' && p[1] == 'O')
5249 p += 2;
5250 /* We don't support extra suffix characters after %O. */
5251 if (*p == '.' || ISALNUM ((unsigned char) *p))
5252 fatal_error (input_location,
5253 "spec %qs has invalid %<%%0%c%>", spec, *p);
5254 if (suffix_length == 0)
5255 suffix = TARGET_OBJECT_SUFFIX;
5256 else
5258 saved_suffix
5259 = XNEWVEC (char, suffix_length
5260 + strlen (TARGET_OBJECT_SUFFIX) + 1);
5261 strncpy (saved_suffix, suffix, suffix_length);
5262 strcpy (saved_suffix + suffix_length,
5263 TARGET_OBJECT_SUFFIX);
5265 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
5268 if (compare_debug < 0)
5270 suffix = concat (".gk", suffix, NULL);
5271 suffix_length += 3;
5274 /* If -save-temps=obj and -o were specified, use that for the
5275 temp file. */
5276 if (save_temps_length)
5278 char *tmp;
5279 temp_filename_length
5280 = save_temps_length + suffix_length + 1;
5281 tmp = (char *) alloca (temp_filename_length);
5282 memcpy (tmp, save_temps_prefix, save_temps_length);
5283 memcpy (tmp + save_temps_length, suffix, suffix_length);
5284 tmp[save_temps_length + suffix_length] = '\0';
5285 temp_filename = save_string (tmp, save_temps_length
5286 + suffix_length);
5287 obstack_grow (&obstack, temp_filename,
5288 temp_filename_length);
5289 arg_going = 1;
5290 delete_this_arg = 0;
5291 break;
5294 /* If the gcc_input_filename has the same suffix specified
5295 for the %g, %u, or %U, and -save-temps is specified,
5296 we could end up using that file as an intermediate
5297 thus clobbering the user's source file (.e.g.,
5298 gcc -save-temps foo.s would clobber foo.s with the
5299 output of cpp0). So check for this condition and
5300 generate a temp file as the intermediate. */
5302 if (save_temps_flag)
5304 char *tmp;
5305 temp_filename_length = basename_length + suffix_length + 1;
5306 tmp = (char *) alloca (temp_filename_length);
5307 memcpy (tmp, input_basename, basename_length);
5308 memcpy (tmp + basename_length, suffix, suffix_length);
5309 tmp[basename_length + suffix_length] = '\0';
5310 temp_filename = tmp;
5312 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
5314 #ifndef HOST_LACKS_INODE_NUMBERS
5315 struct stat st_temp;
5317 /* Note, set_input() resets input_stat_set to 0. */
5318 if (input_stat_set == 0)
5320 input_stat_set = stat (gcc_input_filename,
5321 &input_stat);
5322 if (input_stat_set >= 0)
5323 input_stat_set = 1;
5326 /* If we have the stat for the gcc_input_filename
5327 and we can do the stat for the temp_filename
5328 then the they could still refer to the same
5329 file if st_dev/st_ino's are the same. */
5330 if (input_stat_set != 1
5331 || stat (temp_filename, &st_temp) < 0
5332 || input_stat.st_dev != st_temp.st_dev
5333 || input_stat.st_ino != st_temp.st_ino)
5334 #else
5335 /* Just compare canonical pathnames. */
5336 char* input_realname = lrealpath (gcc_input_filename);
5337 char* temp_realname = lrealpath (temp_filename);
5338 bool files_differ = filename_cmp (input_realname, temp_realname);
5339 free (input_realname);
5340 free (temp_realname);
5341 if (files_differ)
5342 #endif
5344 temp_filename = save_string (temp_filename,
5345 temp_filename_length + 1);
5346 obstack_grow (&obstack, temp_filename,
5347 temp_filename_length);
5348 arg_going = 1;
5349 delete_this_arg = 0;
5350 break;
5355 /* See if we already have an association of %g/%u/%U and
5356 suffix. */
5357 for (t = temp_names; t; t = t->next)
5358 if (t->length == suffix_length
5359 && strncmp (t->suffix, suffix, suffix_length) == 0
5360 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
5361 break;
5363 /* Make a new association if needed. %u and %j
5364 require one. */
5365 if (t == 0 || c == 'u' || c == 'j')
5367 if (t == 0)
5369 t = XNEW (struct temp_name);
5370 t->next = temp_names;
5371 temp_names = t;
5373 t->length = suffix_length;
5374 if (saved_suffix)
5376 t->suffix = saved_suffix;
5377 saved_suffix = NULL;
5379 else
5380 t->suffix = save_string (suffix, suffix_length);
5381 t->unique = (c == 'u' || c == 'U' || c == 'j');
5382 temp_filename = make_temp_file (t->suffix);
5383 temp_filename_length = strlen (temp_filename);
5384 t->filename = temp_filename;
5385 t->filename_length = temp_filename_length;
5388 free (saved_suffix);
5390 obstack_grow (&obstack, t->filename, t->filename_length);
5391 delete_this_arg = 1;
5393 arg_going = 1;
5394 break;
5396 case 'i':
5397 if (combine_inputs)
5399 if (at_file_supplied)
5401 /* We are going to expand `%i' to `@FILE', where FILE
5402 is a newly-created temporary filename. The filenames
5403 that would usually be expanded in place of %o will be
5404 written to the temporary file. */
5405 char **argv;
5406 int n_files = 0;
5407 int j;
5409 for (i = 0; i < n_infiles; i++)
5410 if (compile_input_file_p (&infiles[i]))
5411 n_files++;
5413 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5415 /* Copy the strings over. */
5416 for (i = 0, j = 0; i < n_infiles; i++)
5417 if (compile_input_file_p (&infiles[i]))
5419 argv[j] = CONST_CAST (char *, infiles[i].name);
5420 infiles[i].compiled = true;
5421 j++;
5423 argv[j] = NULL;
5425 create_at_file (argv);
5427 else
5428 for (i = 0; (int) i < n_infiles; i++)
5429 if (compile_input_file_p (&infiles[i]))
5431 store_arg (infiles[i].name, 0, 0);
5432 infiles[i].compiled = true;
5435 else
5437 obstack_grow (&obstack, gcc_input_filename,
5438 input_filename_length);
5439 arg_going = 1;
5441 break;
5443 case 'I':
5445 struct spec_path_info info;
5447 if (multilib_dir)
5449 do_spec_1 ("-imultilib", 1, NULL);
5450 /* Make this a separate argument. */
5451 do_spec_1 (" ", 0, NULL);
5452 do_spec_1 (multilib_dir, 1, NULL);
5453 do_spec_1 (" ", 0, NULL);
5456 if (multiarch_dir)
5458 do_spec_1 ("-imultiarch", 1, NULL);
5459 /* Make this a separate argument. */
5460 do_spec_1 (" ", 0, NULL);
5461 do_spec_1 (multiarch_dir, 1, NULL);
5462 do_spec_1 (" ", 0, NULL);
5465 if (gcc_exec_prefix)
5467 do_spec_1 ("-iprefix", 1, NULL);
5468 /* Make this a separate argument. */
5469 do_spec_1 (" ", 0, NULL);
5470 do_spec_1 (gcc_exec_prefix, 1, NULL);
5471 do_spec_1 (" ", 0, NULL);
5474 if (target_system_root_changed ||
5475 (target_system_root && target_sysroot_hdrs_suffix))
5477 do_spec_1 ("-isysroot", 1, NULL);
5478 /* Make this a separate argument. */
5479 do_spec_1 (" ", 0, NULL);
5480 do_spec_1 (target_system_root, 1, NULL);
5481 if (target_sysroot_hdrs_suffix)
5482 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
5483 do_spec_1 (" ", 0, NULL);
5486 info.option = "-isystem";
5487 info.append = "include";
5488 info.append_len = strlen (info.append);
5489 info.omit_relative = false;
5490 info.separate_options = true;
5492 for_each_path (&include_prefixes, false, info.append_len,
5493 spec_path, &info);
5495 info.append = "include-fixed";
5496 if (*sysroot_hdrs_suffix_spec)
5497 info.append = concat (info.append, dir_separator_str,
5498 multilib_dir, NULL);
5499 info.append_len = strlen (info.append);
5500 for_each_path (&include_prefixes, false, info.append_len,
5501 spec_path, &info);
5503 break;
5505 case 'o':
5507 int max = n_infiles;
5508 max += lang_specific_extra_outfiles;
5510 if (HAVE_GNU_LD && at_file_supplied)
5512 /* We are going to expand `%o' to `@FILE', where FILE
5513 is a newly-created temporary filename. The filenames
5514 that would usually be expanded in place of %o will be
5515 written to the temporary file. */
5517 char **argv;
5518 int n_files, j;
5520 /* Convert OUTFILES into a form suitable for writeargv. */
5522 /* Determine how many are non-NULL. */
5523 for (n_files = 0, i = 0; i < max; i++)
5524 n_files += outfiles[i] != NULL;
5526 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5528 /* Copy the strings over. */
5529 for (i = 0, j = 0; i < max; i++)
5530 if (outfiles[i])
5532 argv[j] = CONST_CAST (char *, outfiles[i]);
5533 j++;
5535 argv[j] = NULL;
5537 create_at_file (argv);
5539 else
5540 for (i = 0; i < max; i++)
5541 if (outfiles[i])
5542 store_arg (outfiles[i], 0, 0);
5543 break;
5546 case 'O':
5547 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5548 arg_going = 1;
5549 break;
5551 case 's':
5552 this_is_library_file = 1;
5553 break;
5555 case 'T':
5556 this_is_linker_script = 1;
5557 break;
5559 case 'V':
5560 outfiles[input_file_number] = NULL;
5561 break;
5563 case 'w':
5564 this_is_output_file = 1;
5565 break;
5567 case 'W':
5569 unsigned int cur_index = argbuf.length ();
5570 /* Handle the {...} following the %W. */
5571 if (*p != '{')
5572 fatal_error (input_location,
5573 "spec %qs has invalid %<%%W%c%>", spec, *p);
5574 p = handle_braces (p + 1);
5575 if (p == 0)
5576 return -1;
5577 end_going_arg ();
5578 /* If any args were output, mark the last one for deletion
5579 on failure. */
5580 if (argbuf.length () != cur_index)
5581 record_temp_file (argbuf.last (), 0, 1);
5582 break;
5585 /* %x{OPTION} records OPTION for %X to output. */
5586 case 'x':
5588 const char *p1 = p;
5589 char *string;
5590 char *opt;
5591 unsigned ix;
5593 /* Skip past the option value and make a copy. */
5594 if (*p != '{')
5595 fatal_error (input_location,
5596 "spec %qs has invalid %<%%x%c%>", spec, *p);
5597 while (*p++ != '}')
5599 string = save_string (p1 + 1, p - p1 - 2);
5601 /* See if we already recorded this option. */
5602 FOR_EACH_VEC_ELT (linker_options, ix, opt)
5603 if (! strcmp (string, opt))
5605 free (string);
5606 return 0;
5609 /* This option is new; add it. */
5610 add_linker_option (string, strlen (string));
5611 free (string);
5613 break;
5615 /* Dump out the options accumulated previously using %x. */
5616 case 'X':
5617 do_specs_vec (linker_options);
5618 break;
5620 /* Dump out the options accumulated previously using -Wa,. */
5621 case 'Y':
5622 do_specs_vec (assembler_options);
5623 break;
5625 /* Dump out the options accumulated previously using -Wp,. */
5626 case 'Z':
5627 do_specs_vec (preprocessor_options);
5628 break;
5630 /* Here are digits and numbers that just process
5631 a certain constant string as a spec. */
5633 case '1':
5634 value = do_spec_1 (cc1_spec, 0, NULL);
5635 if (value != 0)
5636 return value;
5637 break;
5639 case '2':
5640 value = do_spec_1 (cc1plus_spec, 0, NULL);
5641 if (value != 0)
5642 return value;
5643 break;
5645 case 'a':
5646 value = do_spec_1 (asm_spec, 0, NULL);
5647 if (value != 0)
5648 return value;
5649 break;
5651 case 'A':
5652 value = do_spec_1 (asm_final_spec, 0, NULL);
5653 if (value != 0)
5654 return value;
5655 break;
5657 case 'C':
5659 const char *const spec
5660 = (input_file_compiler->cpp_spec
5661 ? input_file_compiler->cpp_spec
5662 : cpp_spec);
5663 value = do_spec_1 (spec, 0, NULL);
5664 if (value != 0)
5665 return value;
5667 break;
5669 case 'E':
5670 value = do_spec_1 (endfile_spec, 0, NULL);
5671 if (value != 0)
5672 return value;
5673 break;
5675 case 'l':
5676 value = do_spec_1 (link_spec, 0, NULL);
5677 if (value != 0)
5678 return value;
5679 break;
5681 case 'L':
5682 value = do_spec_1 (lib_spec, 0, NULL);
5683 if (value != 0)
5684 return value;
5685 break;
5687 case 'M':
5688 if (multilib_os_dir == NULL)
5689 obstack_1grow (&obstack, '.');
5690 else
5691 obstack_grow (&obstack, multilib_os_dir,
5692 strlen (multilib_os_dir));
5693 break;
5695 case 'G':
5696 value = do_spec_1 (libgcc_spec, 0, NULL);
5697 if (value != 0)
5698 return value;
5699 break;
5701 case 'R':
5702 /* We assume there is a directory
5703 separator at the end of this string. */
5704 if (target_system_root)
5706 obstack_grow (&obstack, target_system_root,
5707 strlen (target_system_root));
5708 if (target_sysroot_suffix)
5709 obstack_grow (&obstack, target_sysroot_suffix,
5710 strlen (target_sysroot_suffix));
5712 break;
5714 case 'S':
5715 value = do_spec_1 (startfile_spec, 0, NULL);
5716 if (value != 0)
5717 return value;
5718 break;
5720 /* Here we define characters other than letters and digits. */
5722 case '{':
5723 p = handle_braces (p);
5724 if (p == 0)
5725 return -1;
5726 break;
5728 case ':':
5729 p = handle_spec_function (p, NULL);
5730 if (p == 0)
5731 return -1;
5732 break;
5734 case '%':
5735 obstack_1grow (&obstack, '%');
5736 break;
5738 case '.':
5740 unsigned len = 0;
5742 while (p[len] && p[len] != ' ' && p[len] != '%')
5743 len++;
5744 suffix_subst = save_string (p - 1, len + 1);
5745 p += len;
5747 break;
5749 /* Henceforth ignore the option(s) matching the pattern
5750 after the %<. */
5751 case '<':
5752 case '>':
5754 unsigned len = 0;
5755 int have_wildcard = 0;
5756 int i;
5757 int switch_option;
5759 if (c == '>')
5760 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5761 else
5762 switch_option = SWITCH_IGNORE;
5764 while (p[len] && p[len] != ' ' && p[len] != '\t')
5765 len++;
5767 if (p[len-1] == '*')
5768 have_wildcard = 1;
5770 for (i = 0; i < n_switches; i++)
5771 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5772 && (have_wildcard || switches[i].part1[len] == '\0'))
5774 switches[i].live_cond |= switch_option;
5775 /* User switch be validated from validate_all_switches.
5776 when the definition is seen from the spec file.
5777 If not defined anywhere, will be rejected. */
5778 if (switches[i].known)
5779 switches[i].validated = true;
5782 p += len;
5784 break;
5786 case '*':
5787 if (soft_matched_part)
5789 if (soft_matched_part[0])
5790 do_spec_1 (soft_matched_part, 1, NULL);
5791 /* Only insert a space after the substitution if it is at the
5792 end of the current sequence. So if:
5794 "%{foo=*:bar%*}%{foo=*:one%*two}"
5796 matches -foo=hello then it will produce:
5798 barhello onehellotwo
5800 if (*p == 0 || *p == '}')
5801 do_spec_1 (" ", 0, NULL);
5803 else
5804 /* Catch the case where a spec string contains something like
5805 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5806 hand side of the :. */
5807 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5808 break;
5810 /* Process a string found as the value of a spec given by name.
5811 This feature allows individual machine descriptions
5812 to add and use their own specs. */
5813 case '(':
5815 const char *name = p;
5816 struct spec_list *sl;
5817 int len;
5819 /* The string after the S/P is the name of a spec that is to be
5820 processed. */
5821 while (*p && *p != ')')
5822 p++;
5824 /* See if it's in the list. */
5825 for (len = p - name, sl = specs; sl; sl = sl->next)
5826 if (sl->name_len == len && !strncmp (sl->name, name, len))
5828 name = *(sl->ptr_spec);
5829 #ifdef DEBUG_SPECS
5830 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5831 sl->name, name);
5832 #endif
5833 break;
5836 if (sl)
5838 value = do_spec_1 (name, 0, NULL);
5839 if (value != 0)
5840 return value;
5843 /* Discard the closing paren. */
5844 if (*p)
5845 p++;
5847 break;
5849 default:
5850 error ("spec failure: unrecognized spec option %qc", c);
5851 break;
5853 break;
5855 case '\\':
5856 /* Backslash: treat next character as ordinary. */
5857 c = *p++;
5859 /* Fall through. */
5860 default:
5861 /* Ordinary character: put it into the current argument. */
5862 obstack_1grow (&obstack, c);
5863 arg_going = 1;
5866 /* End of string. If we are processing a spec function, we need to
5867 end any pending argument. */
5868 if (processing_spec_function)
5869 end_going_arg ();
5871 return 0;
5874 /* Look up a spec function. */
5876 static const struct spec_function *
5877 lookup_spec_function (const char *name)
5879 const struct spec_function *sf;
5881 for (sf = static_spec_functions; sf->name != NULL; sf++)
5882 if (strcmp (sf->name, name) == 0)
5883 return sf;
5885 return NULL;
5888 /* Evaluate a spec function. */
5890 static const char *
5891 eval_spec_function (const char *func, const char *args)
5893 const struct spec_function *sf;
5894 const char *funcval;
5896 /* Saved spec processing context. */
5897 vec<const_char_p> save_argbuf;
5899 int save_arg_going;
5900 int save_delete_this_arg;
5901 int save_this_is_output_file;
5902 int save_this_is_library_file;
5903 int save_input_from_pipe;
5904 int save_this_is_linker_script;
5905 const char *save_suffix_subst;
5907 int save_growing_size;
5908 void *save_growing_value = NULL;
5910 sf = lookup_spec_function (func);
5911 if (sf == NULL)
5912 fatal_error (input_location, "unknown spec function %qs", func);
5914 /* Push the spec processing context. */
5915 save_argbuf = argbuf;
5917 save_arg_going = arg_going;
5918 save_delete_this_arg = delete_this_arg;
5919 save_this_is_output_file = this_is_output_file;
5920 save_this_is_library_file = this_is_library_file;
5921 save_this_is_linker_script = this_is_linker_script;
5922 save_input_from_pipe = input_from_pipe;
5923 save_suffix_subst = suffix_subst;
5925 /* If we have some object growing now, finalize it so the args and function
5926 eval proceed from a cleared context. This is needed to prevent the first
5927 constructed arg from mistakenly including the growing value. We'll push
5928 this value back on the obstack once the function evaluation is done, to
5929 restore a consistent processing context for our caller. This is fine as
5930 the address of growing objects isn't guaranteed to remain stable until
5931 they are finalized, and we expect this situation to be rare enough for
5932 the extra copy not to be an issue. */
5933 save_growing_size = obstack_object_size (&obstack);
5934 if (save_growing_size > 0)
5935 save_growing_value = obstack_finish (&obstack);
5937 /* Create a new spec processing context, and build the function
5938 arguments. */
5940 alloc_args ();
5941 if (do_spec_2 (args) < 0)
5942 fatal_error (input_location, "error in args to spec function %qs", func);
5944 /* argbuf_index is an index for the next argument to be inserted, and
5945 so contains the count of the args already inserted. */
5947 funcval = (*sf->func) (argbuf.length (),
5948 argbuf.address ());
5950 /* Pop the spec processing context. */
5951 argbuf.release ();
5952 argbuf = save_argbuf;
5954 arg_going = save_arg_going;
5955 delete_this_arg = save_delete_this_arg;
5956 this_is_output_file = save_this_is_output_file;
5957 this_is_library_file = save_this_is_library_file;
5958 this_is_linker_script = save_this_is_linker_script;
5959 input_from_pipe = save_input_from_pipe;
5960 suffix_subst = save_suffix_subst;
5962 if (save_growing_size > 0)
5963 obstack_grow (&obstack, save_growing_value, save_growing_size);
5965 return funcval;
5968 /* Handle a spec function call of the form:
5970 %:function(args)
5972 ARGS is processed as a spec in a separate context and split into an
5973 argument vector in the normal fashion. The function returns a string
5974 containing a spec which we then process in the caller's context, or
5975 NULL if no processing is required.
5977 If RETVAL_NONNULL is not NULL, then store a bool whether function
5978 returned non-NULL. */
5980 static const char *
5981 handle_spec_function (const char *p, bool *retval_nonnull)
5983 char *func, *args;
5984 const char *endp, *funcval;
5985 int count;
5987 processing_spec_function++;
5989 /* Get the function name. */
5990 for (endp = p; *endp != '\0'; endp++)
5992 if (*endp == '(') /* ) */
5993 break;
5994 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5995 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5996 fatal_error (input_location, "malformed spec function name");
5998 if (*endp != '(') /* ) */
5999 fatal_error (input_location, "no arguments for spec function");
6000 func = save_string (p, endp - p);
6001 p = ++endp;
6003 /* Get the arguments. */
6004 for (count = 0; *endp != '\0'; endp++)
6006 /* ( */
6007 if (*endp == ')')
6009 if (count == 0)
6010 break;
6011 count--;
6013 else if (*endp == '(') /* ) */
6014 count++;
6016 /* ( */
6017 if (*endp != ')')
6018 fatal_error (input_location, "malformed spec function arguments");
6019 args = save_string (p, endp - p);
6020 p = ++endp;
6022 /* p now points to just past the end of the spec function expression. */
6024 funcval = eval_spec_function (func, args);
6025 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
6026 p = NULL;
6027 if (retval_nonnull)
6028 *retval_nonnull = funcval != NULL;
6030 free (func);
6031 free (args);
6033 processing_spec_function--;
6035 return p;
6038 /* Inline subroutine of handle_braces. Returns true if the current
6039 input suffix matches the atom bracketed by ATOM and END_ATOM. */
6040 static inline bool
6041 input_suffix_matches (const char *atom, const char *end_atom)
6043 return (input_suffix
6044 && !strncmp (input_suffix, atom, end_atom - atom)
6045 && input_suffix[end_atom - atom] == '\0');
6048 /* Subroutine of handle_braces. Returns true if the current
6049 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
6050 static bool
6051 input_spec_matches (const char *atom, const char *end_atom)
6053 return (input_file_compiler
6054 && input_file_compiler->suffix
6055 && input_file_compiler->suffix[0] != '\0'
6056 && !strncmp (input_file_compiler->suffix + 1, atom,
6057 end_atom - atom)
6058 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
6061 /* Subroutine of handle_braces. Returns true if a switch
6062 matching the atom bracketed by ATOM and END_ATOM appeared on the
6063 command line. */
6064 static bool
6065 switch_matches (const char *atom, const char *end_atom, int starred)
6067 int i;
6068 int len = end_atom - atom;
6069 int plen = starred ? len : -1;
6071 for (i = 0; i < n_switches; i++)
6072 if (!strncmp (switches[i].part1, atom, len)
6073 && (starred || switches[i].part1[len] == '\0')
6074 && check_live_switch (i, plen))
6075 return true;
6077 /* Check if a switch with separated form matching the atom.
6078 We check -D and -U switches. */
6079 else if (switches[i].args != 0)
6081 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
6082 && *switches[i].part1 == atom[0])
6084 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
6085 && (starred || (switches[i].part1[1] == '\0'
6086 && switches[i].args[0][len - 1] == '\0'))
6087 && check_live_switch (i, (starred ? 1 : -1)))
6088 return true;
6092 return false;
6095 /* Inline subroutine of handle_braces. Mark all of the switches which
6096 match ATOM (extends to END_ATOM; STARRED indicates whether there
6097 was a star after the atom) for later processing. */
6098 static inline void
6099 mark_matching_switches (const char *atom, const char *end_atom, int starred)
6101 int i;
6102 int len = end_atom - atom;
6103 int plen = starred ? len : -1;
6105 for (i = 0; i < n_switches; i++)
6106 if (!strncmp (switches[i].part1, atom, len)
6107 && (starred || switches[i].part1[len] == '\0')
6108 && check_live_switch (i, plen))
6109 switches[i].ordering = 1;
6112 /* Inline subroutine of handle_braces. Process all the currently
6113 marked switches through give_switch, and clear the marks. */
6114 static inline void
6115 process_marked_switches (void)
6117 int i;
6119 for (i = 0; i < n_switches; i++)
6120 if (switches[i].ordering == 1)
6122 switches[i].ordering = 0;
6123 give_switch (i, 0);
6127 /* Handle a %{ ... } construct. P points just inside the leading {.
6128 Returns a pointer one past the end of the brace block, or 0
6129 if we call do_spec_1 and that returns -1. */
6131 static const char *
6132 handle_braces (const char *p)
6134 const char *atom, *end_atom;
6135 const char *d_atom = NULL, *d_end_atom = NULL;
6136 const char *orig = p;
6138 bool a_is_suffix;
6139 bool a_is_spectype;
6140 bool a_is_starred;
6141 bool a_is_negated;
6142 bool a_matched;
6144 bool a_must_be_last = false;
6145 bool ordered_set = false;
6146 bool disjunct_set = false;
6147 bool disj_matched = false;
6148 bool disj_starred = true;
6149 bool n_way_choice = false;
6150 bool n_way_matched = false;
6152 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
6156 if (a_must_be_last)
6157 goto invalid;
6159 /* Scan one "atom" (S in the description above of %{}, possibly
6160 with '!', '.', '@', ',', or '*' modifiers). */
6161 a_matched = false;
6162 a_is_suffix = false;
6163 a_is_starred = false;
6164 a_is_negated = false;
6165 a_is_spectype = false;
6167 SKIP_WHITE ();
6168 if (*p == '!')
6169 p++, a_is_negated = true;
6171 SKIP_WHITE ();
6172 if (*p == '%' && p[1] == ':')
6174 atom = NULL;
6175 end_atom = NULL;
6176 p = handle_spec_function (p + 2, &a_matched);
6178 else
6180 if (*p == '.')
6181 p++, a_is_suffix = true;
6182 else if (*p == ',')
6183 p++, a_is_spectype = true;
6185 atom = p;
6186 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
6187 || *p == ',' || *p == '.' || *p == '@')
6188 p++;
6189 end_atom = p;
6191 if (*p == '*')
6192 p++, a_is_starred = 1;
6195 SKIP_WHITE ();
6196 switch (*p)
6198 case '&': case '}':
6199 /* Substitute the switch(es) indicated by the current atom. */
6200 ordered_set = true;
6201 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
6202 || a_is_spectype || atom == end_atom)
6203 goto invalid;
6205 mark_matching_switches (atom, end_atom, a_is_starred);
6207 if (*p == '}')
6208 process_marked_switches ();
6209 break;
6211 case '|': case ':':
6212 /* Substitute some text if the current atom appears as a switch
6213 or suffix. */
6214 disjunct_set = true;
6215 if (ordered_set)
6216 goto invalid;
6218 if (atom && atom == end_atom)
6220 if (!n_way_choice || disj_matched || *p == '|'
6221 || a_is_negated || a_is_suffix || a_is_spectype
6222 || a_is_starred)
6223 goto invalid;
6225 /* An empty term may appear as the last choice of an
6226 N-way choice set; it means "otherwise". */
6227 a_must_be_last = true;
6228 disj_matched = !n_way_matched;
6229 disj_starred = false;
6231 else
6233 if ((a_is_suffix || a_is_spectype) && a_is_starred)
6234 goto invalid;
6236 if (!a_is_starred)
6237 disj_starred = false;
6239 /* Don't bother testing this atom if we already have a
6240 match. */
6241 if (!disj_matched && !n_way_matched)
6243 if (atom == NULL)
6244 /* a_matched is already set by handle_spec_function. */;
6245 else if (a_is_suffix)
6246 a_matched = input_suffix_matches (atom, end_atom);
6247 else if (a_is_spectype)
6248 a_matched = input_spec_matches (atom, end_atom);
6249 else
6250 a_matched = switch_matches (atom, end_atom, a_is_starred);
6252 if (a_matched != a_is_negated)
6254 disj_matched = true;
6255 d_atom = atom;
6256 d_end_atom = end_atom;
6261 if (*p == ':')
6263 /* Found the body, that is, the text to substitute if the
6264 current disjunction matches. */
6265 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
6266 disj_matched && !n_way_matched);
6267 if (p == 0)
6268 return 0;
6270 /* If we have an N-way choice, reset state for the next
6271 disjunction. */
6272 if (*p == ';')
6274 n_way_choice = true;
6275 n_way_matched |= disj_matched;
6276 disj_matched = false;
6277 disj_starred = true;
6278 d_atom = d_end_atom = NULL;
6281 break;
6283 default:
6284 goto invalid;
6287 while (*p++ != '}');
6289 return p;
6291 invalid:
6292 fatal_error (input_location, "braced spec %qs is invalid at %qc", orig, *p);
6294 #undef SKIP_WHITE
6297 /* Subroutine of handle_braces. Scan and process a brace substitution body
6298 (X in the description of %{} syntax). P points one past the colon;
6299 ATOM and END_ATOM bracket the first atom which was found to be true
6300 (present) in the current disjunction; STARRED indicates whether all
6301 the atoms in the current disjunction were starred (for syntax validation);
6302 MATCHED indicates whether the disjunction matched or not, and therefore
6303 whether or not the body is to be processed through do_spec_1 or just
6304 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
6305 returns -1. */
6307 static const char *
6308 process_brace_body (const char *p, const char *atom, const char *end_atom,
6309 int starred, int matched)
6311 const char *body, *end_body;
6312 unsigned int nesting_level;
6313 bool have_subst = false;
6315 /* Locate the closing } or ;, honoring nested braces.
6316 Trim trailing whitespace. */
6317 body = p;
6318 nesting_level = 1;
6319 for (;;)
6321 if (*p == '{')
6322 nesting_level++;
6323 else if (*p == '}')
6325 if (!--nesting_level)
6326 break;
6328 else if (*p == ';' && nesting_level == 1)
6329 break;
6330 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
6331 have_subst = true;
6332 else if (*p == '\0')
6333 goto invalid;
6334 p++;
6337 end_body = p;
6338 while (end_body[-1] == ' ' || end_body[-1] == '\t')
6339 end_body--;
6341 if (have_subst && !starred)
6342 goto invalid;
6344 if (matched)
6346 /* Copy the substitution body to permanent storage and execute it.
6347 If have_subst is false, this is a simple matter of running the
6348 body through do_spec_1... */
6349 char *string = save_string (body, end_body - body);
6350 if (!have_subst)
6352 if (do_spec_1 (string, 0, NULL) < 0)
6354 free (string);
6355 return 0;
6358 else
6360 /* ... but if have_subst is true, we have to process the
6361 body once for each matching switch, with %* set to the
6362 variant part of the switch. */
6363 unsigned int hard_match_len = end_atom - atom;
6364 int i;
6366 for (i = 0; i < n_switches; i++)
6367 if (!strncmp (switches[i].part1, atom, hard_match_len)
6368 && check_live_switch (i, hard_match_len))
6370 if (do_spec_1 (string, 0,
6371 &switches[i].part1[hard_match_len]) < 0)
6373 free (string);
6374 return 0;
6376 /* Pass any arguments this switch has. */
6377 give_switch (i, 1);
6378 suffix_subst = NULL;
6381 free (string);
6384 return p;
6386 invalid:
6387 fatal_error (input_location, "braced spec body %qs is invalid", body);
6390 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
6391 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
6392 spec, or -1 if either exact match or %* is used.
6394 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
6395 whose value does not begin with "no-" is obsoleted by the same value
6396 with the "no-", similarly for a switch with the "no-" prefix. */
6398 static int
6399 check_live_switch (int switchnum, int prefix_length)
6401 const char *name = switches[switchnum].part1;
6402 int i;
6404 /* If we already processed this switch and determined if it was
6405 live or not, return our past determination. */
6406 if (switches[switchnum].live_cond != 0)
6407 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
6408 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
6409 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
6410 == 0);
6412 /* In the common case of {<at-most-one-letter>*}, a negating
6413 switch would always match, so ignore that case. We will just
6414 send the conflicting switches to the compiler phase. */
6415 if (prefix_length >= 0 && prefix_length <= 1)
6416 return 1;
6418 /* Now search for duplicate in a manner that depends on the name. */
6419 switch (*name)
6421 case 'O':
6422 for (i = switchnum + 1; i < n_switches; i++)
6423 if (switches[i].part1[0] == 'O')
6425 switches[switchnum].validated = true;
6426 switches[switchnum].live_cond = SWITCH_FALSE;
6427 return 0;
6429 break;
6431 case 'W': case 'f': case 'm': case 'g':
6432 if (! strncmp (name + 1, "no-", 3))
6434 /* We have Xno-YYY, search for XYYY. */
6435 for (i = switchnum + 1; i < n_switches; i++)
6436 if (switches[i].part1[0] == name[0]
6437 && ! strcmp (&switches[i].part1[1], &name[4]))
6439 /* --specs are validated with the validate_switches mechanism. */
6440 if (switches[switchnum].known)
6441 switches[switchnum].validated = true;
6442 switches[switchnum].live_cond = SWITCH_FALSE;
6443 return 0;
6446 else
6448 /* We have XYYY, search for Xno-YYY. */
6449 for (i = switchnum + 1; i < n_switches; i++)
6450 if (switches[i].part1[0] == name[0]
6451 && switches[i].part1[1] == 'n'
6452 && switches[i].part1[2] == 'o'
6453 && switches[i].part1[3] == '-'
6454 && !strcmp (&switches[i].part1[4], &name[1]))
6456 /* --specs are validated with the validate_switches mechanism. */
6457 if (switches[switchnum].known)
6458 switches[switchnum].validated = true;
6459 switches[switchnum].live_cond = SWITCH_FALSE;
6460 return 0;
6463 break;
6466 /* Otherwise the switch is live. */
6467 switches[switchnum].live_cond |= SWITCH_LIVE;
6468 return 1;
6471 /* Pass a switch to the current accumulating command
6472 in the same form that we received it.
6473 SWITCHNUM identifies the switch; it is an index into
6474 the vector of switches gcc received, which is `switches'.
6475 This cannot fail since it never finishes a command line.
6477 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
6479 static void
6480 give_switch (int switchnum, int omit_first_word)
6482 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
6483 return;
6485 if (!omit_first_word)
6487 do_spec_1 ("-", 0, NULL);
6488 do_spec_1 (switches[switchnum].part1, 1, NULL);
6491 if (switches[switchnum].args != 0)
6493 const char **p;
6494 for (p = switches[switchnum].args; *p; p++)
6496 const char *arg = *p;
6498 do_spec_1 (" ", 0, NULL);
6499 if (suffix_subst)
6501 unsigned length = strlen (arg);
6502 int dot = 0;
6504 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
6505 if (arg[length] == '.')
6507 (CONST_CAST (char *, arg))[length] = 0;
6508 dot = 1;
6509 break;
6511 do_spec_1 (arg, 1, NULL);
6512 if (dot)
6513 (CONST_CAST (char *, arg))[length] = '.';
6514 do_spec_1 (suffix_subst, 1, NULL);
6516 else
6517 do_spec_1 (arg, 1, NULL);
6521 do_spec_1 (" ", 0, NULL);
6522 switches[switchnum].validated = true;
6525 /* Print GCC configuration (e.g. version, thread model, target,
6526 configuration_arguments) to a given FILE. */
6528 static void
6529 print_configuration (FILE *file)
6531 int n;
6532 const char *thrmod;
6534 fnotice (file, "Target: %s\n", spec_machine);
6535 fnotice (file, "Configured with: %s\n", configuration_arguments);
6537 #ifdef THREAD_MODEL_SPEC
6538 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6539 but there's no point in doing all this processing just to get
6540 thread_model back. */
6541 obstack_init (&obstack);
6542 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6543 obstack_1grow (&obstack, '\0');
6544 thrmod = XOBFINISH (&obstack, const char *);
6545 #else
6546 thrmod = thread_model;
6547 #endif
6549 fnotice (file, "Thread model: %s\n", thrmod);
6551 /* compiler_version is truncated at the first space when initialized
6552 from version string, so truncate version_string at the first space
6553 before comparing. */
6554 for (n = 0; version_string[n]; n++)
6555 if (version_string[n] == ' ')
6556 break;
6558 if (! strncmp (version_string, compiler_version, n)
6559 && compiler_version[n] == 0)
6560 fnotice (file, "gcc version %s %s\n", version_string,
6561 pkgversion_string);
6562 else
6563 fnotice (file, "gcc driver version %s %sexecuting gcc version %s\n",
6564 version_string, pkgversion_string, compiler_version);
6568 #define RETRY_ICE_ATTEMPTS 3
6570 /* Returns true if FILE1 and FILE2 contain equivalent data, 0 otherwise. */
6572 static bool
6573 files_equal_p (char *file1, char *file2)
6575 struct stat st1, st2;
6576 off_t n, len;
6577 int fd1, fd2;
6578 const int bufsize = 8192;
6579 char *buf = XNEWVEC (char, bufsize);
6581 fd1 = open (file1, O_RDONLY);
6582 fd2 = open (file2, O_RDONLY);
6584 if (fd1 < 0 || fd2 < 0)
6585 goto error;
6587 if (fstat (fd1, &st1) < 0 || fstat (fd2, &st2) < 0)
6588 goto error;
6590 if (st1.st_size != st2.st_size)
6591 goto error;
6593 for (n = st1.st_size; n; n -= len)
6595 len = n;
6596 if ((int) len > bufsize / 2)
6597 len = bufsize / 2;
6599 if (read (fd1, buf, len) != (int) len
6600 || read (fd2, buf + bufsize / 2, len) != (int) len)
6602 goto error;
6605 if (memcmp (buf, buf + bufsize / 2, len) != 0)
6606 goto error;
6609 free (buf);
6610 close (fd1);
6611 close (fd2);
6613 return 1;
6615 error:
6616 free (buf);
6617 close (fd1);
6618 close (fd2);
6619 return 0;
6622 /* Check that compiler's output doesn't differ across runs.
6623 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are arrays of files, containing
6624 stdout and stderr for each compiler run. Return true if all of
6625 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are equivalent. */
6627 static bool
6628 check_repro (char **temp_stdout_files, char **temp_stderr_files)
6630 int i;
6631 for (i = 0; i < RETRY_ICE_ATTEMPTS - 2; ++i)
6633 if (!files_equal_p (temp_stdout_files[i], temp_stdout_files[i + 1])
6634 || !files_equal_p (temp_stderr_files[i], temp_stderr_files[i + 1]))
6636 fnotice (stderr, "The bug is not reproducible, so it is"
6637 " likely a hardware or OS problem.\n");
6638 break;
6641 return i == RETRY_ICE_ATTEMPTS - 2;
6644 enum attempt_status {
6645 ATTEMPT_STATUS_FAIL_TO_RUN,
6646 ATTEMPT_STATUS_SUCCESS,
6647 ATTEMPT_STATUS_ICE
6651 /* Run compiler with arguments NEW_ARGV to reproduce the ICE, storing stdout
6652 to OUT_TEMP and stderr to ERR_TEMP. If APPEND is TRUE, append to OUT_TEMP
6653 and ERR_TEMP instead of truncating. If EMIT_SYSTEM_INFO is TRUE, also write
6654 GCC configuration into to ERR_TEMP. Return ATTEMPT_STATUS_FAIL_TO_RUN if
6655 compiler failed to run, ATTEMPT_STATUS_ICE if compiled ICE-ed and
6656 ATTEMPT_STATUS_SUCCESS otherwise. */
6658 static enum attempt_status
6659 run_attempt (const char **new_argv, const char *out_temp,
6660 const char *err_temp, int emit_system_info, int append)
6663 if (emit_system_info)
6665 FILE *file_out = fopen (err_temp, "a");
6666 print_configuration (file_out);
6667 fputs ("\n", file_out);
6668 fclose (file_out);
6671 int exit_status;
6672 const char *errmsg;
6673 struct pex_obj *pex;
6674 int err;
6675 int pex_flags = PEX_USE_PIPES | PEX_LAST;
6676 enum attempt_status status = ATTEMPT_STATUS_FAIL_TO_RUN;
6678 if (append)
6679 pex_flags |= PEX_STDOUT_APPEND | PEX_STDERR_APPEND;
6681 pex = pex_init (PEX_USE_PIPES, new_argv[0], NULL);
6682 if (!pex)
6683 fatal_error (input_location, "pex_init failed: %m");
6685 errmsg = pex_run (pex, pex_flags, new_argv[0],
6686 CONST_CAST2 (char *const *, const char **, &new_argv[1]), out_temp,
6687 err_temp, &err);
6688 if (errmsg != NULL)
6690 if (err == 0)
6691 fatal_error (input_location, errmsg);
6692 else
6694 errno = err;
6695 pfatal_with_name (errmsg);
6699 if (!pex_get_status (pex, 1, &exit_status))
6700 goto out;
6702 switch (WEXITSTATUS (exit_status))
6704 case ICE_EXIT_CODE:
6705 status = ATTEMPT_STATUS_ICE;
6706 break;
6708 case SUCCESS_EXIT_CODE:
6709 status = ATTEMPT_STATUS_SUCCESS;
6710 break;
6712 default:
6716 out:
6717 pex_free (pex);
6718 return status;
6721 /* This routine reads lines from IN file, adds C++ style comments
6722 at the begining of each line and writes result into OUT. */
6724 static void
6725 insert_comments (const char *file_in, const char *file_out)
6727 FILE *in = fopen (file_in, "rb");
6728 FILE *out = fopen (file_out, "wb");
6729 char line[256];
6731 bool add_comment = true;
6732 while (fgets (line, sizeof (line), in))
6734 if (add_comment)
6735 fputs ("// ", out);
6736 fputs (line, out);
6737 add_comment = strchr (line, '\n') != NULL;
6740 fclose (in);
6741 fclose (out);
6744 /* This routine adds preprocessed source code into the given ERR_FILE.
6745 To do this, it adds "-E" to NEW_ARGV and execute RUN_ATTEMPT routine to
6746 add information in report file. RUN_ATTEMPT should return
6747 ATTEMPT_STATUS_SUCCESS, in other case we cannot generate the report. */
6749 static void
6750 do_report_bug (const char **new_argv, const int nargs,
6751 char **out_file, char **err_file)
6753 int i, status;
6754 int fd = open (*out_file, O_RDWR | O_APPEND);
6755 if (fd < 0)
6756 return;
6757 write (fd, "\n//", 3);
6758 for (i = 0; i < nargs; i++)
6760 write (fd, " ", 1);
6761 write (fd, new_argv[i], strlen (new_argv[i]));
6763 write (fd, "\n\n", 2);
6764 close (fd);
6765 new_argv[nargs] = "-E";
6766 new_argv[nargs + 1] = NULL;
6768 status = run_attempt (new_argv, *out_file, *err_file, 0, 1);
6770 if (status == ATTEMPT_STATUS_SUCCESS)
6772 fnotice (stderr, "Preprocessed source stored into %s file,"
6773 " please attach this to your bugreport.\n", *out_file);
6774 /* Make sure it is not deleted. */
6775 free (*out_file);
6776 *out_file = NULL;
6780 /* Try to reproduce ICE. If bug is reproducible, generate report .err file
6781 containing GCC configuration, backtrace, compiler's command line options
6782 and preprocessed source code. */
6784 static void
6785 try_generate_repro (const char **argv)
6787 int i, nargs, out_arg = -1, quiet = 0, attempt;
6788 const char **new_argv;
6789 char *temp_files[RETRY_ICE_ATTEMPTS * 2];
6790 char **temp_stdout_files = &temp_files[0];
6791 char **temp_stderr_files = &temp_files[RETRY_ICE_ATTEMPTS];
6793 if (gcc_input_filename == NULL || ! strcmp (gcc_input_filename, "-"))
6794 return;
6796 for (nargs = 0; argv[nargs] != NULL; ++nargs)
6797 /* Only retry compiler ICEs, not preprocessor ones. */
6798 if (! strcmp (argv[nargs], "-E"))
6799 return;
6800 else if (argv[nargs][0] == '-' && argv[nargs][1] == 'o')
6802 if (out_arg == -1)
6803 out_arg = nargs;
6804 else
6805 return;
6807 /* If the compiler is going to output any time information,
6808 it might varry between invocations. */
6809 else if (! strcmp (argv[nargs], "-quiet"))
6810 quiet = 1;
6811 else if (! strcmp (argv[nargs], "-ftime-report"))
6812 return;
6814 if (out_arg == -1 || !quiet)
6815 return;
6817 memset (temp_files, '\0', sizeof (temp_files));
6818 new_argv = XALLOCAVEC (const char *, nargs + 4);
6819 memcpy (new_argv, argv, (nargs + 1) * sizeof (const char *));
6820 new_argv[nargs++] = "-frandom-seed=0";
6821 new_argv[nargs++] = "-fdump-noaddr";
6822 new_argv[nargs] = NULL;
6823 if (new_argv[out_arg][2] == '\0')
6824 new_argv[out_arg + 1] = "-";
6825 else
6826 new_argv[out_arg] = "-o-";
6828 int status;
6829 for (attempt = 0; attempt < RETRY_ICE_ATTEMPTS; ++attempt)
6831 int emit_system_info = 0;
6832 int append = 0;
6833 temp_stdout_files[attempt] = make_temp_file (".out");
6834 temp_stderr_files[attempt] = make_temp_file (".err");
6836 if (attempt == RETRY_ICE_ATTEMPTS - 1)
6838 append = 1;
6839 emit_system_info = 1;
6842 status = run_attempt (new_argv, temp_stdout_files[attempt],
6843 temp_stderr_files[attempt], emit_system_info,
6844 append);
6846 if (status != ATTEMPT_STATUS_ICE)
6848 fnotice (stderr, "The bug is not reproducible, so it is"
6849 " likely a hardware or OS problem.\n");
6850 goto out;
6854 if (!check_repro (temp_stdout_files, temp_stderr_files))
6855 goto out;
6858 /* Insert commented out backtrace into report file. */
6859 char **stderr_commented = &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1];
6860 insert_comments (temp_stderr_files[RETRY_ICE_ATTEMPTS - 1],
6861 *stderr_commented);
6863 /* In final attempt we append compiler options and preprocesssed code to last
6864 generated .out file with configuration and backtrace. */
6865 char **output = &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1];
6866 do_report_bug (new_argv, nargs, stderr_commented, output);
6869 out:
6870 for (i = 0; i < RETRY_ICE_ATTEMPTS * 2; i++)
6871 if (temp_files[i])
6873 unlink (temp_stdout_files[i]);
6874 free (temp_stdout_files[i]);
6878 /* Search for a file named NAME trying various prefixes including the
6879 user's -B prefix and some standard ones.
6880 Return the absolute file name found. If nothing is found, return NAME. */
6882 static const char *
6883 find_file (const char *name)
6885 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
6886 return newname ? newname : name;
6889 /* Determine whether a directory exists. If LINKER, return 0 for
6890 certain fixed names not needed by the linker. */
6892 static int
6893 is_directory (const char *path1, bool linker)
6895 int len1;
6896 char *path;
6897 char *cp;
6898 struct stat st;
6900 /* Ensure the string ends with "/.". The resulting path will be a
6901 directory even if the given path is a symbolic link. */
6902 len1 = strlen (path1);
6903 path = (char *) alloca (3 + len1);
6904 memcpy (path, path1, len1);
6905 cp = path + len1;
6906 if (!IS_DIR_SEPARATOR (cp[-1]))
6907 *cp++ = DIR_SEPARATOR;
6908 *cp++ = '.';
6909 *cp = '\0';
6911 /* Exclude directories that the linker is known to search. */
6912 if (linker
6913 && IS_DIR_SEPARATOR (path[0])
6914 && ((cp - path == 6
6915 && filename_ncmp (path + 1, "lib", 3) == 0)
6916 || (cp - path == 10
6917 && filename_ncmp (path + 1, "usr", 3) == 0
6918 && IS_DIR_SEPARATOR (path[4])
6919 && filename_ncmp (path + 5, "lib", 3) == 0)))
6920 return 0;
6922 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
6925 /* Set up the various global variables to indicate that we're processing
6926 the input file named FILENAME. */
6928 void
6929 set_input (const char *filename)
6931 const char *p;
6933 gcc_input_filename = filename;
6934 input_filename_length = strlen (gcc_input_filename);
6935 input_basename = lbasename (gcc_input_filename);
6937 /* Find a suffix starting with the last period,
6938 and set basename_length to exclude that suffix. */
6939 basename_length = strlen (input_basename);
6940 suffixed_basename_length = basename_length;
6941 p = input_basename + basename_length;
6942 while (p != input_basename && *p != '.')
6943 --p;
6944 if (*p == '.' && p != input_basename)
6946 basename_length = p - input_basename;
6947 input_suffix = p + 1;
6949 else
6950 input_suffix = "";
6952 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6953 we will need to do a stat on the gcc_input_filename. The
6954 INPUT_STAT_SET signals that the stat is needed. */
6955 input_stat_set = 0;
6958 /* On fatal signals, delete all the temporary files. */
6960 static void
6961 fatal_signal (int signum)
6963 signal (signum, SIG_DFL);
6964 delete_failure_queue ();
6965 delete_temp_files ();
6966 /* Get the same signal again, this time not handled,
6967 so its normal effect occurs. */
6968 kill (getpid (), signum);
6971 /* Compare the contents of the two files named CMPFILE[0] and
6972 CMPFILE[1]. Return zero if they're identical, nonzero
6973 otherwise. */
6975 static int
6976 compare_files (char *cmpfile[])
6978 int ret = 0;
6979 FILE *temp[2] = { NULL, NULL };
6980 int i;
6982 #if HAVE_MMAP_FILE
6984 size_t length[2];
6985 void *map[2] = { NULL, NULL };
6987 for (i = 0; i < 2; i++)
6989 struct stat st;
6991 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
6993 error ("%s: could not determine length of compare-debug file %s",
6994 gcc_input_filename, cmpfile[i]);
6995 ret = 1;
6996 break;
6999 length[i] = st.st_size;
7002 if (!ret && length[0] != length[1])
7004 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
7005 ret = 1;
7008 if (!ret)
7009 for (i = 0; i < 2; i++)
7011 int fd = open (cmpfile[i], O_RDONLY);
7012 if (fd < 0)
7014 error ("%s: could not open compare-debug file %s",
7015 gcc_input_filename, cmpfile[i]);
7016 ret = 1;
7017 break;
7020 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
7021 close (fd);
7023 if (map[i] == (void *) MAP_FAILED)
7025 ret = -1;
7026 break;
7030 if (!ret)
7032 if (memcmp (map[0], map[1], length[0]) != 0)
7034 error ("%s: -fcompare-debug failure", gcc_input_filename);
7035 ret = 1;
7039 for (i = 0; i < 2; i++)
7040 if (map[i])
7041 munmap ((caddr_t) map[i], length[i]);
7043 if (ret >= 0)
7044 return ret;
7046 ret = 0;
7048 #endif
7050 for (i = 0; i < 2; i++)
7052 temp[i] = fopen (cmpfile[i], "r");
7053 if (!temp[i])
7055 error ("%s: could not open compare-debug file %s",
7056 gcc_input_filename, cmpfile[i]);
7057 ret = 1;
7058 break;
7062 if (!ret && temp[0] && temp[1])
7063 for (;;)
7065 int c0, c1;
7066 c0 = fgetc (temp[0]);
7067 c1 = fgetc (temp[1]);
7069 if (c0 != c1)
7071 error ("%s: -fcompare-debug failure",
7072 gcc_input_filename);
7073 ret = 1;
7074 break;
7077 if (c0 == EOF)
7078 break;
7081 for (i = 1; i >= 0; i--)
7083 if (temp[i])
7084 fclose (temp[i]);
7087 return ret;
7090 driver::driver (bool can_finalize, bool debug) :
7091 explicit_link_files (NULL),
7092 decoded_options (NULL)
7094 env.init (can_finalize, debug);
7097 driver::~driver ()
7099 XDELETEVEC (explicit_link_files);
7100 XDELETEVEC (decoded_options);
7103 /* driver::main is implemented as a series of driver:: method calls. */
7106 driver::main (int argc, char **argv)
7108 bool early_exit;
7110 set_progname (argv[0]);
7111 expand_at_files (&argc, &argv);
7112 decode_argv (argc, const_cast <const char **> (argv));
7113 global_initializations ();
7114 build_multilib_strings ();
7115 set_up_specs ();
7116 putenv_COLLECT_GCC (argv[0]);
7117 maybe_putenv_COLLECT_LTO_WRAPPER ();
7118 maybe_putenv_OFFLOAD_TARGETS ();
7119 handle_unrecognized_options ();
7121 if (!maybe_print_and_exit ())
7122 return 0;
7124 early_exit = prepare_infiles ();
7125 if (early_exit)
7126 return get_exit_code ();
7128 do_spec_on_infiles ();
7129 maybe_run_linker (argv[0]);
7130 final_actions ();
7131 return get_exit_code ();
7134 /* Locate the final component of argv[0] after any leading path, and set
7135 the program name accordingly. */
7137 void
7138 driver::set_progname (const char *argv0) const
7140 const char *p = argv0 + strlen (argv0);
7141 while (p != argv0 && !IS_DIR_SEPARATOR (p[-1]))
7142 --p;
7143 progname = p;
7145 xmalloc_set_program_name (progname);
7148 /* Expand any @ files within the command-line args,
7149 setting at_file_supplied if any were expanded. */
7151 void
7152 driver::expand_at_files (int *argc, char ***argv) const
7154 char **old_argv = *argv;
7156 expandargv (argc, argv);
7158 /* Determine if any expansions were made. */
7159 if (*argv != old_argv)
7160 at_file_supplied = true;
7163 /* Decode the command-line arguments from argc/argv into the
7164 decoded_options array. */
7166 void
7167 driver::decode_argv (int argc, const char **argv)
7169 /* Register the language-independent parameters. */
7170 global_init_params ();
7171 finish_params ();
7173 init_options_struct (&global_options, &global_options_set);
7175 decode_cmdline_options_to_array (argc, argv,
7176 CL_DRIVER,
7177 &decoded_options, &decoded_options_count);
7180 /* Perform various initializations and setup. */
7182 void
7183 driver::global_initializations ()
7185 /* Unlock the stdio streams. */
7186 unlock_std_streams ();
7188 gcc_init_libintl ();
7190 diagnostic_initialize (global_dc, 0);
7191 diagnostic_color_init (global_dc);
7193 #ifdef GCC_DRIVER_HOST_INITIALIZATION
7194 /* Perform host dependent initialization when needed. */
7195 GCC_DRIVER_HOST_INITIALIZATION;
7196 #endif
7198 if (atexit (delete_temp_files) != 0)
7199 fatal_error (input_location, "atexit failed");
7201 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
7202 signal (SIGINT, fatal_signal);
7203 #ifdef SIGHUP
7204 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
7205 signal (SIGHUP, fatal_signal);
7206 #endif
7207 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
7208 signal (SIGTERM, fatal_signal);
7209 #ifdef SIGPIPE
7210 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
7211 signal (SIGPIPE, fatal_signal);
7212 #endif
7213 #ifdef SIGCHLD
7214 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
7215 receive the signal. A different setting is inheritable */
7216 signal (SIGCHLD, SIG_DFL);
7217 #endif
7219 /* Parsing and gimplification sometimes need quite large stack.
7220 Increase stack size limits if possible. */
7221 stack_limit_increase (64 * 1024 * 1024);
7223 /* Allocate the argument vector. */
7224 alloc_args ();
7226 obstack_init (&obstack);
7229 /* Build multilib_select, et. al from the separate lines that make up each
7230 multilib selection. */
7232 void
7233 driver::build_multilib_strings () const
7236 const char *p;
7237 const char *const *q = multilib_raw;
7238 int need_space;
7240 obstack_init (&multilib_obstack);
7241 while ((p = *q++) != (char *) 0)
7242 obstack_grow (&multilib_obstack, p, strlen (p));
7244 obstack_1grow (&multilib_obstack, 0);
7245 multilib_select = XOBFINISH (&multilib_obstack, const char *);
7247 q = multilib_matches_raw;
7248 while ((p = *q++) != (char *) 0)
7249 obstack_grow (&multilib_obstack, p, strlen (p));
7251 obstack_1grow (&multilib_obstack, 0);
7252 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
7254 q = multilib_exclusions_raw;
7255 while ((p = *q++) != (char *) 0)
7256 obstack_grow (&multilib_obstack, p, strlen (p));
7258 obstack_1grow (&multilib_obstack, 0);
7259 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
7261 q = multilib_reuse_raw;
7262 while ((p = *q++) != (char *) 0)
7263 obstack_grow (&multilib_obstack, p, strlen (p));
7265 obstack_1grow (&multilib_obstack, 0);
7266 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
7268 need_space = FALSE;
7269 for (size_t i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
7271 if (need_space)
7272 obstack_1grow (&multilib_obstack, ' ');
7273 obstack_grow (&multilib_obstack,
7274 multilib_defaults_raw[i],
7275 strlen (multilib_defaults_raw[i]));
7276 need_space = TRUE;
7279 obstack_1grow (&multilib_obstack, 0);
7280 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
7284 /* Set up the spec-handling machinery. */
7286 void
7287 driver::set_up_specs () const
7289 const char *spec_machine_suffix;
7290 char *specs_file;
7291 size_t i;
7293 #ifdef INIT_ENVIRONMENT
7294 /* Set up any other necessary machine specific environment variables. */
7295 xputenv (INIT_ENVIRONMENT);
7296 #endif
7298 /* Make a table of what switches there are (switches, n_switches).
7299 Make a table of specified input files (infiles, n_infiles).
7300 Decode switches that are handled locally. */
7302 process_command (decoded_options_count, decoded_options);
7304 /* Initialize the vector of specs to just the default.
7305 This means one element containing 0s, as a terminator. */
7307 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
7308 memcpy (compilers, default_compilers, sizeof default_compilers);
7309 n_compilers = n_default_compilers;
7311 /* Read specs from a file if there is one. */
7313 machine_suffix = concat (spec_host_machine, dir_separator_str, spec_version,
7314 accel_dir_suffix, dir_separator_str, NULL);
7315 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
7317 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
7318 /* Read the specs file unless it is a default one. */
7319 if (specs_file != 0 && strcmp (specs_file, "specs"))
7320 read_specs (specs_file, true, false);
7321 else
7322 init_spec ();
7324 #ifdef ACCEL_COMPILER
7325 spec_machine_suffix = machine_suffix;
7326 #else
7327 spec_machine_suffix = just_machine_suffix;
7328 #endif
7330 /* We need to check standard_exec_prefix/spec_machine_suffix/specs
7331 for any override of as, ld and libraries. */
7332 specs_file = (char *) alloca (strlen (standard_exec_prefix)
7333 + strlen (spec_machine_suffix) + sizeof ("specs"));
7334 strcpy (specs_file, standard_exec_prefix);
7335 strcat (specs_file, spec_machine_suffix);
7336 strcat (specs_file, "specs");
7337 if (access (specs_file, R_OK) == 0)
7338 read_specs (specs_file, true, false);
7340 /* Process any configure-time defaults specified for the command line
7341 options, via OPTION_DEFAULT_SPECS. */
7342 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
7343 do_option_spec (option_default_specs[i].name,
7344 option_default_specs[i].spec);
7346 /* Process DRIVER_SELF_SPECS, adding any new options to the end
7347 of the command line. */
7349 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
7350 do_self_spec (driver_self_specs[i]);
7352 /* If not cross-compiling, look for executables in the standard
7353 places. */
7354 if (*cross_compile == '0')
7356 if (*md_exec_prefix)
7358 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
7359 PREFIX_PRIORITY_LAST, 0, 0);
7363 /* Process sysroot_suffix_spec. */
7364 if (*sysroot_suffix_spec != 0
7365 && !no_sysroot_suffix
7366 && do_spec_2 (sysroot_suffix_spec) == 0)
7368 if (argbuf.length () > 1)
7369 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
7370 else if (argbuf.length () == 1)
7371 target_sysroot_suffix = xstrdup (argbuf.last ());
7374 #ifdef HAVE_LD_SYSROOT
7375 /* Pass the --sysroot option to the linker, if it supports that. If
7376 there is a sysroot_suffix_spec, it has already been processed by
7377 this point, so target_system_root really is the system root we
7378 should be using. */
7379 if (target_system_root)
7381 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
7382 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
7383 set_spec ("link", XOBFINISH (&obstack, const char *), false);
7385 #endif
7387 /* Process sysroot_hdrs_suffix_spec. */
7388 if (*sysroot_hdrs_suffix_spec != 0
7389 && !no_sysroot_suffix
7390 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
7392 if (argbuf.length () > 1)
7393 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
7394 else if (argbuf.length () == 1)
7395 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
7398 /* Look for startfiles in the standard places. */
7399 if (*startfile_prefix_spec != 0
7400 && do_spec_2 (startfile_prefix_spec) == 0
7401 && do_spec_1 (" ", 0, NULL) == 0)
7403 const char *arg;
7404 int ndx;
7405 FOR_EACH_VEC_ELT (argbuf, ndx, arg)
7406 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
7407 PREFIX_PRIORITY_LAST, 0, 1);
7409 /* We should eventually get rid of all these and stick to
7410 startfile_prefix_spec exclusively. */
7411 else if (*cross_compile == '0' || target_system_root)
7413 if (*md_startfile_prefix)
7414 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
7415 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7417 if (*md_startfile_prefix_1)
7418 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
7419 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7421 /* If standard_startfile_prefix is relative, base it on
7422 standard_exec_prefix. This lets us move the installed tree
7423 as a unit. If GCC_EXEC_PREFIX is defined, base
7424 standard_startfile_prefix on that as well.
7426 If the prefix is relative, only search it for native compilers;
7427 otherwise we will search a directory containing host libraries. */
7428 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
7429 add_sysrooted_prefix (&startfile_prefixes,
7430 standard_startfile_prefix, "BINUTILS",
7431 PREFIX_PRIORITY_LAST, 0, 1);
7432 else if (*cross_compile == '0')
7434 add_prefix (&startfile_prefixes,
7435 concat (gcc_exec_prefix
7436 ? gcc_exec_prefix : standard_exec_prefix,
7437 machine_suffix,
7438 standard_startfile_prefix, NULL),
7439 NULL, PREFIX_PRIORITY_LAST, 0, 1);
7442 /* Sysrooted prefixes are relocated because target_system_root is
7443 also relocated by gcc_exec_prefix. */
7444 if (*standard_startfile_prefix_1)
7445 add_sysrooted_prefix (&startfile_prefixes,
7446 standard_startfile_prefix_1, "BINUTILS",
7447 PREFIX_PRIORITY_LAST, 0, 1);
7448 if (*standard_startfile_prefix_2)
7449 add_sysrooted_prefix (&startfile_prefixes,
7450 standard_startfile_prefix_2, "BINUTILS",
7451 PREFIX_PRIORITY_LAST, 0, 1);
7454 /* Process any user specified specs in the order given on the command
7455 line. */
7456 for (struct user_specs *uptr = user_specs_head; uptr; uptr = uptr->next)
7458 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
7459 R_OK, true);
7460 read_specs (filename ? filename : uptr->filename, false, true);
7463 /* Process any user self specs. */
7465 struct spec_list *sl;
7466 for (sl = specs; sl; sl = sl->next)
7467 if (sl->name_len == sizeof "self_spec" - 1
7468 && !strcmp (sl->name, "self_spec"))
7469 do_self_spec (*sl->ptr_spec);
7472 if (compare_debug)
7474 enum save_temps save;
7476 if (!compare_debug_second)
7478 n_switches_debug_check[1] = n_switches;
7479 n_switches_alloc_debug_check[1] = n_switches_alloc;
7480 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
7481 n_switches_alloc);
7483 do_self_spec ("%:compare-debug-self-opt()");
7484 n_switches_debug_check[0] = n_switches;
7485 n_switches_alloc_debug_check[0] = n_switches_alloc;
7486 switches_debug_check[0] = switches;
7488 n_switches = n_switches_debug_check[1];
7489 n_switches_alloc = n_switches_alloc_debug_check[1];
7490 switches = switches_debug_check[1];
7493 /* Avoid crash when computing %j in this early. */
7494 save = save_temps_flag;
7495 save_temps_flag = SAVE_TEMPS_NONE;
7497 compare_debug = -compare_debug;
7498 do_self_spec ("%:compare-debug-self-opt()");
7500 save_temps_flag = save;
7502 if (!compare_debug_second)
7504 n_switches_debug_check[1] = n_switches;
7505 n_switches_alloc_debug_check[1] = n_switches_alloc;
7506 switches_debug_check[1] = switches;
7507 compare_debug = -compare_debug;
7508 n_switches = n_switches_debug_check[0];
7509 n_switches_alloc = n_switches_debug_check[0];
7510 switches = switches_debug_check[0];
7515 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
7516 if (gcc_exec_prefix)
7517 gcc_exec_prefix = concat (gcc_exec_prefix, spec_host_machine,
7518 dir_separator_str, spec_version,
7519 accel_dir_suffix, dir_separator_str, NULL);
7521 /* Now we have the specs.
7522 Set the `valid' bits for switches that match anything in any spec. */
7524 validate_all_switches ();
7526 /* Now that we have the switches and the specs, set
7527 the subdirectory based on the options. */
7528 set_multilib_dir ();
7531 /* Set up to remember the pathname of gcc and any options
7532 needed for collect. We use argv[0] instead of progname because
7533 we need the complete pathname. */
7535 void
7536 driver::putenv_COLLECT_GCC (const char *argv0) const
7538 obstack_init (&collect_obstack);
7539 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
7540 obstack_grow (&collect_obstack, argv0, strlen (argv0) + 1);
7541 xputenv (XOBFINISH (&collect_obstack, char *));
7544 /* Set up to remember the pathname of the lto wrapper. */
7546 void
7547 driver::maybe_putenv_COLLECT_LTO_WRAPPER () const
7549 char *lto_wrapper_file;
7551 if (have_c)
7552 lto_wrapper_file = NULL;
7553 else
7554 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
7555 X_OK, false);
7556 if (lto_wrapper_file)
7558 lto_wrapper_file = convert_white_space (lto_wrapper_file);
7559 lto_wrapper_spec = lto_wrapper_file;
7560 obstack_init (&collect_obstack);
7561 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
7562 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
7563 obstack_grow (&collect_obstack, lto_wrapper_spec,
7564 strlen (lto_wrapper_spec) + 1);
7565 xputenv (XOBFINISH (&collect_obstack, char *));
7570 /* Set up to remember the names of offload targets. */
7572 void
7573 driver::maybe_putenv_OFFLOAD_TARGETS () const
7575 const char *targets = offload_targets;
7577 /* If no targets specified by -foffload, use all available targets. */
7578 if (!targets)
7579 targets = OFFLOAD_TARGETS;
7581 if (strlen (targets) > 0)
7583 obstack_grow (&collect_obstack, "OFFLOAD_TARGET_NAMES=",
7584 sizeof ("OFFLOAD_TARGET_NAMES=") - 1);
7585 obstack_grow (&collect_obstack, targets,
7586 strlen (targets) + 1);
7587 xputenv (XOBFINISH (&collect_obstack, char *));
7590 free (offload_targets);
7593 /* Reject switches that no pass was interested in. */
7595 void
7596 driver::handle_unrecognized_options () const
7598 for (size_t i = 0; (int) i < n_switches; i++)
7599 if (! switches[i].validated)
7600 error ("unrecognized command line option %<-%s%>", switches[i].part1);
7603 /* Handle the various -print-* options, returning 0 if the driver
7604 should exit, or nonzero if the driver should continue. */
7607 driver::maybe_print_and_exit () const
7609 if (print_search_dirs)
7611 printf (_("install: %s%s\n"),
7612 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
7613 gcc_exec_prefix ? "" : machine_suffix);
7614 printf (_("programs: %s\n"),
7615 build_search_list (&exec_prefixes, "", false, false));
7616 printf (_("libraries: %s\n"),
7617 build_search_list (&startfile_prefixes, "", false, true));
7618 return (0);
7621 if (print_file_name)
7623 printf ("%s\n", find_file (print_file_name));
7624 return (0);
7627 if (print_prog_name)
7629 if (use_ld != NULL && ! strcmp (print_prog_name, "ld"))
7631 /* Append USE_LD to the default linker. */
7632 #ifdef DEFAULT_LINKER
7633 char *ld;
7634 # ifdef HAVE_HOST_EXECUTABLE_SUFFIX
7635 int len = (sizeof (DEFAULT_LINKER)
7636 - sizeof (HOST_EXECUTABLE_SUFFIX));
7637 ld = NULL;
7638 if (len > 0)
7640 char *default_linker = xstrdup (DEFAULT_LINKER);
7641 /* Strip HOST_EXECUTABLE_SUFFIX if DEFAULT_LINKER contains
7642 HOST_EXECUTABLE_SUFFIX. */
7643 if (! strcmp (&default_linker[len], HOST_EXECUTABLE_SUFFIX))
7645 default_linker[len] = '\0';
7646 ld = concat (default_linker, use_ld,
7647 HOST_EXECUTABLE_SUFFIX, NULL);
7650 if (ld == NULL)
7651 # endif
7652 ld = concat (DEFAULT_LINKER, use_ld, NULL);
7653 if (access (ld, X_OK) == 0)
7655 printf ("%s\n", ld);
7656 return (0);
7658 #endif
7659 print_prog_name = concat (print_prog_name, use_ld, NULL);
7661 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
7662 printf ("%s\n", (newname ? newname : print_prog_name));
7663 return (0);
7666 if (print_multi_lib)
7668 print_multilib_info ();
7669 return (0);
7672 if (print_multi_directory)
7674 if (multilib_dir == NULL)
7675 printf (".\n");
7676 else
7677 printf ("%s\n", multilib_dir);
7678 return (0);
7681 if (print_multiarch)
7683 if (multiarch_dir == NULL)
7684 printf ("\n");
7685 else
7686 printf ("%s\n", multiarch_dir);
7687 return (0);
7690 if (print_sysroot)
7692 if (target_system_root)
7694 if (target_sysroot_suffix)
7695 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
7696 else
7697 printf ("%s\n", target_system_root);
7699 return (0);
7702 if (print_multi_os_directory)
7704 if (multilib_os_dir == NULL)
7705 printf (".\n");
7706 else
7707 printf ("%s\n", multilib_os_dir);
7708 return (0);
7711 if (print_sysroot_headers_suffix)
7713 if (*sysroot_hdrs_suffix_spec)
7715 printf("%s\n", (target_sysroot_hdrs_suffix
7716 ? target_sysroot_hdrs_suffix
7717 : ""));
7718 return (0);
7720 else
7721 /* The error status indicates that only one set of fixed
7722 headers should be built. */
7723 fatal_error (input_location,
7724 "not configured with sysroot headers suffix");
7727 if (print_help_list)
7729 display_help ();
7731 if (! verbose_flag)
7733 printf (_("\nFor bug reporting instructions, please see:\n"));
7734 printf ("%s.\n", bug_report_url);
7736 return (0);
7739 /* We do not exit here. Instead we have created a fake input file
7740 called 'help-dummy' which needs to be compiled, and we pass this
7741 on the various sub-processes, along with the --help switch.
7742 Ensure their output appears after ours. */
7743 fputc ('\n', stdout);
7744 fflush (stdout);
7747 if (print_version)
7749 printf (_("%s %s%s\n"), progname, pkgversion_string,
7750 version_string);
7751 printf ("Copyright %s 2015 Free Software Foundation, Inc.\n",
7752 _("(C)"));
7753 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
7754 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
7755 stdout);
7756 if (! verbose_flag)
7757 return 0;
7759 /* We do not exit here. We use the same mechanism of --help to print
7760 the version of the sub-processes. */
7761 fputc ('\n', stdout);
7762 fflush (stdout);
7765 if (verbose_flag)
7767 print_configuration (stderr);
7768 if (n_infiles == 0)
7769 return (0);
7772 return 1;
7775 /* Figure out what to do with each input file.
7776 Return true if we need to exit early from "main", false otherwise. */
7778 bool
7779 driver::prepare_infiles ()
7781 size_t i;
7782 int lang_n_infiles = 0;
7784 if (n_infiles == added_libraries)
7785 fatal_error (input_location, "no input files");
7787 if (seen_error ())
7788 /* Early exit needed from main. */
7789 return true;
7791 /* Make a place to record the compiler output file names
7792 that correspond to the input files. */
7794 i = n_infiles;
7795 i += lang_specific_extra_outfiles;
7796 outfiles = XCNEWVEC (const char *, i);
7798 /* Record which files were specified explicitly as link input. */
7800 explicit_link_files = XCNEWVEC (char, n_infiles);
7802 combine_inputs = have_o || flag_wpa;
7804 for (i = 0; (int) i < n_infiles; i++)
7806 const char *name = infiles[i].name;
7807 struct compiler *compiler = lookup_compiler (name,
7808 strlen (name),
7809 infiles[i].language);
7811 if (compiler && !(compiler->combinable))
7812 combine_inputs = false;
7814 if (lang_n_infiles > 0 && compiler != input_file_compiler
7815 && infiles[i].language && infiles[i].language[0] != '*')
7816 infiles[i].incompiler = compiler;
7817 else if (compiler)
7819 lang_n_infiles++;
7820 input_file_compiler = compiler;
7821 infiles[i].incompiler = compiler;
7823 else
7825 /* Since there is no compiler for this input file, assume it is a
7826 linker file. */
7827 explicit_link_files[i] = 1;
7828 infiles[i].incompiler = NULL;
7830 infiles[i].compiled = false;
7831 infiles[i].preprocessed = false;
7834 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
7835 fatal_error (input_location,
7836 "cannot specify -o with -c, -S or -E with multiple files");
7838 /* No early exit needed from main; we can continue. */
7839 return false;
7842 /* Run the spec machinery on each input file. */
7844 void
7845 driver::do_spec_on_infiles () const
7847 size_t i;
7849 for (i = 0; (int) i < n_infiles; i++)
7851 int this_file_error = 0;
7853 /* Tell do_spec what to substitute for %i. */
7855 input_file_number = i;
7856 set_input (infiles[i].name);
7858 if (infiles[i].compiled)
7859 continue;
7861 /* Use the same thing in %o, unless cp->spec says otherwise. */
7863 outfiles[i] = gcc_input_filename;
7865 /* Figure out which compiler from the file's suffix. */
7867 input_file_compiler
7868 = lookup_compiler (infiles[i].name, input_filename_length,
7869 infiles[i].language);
7871 if (input_file_compiler)
7873 /* Ok, we found an applicable compiler. Run its spec. */
7875 if (input_file_compiler->spec[0] == '#')
7877 error ("%s: %s compiler not installed on this system",
7878 gcc_input_filename, &input_file_compiler->spec[1]);
7879 this_file_error = 1;
7881 else
7883 int value;
7885 if (compare_debug)
7887 free (debug_check_temp_file[0]);
7888 debug_check_temp_file[0] = NULL;
7890 free (debug_check_temp_file[1]);
7891 debug_check_temp_file[1] = NULL;
7894 value = do_spec (input_file_compiler->spec);
7895 infiles[i].compiled = true;
7896 if (value < 0)
7897 this_file_error = 1;
7898 else if (compare_debug && debug_check_temp_file[0])
7900 if (verbose_flag)
7901 inform (0, "recompiling with -fcompare-debug");
7903 compare_debug = -compare_debug;
7904 n_switches = n_switches_debug_check[1];
7905 n_switches_alloc = n_switches_alloc_debug_check[1];
7906 switches = switches_debug_check[1];
7908 value = do_spec (input_file_compiler->spec);
7910 compare_debug = -compare_debug;
7911 n_switches = n_switches_debug_check[0];
7912 n_switches_alloc = n_switches_alloc_debug_check[0];
7913 switches = switches_debug_check[0];
7915 if (value < 0)
7917 error ("during -fcompare-debug recompilation");
7918 this_file_error = 1;
7921 gcc_assert (debug_check_temp_file[1]
7922 && filename_cmp (debug_check_temp_file[0],
7923 debug_check_temp_file[1]));
7925 if (verbose_flag)
7926 inform (0, "comparing final insns dumps");
7928 if (compare_files (debug_check_temp_file))
7929 this_file_error = 1;
7932 if (compare_debug)
7934 free (debug_check_temp_file[0]);
7935 debug_check_temp_file[0] = NULL;
7937 free (debug_check_temp_file[1]);
7938 debug_check_temp_file[1] = NULL;
7943 /* If this file's name does not contain a recognized suffix,
7944 record it as explicit linker input. */
7946 else
7947 explicit_link_files[i] = 1;
7949 /* Clear the delete-on-failure queue, deleting the files in it
7950 if this compilation failed. */
7952 if (this_file_error)
7954 delete_failure_queue ();
7955 errorcount++;
7957 /* If this compilation succeeded, don't delete those files later. */
7958 clear_failure_queue ();
7961 /* Reset the input file name to the first compile/object file name, for use
7962 with %b in LINK_SPEC. We use the first input file that we can find
7963 a compiler to compile it instead of using infiles.language since for
7964 languages other than C we use aliases that we then lookup later. */
7965 if (n_infiles > 0)
7967 int i;
7969 for (i = 0; i < n_infiles ; i++)
7970 if (infiles[i].incompiler
7971 || (infiles[i].language && infiles[i].language[0] != '*'))
7973 set_input (infiles[i].name);
7974 break;
7978 if (!seen_error ())
7980 /* Make sure INPUT_FILE_NUMBER points to first available open
7981 slot. */
7982 input_file_number = n_infiles;
7983 if (lang_specific_pre_link ())
7984 errorcount++;
7988 /* If we have to run the linker, do it now. */
7990 void
7991 driver::maybe_run_linker (const char *argv0) const
7993 size_t i;
7994 int linker_was_run = 0;
7995 int num_linker_inputs;
7997 /* Determine if there are any linker input files. */
7998 num_linker_inputs = 0;
7999 for (i = 0; (int) i < n_infiles; i++)
8000 if (explicit_link_files[i] || outfiles[i] != NULL)
8001 num_linker_inputs++;
8003 /* Run ld to link all the compiler output files. */
8005 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
8007 int tmp = execution_count;
8009 if (! have_c)
8011 #if HAVE_LTO_PLUGIN > 0
8012 #if HAVE_LTO_PLUGIN == 2
8013 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
8014 #else
8015 const char *fuse_linker_plugin = "fuse-linker-plugin";
8016 #endif
8017 #endif
8019 /* We'll use ld if we can't find collect2. */
8020 if (! strcmp (linker_name_spec, "collect2"))
8022 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
8023 if (s == NULL)
8024 linker_name_spec = "ld";
8027 #if HAVE_LTO_PLUGIN > 0
8028 #if HAVE_LTO_PLUGIN == 2
8029 if (!switch_matches (fno_use_linker_plugin,
8030 fno_use_linker_plugin
8031 + strlen (fno_use_linker_plugin), 0))
8032 #else
8033 if (switch_matches (fuse_linker_plugin,
8034 fuse_linker_plugin
8035 + strlen (fuse_linker_plugin), 0))
8036 #endif
8038 char *temp_spec = find_a_file (&exec_prefixes,
8039 LTOPLUGINSONAME, R_OK,
8040 false);
8041 if (!temp_spec)
8042 fatal_error (input_location,
8043 "-fuse-linker-plugin, but %s not found",
8044 LTOPLUGINSONAME);
8045 linker_plugin_file_spec = convert_white_space (temp_spec);
8047 #endif
8048 lto_gcc_spec = argv0;
8051 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
8052 for collect. */
8053 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
8054 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
8056 if (print_subprocess_help == 1)
8058 printf (_("\nLinker options\n==============\n\n"));
8059 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
8060 " to the linker.\n\n"));
8061 fflush (stdout);
8063 int value = do_spec (link_command_spec);
8064 if (value < 0)
8065 errorcount = 1;
8066 linker_was_run = (tmp != execution_count);
8069 /* If options said don't run linker,
8070 complain about input files to be given to the linker. */
8072 if (! linker_was_run && !seen_error ())
8073 for (i = 0; (int) i < n_infiles; i++)
8074 if (explicit_link_files[i]
8075 && !(infiles[i].language && infiles[i].language[0] == '*'))
8076 warning (0, "%s: linker input file unused because linking not done",
8077 outfiles[i]);
8080 /* The end of "main". */
8082 void
8083 driver::final_actions () const
8085 /* Delete some or all of the temporary files we made. */
8087 if (seen_error ())
8088 delete_failure_queue ();
8089 delete_temp_files ();
8091 if (print_help_list)
8093 printf (("\nFor bug reporting instructions, please see:\n"));
8094 printf ("%s\n", bug_report_url);
8098 /* Determine what the exit code of the driver should be. */
8101 driver::get_exit_code () const
8103 return (signal_count != 0 ? 2
8104 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
8105 : 0);
8108 /* Find the proper compilation spec for the file name NAME,
8109 whose length is LENGTH. LANGUAGE is the specified language,
8110 or 0 if this file is to be passed to the linker. */
8112 static struct compiler *
8113 lookup_compiler (const char *name, size_t length, const char *language)
8115 struct compiler *cp;
8117 /* If this was specified by the user to be a linker input, indicate that. */
8118 if (language != 0 && language[0] == '*')
8119 return 0;
8121 /* Otherwise, look for the language, if one is spec'd. */
8122 if (language != 0)
8124 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8125 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
8126 return cp;
8128 error ("language %s not recognized", language);
8129 return 0;
8132 /* Look for a suffix. */
8133 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8135 if (/* The suffix `-' matches only the file name `-'. */
8136 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
8137 || (strlen (cp->suffix) < length
8138 /* See if the suffix matches the end of NAME. */
8139 && !strcmp (cp->suffix,
8140 name + length - strlen (cp->suffix))
8142 break;
8145 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
8146 /* Look again, but case-insensitively this time. */
8147 if (cp < compilers)
8148 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8150 if (/* The suffix `-' matches only the file name `-'. */
8151 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
8152 || (strlen (cp->suffix) < length
8153 /* See if the suffix matches the end of NAME. */
8154 && ((!strcmp (cp->suffix,
8155 name + length - strlen (cp->suffix))
8156 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
8157 && !strcasecmp (cp->suffix,
8158 name + length - strlen (cp->suffix)))
8160 break;
8162 #endif
8164 if (cp >= compilers)
8166 if (cp->spec[0] != '@')
8167 /* A non-alias entry: return it. */
8168 return cp;
8170 /* An alias entry maps a suffix to a language.
8171 Search for the language; pass 0 for NAME and LENGTH
8172 to avoid infinite recursion if language not found. */
8173 return lookup_compiler (NULL, 0, cp->spec + 1);
8175 return 0;
8178 static char *
8179 save_string (const char *s, int len)
8181 char *result = XNEWVEC (char, len + 1);
8183 memcpy (result, s, len);
8184 result[len] = 0;
8185 return result;
8188 void
8189 pfatal_with_name (const char *name)
8191 perror_with_name (name);
8192 delete_temp_files ();
8193 exit (1);
8196 static void
8197 perror_with_name (const char *name)
8199 error ("%s: %m", name);
8202 static inline void
8203 validate_switches_from_spec (const char *spec, bool user)
8205 const char *p = spec;
8206 char c;
8207 while ((c = *p++))
8208 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
8209 /* We have a switch spec. */
8210 p = validate_switches (p + 1, user);
8213 static void
8214 validate_all_switches (void)
8216 struct compiler *comp;
8217 struct spec_list *spec;
8219 for (comp = compilers; comp->spec; comp++)
8220 validate_switches_from_spec (comp->spec, false);
8222 /* Look through the linked list of specs read from the specs file. */
8223 for (spec = specs; spec; spec = spec->next)
8224 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
8226 validate_switches_from_spec (link_command_spec, false);
8229 /* Look at the switch-name that comes after START
8230 and mark as valid all supplied switches that match it. */
8232 static const char *
8233 validate_switches (const char *start, bool user_spec)
8235 const char *p = start;
8236 const char *atom;
8237 size_t len;
8238 int i;
8239 bool suffix = false;
8240 bool starred = false;
8242 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
8244 next_member:
8245 SKIP_WHITE ();
8247 if (*p == '!')
8248 p++;
8250 SKIP_WHITE ();
8251 if (*p == '.' || *p == ',')
8252 suffix = true, p++;
8254 atom = p;
8255 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
8256 || *p == ',' || *p == '.' || *p == '@')
8257 p++;
8258 len = p - atom;
8260 if (*p == '*')
8261 starred = true, p++;
8263 SKIP_WHITE ();
8265 if (!suffix)
8267 /* Mark all matching switches as valid. */
8268 for (i = 0; i < n_switches; i++)
8269 if (!strncmp (switches[i].part1, atom, len)
8270 && (starred || switches[i].part1[len] == '\0')
8271 && (switches[i].known || user_spec))
8272 switches[i].validated = true;
8275 if (*p) p++;
8276 if (*p && (p[-1] == '|' || p[-1] == '&'))
8277 goto next_member;
8279 if (*p && p[-1] == ':')
8281 while (*p && *p != ';' && *p != '}')
8283 if (*p == '%')
8285 p++;
8286 if (*p == '{' || *p == '<')
8287 p = validate_switches (p+1, user_spec);
8288 else if (p[0] == 'W' && p[1] == '{')
8289 p = validate_switches (p+2, user_spec);
8291 else
8292 p++;
8295 if (*p) p++;
8296 if (*p && p[-1] == ';')
8297 goto next_member;
8300 return p;
8301 #undef SKIP_WHITE
8304 struct mdswitchstr
8306 const char *str;
8307 int len;
8310 static struct mdswitchstr *mdswitches;
8311 static int n_mdswitches;
8313 /* Check whether a particular argument was used. The first time we
8314 canonicalize the switches to keep only the ones we care about. */
8316 class used_arg_t
8318 public:
8319 int operator () (const char *p, int len);
8320 void finalize ();
8322 private:
8323 struct mswitchstr
8325 const char *str;
8326 const char *replace;
8327 int len;
8328 int rep_len;
8331 mswitchstr *mswitches;
8332 int n_mswitches;
8336 used_arg_t used_arg;
8339 used_arg_t::operator () (const char *p, int len)
8341 int i, j;
8343 if (!mswitches)
8345 struct mswitchstr *matches;
8346 const char *q;
8347 int cnt = 0;
8349 /* Break multilib_matches into the component strings of string
8350 and replacement string. */
8351 for (q = multilib_matches; *q != '\0'; q++)
8352 if (*q == ';')
8353 cnt++;
8355 matches
8356 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
8357 i = 0;
8358 q = multilib_matches;
8359 while (*q != '\0')
8361 matches[i].str = q;
8362 while (*q != ' ')
8364 if (*q == '\0')
8366 invalid_matches:
8367 fatal_error (input_location, "multilib spec %qs is invalid",
8368 multilib_matches);
8370 q++;
8372 matches[i].len = q - matches[i].str;
8374 matches[i].replace = ++q;
8375 while (*q != ';' && *q != '\0')
8377 if (*q == ' ')
8378 goto invalid_matches;
8379 q++;
8381 matches[i].rep_len = q - matches[i].replace;
8382 i++;
8383 if (*q == ';')
8384 q++;
8387 /* Now build a list of the replacement string for switches that we care
8388 about. Make sure we allocate at least one entry. This prevents
8389 xmalloc from calling fatal, and prevents us from re-executing this
8390 block of code. */
8391 mswitches
8392 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
8393 for (i = 0; i < n_switches; i++)
8394 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
8396 int xlen = strlen (switches[i].part1);
8397 for (j = 0; j < cnt; j++)
8398 if (xlen == matches[j].len
8399 && ! strncmp (switches[i].part1, matches[j].str, xlen))
8401 mswitches[n_mswitches].str = matches[j].replace;
8402 mswitches[n_mswitches].len = matches[j].rep_len;
8403 mswitches[n_mswitches].replace = (char *) 0;
8404 mswitches[n_mswitches].rep_len = 0;
8405 n_mswitches++;
8406 break;
8410 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
8411 on the command line nor any options mutually incompatible with
8412 them. */
8413 for (i = 0; i < n_mdswitches; i++)
8415 const char *r;
8417 for (q = multilib_options; *q != '\0'; *q && q++)
8419 while (*q == ' ')
8420 q++;
8422 r = q;
8423 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
8424 || strchr (" /", q[mdswitches[i].len]) == NULL)
8426 while (*q != ' ' && *q != '/' && *q != '\0')
8427 q++;
8428 if (*q != '/')
8429 break;
8430 q++;
8433 if (*q != ' ' && *q != '\0')
8435 while (*r != ' ' && *r != '\0')
8437 q = r;
8438 while (*q != ' ' && *q != '/' && *q != '\0')
8439 q++;
8441 if (used_arg (r, q - r))
8442 break;
8444 if (*q != '/')
8446 mswitches[n_mswitches].str = mdswitches[i].str;
8447 mswitches[n_mswitches].len = mdswitches[i].len;
8448 mswitches[n_mswitches].replace = (char *) 0;
8449 mswitches[n_mswitches].rep_len = 0;
8450 n_mswitches++;
8451 break;
8454 r = q + 1;
8456 break;
8462 for (i = 0; i < n_mswitches; i++)
8463 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
8464 return 1;
8466 return 0;
8469 void used_arg_t::finalize ()
8471 XDELETEVEC (mswitches);
8472 mswitches = NULL;
8473 n_mswitches = 0;
8477 static int
8478 default_arg (const char *p, int len)
8480 int i;
8482 for (i = 0; i < n_mdswitches; i++)
8483 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
8484 return 1;
8486 return 0;
8489 /* Work out the subdirectory to use based on the options. The format of
8490 multilib_select is a list of elements. Each element is a subdirectory
8491 name followed by a list of options followed by a semicolon. The format
8492 of multilib_exclusions is the same, but without the preceding
8493 directory. First gcc will check the exclusions, if none of the options
8494 beginning with an exclamation point are present, and all of the other
8495 options are present, then we will ignore this completely. Passing
8496 that, gcc will consider each multilib_select in turn using the same
8497 rules for matching the options. If a match is found, that subdirectory
8498 will be used.
8499 A subdirectory name is optionally followed by a colon and the corresponding
8500 multiarch name. */
8502 static void
8503 set_multilib_dir (void)
8505 const char *p;
8506 unsigned int this_path_len;
8507 const char *this_path, *this_arg;
8508 const char *start, *end;
8509 int not_arg;
8510 int ok, ndfltok, first;
8512 n_mdswitches = 0;
8513 start = multilib_defaults;
8514 while (*start == ' ' || *start == '\t')
8515 start++;
8516 while (*start != '\0')
8518 n_mdswitches++;
8519 while (*start != ' ' && *start != '\t' && *start != '\0')
8520 start++;
8521 while (*start == ' ' || *start == '\t')
8522 start++;
8525 if (n_mdswitches)
8527 int i = 0;
8529 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
8530 for (start = multilib_defaults; *start != '\0'; start = end + 1)
8532 while (*start == ' ' || *start == '\t')
8533 start++;
8535 if (*start == '\0')
8536 break;
8538 for (end = start + 1;
8539 *end != ' ' && *end != '\t' && *end != '\0'; end++)
8542 obstack_grow (&multilib_obstack, start, end - start);
8543 obstack_1grow (&multilib_obstack, 0);
8544 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
8545 mdswitches[i++].len = end - start;
8547 if (*end == '\0')
8548 break;
8552 p = multilib_exclusions;
8553 while (*p != '\0')
8555 /* Ignore newlines. */
8556 if (*p == '\n')
8558 ++p;
8559 continue;
8562 /* Check the arguments. */
8563 ok = 1;
8564 while (*p != ';')
8566 if (*p == '\0')
8568 invalid_exclusions:
8569 fatal_error (input_location, "multilib exclusions %qs is invalid",
8570 multilib_exclusions);
8573 if (! ok)
8575 ++p;
8576 continue;
8579 this_arg = p;
8580 while (*p != ' ' && *p != ';')
8582 if (*p == '\0')
8583 goto invalid_exclusions;
8584 ++p;
8587 if (*this_arg != '!')
8588 not_arg = 0;
8589 else
8591 not_arg = 1;
8592 ++this_arg;
8595 ok = used_arg (this_arg, p - this_arg);
8596 if (not_arg)
8597 ok = ! ok;
8599 if (*p == ' ')
8600 ++p;
8603 if (ok)
8604 return;
8606 ++p;
8609 first = 1;
8610 p = multilib_select;
8612 /* Append multilib reuse rules if any. With those rules, we can reuse
8613 one multilib for certain different options sets. */
8614 if (strlen (multilib_reuse) > 0)
8615 p = concat (p, multilib_reuse, NULL);
8617 while (*p != '\0')
8619 /* Ignore newlines. */
8620 if (*p == '\n')
8622 ++p;
8623 continue;
8626 /* Get the initial path. */
8627 this_path = p;
8628 while (*p != ' ')
8630 if (*p == '\0')
8632 invalid_select:
8633 fatal_error (input_location, "multilib select %qs %qs is invalid",
8634 multilib_select, multilib_reuse);
8636 ++p;
8638 this_path_len = p - this_path;
8640 /* Check the arguments. */
8641 ok = 1;
8642 ndfltok = 1;
8643 ++p;
8644 while (*p != ';')
8646 if (*p == '\0')
8647 goto invalid_select;
8649 if (! ok)
8651 ++p;
8652 continue;
8655 this_arg = p;
8656 while (*p != ' ' && *p != ';')
8658 if (*p == '\0')
8659 goto invalid_select;
8660 ++p;
8663 if (*this_arg != '!')
8664 not_arg = 0;
8665 else
8667 not_arg = 1;
8668 ++this_arg;
8671 /* If this is a default argument, we can just ignore it.
8672 This is true even if this_arg begins with '!'. Beginning
8673 with '!' does not mean that this argument is necessarily
8674 inappropriate for this library: it merely means that
8675 there is a more specific library which uses this
8676 argument. If this argument is a default, we need not
8677 consider that more specific library. */
8678 ok = used_arg (this_arg, p - this_arg);
8679 if (not_arg)
8680 ok = ! ok;
8682 if (! ok)
8683 ndfltok = 0;
8685 if (default_arg (this_arg, p - this_arg))
8686 ok = 1;
8688 if (*p == ' ')
8689 ++p;
8692 if (ok && first)
8694 if (this_path_len != 1
8695 || this_path[0] != '.')
8697 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
8698 char *q;
8700 strncpy (new_multilib_dir, this_path, this_path_len);
8701 new_multilib_dir[this_path_len] = '\0';
8702 q = strchr (new_multilib_dir, ':');
8703 if (q != NULL)
8704 *q = '\0';
8705 multilib_dir = new_multilib_dir;
8707 first = 0;
8710 if (ndfltok)
8712 const char *q = this_path, *end = this_path + this_path_len;
8714 while (q < end && *q != ':')
8715 q++;
8716 if (q < end)
8718 const char *q2 = q + 1, *ml_end = end;
8719 char *new_multilib_os_dir;
8721 while (q2 < end && *q2 != ':')
8722 q2++;
8723 if (*q2 == ':')
8724 ml_end = q2;
8725 if (ml_end - q == 1)
8726 multilib_os_dir = xstrdup (".");
8727 else
8729 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
8730 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
8731 new_multilib_os_dir[ml_end - q - 1] = '\0';
8732 multilib_os_dir = new_multilib_os_dir;
8735 if (q2 < end && *q2 == ':')
8737 char *new_multiarch_dir = XNEWVEC (char, end - q2);
8738 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
8739 new_multiarch_dir[end - q2 - 1] = '\0';
8740 multiarch_dir = new_multiarch_dir;
8742 break;
8746 ++p;
8749 if (multilib_dir == NULL && multilib_os_dir != NULL
8750 && strcmp (multilib_os_dir, ".") == 0)
8752 free (CONST_CAST (char *, multilib_os_dir));
8753 multilib_os_dir = NULL;
8755 else if (multilib_dir != NULL && multilib_os_dir == NULL)
8756 multilib_os_dir = multilib_dir;
8759 /* Print out the multiple library subdirectory selection
8760 information. This prints out a series of lines. Each line looks
8761 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
8762 required. Only the desired options are printed out, the negative
8763 matches. The options are print without a leading dash. There are
8764 no spaces to make it easy to use the information in the shell.
8765 Each subdirectory is printed only once. This assumes the ordering
8766 generated by the genmultilib script. Also, we leave out ones that match
8767 the exclusions. */
8769 static void
8770 print_multilib_info (void)
8772 const char *p = multilib_select;
8773 const char *last_path = 0, *this_path;
8774 int skip;
8775 unsigned int last_path_len = 0;
8777 while (*p != '\0')
8779 skip = 0;
8780 /* Ignore newlines. */
8781 if (*p == '\n')
8783 ++p;
8784 continue;
8787 /* Get the initial path. */
8788 this_path = p;
8789 while (*p != ' ')
8791 if (*p == '\0')
8793 invalid_select:
8794 fatal_error (input_location,
8795 "multilib select %qs is invalid", multilib_select);
8798 ++p;
8801 /* When --disable-multilib was used but target defines
8802 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
8803 with .:: for multiarch configurations) are there just to find
8804 multilib_os_dir, so skip them from output. */
8805 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
8806 skip = 1;
8808 /* Check for matches with the multilib_exclusions. We don't bother
8809 with the '!' in either list. If any of the exclusion rules match
8810 all of its options with the select rule, we skip it. */
8812 const char *e = multilib_exclusions;
8813 const char *this_arg;
8815 while (*e != '\0')
8817 int m = 1;
8818 /* Ignore newlines. */
8819 if (*e == '\n')
8821 ++e;
8822 continue;
8825 /* Check the arguments. */
8826 while (*e != ';')
8828 const char *q;
8829 int mp = 0;
8831 if (*e == '\0')
8833 invalid_exclusion:
8834 fatal_error (input_location,
8835 "multilib exclusion %qs is invalid",
8836 multilib_exclusions);
8839 if (! m)
8841 ++e;
8842 continue;
8845 this_arg = e;
8847 while (*e != ' ' && *e != ';')
8849 if (*e == '\0')
8850 goto invalid_exclusion;
8851 ++e;
8854 q = p + 1;
8855 while (*q != ';')
8857 const char *arg;
8858 int len = e - this_arg;
8860 if (*q == '\0')
8861 goto invalid_select;
8863 arg = q;
8865 while (*q != ' ' && *q != ';')
8867 if (*q == '\0')
8868 goto invalid_select;
8869 ++q;
8872 if (! strncmp (arg, this_arg,
8873 (len < q - arg) ? q - arg : len)
8874 || default_arg (this_arg, e - this_arg))
8876 mp = 1;
8877 break;
8880 if (*q == ' ')
8881 ++q;
8884 if (! mp)
8885 m = 0;
8887 if (*e == ' ')
8888 ++e;
8891 if (m)
8893 skip = 1;
8894 break;
8897 if (*e != '\0')
8898 ++e;
8902 if (! skip)
8904 /* If this is a duplicate, skip it. */
8905 skip = (last_path != 0
8906 && (unsigned int) (p - this_path) == last_path_len
8907 && ! filename_ncmp (last_path, this_path, last_path_len));
8909 last_path = this_path;
8910 last_path_len = p - this_path;
8913 /* If this directory requires any default arguments, we can skip
8914 it. We will already have printed a directory identical to
8915 this one which does not require that default argument. */
8916 if (! skip)
8918 const char *q;
8920 q = p + 1;
8921 while (*q != ';')
8923 const char *arg;
8925 if (*q == '\0')
8926 goto invalid_select;
8928 if (*q == '!')
8929 arg = NULL;
8930 else
8931 arg = q;
8933 while (*q != ' ' && *q != ';')
8935 if (*q == '\0')
8936 goto invalid_select;
8937 ++q;
8940 if (arg != NULL
8941 && default_arg (arg, q - arg))
8943 skip = 1;
8944 break;
8947 if (*q == ' ')
8948 ++q;
8952 if (! skip)
8954 const char *p1;
8956 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
8957 putchar (*p1);
8958 putchar (';');
8961 ++p;
8962 while (*p != ';')
8964 int use_arg;
8966 if (*p == '\0')
8967 goto invalid_select;
8969 if (skip)
8971 ++p;
8972 continue;
8975 use_arg = *p != '!';
8977 if (use_arg)
8978 putchar ('@');
8980 while (*p != ' ' && *p != ';')
8982 if (*p == '\0')
8983 goto invalid_select;
8984 if (use_arg)
8985 putchar (*p);
8986 ++p;
8989 if (*p == ' ')
8990 ++p;
8993 if (! skip)
8995 /* If there are extra options, print them now. */
8996 if (multilib_extra && *multilib_extra)
8998 int print_at = TRUE;
8999 const char *q;
9001 for (q = multilib_extra; *q != '\0'; q++)
9003 if (*q == ' ')
9004 print_at = TRUE;
9005 else
9007 if (print_at)
9008 putchar ('@');
9009 putchar (*q);
9010 print_at = FALSE;
9015 putchar ('\n');
9018 ++p;
9022 /* getenv built-in spec function.
9024 Returns the value of the environment variable given by its first
9025 argument, concatenated with the second argument. If the
9026 environment variable is not defined, a fatal error is issued. */
9028 static const char *
9029 getenv_spec_function (int argc, const char **argv)
9031 const char *value;
9032 char *result;
9033 char *ptr;
9034 size_t len;
9036 if (argc != 2)
9037 return NULL;
9039 value = env.get (argv[0]);
9040 if (!value)
9041 fatal_error (input_location,
9042 "environment variable %qs not defined", argv[0]);
9044 /* We have to escape every character of the environment variable so
9045 they are not interpreted as active spec characters. A
9046 particularly painful case is when we are reading a variable
9047 holding a windows path complete with \ separators. */
9048 len = strlen (value) * 2 + strlen (argv[1]) + 1;
9049 result = XNEWVAR (char, len);
9050 for (ptr = result; *value; ptr += 2)
9052 ptr[0] = '\\';
9053 ptr[1] = *value++;
9056 strcpy (ptr, argv[1]);
9058 return result;
9061 /* if-exists built-in spec function.
9063 Checks to see if the file specified by the absolute pathname in
9064 ARGS exists. Returns that pathname if found.
9066 The usual use for this function is to check for a library file
9067 (whose name has been expanded with %s). */
9069 static const char *
9070 if_exists_spec_function (int argc, const char **argv)
9072 /* Must have only one argument. */
9073 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
9074 return argv[0];
9076 return NULL;
9079 /* if-exists-else built-in spec function.
9081 This is like if-exists, but takes an additional argument which
9082 is returned if the first argument does not exist. */
9084 static const char *
9085 if_exists_else_spec_function (int argc, const char **argv)
9087 /* Must have exactly two arguments. */
9088 if (argc != 2)
9089 return NULL;
9091 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
9092 return argv[0];
9094 return argv[1];
9097 /* sanitize built-in spec function.
9099 This returns non-NULL, if sanitizing address, thread or
9100 any of the undefined behavior sanitizers. */
9102 static const char *
9103 sanitize_spec_function (int argc, const char **argv)
9105 if (argc != 1)
9106 return NULL;
9108 if (strcmp (argv[0], "address") == 0)
9109 return (flag_sanitize & SANITIZE_USER_ADDRESS) ? "" : NULL;
9110 if (strcmp (argv[0], "kernel-address") == 0)
9111 return (flag_sanitize & SANITIZE_KERNEL_ADDRESS) ? "" : NULL;
9112 if (strcmp (argv[0], "thread") == 0)
9113 return (flag_sanitize & SANITIZE_THREAD) ? "" : NULL;
9114 if (strcmp (argv[0], "undefined") == 0)
9115 return ((flag_sanitize & (SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT))
9116 && !flag_sanitize_undefined_trap_on_error) ? "" : NULL;
9117 if (strcmp (argv[0], "leak") == 0)
9118 return ((flag_sanitize
9119 & (SANITIZE_ADDRESS | SANITIZE_LEAK | SANITIZE_THREAD))
9120 == SANITIZE_LEAK) ? "" : NULL;
9121 return NULL;
9124 /* replace-outfile built-in spec function.
9126 This looks for the first argument in the outfiles array's name and
9127 replaces it with the second argument. */
9129 static const char *
9130 replace_outfile_spec_function (int argc, const char **argv)
9132 int i;
9133 /* Must have exactly two arguments. */
9134 if (argc != 2)
9135 abort ();
9137 for (i = 0; i < n_infiles; i++)
9139 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
9140 outfiles[i] = xstrdup (argv[1]);
9142 return NULL;
9145 /* remove-outfile built-in spec function.
9147 * This looks for the first argument in the outfiles array's name and
9148 * removes it. */
9150 static const char *
9151 remove_outfile_spec_function (int argc, const char **argv)
9153 int i;
9154 /* Must have exactly one argument. */
9155 if (argc != 1)
9156 abort ();
9158 for (i = 0; i < n_infiles; i++)
9160 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
9161 outfiles[i] = NULL;
9163 return NULL;
9166 /* Given two version numbers, compares the two numbers.
9167 A version number must match the regular expression
9168 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
9170 static int
9171 compare_version_strings (const char *v1, const char *v2)
9173 int rresult;
9174 regex_t r;
9176 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
9177 REG_EXTENDED | REG_NOSUB) != 0)
9178 abort ();
9179 rresult = regexec (&r, v1, 0, NULL, 0);
9180 if (rresult == REG_NOMATCH)
9181 fatal_error (input_location, "invalid version number %qs", v1);
9182 else if (rresult != 0)
9183 abort ();
9184 rresult = regexec (&r, v2, 0, NULL, 0);
9185 if (rresult == REG_NOMATCH)
9186 fatal_error (input_location, "invalid version number %qs", v2);
9187 else if (rresult != 0)
9188 abort ();
9190 return strverscmp (v1, v2);
9194 /* version_compare built-in spec function.
9196 This takes an argument of the following form:
9198 <comparison-op> <arg1> [<arg2>] <switch> <result>
9200 and produces "result" if the comparison evaluates to true,
9201 and nothing if it doesn't.
9203 The supported <comparison-op> values are:
9205 >= true if switch is a later (or same) version than arg1
9206 !> opposite of >=
9207 < true if switch is an earlier version than arg1
9208 !< opposite of <
9209 >< true if switch is arg1 or later, and earlier than arg2
9210 <> true if switch is earlier than arg1 or is arg2 or later
9212 If the switch is not present, the condition is false unless
9213 the first character of the <comparison-op> is '!'.
9215 For example,
9216 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
9217 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
9219 static const char *
9220 version_compare_spec_function (int argc, const char **argv)
9222 int comp1, comp2;
9223 size_t switch_len;
9224 const char *switch_value = NULL;
9225 int nargs = 1, i;
9226 bool result;
9228 if (argc < 3)
9229 fatal_error (input_location, "too few arguments to %%:version-compare");
9230 if (argv[0][0] == '\0')
9231 abort ();
9232 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
9233 nargs = 2;
9234 if (argc != nargs + 3)
9235 fatal_error (input_location, "too many arguments to %%:version-compare");
9237 switch_len = strlen (argv[nargs + 1]);
9238 for (i = 0; i < n_switches; i++)
9239 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
9240 && check_live_switch (i, switch_len))
9241 switch_value = switches[i].part1 + switch_len;
9243 if (switch_value == NULL)
9244 comp1 = comp2 = -1;
9245 else
9247 comp1 = compare_version_strings (switch_value, argv[1]);
9248 if (nargs == 2)
9249 comp2 = compare_version_strings (switch_value, argv[2]);
9250 else
9251 comp2 = -1; /* This value unused. */
9254 switch (argv[0][0] << 8 | argv[0][1])
9256 case '>' << 8 | '=':
9257 result = comp1 >= 0;
9258 break;
9259 case '!' << 8 | '<':
9260 result = comp1 >= 0 || switch_value == NULL;
9261 break;
9262 case '<' << 8:
9263 result = comp1 < 0;
9264 break;
9265 case '!' << 8 | '>':
9266 result = comp1 < 0 || switch_value == NULL;
9267 break;
9268 case '>' << 8 | '<':
9269 result = comp1 >= 0 && comp2 < 0;
9270 break;
9271 case '<' << 8 | '>':
9272 result = comp1 < 0 || comp2 >= 0;
9273 break;
9275 default:
9276 fatal_error (input_location,
9277 "unknown operator %qs in %%:version-compare", argv[0]);
9279 if (! result)
9280 return NULL;
9282 return argv[nargs + 2];
9285 /* %:include builtin spec function. This differs from %include in that it
9286 can be nested inside a spec, and thus be conditionalized. It takes
9287 one argument, the filename, and looks for it in the startfile path.
9288 The result is always NULL, i.e. an empty expansion. */
9290 static const char *
9291 include_spec_function (int argc, const char **argv)
9293 char *file;
9295 if (argc != 1)
9296 abort ();
9298 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
9299 read_specs (file ? file : argv[0], false, false);
9301 return NULL;
9304 /* %:find-file spec function. This function replaces its argument by
9305 the file found through find_file, that is the -print-file-name gcc
9306 program option. */
9307 static const char *
9308 find_file_spec_function (int argc, const char **argv)
9310 const char *file;
9312 if (argc != 1)
9313 abort ();
9315 file = find_file (argv[0]);
9316 return file;
9320 /* %:find-plugindir spec function. This function replaces its argument
9321 by the -iplugindir=<dir> option. `dir' is found through find_file, that
9322 is the -print-file-name gcc program option. */
9323 static const char *
9324 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
9326 const char *option;
9328 if (argc != 0)
9329 abort ();
9331 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
9332 return option;
9336 /* %:print-asm-header spec function. Print a banner to say that the
9337 following output is from the assembler. */
9339 static const char *
9340 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
9341 const char **argv ATTRIBUTE_UNUSED)
9343 printf (_("Assembler options\n=================\n\n"));
9344 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
9345 fflush (stdout);
9346 return NULL;
9349 /* Get a random number for -frandom-seed */
9351 static unsigned HOST_WIDE_INT
9352 get_random_number (void)
9354 unsigned HOST_WIDE_INT ret = 0;
9355 int fd;
9357 fd = open ("/dev/urandom", O_RDONLY);
9358 if (fd >= 0)
9360 read (fd, &ret, sizeof (HOST_WIDE_INT));
9361 close (fd);
9362 if (ret)
9363 return ret;
9366 /* Get some more or less random data. */
9367 #ifdef HAVE_GETTIMEOFDAY
9369 struct timeval tv;
9371 gettimeofday (&tv, NULL);
9372 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
9374 #else
9376 time_t now = time (NULL);
9378 if (now != (time_t)-1)
9379 ret = (unsigned) now;
9381 #endif
9383 return ret ^ getpid ();
9386 /* %:compare-debug-dump-opt spec function. Save the last argument,
9387 expected to be the last -fdump-final-insns option, or generate a
9388 temporary. */
9390 static const char *
9391 compare_debug_dump_opt_spec_function (int arg,
9392 const char **argv ATTRIBUTE_UNUSED)
9394 char *ret;
9395 char *name;
9396 int which;
9397 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
9399 if (arg != 0)
9400 fatal_error (input_location,
9401 "too many arguments to %%:compare-debug-dump-opt");
9403 do_spec_2 ("%{fdump-final-insns=*:%*}");
9404 do_spec_1 (" ", 0, NULL);
9406 if (argbuf.length () > 0
9407 && strcmp (argv[argbuf.length () - 1], "."))
9409 if (!compare_debug)
9410 return NULL;
9412 name = xstrdup (argv[argbuf.length () - 1]);
9413 ret = NULL;
9415 else
9417 const char *ext = NULL;
9419 if (argbuf.length () > 0)
9421 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
9422 ext = ".gkd";
9424 else if (!compare_debug)
9425 return NULL;
9426 else
9427 do_spec_2 ("%g.gkd");
9429 do_spec_1 (" ", 0, NULL);
9431 gcc_assert (argbuf.length () > 0);
9433 name = concat (argbuf.last (), ext, NULL);
9435 ret = concat ("-fdump-final-insns=", name, NULL);
9438 which = compare_debug < 0;
9439 debug_check_temp_file[which] = name;
9441 if (!which)
9443 unsigned HOST_WIDE_INT value = get_random_number ();
9445 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
9448 if (*random_seed)
9450 char *tmp = ret;
9451 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
9452 ret, NULL);
9453 free (tmp);
9456 if (which)
9457 *random_seed = 0;
9459 return ret;
9462 static const char *debug_auxbase_opt;
9464 /* %:compare-debug-self-opt spec function. Expands to the options
9465 that are to be passed in the second compilation of
9466 compare-debug. */
9468 static const char *
9469 compare_debug_self_opt_spec_function (int arg,
9470 const char **argv ATTRIBUTE_UNUSED)
9472 if (arg != 0)
9473 fatal_error (input_location,
9474 "too many arguments to %%:compare-debug-self-opt");
9476 if (compare_debug >= 0)
9477 return NULL;
9479 do_spec_2 ("%{c|S:%{o*:%*}}");
9480 do_spec_1 (" ", 0, NULL);
9482 if (argbuf.length () > 0)
9483 debug_auxbase_opt = concat ("-auxbase-strip ",
9484 argbuf.last (),
9485 NULL);
9486 else
9487 debug_auxbase_opt = NULL;
9489 return concat ("\
9490 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
9491 %<fdump-final-insns=* -w -S -o %j \
9492 %{!fcompare-debug-second:-fcompare-debug-second} \
9493 ", compare_debug_opt, NULL);
9496 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
9497 options that are to be passed in the second compilation of
9498 compare-debug. It expects, as an argument, the basename of the
9499 current input file name, with the .gk suffix appended to it. */
9501 static const char *
9502 compare_debug_auxbase_opt_spec_function (int arg,
9503 const char **argv)
9505 char *name;
9506 int len;
9508 if (arg == 0)
9509 fatal_error (input_location,
9510 "too few arguments to %%:compare-debug-auxbase-opt");
9512 if (arg != 1)
9513 fatal_error (input_location,
9514 "too many arguments to %%:compare-debug-auxbase-opt");
9516 if (compare_debug >= 0)
9517 return NULL;
9519 len = strlen (argv[0]);
9520 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
9521 fatal_error (input_location, "argument to %%:compare-debug-auxbase-opt "
9522 "does not end in .gk");
9524 if (debug_auxbase_opt)
9525 return debug_auxbase_opt;
9527 #define OPT "-auxbase "
9529 len -= 3;
9530 name = (char*) xmalloc (sizeof (OPT) + len);
9531 memcpy (name, OPT, sizeof (OPT) - 1);
9532 memcpy (name + sizeof (OPT) - 1, argv[0], len);
9533 name[sizeof (OPT) - 1 + len] = '\0';
9535 #undef OPT
9537 return name;
9540 /* %:pass-through-libs spec function. Finds all -l options and input
9541 file names in the lib spec passed to it, and makes a list of them
9542 prepended with the plugin option to cause them to be passed through
9543 to the final link after all the new object files have been added. */
9545 const char *
9546 pass_through_libs_spec_func (int argc, const char **argv)
9548 char *prepended = xstrdup (" ");
9549 int n;
9550 /* Shlemiel the painter's algorithm. Innately horrible, but at least
9551 we know that there will never be more than a handful of strings to
9552 concat, and it's only once per run, so it's not worth optimising. */
9553 for (n = 0; n < argc; n++)
9555 char *old = prepended;
9556 /* Anything that isn't an option is a full path to an output
9557 file; pass it through if it ends in '.a'. Among options,
9558 pass only -l. */
9559 if (argv[n][0] == '-' && argv[n][1] == 'l')
9561 const char *lopt = argv[n] + 2;
9562 /* Handle both joined and non-joined -l options. If for any
9563 reason there's a trailing -l with no joined or following
9564 arg just discard it. */
9565 if (!*lopt && ++n >= argc)
9566 break;
9567 else if (!*lopt)
9568 lopt = argv[n];
9569 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
9570 lopt, " ", NULL);
9572 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
9574 prepended = concat (prepended, "-plugin-opt=-pass-through=",
9575 argv[n], " ", NULL);
9577 if (prepended != old)
9578 free (old);
9580 return prepended;
9583 /* %:replace-extension spec function. Replaces the extension of the
9584 first argument with the second argument. */
9586 const char *
9587 replace_extension_spec_func (int argc, const char **argv)
9589 char *name;
9590 char *p;
9591 char *result;
9592 int i;
9594 if (argc != 2)
9595 fatal_error (input_location, "too few arguments to %%:replace-extension");
9597 name = xstrdup (argv[0]);
9599 for (i = strlen (name) - 1; i >= 0; i--)
9600 if (IS_DIR_SEPARATOR (name[i]))
9601 break;
9603 p = strrchr (name + i + 1, '.');
9604 if (p != NULL)
9605 *p = '\0';
9607 result = concat (name, argv[1], NULL);
9609 free (name);
9610 return result;
9613 /* Returns "" if the n in ARGV[1] == -opt=<n> is greater than ARGV[2].
9614 Otherwise, return NULL. */
9616 static const char *
9617 greater_than_spec_func (int argc, const char **argv)
9619 char *converted;
9621 if (argc == 1)
9622 return NULL;
9624 gcc_assert (argc == 3);
9625 gcc_assert (argv[0][0] == '-');
9626 gcc_assert (argv[0][1] == '\0');
9628 /* Point p to <n> in in -opt=<n>. */
9629 const char *p = argv[1];
9630 while (true)
9632 char c = *p;
9633 if (c == '\0')
9634 gcc_unreachable ();
9636 ++p;
9638 if (c == '=')
9639 break;
9642 long arg = strtol (p, &converted, 10);
9643 gcc_assert (converted != p);
9645 long lim = strtol (argv[2], &converted, 10);
9646 gcc_assert (converted != argv[2]);
9648 if (arg > lim)
9649 return "";
9651 return NULL;
9654 /* Insert backslash before spaces in ORIG (usually a file path), to
9655 avoid being broken by spec parser.
9657 This function is needed as do_spec_1 treats white space (' ' and '\t')
9658 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
9659 the file name should be treated as a single argument rather than being
9660 broken into multiple. Solution is to insert '\\' before the space in a
9661 file name.
9663 This function converts and only converts all occurrence of ' '
9664 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
9665 "a b" -> "a\\ b"
9666 "a b" -> "a\\ \\ b"
9667 "a\tb" -> "a\\\tb"
9668 "a\\ b" -> "a\\\\ b"
9670 orig: input null-terminating string that was allocated by xalloc. The
9671 memory it points to might be freed in this function. Behavior undefined
9672 if ORIG wasn't xalloced or was freed already at entry.
9674 Return: ORIG if no conversion needed. Otherwise a newly allocated string
9675 that was converted from ORIG. */
9677 static char *
9678 convert_white_space (char *orig)
9680 int len, number_of_space = 0;
9682 for (len = 0; orig[len]; len++)
9683 if (orig[len] == ' ' || orig[len] == '\t') number_of_space++;
9685 if (number_of_space)
9687 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
9688 int j, k;
9689 for (j = 0, k = 0; j <= len; j++, k++)
9691 if (orig[j] == ' ' || orig[j] == '\t')
9692 new_spec[k++] = '\\';
9693 new_spec[k] = orig[j];
9695 free (orig);
9696 return new_spec;
9698 else
9699 return orig;
9702 static void
9703 path_prefix_reset (path_prefix *prefix)
9705 struct prefix_list *iter, *next;
9706 iter = prefix->plist;
9707 while (iter)
9709 next = iter->next;
9710 free (const_cast <char *> (iter->prefix));
9711 XDELETE (iter);
9712 iter = next;
9714 prefix->plist = 0;
9715 prefix->max_len = 0;
9718 /* Restore all state within gcc.c to the initial state, so that the driver
9719 code can be safely re-run in-process.
9721 Many const char * variables are referenced by static specs (see
9722 INIT_STATIC_SPEC above). These variables are restored to their default
9723 values by a simple loop over the static specs.
9725 For other variables, we directly restore them all to their initial
9726 values (often implicitly 0).
9728 Free the various obstacks in this file, along with "opts_obstack"
9729 from opts.c.
9731 This function also restores any environment variables that were changed. */
9733 void
9734 driver::finalize ()
9736 env.restore ();
9737 params_c_finalize ();
9738 diagnostic_finish (global_dc);
9740 is_cpp_driver = 0;
9741 at_file_supplied = 0;
9742 print_help_list = 0;
9743 print_version = 0;
9744 verbose_only_flag = 0;
9745 print_subprocess_help = 0;
9746 use_ld = NULL;
9747 report_times_to_file = NULL;
9748 target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
9749 target_system_root_changed = 0;
9750 target_sysroot_suffix = 0;
9751 target_sysroot_hdrs_suffix = 0;
9752 save_temps_flag = SAVE_TEMPS_NONE;
9753 save_temps_prefix = 0;
9754 save_temps_length = 0;
9755 spec_machine = DEFAULT_TARGET_MACHINE;
9756 greatest_status = 1;
9758 finalize_options_struct (&global_options);
9759 finalize_options_struct (&global_options_set);
9761 obstack_free (&obstack, NULL);
9762 obstack_free (&opts_obstack, NULL); /* in opts.c */
9763 obstack_free (&collect_obstack, NULL);
9765 link_command_spec = LINK_COMMAND_SPEC;
9767 obstack_free (&multilib_obstack, NULL);
9769 user_specs_head = NULL;
9770 user_specs_tail = NULL;
9772 /* Within the "compilers" vec, the fields "suffix" and "spec" were
9773 statically allocated for the default compilers, but dynamically
9774 allocated for additional compilers. Delete them for the latter. */
9775 for (int i = n_default_compilers; i < n_compilers; i++)
9777 free (const_cast <char *> (compilers[i].suffix));
9778 free (const_cast <char *> (compilers[i].spec));
9780 XDELETEVEC (compilers);
9781 compilers = NULL;
9782 n_compilers = 0;
9784 linker_options.truncate (0);
9785 assembler_options.truncate (0);
9786 preprocessor_options.truncate (0);
9788 path_prefix_reset (&exec_prefixes);
9789 path_prefix_reset (&startfile_prefixes);
9790 path_prefix_reset (&include_prefixes);
9792 machine_suffix = 0;
9793 just_machine_suffix = 0;
9794 gcc_exec_prefix = 0;
9795 gcc_libexec_prefix = 0;
9796 md_exec_prefix = MD_EXEC_PREFIX;
9797 md_startfile_prefix = MD_STARTFILE_PREFIX;
9798 md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
9799 multilib_dir = 0;
9800 multilib_os_dir = 0;
9801 multiarch_dir = 0;
9803 XDELETEVEC (specs);
9804 specs = 0;
9805 for (unsigned i = 0; i < ARRAY_SIZE (static_specs); i++)
9807 spec_list *sl = &static_specs[i];
9808 if (sl->alloc_p)
9810 if (0)
9811 free (const_cast <char *> (*(sl->ptr_spec)));
9812 sl->alloc_p = false;
9814 *(sl->ptr_spec) = sl->default_ptr;
9816 #ifdef EXTRA_SPECS
9817 extra_specs = NULL;
9818 #endif
9820 processing_spec_function = 0;
9822 argbuf.truncate (0);
9824 have_c = 0;
9825 have_o = 0;
9827 temp_names = NULL;
9828 execution_count = 0;
9829 signal_count = 0;
9831 temp_filename = NULL;
9832 temp_filename_length = 0;
9833 always_delete_queue = NULL;
9834 failure_delete_queue = NULL;
9836 XDELETEVEC (switches);
9837 switches = NULL;
9838 n_switches = 0;
9839 n_switches_alloc = 0;
9841 compare_debug = 0;
9842 compare_debug_second = 0;
9843 compare_debug_opt = NULL;
9844 for (int i = 0; i < 2; i++)
9846 switches_debug_check[i] = NULL;
9847 n_switches_debug_check[i] = 0;
9848 n_switches_alloc_debug_check[i] = 0;
9849 debug_check_temp_file[i] = NULL;
9852 XDELETEVEC (infiles);
9853 infiles = NULL;
9854 n_infiles = 0;
9855 n_infiles_alloc = 0;
9857 combine_inputs = false;
9858 added_libraries = 0;
9859 XDELETEVEC (outfiles);
9860 outfiles = NULL;
9861 spec_lang = 0;
9862 last_language_n_infiles = 0;
9863 gcc_input_filename = NULL;
9864 input_file_number = 0;
9865 input_filename_length = 0;
9866 basename_length = 0;
9867 suffixed_basename_length = 0;
9868 input_basename = NULL;
9869 input_suffix = NULL;
9870 /* We don't need to purge "input_stat", just to unset "input_stat_set". */
9871 input_stat_set = 0;
9872 input_file_compiler = NULL;
9873 arg_going = 0;
9874 delete_this_arg = 0;
9875 this_is_output_file = 0;
9876 this_is_library_file = 0;
9877 this_is_linker_script = 0;
9878 input_from_pipe = 0;
9879 suffix_subst = NULL;
9881 mdswitches = NULL;
9882 n_mdswitches = 0;
9884 debug_auxbase_opt = NULL;
9886 used_arg.finalize ();
9889 /* PR jit/64810.
9890 Targets can provide configure-time default options in
9891 OPTION_DEFAULT_SPECS. The jit needs to access these, but
9892 they are expressed in the spec language.
9894 Run just enough of the driver to be able to expand these
9895 specs, and then call the callback CB on each
9896 such option. The options strings are *without* a leading
9897 '-' character e.g. ("march=x86-64"). Finally, clean up. */
9899 void
9900 driver_get_configure_time_options (void (*cb) (const char *option,
9901 void *user_data),
9902 void *user_data)
9904 size_t i;
9906 obstack_init (&obstack);
9907 gcc_obstack_init (&opts_obstack);
9908 n_switches = 0;
9910 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
9911 do_option_spec (option_default_specs[i].name,
9912 option_default_specs[i].spec);
9914 for (i = 0; (int) i < n_switches; i++)
9916 gcc_assert (switches[i].part1);
9917 (*cb) (switches[i].part1, user_data);
9920 obstack_free (&opts_obstack, NULL);
9921 obstack_free (&obstack, NULL);
9922 n_switches = 0;