2015-09-24 Vladimir Makarov <vmakarov@redhat.com>
[official-gcc.git] / gcc / gcc.c
blob55a725583b87406e79c4f470d80fc0502e122d00
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. Separated by colon. Empty string for
288 -foffload=disable. */
290 static char *offload_targets = NULL;
292 /* Nonzero if cross-compiling.
293 When -b is used, the value comes from the `specs' file. */
295 #ifdef CROSS_DIRECTORY_STRUCTURE
296 static const char *cross_compile = "1";
297 #else
298 static const char *cross_compile = "0";
299 #endif
301 /* Greatest exit code of sub-processes that has been encountered up to
302 now. */
303 static int greatest_status = 1;
305 /* This is the obstack which we use to allocate many strings. */
307 static struct obstack obstack;
309 /* This is the obstack to build an environment variable to pass to
310 collect2 that describes all of the relevant switches of what to
311 pass the compiler in building the list of pointers to constructors
312 and destructors. */
314 static struct obstack collect_obstack;
316 /* Forward declaration for prototypes. */
317 struct path_prefix;
318 struct prefix_list;
320 static void init_spec (void);
321 static void store_arg (const char *, int, int);
322 static void insert_wrapper (const char *);
323 static char *load_specs (const char *);
324 static void read_specs (const char *, bool, bool);
325 static void set_spec (const char *, const char *, bool);
326 static struct compiler *lookup_compiler (const char *, size_t, const char *);
327 static char *build_search_list (const struct path_prefix *, const char *,
328 bool, bool);
329 static void xputenv (const char *);
330 static void putenv_from_prefixes (const struct path_prefix *, const char *,
331 bool);
332 static int access_check (const char *, int);
333 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
334 static void add_prefix (struct path_prefix *, const char *, const char *,
335 int, int, int);
336 static void add_sysrooted_prefix (struct path_prefix *, const char *,
337 const char *, int, int, int);
338 static char *skip_whitespace (char *);
339 static void delete_if_ordinary (const char *);
340 static void delete_temp_files (void);
341 static void delete_failure_queue (void);
342 static void clear_failure_queue (void);
343 static int check_live_switch (int, int);
344 static const char *handle_braces (const char *);
345 static inline bool input_suffix_matches (const char *, const char *);
346 static inline bool switch_matches (const char *, const char *, int);
347 static inline void mark_matching_switches (const char *, const char *, int);
348 static inline void process_marked_switches (void);
349 static const char *process_brace_body (const char *, const char *, const char *, int, int);
350 static const struct spec_function *lookup_spec_function (const char *);
351 static const char *eval_spec_function (const char *, const char *);
352 static const char *handle_spec_function (const char *, bool *);
353 static char *save_string (const char *, int);
354 static void set_collect_gcc_options (void);
355 static int do_spec_1 (const char *, int, const char *);
356 static int do_spec_2 (const char *);
357 static void do_option_spec (const char *, const char *);
358 static void do_self_spec (const char *);
359 static const char *find_file (const char *);
360 static int is_directory (const char *, bool);
361 static const char *validate_switches (const char *, bool);
362 static void validate_all_switches (void);
363 static inline void validate_switches_from_spec (const char *, bool);
364 static void give_switch (int, int);
365 static int default_arg (const char *, int);
366 static void set_multilib_dir (void);
367 static void print_multilib_info (void);
368 static void perror_with_name (const char *);
369 static void display_help (void);
370 static void add_preprocessor_option (const char *, int);
371 static void add_assembler_option (const char *, int);
372 static void add_linker_option (const char *, int);
373 static void process_command (unsigned int, struct cl_decoded_option *);
374 static int execute (void);
375 static void alloc_args (void);
376 static void clear_args (void);
377 static void fatal_signal (int);
378 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
379 static void init_gcc_specs (struct obstack *, const char *, const char *,
380 const char *);
381 #endif
382 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
383 static const char *convert_filename (const char *, int, int);
384 #endif
386 static void try_generate_repro (const char **argv);
387 static const char *getenv_spec_function (int, const char **);
388 static const char *if_exists_spec_function (int, const char **);
389 static const char *if_exists_else_spec_function (int, const char **);
390 static const char *sanitize_spec_function (int, const char **);
391 static const char *replace_outfile_spec_function (int, const char **);
392 static const char *remove_outfile_spec_function (int, const char **);
393 static const char *version_compare_spec_function (int, const char **);
394 static const char *include_spec_function (int, const char **);
395 static const char *find_file_spec_function (int, const char **);
396 static const char *find_plugindir_spec_function (int, const char **);
397 static const char *print_asm_header_spec_function (int, const char **);
398 static const char *compare_debug_dump_opt_spec_function (int, const char **);
399 static const char *compare_debug_self_opt_spec_function (int, const char **);
400 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
401 static const char *pass_through_libs_spec_func (int, const char **);
402 static const char *replace_extension_spec_func (int, const char **);
403 static const char *greater_than_spec_func (int, const char **);
404 static char *convert_white_space (char *);
406 /* The Specs Language
408 Specs are strings containing lines, each of which (if not blank)
409 is made up of a program name, and arguments separated by spaces.
410 The program name must be exact and start from root, since no path
411 is searched and it is unreliable to depend on the current working directory.
412 Redirection of input or output is not supported; the subprograms must
413 accept filenames saying what files to read and write.
415 In addition, the specs can contain %-sequences to substitute variable text
416 or for conditional text. Here is a table of all defined %-sequences.
417 Note that spaces are not generated automatically around the results of
418 expanding these sequences; therefore, you can concatenate them together
419 or with constant text in a single argument.
421 %% substitute one % into the program name or argument.
422 %i substitute the name of the input file being processed.
423 %b substitute the basename of the input file being processed.
424 This is the substring up to (and not including) the last period
425 and not including the directory unless -save-temps was specified
426 to put temporaries in a different location.
427 %B same as %b, but include the file suffix (text after the last period).
428 %gSUFFIX
429 substitute a file name that has suffix SUFFIX and is chosen
430 once per compilation, and mark the argument a la %d. To reduce
431 exposure to denial-of-service attacks, the file name is now
432 chosen in a way that is hard to predict even when previously
433 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
434 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
435 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
436 had been pre-processed. Previously, %g was simply substituted
437 with a file name chosen once per compilation, without regard
438 to any appended suffix (which was therefore treated just like
439 ordinary text), making such attacks more likely to succeed.
440 %|SUFFIX
441 like %g, but if -pipe is in effect, expands simply to "-".
442 %mSUFFIX
443 like %g, but if -pipe is in effect, expands to nothing. (We have both
444 %| and %m to accommodate differences between system assemblers; see
445 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
446 %uSUFFIX
447 like %g, but generates a new temporary file name even if %uSUFFIX
448 was already seen.
449 %USUFFIX
450 substitutes the last file name generated with %uSUFFIX, generating a
451 new one if there is no such last file name. In the absence of any
452 %uSUFFIX, this is just like %gSUFFIX, except they don't share
453 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
454 would involve the generation of two distinct file names, one
455 for each `%g.s' and another for each `%U.s'. Previously, %U was
456 simply substituted with a file name chosen for the previous %u,
457 without regard to any appended suffix.
458 %jSUFFIX
459 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
460 writable, and if save-temps is off; otherwise, substitute the name
461 of a temporary file, just like %u. This temporary file is not
462 meant for communication between processes, but rather as a junk
463 disposal mechanism.
464 %.SUFFIX
465 substitutes .SUFFIX for the suffixes of a matched switch's args when
466 it is subsequently output with %*. SUFFIX is terminated by the next
467 space or %.
468 %d marks the argument containing or following the %d as a
469 temporary file name, so that file will be deleted if GCC exits
470 successfully. Unlike %g, this contributes no text to the argument.
471 %w marks the argument containing or following the %w as the
472 "output file" of this compilation. This puts the argument
473 into the sequence of arguments that %o will substitute later.
474 %V indicates that this compilation produces no "output file".
475 %W{...}
476 like %{...} but mark last argument supplied within
477 as a file to be deleted on failure.
478 %o substitutes the names of all the output files, with spaces
479 automatically placed around them. You should write spaces
480 around the %o as well or the results are undefined.
481 %o is for use in the specs for running the linker.
482 Input files whose names have no recognized suffix are not compiled
483 at all, but they are included among the output files, so they will
484 be linked.
485 %O substitutes the suffix for object files. Note that this is
486 handled specially when it immediately follows %g, %u, or %U
487 (with or without a suffix argument) because of the need for
488 those to form complete file names. The handling is such that
489 %O is treated exactly as if it had already been substituted,
490 except that %g, %u, and %U do not currently support additional
491 SUFFIX characters following %O as they would following, for
492 example, `.o'.
493 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
494 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
495 and -B options) and -imultilib as necessary.
496 %s current argument is the name of a library or startup file of some sort.
497 Search for that file in a standard list of directories
498 and substitute the full name found.
499 %eSTR Print STR as an error message. STR is terminated by a newline.
500 Use this when inconsistent options are detected.
501 %nSTR Print STR as a notice. STR is terminated by a newline.
502 %x{OPTION} Accumulate an option for %X.
503 %X Output the accumulated linker options specified by compilations.
504 %Y Output the accumulated assembler options specified by compilations.
505 %Z Output the accumulated preprocessor options specified by compilations.
506 %a process ASM_SPEC as a spec.
507 This allows config.h to specify part of the spec for running as.
508 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
509 used here. This can be used to run a post-processor after the
510 assembler has done its job.
511 %D Dump out a -L option for each directory in startfile_prefixes.
512 If multilib_dir is set, extra entries are generated with it affixed.
513 %l process LINK_SPEC as a spec.
514 %L process LIB_SPEC as a spec.
515 %M Output multilib_os_dir.
516 %G process LIBGCC_SPEC as a spec.
517 %R Output the concatenation of target_system_root and
518 target_sysroot_suffix.
519 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
520 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
521 %C process CPP_SPEC as a spec.
522 %1 process CC1_SPEC as a spec.
523 %2 process CC1PLUS_SPEC as a spec.
524 %* substitute the variable part of a matched option. (See below.)
525 Note that each comma in the substituted string is replaced by
526 a single space. A space is appended after the last substition
527 unless there is more text in current sequence.
528 %<S remove all occurrences of -S from the command line.
529 Note - this command is position dependent. % commands in the
530 spec string before this one will see -S, % commands in the
531 spec string after this one will not.
532 %>S Similar to "%<S", but keep it in the GCC command line.
533 %<S* remove all occurrences of all switches beginning with -S from the
534 command line.
535 %:function(args)
536 Call the named function FUNCTION, passing it ARGS. ARGS is
537 first processed as a nested spec string, then split into an
538 argument vector in the usual fashion. The function returns
539 a string which is processed as if it had appeared literally
540 as part of the current spec.
541 %{S} substitutes the -S switch, if that switch was given to GCC.
542 If that switch was not specified, this substitutes nothing.
543 Here S is a metasyntactic variable.
544 %{S*} substitutes all the switches specified to GCC whose names start
545 with -S. This is used for -o, -I, etc; switches that take
546 arguments. GCC considers `-o foo' as being one switch whose
547 name starts with `o'. %{o*} would substitute this text,
548 including the space; thus, two arguments would be generated.
549 %{S*&T*} likewise, but preserve order of S and T options (the order
550 of S and T in the spec is not significant). Can be any number
551 of ampersand-separated variables; for each the wild card is
552 optional. Useful for CPP as %{D*&U*&A*}.
554 %{S:X} substitutes X, if the -S switch was given to GCC.
555 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
556 %{S*:X} substitutes X if one or more switches whose names start
557 with -S was given to GCC. Normally X is substituted only
558 once, no matter how many such switches appeared. However,
559 if %* appears somewhere in X, then X will be substituted
560 once for each matching switch, with the %* replaced by the
561 part of that switch that matched the '*'. A space will be
562 appended after the last substition unless there is more
563 text in current sequence.
564 %{.S:X} substitutes X, if processing a file with suffix S.
565 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
566 %{,S:X} substitutes X, if processing a file which will use spec S.
567 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
569 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
570 combined with '!', '.', ',', and '*' as above binding stronger
571 than the OR.
572 If %* appears in X, all of the alternatives must be starred, and
573 only the first matching alternative is substituted.
574 %{%:function(args):X}
575 Call function named FUNCTION with args ARGS. If the function
576 returns non-NULL, then X is substituted, if it returns
577 NULL, it isn't substituted.
578 %{S:X; if S was given to GCC, substitutes X;
579 T:Y; else if T was given to GCC, substitutes Y;
580 :D} else substitutes D. There can be as many clauses as you need.
581 This may be combined with '.', '!', ',', '|', and '*' as above.
583 %(Spec) processes a specification defined in a specs file as *Spec:
585 The conditional text X in a %{S:X} or similar construct may contain
586 other nested % constructs or spaces, or even newlines. They are
587 processed as usual, as described above. Trailing white space in X is
588 ignored. White space may also appear anywhere on the left side of the
589 colon in these constructs, except between . or * and the corresponding
590 word.
592 The -O, -f, -g, -m, and -W switches are handled specifically in these
593 constructs. If another value of -O or the negated form of a -f, -m, or
594 -W switch is found later in the command line, the earlier switch
595 value is ignored, except with {S*} where S is just one letter; this
596 passes all matching options.
598 The character | at the beginning of the predicate text is used to indicate
599 that a command should be piped to the following command, but only if -pipe
600 is specified.
602 Note that it is built into GCC which switches take arguments and which
603 do not. You might think it would be useful to generalize this to
604 allow each compiler's spec to say which switches take arguments. But
605 this cannot be done in a consistent fashion. GCC cannot even decide
606 which input files have been specified without knowing which switches
607 take arguments, and it must know which input files to compile in order
608 to tell which compilers to run.
610 GCC also knows implicitly that arguments starting in `-l' are to be
611 treated as compiler output files, and passed to the linker in their
612 proper position among the other output files. */
614 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
616 /* config.h can define ASM_SPEC to provide extra args to the assembler
617 or extra switch-translations. */
618 #ifndef ASM_SPEC
619 #define ASM_SPEC ""
620 #endif
622 /* config.h can define ASM_FINAL_SPEC to run a post processor after
623 the assembler has run. */
624 #ifndef ASM_FINAL_SPEC
625 #define ASM_FINAL_SPEC \
626 "%{gsplit-dwarf: \n\
627 objcopy --extract-dwo \
628 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
629 %{c:%{o*:%:replace-extension(%{o*:%*} .dwo)}%{!o*:%b.dwo}}%{!c:%b.dwo} \n\
630 objcopy --strip-dwo \
631 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
633 #endif
635 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
636 or extra switch-translations. */
637 #ifndef CPP_SPEC
638 #define CPP_SPEC ""
639 #endif
641 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
642 or extra switch-translations. */
643 #ifndef CC1_SPEC
644 #define CC1_SPEC ""
645 #endif
647 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
648 or extra switch-translations. */
649 #ifndef CC1PLUS_SPEC
650 #define CC1PLUS_SPEC ""
651 #endif
653 /* config.h can define LINK_SPEC to provide extra args to the linker
654 or extra switch-translations. */
655 #ifndef LINK_SPEC
656 #define LINK_SPEC ""
657 #endif
659 /* config.h can define LIB_SPEC to override the default libraries. */
660 #ifndef LIB_SPEC
661 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
662 #endif
664 /* When using -fsplit-stack we need to wrap pthread_create, in order
665 to initialize the stack guard. We always use wrapping, rather than
666 shared library ordering, and we keep the wrapper function in
667 libgcc. This is not yet a real spec, though it could become one;
668 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
669 only works with GNU ld and gold. */
670 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
672 #ifndef LIBASAN_SPEC
673 #define STATIC_LIBASAN_LIBS \
674 " %{static-libasan:%:include(libsanitizer.spec)%(link_libasan)}"
675 #ifdef LIBASAN_EARLY_SPEC
676 #define LIBASAN_SPEC STATIC_LIBASAN_LIBS
677 #elif defined(HAVE_LD_STATIC_DYNAMIC)
678 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
679 "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
680 STATIC_LIBASAN_LIBS
681 #else
682 #define LIBASAN_SPEC "-lasan" STATIC_LIBASAN_LIBS
683 #endif
684 #endif
686 #ifndef LIBASAN_EARLY_SPEC
687 #define LIBASAN_EARLY_SPEC ""
688 #endif
690 #ifndef LIBTSAN_SPEC
691 #define STATIC_LIBTSAN_LIBS \
692 " %{static-libtsan:%:include(libsanitizer.spec)%(link_libtsan)}"
693 #ifdef LIBTSAN_EARLY_SPEC
694 #define LIBTSAN_SPEC STATIC_LIBTSAN_LIBS
695 #elif defined(HAVE_LD_STATIC_DYNAMIC)
696 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
697 "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}" \
698 STATIC_LIBTSAN_LIBS
699 #else
700 #define LIBTSAN_SPEC "-ltsan" STATIC_LIBTSAN_LIBS
701 #endif
702 #endif
704 #ifndef LIBTSAN_EARLY_SPEC
705 #define LIBTSAN_EARLY_SPEC ""
706 #endif
708 #ifndef LIBLSAN_SPEC
709 #define STATIC_LIBLSAN_LIBS \
710 " %{static-liblsan:%:include(libsanitizer.spec)%(link_liblsan)}"
711 #ifdef LIBLSAN_EARLY_SPEC
712 #define LIBLSAN_SPEC STATIC_LIBLSAN_LIBS
713 #elif defined(HAVE_LD_STATIC_DYNAMIC)
714 #define LIBLSAN_SPEC "%{static-liblsan:" LD_STATIC_OPTION \
715 "} -llsan %{static-liblsan:" LD_DYNAMIC_OPTION "}" \
716 STATIC_LIBLSAN_LIBS
717 #else
718 #define LIBLSAN_SPEC "-llsan" STATIC_LIBLSAN_LIBS
719 #endif
720 #endif
722 #ifndef LIBLSAN_EARLY_SPEC
723 #define LIBLSAN_EARLY_SPEC ""
724 #endif
726 #ifndef LIBUBSAN_SPEC
727 #define STATIC_LIBUBSAN_LIBS \
728 " %{static-libubsan:%:include(libsanitizer.spec)%(link_libubsan)}"
729 #ifdef HAVE_LD_STATIC_DYNAMIC
730 #define LIBUBSAN_SPEC "%{static-libubsan:" LD_STATIC_OPTION \
731 "} -lubsan %{static-libubsan:" LD_DYNAMIC_OPTION "}" \
732 STATIC_LIBUBSAN_LIBS
733 #else
734 #define LIBUBSAN_SPEC "-lubsan" STATIC_LIBUBSAN_LIBS
735 #endif
736 #endif
738 /* Linker options for compressed debug sections. */
739 #if HAVE_LD_COMPRESS_DEBUG == 0
740 /* No linker support. */
741 #define LINK_COMPRESS_DEBUG_SPEC \
742 " %{gz*:%e-gz is not supported in this configuration} "
743 #elif HAVE_LD_COMPRESS_DEBUG == 1
744 /* GNU style on input, GNU ld options. Reject, not useful. */
745 #define LINK_COMPRESS_DEBUG_SPEC \
746 " %{gz*:%e-gz is not supported in this configuration} "
747 #elif HAVE_LD_COMPRESS_DEBUG == 2
748 /* GNU style, GNU gold options. */
749 #define LINK_COMPRESS_DEBUG_SPEC \
750 " %{gz|gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
751 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
752 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
753 #elif HAVE_LD_COMPRESS_DEBUG == 3
754 /* ELF gABI style. */
755 #define LINK_COMPRESS_DEBUG_SPEC \
756 " %{gz|gz=zlib:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
757 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
758 " %{gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
759 #else
760 #error Unknown value for HAVE_LD_COMPRESS_DEBUG.
761 #endif
763 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
764 included. */
765 #ifndef LIBGCC_SPEC
766 #if defined(REAL_LIBGCC_SPEC)
767 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
768 #elif defined(LINK_LIBGCC_SPECIAL_1)
769 /* Have gcc do the search for libgcc.a. */
770 #define LIBGCC_SPEC "libgcc.a%s"
771 #else
772 #define LIBGCC_SPEC "-lgcc"
773 #endif
774 #endif
776 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
777 #ifndef STARTFILE_SPEC
778 #define STARTFILE_SPEC \
779 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
780 #endif
782 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
783 #ifndef ENDFILE_SPEC
784 #define ENDFILE_SPEC ""
785 #endif
787 #ifndef LINKER_NAME
788 #define LINKER_NAME "collect2"
789 #endif
791 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
792 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
793 #else
794 #define ASM_MAP ""
795 #endif
797 /* Assembler options for compressed debug sections. */
798 #if HAVE_LD_COMPRESS_DEBUG < 2
799 /* Reject if the linker cannot write compressed debug sections. */
800 #define ASM_COMPRESS_DEBUG_SPEC \
801 " %{gz*:%e-gz is not supported in this configuration} "
802 #else /* HAVE_LD_COMPRESS_DEBUG >= 2 */
803 #if HAVE_AS_COMPRESS_DEBUG == 0
804 /* No assembler support. Ignore silently. */
805 #define ASM_COMPRESS_DEBUG_SPEC \
806 " %{gz*:} "
807 #elif HAVE_AS_COMPRESS_DEBUG == 1
808 /* GNU style, GNU as options. */
809 #define ASM_COMPRESS_DEBUG_SPEC \
810 " %{gz|gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "}" \
811 " %{gz=none:" AS_NO_COMPRESS_DEBUG_OPTION "}" \
812 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
813 #elif HAVE_AS_COMPRESS_DEBUG == 2
814 /* ELF gABI style. */
815 #define ASM_COMPRESS_DEBUG_SPEC \
816 " %{gz|gz=zlib:" AS_COMPRESS_DEBUG_OPTION "=zlib}" \
817 " %{gz=none:" AS_COMPRESS_DEBUG_OPTION "=none}" \
818 " %{gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
819 #else
820 #error Unknown value for HAVE_AS_COMPRESS_DEBUG.
821 #endif
822 #endif /* HAVE_LD_COMPRESS_DEBUG >= 2 */
824 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
825 to the assembler. */
826 #ifndef ASM_DEBUG_SPEC
827 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
828 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
829 # define ASM_DEBUG_SPEC \
830 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
831 ? "%{!g0:%{gdwarf*:--gdwarf2}%{!gdwarf*:%{g*:--gstabs}}}" ASM_MAP \
832 : "%{!g0:%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
833 # else
834 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
835 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gstabs}}" ASM_MAP
836 # endif
837 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
838 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gdwarf2}}" ASM_MAP
839 # endif
840 # endif
841 #endif
842 #ifndef ASM_DEBUG_SPEC
843 # define ASM_DEBUG_SPEC ""
844 #endif
846 /* Here is the spec for running the linker, after compiling all files. */
848 /* This is overridable by the target in case they need to specify the
849 -lgcc and -lc order specially, yet not require them to override all
850 of LINK_COMMAND_SPEC. */
851 #ifndef LINK_GCC_C_SEQUENCE_SPEC
852 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
853 #endif
855 #ifndef LINK_SSP_SPEC
856 #ifdef TARGET_LIBC_PROVIDES_SSP
857 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
858 "|fstack-protector-strong|fstack-protector-explicit:}"
859 #else
860 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
861 "|fstack-protector-strong|fstack-protector-explicit" \
862 ":-lssp_nonshared -lssp}"
863 #endif
864 #endif
866 #ifdef ENABLE_DEFAULT_PIE
867 #define NO_PIE_SPEC "no-pie|static"
868 #define PIE_SPEC NO_PIE_SPEC "|r|shared:;"
869 #define NO_FPIE1_SPEC "fno-pie"
870 #define FPIE1_SPEC NO_FPIE1_SPEC ":;"
871 #define NO_FPIE2_SPEC "fno-PIE"
872 #define FPIE2_SPEC NO_FPIE2_SPEC ":;"
873 #define NO_FPIE_SPEC NO_FPIE1_SPEC "|" NO_FPIE2_SPEC
874 #define FPIE_SPEC NO_FPIE_SPEC ":;"
875 #define NO_FPIC1_SPEC "fno-pic"
876 #define FPIC1_SPEC NO_FPIC1_SPEC ":;"
877 #define NO_FPIC2_SPEC "fno-PIC"
878 #define FPIC2_SPEC NO_FPIC2_SPEC ":;"
879 #define NO_FPIC_SPEC NO_FPIC1_SPEC "|" NO_FPIC2_SPEC
880 #define FPIC_SPEC NO_FPIC_SPEC ":;"
881 #define NO_FPIE1_AND_FPIC1_SPEC NO_FPIE1_SPEC "|" NO_FPIC1_SPEC
882 #define FPIE1_OR_FPIC1_SPEC NO_FPIE1_AND_FPIC1_SPEC ":;"
883 #define NO_FPIE2_AND_FPIC2_SPEC NO_FPIE2_SPEC "|" NO_FPIC2_SPEC
884 #define FPIE2_OR_FPIC2_SPEC NO_FPIE2_AND_FPIC2_SPEC ":;"
885 #define NO_FPIE_AND_FPIC_SPEC NO_FPIE_SPEC "|" NO_FPIC_SPEC
886 #define FPIE_OR_FPIC_SPEC NO_FPIE_AND_FPIC_SPEC ":;"
887 #else
888 #define PIE_SPEC "pie"
889 #define NO_PIE_SPEC PIE_SPEC "|r|shared:;"
890 #define FPIE1_SPEC "fpie"
891 #define NO_FPIE1_SPEC FPIE1_SPEC ":;"
892 #define FPIE2_SPEC "fPIE"
893 #define NO_FPIE2_SPEC FPIE2_SPEC ":;"
894 #define FPIE_SPEC FPIE1_SPEC "|" FPIE2_SPEC
895 #define NO_FPIE_SPEC FPIE_SPEC ":;"
896 #define FPIC1_SPEC "fpic"
897 #define NO_FPIC1_SPEC FPIC1_SPEC ":;"
898 #define FPIC2_SPEC "fPIC"
899 #define NO_FPIC2_SPEC FPIC2_SPEC ":;"
900 #define FPIC_SPEC FPIC1_SPEC "|" FPIC2_SPEC
901 #define NO_FPIC_SPEC FPIC_SPEC ":;"
902 #define FPIE1_OR_FPIC1_SPEC FPIE1_SPEC "|" FPIC1_SPEC
903 #define NO_FPIE1_AND_FPIC1_SPEC FPIE1_OR_FPIC1_SPEC ":;"
904 #define FPIE2_OR_FPIC2_SPEC FPIE2_SPEC "|" FPIC2_SPEC
905 #define NO_FPIE2_AND_FPIC2_SPEC FPIE1_OR_FPIC2_SPEC ":;"
906 #define FPIE_OR_FPIC_SPEC FPIE_SPEC "|" FPIC_SPEC
907 #define NO_FPIE_AND_FPIC_SPEC FPIE_OR_FPIC_SPEC ":;"
908 #endif
910 #ifndef LINK_PIE_SPEC
911 #ifdef HAVE_LD_PIE
912 #ifndef LD_PIE_SPEC
913 #define LD_PIE_SPEC "-pie"
914 #endif
915 #else
916 #define LD_PIE_SPEC ""
917 #endif
918 #define LINK_PIE_SPEC "%{no-pie:} " "%{" PIE_SPEC ":" LD_PIE_SPEC "} "
919 #endif
921 #ifndef LINK_BUILDID_SPEC
922 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
923 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
924 # endif
925 #endif
927 /* Conditional to test whether the LTO plugin is used or not.
928 FIXME: For slim LTO we will need to enable plugin unconditionally. This
929 still cause problems with PLUGIN_LD != LD and when plugin is built but
930 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
931 plugin only when LTO is enabled. We still honor explicit
932 -fuse-linker-plugin if the linker used understands -plugin. */
934 /* The linker has some plugin support. */
935 #if HAVE_LTO_PLUGIN > 0
936 /* The linker used has full plugin support, use LTO plugin by default. */
937 #if HAVE_LTO_PLUGIN == 2
938 #define PLUGIN_COND "!fno-use-linker-plugin:%{!fno-lto"
939 #define PLUGIN_COND_CLOSE "}"
940 #else
941 /* The linker used has limited plugin support, use LTO plugin with explicit
942 -fuse-linker-plugin. */
943 #define PLUGIN_COND "fuse-linker-plugin"
944 #define PLUGIN_COND_CLOSE ""
945 #endif
946 #define LINK_PLUGIN_SPEC \
947 "%{" PLUGIN_COND": \
948 -plugin %(linker_plugin_file) \
949 -plugin-opt=%(lto_wrapper) \
950 -plugin-opt=-fresolution=%u.res \
951 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
952 }" PLUGIN_COND_CLOSE
953 #else
954 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
955 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
956 %e-fuse-linker-plugin is not supported in this configuration}"
957 #endif
959 /* Linker command line options for -fsanitize= early on the command line. */
960 #ifndef SANITIZER_EARLY_SPEC
961 #define SANITIZER_EARLY_SPEC "\
962 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_EARLY_SPEC "} \
963 %{%:sanitize(thread):" LIBTSAN_EARLY_SPEC "} \
964 %{%:sanitize(leak):" LIBLSAN_EARLY_SPEC "}}}"
965 #endif
967 /* Linker command line options for -fsanitize= late on the command line. */
968 #ifndef SANITIZER_SPEC
969 #define SANITIZER_SPEC "\
970 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_SPEC "\
971 %{static:%ecannot specify -static with -fsanitize=address}}\
972 %{%:sanitize(thread):" LIBTSAN_SPEC "\
973 %{static:%ecannot specify -static with -fsanitize=thread}}\
974 %{%:sanitize(undefined):" LIBUBSAN_SPEC "}\
975 %{%:sanitize(leak):" LIBLSAN_SPEC "}}}"
976 #endif
978 /* This is the spec to use, once the code for creating the vtable
979 verification runtime library, libvtv.so, has been created. Currently
980 the vtable verification runtime functions are in libstdc++, so we use
981 the spec just below this one. */
982 #ifndef VTABLE_VERIFICATION_SPEC
983 #define VTABLE_VERIFICATION_SPEC "\
984 %{!nostdlib:%{fvtable-verify=std: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}\
985 %{fvtable-verify=preinit: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}}"
986 #endif
988 #ifndef CHKP_SPEC
989 #define CHKP_SPEC ""
990 #endif
992 /* -u* was put back because both BSD and SysV seem to support it. */
993 /* %{static:} simply prevents an error message if the target machine
994 doesn't handle -static. */
995 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
996 scripts which exist in user specified directories, or in standard
997 directories. */
998 /* We pass any -flto flags on to the linker, which is expected
999 to understand them. In practice, this means it had better be collect2. */
1000 /* %{e*} includes -export-dynamic; see comment in common.opt. */
1001 #ifndef LINK_COMMAND_SPEC
1002 #define LINK_COMMAND_SPEC "\
1003 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
1004 %(linker) " \
1005 LINK_PLUGIN_SPEC \
1006 "%{flto|flto=*:%<fcompare-debug*} \
1007 %{flto} %{fno-lto} %{flto=*} %l " LINK_PIE_SPEC \
1008 "%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
1009 "%X %{o*} %{e*} %{N} %{n} %{r}\
1010 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}} " VTABLE_VERIFICATION_SPEC " \
1011 %{static:} %{L*} %(mfwrap) %(link_libgcc) " SANITIZER_EARLY_SPEC " %o\
1012 " CHKP_SPEC " \
1013 %{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*} 1):\
1014 %:include(libgomp.spec)%(link_gomp)}\
1015 %{fcilkplus:%:include(libcilkrts.spec)%(link_cilkrts)}\
1016 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
1017 %(mflib) " STACK_SPLIT_SPEC "\
1018 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
1019 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
1020 %{!nostdlib:%{!nostartfiles:%E}} %{T*} }}}}}}"
1021 #endif
1023 #ifndef LINK_LIBGCC_SPEC
1024 /* Generate -L options for startfile prefix list. */
1025 # define LINK_LIBGCC_SPEC "%D"
1026 #endif
1028 #ifndef STARTFILE_PREFIX_SPEC
1029 # define STARTFILE_PREFIX_SPEC ""
1030 #endif
1032 #ifndef SYSROOT_SPEC
1033 # define SYSROOT_SPEC "--sysroot=%R"
1034 #endif
1036 #ifndef SYSROOT_SUFFIX_SPEC
1037 # define SYSROOT_SUFFIX_SPEC ""
1038 #endif
1040 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
1041 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
1042 #endif
1044 static const char *asm_debug = ASM_DEBUG_SPEC;
1045 static const char *cpp_spec = CPP_SPEC;
1046 static const char *cc1_spec = CC1_SPEC;
1047 static const char *cc1plus_spec = CC1PLUS_SPEC;
1048 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
1049 static const char *link_ssp_spec = LINK_SSP_SPEC;
1050 static const char *asm_spec = ASM_SPEC;
1051 static const char *asm_final_spec = ASM_FINAL_SPEC;
1052 static const char *link_spec = LINK_SPEC;
1053 static const char *lib_spec = LIB_SPEC;
1054 static const char *link_gomp_spec = "";
1055 static const char *libgcc_spec = LIBGCC_SPEC;
1056 static const char *endfile_spec = ENDFILE_SPEC;
1057 static const char *startfile_spec = STARTFILE_SPEC;
1058 static const char *linker_name_spec = LINKER_NAME;
1059 static const char *linker_plugin_file_spec = "";
1060 static const char *lto_wrapper_spec = "";
1061 static const char *lto_gcc_spec = "";
1062 static const char *link_command_spec = LINK_COMMAND_SPEC;
1063 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
1064 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
1065 static const char *sysroot_spec = SYSROOT_SPEC;
1066 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
1067 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
1068 static const char *self_spec = "";
1070 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
1071 There should be no need to override these in target dependent files,
1072 but we need to copy them to the specs file so that newer versions
1073 of the GCC driver can correctly drive older tool chains with the
1074 appropriate -B options. */
1076 /* When cpplib handles traditional preprocessing, get rid of this, and
1077 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
1078 that we default the front end language better. */
1079 static const char *trad_capable_cpp =
1080 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
1082 /* We don't wrap .d files in %W{} since a missing .d file, and
1083 therefore no dependency entry, confuses make into thinking a .o
1084 file that happens to exist is up-to-date. */
1085 static const char *cpp_unique_options =
1086 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
1087 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
1088 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
1089 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
1090 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
1091 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
1092 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1093 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
1094 %{E|M|MM:%W{o*}}";
1096 /* This contains cpp options which are common with cc1_options and are passed
1097 only when preprocessing only to avoid duplication. We pass the cc1 spec
1098 options to the preprocessor so that it the cc1 spec may manipulate
1099 options used to set target flags. Those special target flags settings may
1100 in turn cause preprocessor symbols to be defined specially. */
1101 static const char *cpp_options =
1102 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
1103 %{f*} %{g*:%{!g0:%{g*} %{!fno-working-directory:-fworking-directory}}} %{O*}\
1104 %{undef} %{save-temps*:-fpch-preprocess}";
1106 /* This contains cpp options which are not passed when the preprocessor
1107 output will be used by another program. */
1108 static const char *cpp_debug_options = "%{d*}";
1110 /* NB: This is shared amongst all front-ends, except for Ada. */
1111 static const char *cc1_options =
1112 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
1113 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1114 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
1115 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
1116 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
1117 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
1118 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
1119 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
1120 %{-target-help:--target-help}\
1121 %{-version:--version}\
1122 %{-help=*:--help=%*}\
1123 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
1124 %{fsyntax-only:-o %j} %{-param*}\
1125 %{coverage:-fprofile-arcs -ftest-coverage}";
1127 static const char *asm_options =
1128 "%{-target-help:%:print-asm-header()} "
1129 #if HAVE_GNU_AS
1130 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
1131 to the assembler equivalents. */
1132 "%{v} %{w:-W} %{I*} "
1133 #endif
1134 ASM_COMPRESS_DEBUG_SPEC
1135 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
1137 static const char *invoke_as =
1138 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1139 "%{!fwpa*:\
1140 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1141 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
1143 #else
1144 "%{!fwpa*:\
1145 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1146 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
1148 #endif
1150 /* Some compilers have limits on line lengths, and the multilib_select
1151 and/or multilib_matches strings can be very long, so we build them at
1152 run time. */
1153 static struct obstack multilib_obstack;
1154 static const char *multilib_select;
1155 static const char *multilib_matches;
1156 static const char *multilib_defaults;
1157 static const char *multilib_exclusions;
1158 static const char *multilib_reuse;
1160 /* Check whether a particular argument is a default argument. */
1162 #ifndef MULTILIB_DEFAULTS
1163 #define MULTILIB_DEFAULTS { "" }
1164 #endif
1166 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
1168 #ifndef DRIVER_SELF_SPECS
1169 #define DRIVER_SELF_SPECS ""
1170 #endif
1172 /* Linking to libgomp implies pthreads. This is particularly important
1173 for targets that use different start files and suchlike. */
1174 #ifndef GOMP_SELF_SPECS
1175 #define GOMP_SELF_SPECS \
1176 "%{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*} 1): " \
1177 "-pthread}"
1178 #endif
1180 /* Likewise for -fgnu-tm. */
1181 #ifndef GTM_SELF_SPECS
1182 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
1183 #endif
1185 /* Likewise for -fcilkplus. */
1186 #ifndef CILK_SELF_SPECS
1187 #define CILK_SELF_SPECS "%{fcilkplus: -pthread}"
1188 #endif
1190 static const char *const driver_self_specs[] = {
1191 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
1192 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS,
1193 CILK_SELF_SPECS
1196 #ifndef OPTION_DEFAULT_SPECS
1197 #define OPTION_DEFAULT_SPECS { "", "" }
1198 #endif
1200 struct default_spec
1202 const char *name;
1203 const char *spec;
1206 static const struct default_spec
1207 option_default_specs[] = { OPTION_DEFAULT_SPECS };
1209 struct user_specs
1211 struct user_specs *next;
1212 const char *filename;
1215 static struct user_specs *user_specs_head, *user_specs_tail;
1218 /* Record the mapping from file suffixes for compilation specs. */
1220 struct compiler
1222 const char *suffix; /* Use this compiler for input files
1223 whose names end in this suffix. */
1225 const char *spec; /* To use this compiler, run this spec. */
1227 const char *cpp_spec; /* If non-NULL, substitute this spec
1228 for `%C', rather than the usual
1229 cpp_spec. */
1230 const int combinable; /* If nonzero, compiler can deal with
1231 multiple source files at once (IMA). */
1232 const int needs_preprocessing; /* If nonzero, source files need to
1233 be run through a preprocessor. */
1236 /* Pointer to a vector of `struct compiler' that gives the spec for
1237 compiling a file, based on its suffix.
1238 A file that does not end in any of these suffixes will be passed
1239 unchanged to the loader and nothing else will be done to it.
1241 An entry containing two 0s is used to terminate the vector.
1243 If multiple entries match a file, the last matching one is used. */
1245 static struct compiler *compilers;
1247 /* Number of entries in `compilers', not counting the null terminator. */
1249 static int n_compilers;
1251 /* The default list of file name suffixes and their compilation specs. */
1253 static const struct compiler default_compilers[] =
1255 /* Add lists of suffixes of known languages here. If those languages
1256 were not present when we built the driver, we will hit these copies
1257 and be given a more meaningful error than "file not used since
1258 linking is not done". */
1259 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
1260 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
1261 {".mii", "#Objective-C++", 0, 0, 0},
1262 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
1263 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
1264 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
1265 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
1266 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
1267 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
1268 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
1269 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
1270 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
1271 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
1272 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
1273 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1274 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1275 {".r", "#Ratfor", 0, 0, 0},
1276 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
1277 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
1278 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
1279 {".go", "#Go", 0, 1, 0},
1280 /* Next come the entries for C. */
1281 {".c", "@c", 0, 0, 1},
1282 {"@c",
1283 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1284 external preprocessor if -save-temps is given. */
1285 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1286 %{!E:%{!M:%{!MM:\
1287 %{traditional:\
1288 %eGNU C no longer supports -traditional without -E}\
1289 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1290 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1291 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1292 %(cc1_options)}\
1293 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1294 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1295 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1296 {"-",
1297 "%{!E:%e-E or -x required when input is from standard input}\
1298 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1299 {".h", "@c-header", 0, 0, 0},
1300 {"@c-header",
1301 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1302 external preprocessor if -save-temps is given. */
1303 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1304 %{!E:%{!M:%{!MM:\
1305 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1306 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1307 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1308 %(cc1_options)\
1309 %{!fsyntax-only:-o %g.s \
1310 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1311 %W{o*:--output-pch=%*}}%V}}\
1312 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1313 cc1 %(cpp_unique_options) %(cc1_options)\
1314 %{!fsyntax-only:-o %g.s \
1315 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1316 %W{o*:--output-pch=%*}}%V}}}}}}}", 0, 0, 0},
1317 {".i", "@cpp-output", 0, 0, 0},
1318 {"@cpp-output",
1319 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1320 {".s", "@assembler", 0, 0, 0},
1321 {"@assembler",
1322 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1323 {".sx", "@assembler-with-cpp", 0, 0, 0},
1324 {".S", "@assembler-with-cpp", 0, 0, 0},
1325 {"@assembler-with-cpp",
1326 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1327 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1328 %{E|M|MM:%(cpp_debug_options)}\
1329 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1330 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1331 #else
1332 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1333 %{E|M|MM:%(cpp_debug_options)}\
1334 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1335 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1336 #endif
1337 , 0, 0, 0},
1339 #include "specs.h"
1340 /* Mark end of table. */
1341 {0, 0, 0, 0, 0}
1344 /* Number of elements in default_compilers, not counting the terminator. */
1346 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1348 typedef char *char_p; /* For DEF_VEC_P. */
1350 /* A vector of options to give to the linker.
1351 These options are accumulated by %x,
1352 and substituted into the linker command with %X. */
1353 static vec<char_p> linker_options;
1355 /* A vector of options to give to the assembler.
1356 These options are accumulated by -Wa,
1357 and substituted into the assembler command with %Y. */
1358 static vec<char_p> assembler_options;
1360 /* A vector of options to give to the preprocessor.
1361 These options are accumulated by -Wp,
1362 and substituted into the preprocessor command with %Z. */
1363 static vec<char_p> preprocessor_options;
1365 static char *
1366 skip_whitespace (char *p)
1368 while (1)
1370 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1371 be considered whitespace. */
1372 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1373 return p + 1;
1374 else if (*p == '\n' || *p == ' ' || *p == '\t')
1375 p++;
1376 else if (*p == '#')
1378 while (*p != '\n')
1379 p++;
1380 p++;
1382 else
1383 break;
1386 return p;
1388 /* Structures to keep track of prefixes to try when looking for files. */
1390 struct prefix_list
1392 const char *prefix; /* String to prepend to the path. */
1393 struct prefix_list *next; /* Next in linked list. */
1394 int require_machine_suffix; /* Don't use without machine_suffix. */
1395 /* 2 means try both machine_suffix and just_machine_suffix. */
1396 int priority; /* Sort key - priority within list. */
1397 int os_multilib; /* 1 if OS multilib scheme should be used,
1398 0 for GCC multilib scheme. */
1401 struct path_prefix
1403 struct prefix_list *plist; /* List of prefixes to try */
1404 int max_len; /* Max length of a prefix in PLIST */
1405 const char *name; /* Name of this list (used in config stuff) */
1408 /* List of prefixes to try when looking for executables. */
1410 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1412 /* List of prefixes to try when looking for startup (crt0) files. */
1414 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1416 /* List of prefixes to try when looking for include files. */
1418 static struct path_prefix include_prefixes = { 0, 0, "include" };
1420 /* Suffix to attach to directories searched for commands.
1421 This looks like `MACHINE/VERSION/'. */
1423 static const char *machine_suffix = 0;
1425 /* Suffix to attach to directories searched for commands.
1426 This is just `MACHINE/'. */
1428 static const char *just_machine_suffix = 0;
1430 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1432 static const char *gcc_exec_prefix;
1434 /* Adjusted value of standard_libexec_prefix. */
1436 static const char *gcc_libexec_prefix;
1438 /* Default prefixes to attach to command names. */
1440 #ifndef STANDARD_STARTFILE_PREFIX_1
1441 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1442 #endif
1443 #ifndef STANDARD_STARTFILE_PREFIX_2
1444 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1445 #endif
1447 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1448 #undef MD_EXEC_PREFIX
1449 #undef MD_STARTFILE_PREFIX
1450 #undef MD_STARTFILE_PREFIX_1
1451 #endif
1453 /* If no prefixes defined, use the null string, which will disable them. */
1454 #ifndef MD_EXEC_PREFIX
1455 #define MD_EXEC_PREFIX ""
1456 #endif
1457 #ifndef MD_STARTFILE_PREFIX
1458 #define MD_STARTFILE_PREFIX ""
1459 #endif
1460 #ifndef MD_STARTFILE_PREFIX_1
1461 #define MD_STARTFILE_PREFIX_1 ""
1462 #endif
1464 /* These directories are locations set at configure-time based on the
1465 --prefix option provided to configure. Their initializers are
1466 defined in Makefile.in. These paths are not *directly* used when
1467 gcc_exec_prefix is set because, in that case, we know where the
1468 compiler has been installed, and use paths relative to that
1469 location instead. */
1470 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1471 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1472 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1473 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1475 /* For native compilers, these are well-known paths containing
1476 components that may be provided by the system. For cross
1477 compilers, these paths are not used. */
1478 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1479 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1480 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1481 static const char *const standard_startfile_prefix_1
1482 = STANDARD_STARTFILE_PREFIX_1;
1483 static const char *const standard_startfile_prefix_2
1484 = STANDARD_STARTFILE_PREFIX_2;
1486 /* A relative path to be used in finding the location of tools
1487 relative to the driver. */
1488 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1490 /* A prefix to be used when this is an accelerator compiler. */
1491 static const char *const accel_dir_suffix = ACCEL_DIR_SUFFIX;
1493 /* Subdirectory to use for locating libraries. Set by
1494 set_multilib_dir based on the compilation options. */
1496 static const char *multilib_dir;
1498 /* Subdirectory to use for locating libraries in OS conventions. Set by
1499 set_multilib_dir based on the compilation options. */
1501 static const char *multilib_os_dir;
1503 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1504 set_multilib_dir based on the compilation options. */
1506 static const char *multiarch_dir;
1508 /* Structure to keep track of the specs that have been defined so far.
1509 These are accessed using %(specname) in a compiler or link
1510 spec. */
1512 struct spec_list
1514 /* The following 2 fields must be first */
1515 /* to allow EXTRA_SPECS to be initialized */
1516 const char *name; /* name of the spec. */
1517 const char *ptr; /* available ptr if no static pointer */
1519 /* The following fields are not initialized */
1520 /* by EXTRA_SPECS */
1521 const char **ptr_spec; /* pointer to the spec itself. */
1522 struct spec_list *next; /* Next spec in linked list. */
1523 int name_len; /* length of the name */
1524 bool user_p; /* whether string come from file spec. */
1525 bool alloc_p; /* whether string was allocated */
1526 const char *default_ptr; /* The default value of *ptr_spec. */
1529 #define INIT_STATIC_SPEC(NAME,PTR) \
1530 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false, \
1531 *PTR }
1533 /* List of statically defined specs. */
1534 static struct spec_list static_specs[] =
1536 INIT_STATIC_SPEC ("asm", &asm_spec),
1537 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1538 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1539 INIT_STATIC_SPEC ("asm_options", &asm_options),
1540 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1541 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1542 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1543 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1544 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1545 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1546 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1547 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1548 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1549 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1550 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1551 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1552 INIT_STATIC_SPEC ("link", &link_spec),
1553 INIT_STATIC_SPEC ("lib", &lib_spec),
1554 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1555 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1556 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1557 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1558 INIT_STATIC_SPEC ("version", &compiler_version),
1559 INIT_STATIC_SPEC ("multilib", &multilib_select),
1560 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1561 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1562 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1563 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1564 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1565 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1566 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1567 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1568 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1569 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1570 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1571 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1572 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1573 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1574 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1575 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1576 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1577 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1578 INIT_STATIC_SPEC ("self_spec", &self_spec),
1581 #ifdef EXTRA_SPECS /* additional specs needed */
1582 /* Structure to keep track of just the first two args of a spec_list.
1583 That is all that the EXTRA_SPECS macro gives us. */
1584 struct spec_list_1
1586 const char *const name;
1587 const char *const ptr;
1590 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1591 static struct spec_list *extra_specs = (struct spec_list *) 0;
1592 #endif
1594 /* List of dynamically allocates specs that have been defined so far. */
1596 static struct spec_list *specs = (struct spec_list *) 0;
1598 /* List of static spec functions. */
1600 static const struct spec_function static_spec_functions[] =
1602 { "getenv", getenv_spec_function },
1603 { "if-exists", if_exists_spec_function },
1604 { "if-exists-else", if_exists_else_spec_function },
1605 { "sanitize", sanitize_spec_function },
1606 { "replace-outfile", replace_outfile_spec_function },
1607 { "remove-outfile", remove_outfile_spec_function },
1608 { "version-compare", version_compare_spec_function },
1609 { "include", include_spec_function },
1610 { "find-file", find_file_spec_function },
1611 { "find-plugindir", find_plugindir_spec_function },
1612 { "print-asm-header", print_asm_header_spec_function },
1613 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1614 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1615 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1616 { "pass-through-libs", pass_through_libs_spec_func },
1617 { "replace-extension", replace_extension_spec_func },
1618 { "gt", greater_than_spec_func },
1619 #ifdef EXTRA_SPEC_FUNCTIONS
1620 EXTRA_SPEC_FUNCTIONS
1621 #endif
1622 { 0, 0 }
1625 static int processing_spec_function;
1627 /* Add appropriate libgcc specs to OBSTACK, taking into account
1628 various permutations of -shared-libgcc, -shared, and such. */
1630 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1632 #ifndef USE_LD_AS_NEEDED
1633 #define USE_LD_AS_NEEDED 0
1634 #endif
1636 static void
1637 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1638 const char *static_name, const char *eh_name)
1640 char *buf;
1642 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1643 "%{!static:%{!static-libgcc:"
1644 #if USE_LD_AS_NEEDED
1645 "%{!shared-libgcc:",
1646 static_name, " " LD_AS_NEEDED_OPTION " ",
1647 shared_name, " " LD_NO_AS_NEEDED_OPTION
1649 "%{shared-libgcc:",
1650 shared_name, "%{!shared: ", static_name, "}"
1652 #else
1653 "%{!shared:"
1654 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1655 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1657 #ifdef LINK_EH_SPEC
1658 "%{shared:"
1659 "%{shared-libgcc:", shared_name, "}"
1660 "%{!shared-libgcc:", static_name, "}"
1662 #else
1663 "%{shared:", shared_name, "}"
1664 #endif
1665 #endif
1666 "}}", NULL);
1668 obstack_grow (obstack, buf, strlen (buf));
1669 free (buf);
1671 #endif /* ENABLE_SHARED_LIBGCC */
1673 /* Initialize the specs lookup routines. */
1675 static void
1676 init_spec (void)
1678 struct spec_list *next = (struct spec_list *) 0;
1679 struct spec_list *sl = (struct spec_list *) 0;
1680 int i;
1682 if (specs)
1683 return; /* Already initialized. */
1685 if (verbose_flag)
1686 fnotice (stderr, "Using built-in specs.\n");
1688 #ifdef EXTRA_SPECS
1689 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1691 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1693 sl = &extra_specs[i];
1694 sl->name = extra_specs_1[i].name;
1695 sl->ptr = extra_specs_1[i].ptr;
1696 sl->next = next;
1697 sl->name_len = strlen (sl->name);
1698 sl->ptr_spec = &sl->ptr;
1699 gcc_assert (sl->ptr_spec != NULL);
1700 sl->default_ptr = sl->ptr;
1701 next = sl;
1703 #endif
1705 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1707 sl = &static_specs[i];
1708 sl->next = next;
1709 next = sl;
1712 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1713 /* ??? If neither -shared-libgcc nor --static-libgcc was
1714 seen, then we should be making an educated guess. Some proposed
1715 heuristics for ELF include:
1717 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1718 program will be doing dynamic loading, which will likely
1719 need the shared libgcc.
1721 (2) If "-ldl", then it's also a fair bet that we're doing
1722 dynamic loading.
1724 (3) For each ET_DYN we're linking against (either through -lfoo
1725 or /some/path/foo.so), check to see whether it or one of
1726 its dependencies depends on a shared libgcc.
1728 (4) If "-shared"
1730 If the runtime is fixed to look for program headers instead
1731 of calling __register_frame_info at all, for each object,
1732 use the shared libgcc if any EH symbol referenced.
1734 If crtstuff is fixed to not invoke __register_frame_info
1735 automatically, for each object, use the shared libgcc if
1736 any non-empty unwind section found.
1738 Doing any of this probably requires invoking an external program to
1739 do the actual object file scanning. */
1741 const char *p = libgcc_spec;
1742 int in_sep = 1;
1744 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1745 when given the proper command line arguments. */
1746 while (*p)
1748 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1750 init_gcc_specs (&obstack,
1751 "-lgcc_s"
1752 #ifdef USE_LIBUNWIND_EXCEPTIONS
1753 " -lunwind"
1754 #endif
1756 "-lgcc",
1757 "-lgcc_eh"
1758 #ifdef USE_LIBUNWIND_EXCEPTIONS
1759 # ifdef HAVE_LD_STATIC_DYNAMIC
1760 " %{!static:" LD_STATIC_OPTION "} -lunwind"
1761 " %{!static:" LD_DYNAMIC_OPTION "}"
1762 # else
1763 " -lunwind"
1764 # endif
1765 #endif
1768 p += 5;
1769 in_sep = 0;
1771 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1773 /* Ug. We don't know shared library extensions. Hope that
1774 systems that use this form don't do shared libraries. */
1775 init_gcc_specs (&obstack,
1776 "-lgcc_s",
1777 "libgcc.a%s",
1778 "libgcc_eh.a%s"
1779 #ifdef USE_LIBUNWIND_EXCEPTIONS
1780 " -lunwind"
1781 #endif
1783 p += 10;
1784 in_sep = 0;
1786 else
1788 obstack_1grow (&obstack, *p);
1789 in_sep = (*p == ' ');
1790 p += 1;
1794 obstack_1grow (&obstack, '\0');
1795 libgcc_spec = XOBFINISH (&obstack, const char *);
1797 #endif
1798 #ifdef USE_AS_TRADITIONAL_FORMAT
1799 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1801 static const char tf[] = "--traditional-format ";
1802 obstack_grow (&obstack, tf, sizeof (tf) - 1);
1803 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1804 asm_spec = XOBFINISH (&obstack, const char *);
1806 #endif
1808 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1809 defined LINKER_HASH_STYLE
1810 # ifdef LINK_BUILDID_SPEC
1811 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1812 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof (LINK_BUILDID_SPEC) - 1);
1813 # endif
1814 # ifdef LINK_EH_SPEC
1815 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1816 obstack_grow (&obstack, LINK_EH_SPEC, sizeof (LINK_EH_SPEC) - 1);
1817 # endif
1818 # ifdef LINKER_HASH_STYLE
1819 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1820 before. */
1822 static const char hash_style[] = "--hash-style=";
1823 obstack_grow (&obstack, hash_style, sizeof (hash_style) - 1);
1824 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof (LINKER_HASH_STYLE) - 1);
1825 obstack_1grow (&obstack, ' ');
1827 # endif
1828 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1829 link_spec = XOBFINISH (&obstack, const char *);
1830 #endif
1832 specs = sl;
1835 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1836 removed; If the spec starts with a + then SPEC is added to the end of the
1837 current spec. */
1839 static void
1840 set_spec (const char *name, const char *spec, bool user_p)
1842 struct spec_list *sl;
1843 const char *old_spec;
1844 int name_len = strlen (name);
1845 int i;
1847 /* If this is the first call, initialize the statically allocated specs. */
1848 if (!specs)
1850 struct spec_list *next = (struct spec_list *) 0;
1851 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1853 sl = &static_specs[i];
1854 sl->next = next;
1855 next = sl;
1857 specs = sl;
1860 /* See if the spec already exists. */
1861 for (sl = specs; sl; sl = sl->next)
1862 if (name_len == sl->name_len && !strcmp (sl->name, name))
1863 break;
1865 if (!sl)
1867 /* Not found - make it. */
1868 sl = XNEW (struct spec_list);
1869 sl->name = xstrdup (name);
1870 sl->name_len = name_len;
1871 sl->ptr_spec = &sl->ptr;
1872 sl->alloc_p = 0;
1873 *(sl->ptr_spec) = "";
1874 sl->next = specs;
1875 sl->default_ptr = NULL;
1876 specs = sl;
1879 old_spec = *(sl->ptr_spec);
1880 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1881 ? concat (old_spec, spec + 1, NULL)
1882 : xstrdup (spec));
1884 #ifdef DEBUG_SPECS
1885 if (verbose_flag)
1886 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1887 #endif
1889 /* Free the old spec. */
1890 if (old_spec && sl->alloc_p)
1891 free (CONST_CAST (char *, old_spec));
1893 sl->user_p = user_p;
1894 sl->alloc_p = true;
1897 /* Accumulate a command (program name and args), and run it. */
1899 typedef const char *const_char_p; /* For DEF_VEC_P. */
1901 /* Vector of pointers to arguments in the current line of specifications. */
1903 static vec<const_char_p> argbuf;
1905 /* Were the options -c, -S or -E passed. */
1906 static int have_c = 0;
1908 /* Was the option -o passed. */
1909 static int have_o = 0;
1911 /* Pointer to output file name passed in with -o. */
1912 static const char *output_file = 0;
1914 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1915 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1916 it here. */
1918 static struct temp_name {
1919 const char *suffix; /* suffix associated with the code. */
1920 int length; /* strlen (suffix). */
1921 int unique; /* Indicates whether %g or %u/%U was used. */
1922 const char *filename; /* associated filename. */
1923 int filename_length; /* strlen (filename). */
1924 struct temp_name *next;
1925 } *temp_names;
1927 /* Number of commands executed so far. */
1929 static int execution_count;
1931 /* Number of commands that exited with a signal. */
1933 static int signal_count;
1935 /* Allocate the argument vector. */
1937 static void
1938 alloc_args (void)
1940 argbuf.create (10);
1943 /* Clear out the vector of arguments (after a command is executed). */
1945 static void
1946 clear_args (void)
1948 argbuf.truncate (0);
1951 /* Add one argument to the vector at the end.
1952 This is done when a space is seen or at the end of the line.
1953 If DELETE_ALWAYS is nonzero, the arg is a filename
1954 and the file should be deleted eventually.
1955 If DELETE_FAILURE is nonzero, the arg is a filename
1956 and the file should be deleted if this compilation fails. */
1958 static void
1959 store_arg (const char *arg, int delete_always, int delete_failure)
1961 argbuf.safe_push (arg);
1963 if (delete_always || delete_failure)
1965 const char *p;
1966 /* If the temporary file we should delete is specified as
1967 part of a joined argument extract the filename. */
1968 if (arg[0] == '-'
1969 && (p = strrchr (arg, '=')))
1970 arg = p + 1;
1971 record_temp_file (arg, delete_always, delete_failure);
1975 /* Load specs from a file name named FILENAME, replacing occurrences of
1976 various different types of line-endings, \r\n, \n\r and just \r, with
1977 a single \n. */
1979 static char *
1980 load_specs (const char *filename)
1982 int desc;
1983 int readlen;
1984 struct stat statbuf;
1985 char *buffer;
1986 char *buffer_p;
1987 char *specs;
1988 char *specs_p;
1990 if (verbose_flag)
1991 fnotice (stderr, "Reading specs from %s\n", filename);
1993 /* Open and stat the file. */
1994 desc = open (filename, O_RDONLY, 0);
1995 if (desc < 0)
1996 pfatal_with_name (filename);
1997 if (stat (filename, &statbuf) < 0)
1998 pfatal_with_name (filename);
2000 /* Read contents of file into BUFFER. */
2001 buffer = XNEWVEC (char, statbuf.st_size + 1);
2002 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
2003 if (readlen < 0)
2004 pfatal_with_name (filename);
2005 buffer[readlen] = 0;
2006 close (desc);
2008 specs = XNEWVEC (char, readlen + 1);
2009 specs_p = specs;
2010 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
2012 int skip = 0;
2013 char c = *buffer_p;
2014 if (c == '\r')
2016 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
2017 skip = 1;
2018 else if (*(buffer_p + 1) == '\n') /* \r\n */
2019 skip = 1;
2020 else /* \r */
2021 c = '\n';
2023 if (! skip)
2024 *specs_p++ = c;
2026 *specs_p = '\0';
2028 free (buffer);
2029 return (specs);
2032 /* Read compilation specs from a file named FILENAME,
2033 replacing the default ones.
2035 A suffix which starts with `*' is a definition for
2036 one of the machine-specific sub-specs. The "suffix" should be
2037 *asm, *cc1, *cpp, *link, *startfile, etc.
2038 The corresponding spec is stored in asm_spec, etc.,
2039 rather than in the `compilers' vector.
2041 Anything invalid in the file is a fatal error. */
2043 static void
2044 read_specs (const char *filename, bool main_p, bool user_p)
2046 char *buffer;
2047 char *p;
2049 buffer = load_specs (filename);
2051 /* Scan BUFFER for specs, putting them in the vector. */
2052 p = buffer;
2053 while (1)
2055 char *suffix;
2056 char *spec;
2057 char *in, *out, *p1, *p2, *p3;
2059 /* Advance P in BUFFER to the next nonblank nocomment line. */
2060 p = skip_whitespace (p);
2061 if (*p == 0)
2062 break;
2064 /* Is this a special command that starts with '%'? */
2065 /* Don't allow this for the main specs file, since it would
2066 encourage people to overwrite it. */
2067 if (*p == '%' && !main_p)
2069 p1 = p;
2070 while (*p && *p != '\n')
2071 p++;
2073 /* Skip '\n'. */
2074 p++;
2076 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
2077 && (p1[sizeof "%include" - 1] == ' '
2078 || p1[sizeof "%include" - 1] == '\t'))
2080 char *new_filename;
2082 p1 += sizeof ("%include");
2083 while (*p1 == ' ' || *p1 == '\t')
2084 p1++;
2086 if (*p1++ != '<' || p[-2] != '>')
2087 fatal_error (input_location,
2088 "specs %%include syntax malformed after "
2089 "%ld characters",
2090 (long) (p1 - buffer + 1));
2092 p[-2] = '\0';
2093 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2094 read_specs (new_filename ? new_filename : p1, false, user_p);
2095 continue;
2097 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
2098 && (p1[sizeof "%include_noerr" - 1] == ' '
2099 || p1[sizeof "%include_noerr" - 1] == '\t'))
2101 char *new_filename;
2103 p1 += sizeof "%include_noerr";
2104 while (*p1 == ' ' || *p1 == '\t')
2105 p1++;
2107 if (*p1++ != '<' || p[-2] != '>')
2108 fatal_error (input_location,
2109 "specs %%include syntax malformed after "
2110 "%ld characters",
2111 (long) (p1 - buffer + 1));
2113 p[-2] = '\0';
2114 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2115 if (new_filename)
2116 read_specs (new_filename, false, user_p);
2117 else if (verbose_flag)
2118 fnotice (stderr, "could not find specs file %s\n", p1);
2119 continue;
2121 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
2122 && (p1[sizeof "%rename" - 1] == ' '
2123 || p1[sizeof "%rename" - 1] == '\t'))
2125 int name_len;
2126 struct spec_list *sl;
2127 struct spec_list *newsl;
2129 /* Get original name. */
2130 p1 += sizeof "%rename";
2131 while (*p1 == ' ' || *p1 == '\t')
2132 p1++;
2134 if (! ISALPHA ((unsigned char) *p1))
2135 fatal_error (input_location,
2136 "specs %%rename syntax malformed after "
2137 "%ld characters",
2138 (long) (p1 - buffer));
2140 p2 = p1;
2141 while (*p2 && !ISSPACE ((unsigned char) *p2))
2142 p2++;
2144 if (*p2 != ' ' && *p2 != '\t')
2145 fatal_error (input_location,
2146 "specs %%rename syntax malformed after "
2147 "%ld characters",
2148 (long) (p2 - buffer));
2150 name_len = p2 - p1;
2151 *p2++ = '\0';
2152 while (*p2 == ' ' || *p2 == '\t')
2153 p2++;
2155 if (! ISALPHA ((unsigned char) *p2))
2156 fatal_error (input_location,
2157 "specs %%rename syntax malformed after "
2158 "%ld characters",
2159 (long) (p2 - buffer));
2161 /* Get new spec name. */
2162 p3 = p2;
2163 while (*p3 && !ISSPACE ((unsigned char) *p3))
2164 p3++;
2166 if (p3 != p - 1)
2167 fatal_error (input_location,
2168 "specs %%rename syntax malformed after "
2169 "%ld characters",
2170 (long) (p3 - buffer));
2171 *p3 = '\0';
2173 for (sl = specs; sl; sl = sl->next)
2174 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2175 break;
2177 if (!sl)
2178 fatal_error (input_location,
2179 "specs %s spec was not found to be renamed", p1);
2181 if (strcmp (p1, p2) == 0)
2182 continue;
2184 for (newsl = specs; newsl; newsl = newsl->next)
2185 if (strcmp (newsl->name, p2) == 0)
2186 fatal_error (input_location,
2187 "%s: attempt to rename spec %qs to "
2188 "already defined spec %qs",
2189 filename, p1, p2);
2191 if (verbose_flag)
2193 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
2194 #ifdef DEBUG_SPECS
2195 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
2196 #endif
2199 set_spec (p2, *(sl->ptr_spec), user_p);
2200 if (sl->alloc_p)
2201 free (CONST_CAST (char *, *(sl->ptr_spec)));
2203 *(sl->ptr_spec) = "";
2204 sl->alloc_p = 0;
2205 continue;
2207 else
2208 fatal_error (input_location,
2209 "specs unknown %% command after %ld characters",
2210 (long) (p1 - buffer));
2213 /* Find the colon that should end the suffix. */
2214 p1 = p;
2215 while (*p1 && *p1 != ':' && *p1 != '\n')
2216 p1++;
2218 /* The colon shouldn't be missing. */
2219 if (*p1 != ':')
2220 fatal_error (input_location,
2221 "specs file malformed after %ld characters",
2222 (long) (p1 - buffer));
2224 /* Skip back over trailing whitespace. */
2225 p2 = p1;
2226 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2227 p2--;
2229 /* Copy the suffix to a string. */
2230 suffix = save_string (p, p2 - p);
2231 /* Find the next line. */
2232 p = skip_whitespace (p1 + 1);
2233 if (p[1] == 0)
2234 fatal_error (input_location,
2235 "specs file malformed after %ld characters",
2236 (long) (p - buffer));
2238 p1 = p;
2239 /* Find next blank line or end of string. */
2240 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2241 p1++;
2243 /* Specs end at the blank line and do not include the newline. */
2244 spec = save_string (p, p1 - p);
2245 p = p1;
2247 /* Delete backslash-newline sequences from the spec. */
2248 in = spec;
2249 out = spec;
2250 while (*in != 0)
2252 if (in[0] == '\\' && in[1] == '\n')
2253 in += 2;
2254 else if (in[0] == '#')
2255 while (*in && *in != '\n')
2256 in++;
2258 else
2259 *out++ = *in++;
2261 *out = 0;
2263 if (suffix[0] == '*')
2265 if (! strcmp (suffix, "*link_command"))
2266 link_command_spec = spec;
2267 else
2269 set_spec (suffix + 1, spec, user_p);
2270 free (spec);
2273 else
2275 /* Add this pair to the vector. */
2276 compilers
2277 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
2279 compilers[n_compilers].suffix = suffix;
2280 compilers[n_compilers].spec = spec;
2281 n_compilers++;
2282 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2285 if (*suffix == 0)
2286 link_command_spec = spec;
2289 if (link_command_spec == 0)
2290 fatal_error (input_location, "spec file has no spec for linking");
2292 XDELETEVEC (buffer);
2295 /* Record the names of temporary files we tell compilers to write,
2296 and delete them at the end of the run. */
2298 /* This is the common prefix we use to make temp file names.
2299 It is chosen once for each run of this program.
2300 It is substituted into a spec by %g or %j.
2301 Thus, all temp file names contain this prefix.
2302 In practice, all temp file names start with this prefix.
2304 This prefix comes from the envvar TMPDIR if it is defined;
2305 otherwise, from the P_tmpdir macro if that is defined;
2306 otherwise, in /usr/tmp or /tmp;
2307 or finally the current directory if all else fails. */
2309 static const char *temp_filename;
2311 /* Length of the prefix. */
2313 static int temp_filename_length;
2315 /* Define the list of temporary files to delete. */
2317 struct temp_file
2319 const char *name;
2320 struct temp_file *next;
2323 /* Queue of files to delete on success or failure of compilation. */
2324 static struct temp_file *always_delete_queue;
2325 /* Queue of files to delete on failure of compilation. */
2326 static struct temp_file *failure_delete_queue;
2328 /* Record FILENAME as a file to be deleted automatically.
2329 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2330 otherwise delete it in any case.
2331 FAIL_DELETE nonzero means delete it if a compilation step fails;
2332 otherwise delete it in any case. */
2334 void
2335 record_temp_file (const char *filename, int always_delete, int fail_delete)
2337 char *const name = xstrdup (filename);
2339 if (always_delete)
2341 struct temp_file *temp;
2342 for (temp = always_delete_queue; temp; temp = temp->next)
2343 if (! filename_cmp (name, temp->name))
2344 goto already1;
2346 temp = XNEW (struct temp_file);
2347 temp->next = always_delete_queue;
2348 temp->name = name;
2349 always_delete_queue = temp;
2351 already1:;
2354 if (fail_delete)
2356 struct temp_file *temp;
2357 for (temp = failure_delete_queue; temp; temp = temp->next)
2358 if (! filename_cmp (name, temp->name))
2360 free (name);
2361 goto already2;
2364 temp = XNEW (struct temp_file);
2365 temp->next = failure_delete_queue;
2366 temp->name = name;
2367 failure_delete_queue = temp;
2369 already2:;
2373 /* Delete all the temporary files whose names we previously recorded. */
2375 #ifndef DELETE_IF_ORDINARY
2376 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2377 do \
2379 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2380 if (unlink (NAME) < 0) \
2381 if (VERBOSE_FLAG) \
2382 perror_with_name (NAME); \
2383 } while (0)
2384 #endif
2386 static void
2387 delete_if_ordinary (const char *name)
2389 struct stat st;
2390 #ifdef DEBUG
2391 int i, c;
2393 printf ("Delete %s? (y or n) ", name);
2394 fflush (stdout);
2395 i = getchar ();
2396 if (i != '\n')
2397 while ((c = getchar ()) != '\n' && c != EOF)
2400 if (i == 'y' || i == 'Y')
2401 #endif /* DEBUG */
2402 DELETE_IF_ORDINARY (name, st, verbose_flag);
2405 static void
2406 delete_temp_files (void)
2408 struct temp_file *temp;
2410 for (temp = always_delete_queue; temp; temp = temp->next)
2411 delete_if_ordinary (temp->name);
2412 always_delete_queue = 0;
2415 /* Delete all the files to be deleted on error. */
2417 static void
2418 delete_failure_queue (void)
2420 struct temp_file *temp;
2422 for (temp = failure_delete_queue; temp; temp = temp->next)
2423 delete_if_ordinary (temp->name);
2426 static void
2427 clear_failure_queue (void)
2429 failure_delete_queue = 0;
2432 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2433 returns non-NULL.
2434 If DO_MULTI is true iterate over the paths twice, first with multilib
2435 suffix then without, otherwise iterate over the paths once without
2436 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2437 to avoid visiting the same path twice, but we could do better. For
2438 instance, /usr/lib/../lib is considered different from /usr/lib.
2439 At least EXTRA_SPACE chars past the end of the path passed to
2440 CALLBACK are available for use by the callback.
2441 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2443 Returns the value returned by CALLBACK. */
2445 static void *
2446 for_each_path (const struct path_prefix *paths,
2447 bool do_multi,
2448 size_t extra_space,
2449 void *(*callback) (char *, void *),
2450 void *callback_info)
2452 struct prefix_list *pl;
2453 const char *multi_dir = NULL;
2454 const char *multi_os_dir = NULL;
2455 const char *multiarch_suffix = NULL;
2456 const char *multi_suffix;
2457 const char *just_multi_suffix;
2458 char *path = NULL;
2459 void *ret = NULL;
2460 bool skip_multi_dir = false;
2461 bool skip_multi_os_dir = false;
2463 multi_suffix = machine_suffix;
2464 just_multi_suffix = just_machine_suffix;
2465 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2467 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2468 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2469 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2471 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2472 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2473 if (multiarch_dir)
2474 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2476 while (1)
2478 size_t multi_dir_len = 0;
2479 size_t multi_os_dir_len = 0;
2480 size_t multiarch_len = 0;
2481 size_t suffix_len;
2482 size_t just_suffix_len;
2483 size_t len;
2485 if (multi_dir)
2486 multi_dir_len = strlen (multi_dir);
2487 if (multi_os_dir)
2488 multi_os_dir_len = strlen (multi_os_dir);
2489 if (multiarch_suffix)
2490 multiarch_len = strlen (multiarch_suffix);
2491 suffix_len = strlen (multi_suffix);
2492 just_suffix_len = strlen (just_multi_suffix);
2494 if (path == NULL)
2496 len = paths->max_len + extra_space + 1;
2497 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2498 path = XNEWVEC (char, len);
2501 for (pl = paths->plist; pl != 0; pl = pl->next)
2503 len = strlen (pl->prefix);
2504 memcpy (path, pl->prefix, len);
2506 /* Look first in MACHINE/VERSION subdirectory. */
2507 if (!skip_multi_dir)
2509 memcpy (path + len, multi_suffix, suffix_len + 1);
2510 ret = callback (path, callback_info);
2511 if (ret)
2512 break;
2515 /* Some paths are tried with just the machine (ie. target)
2516 subdir. This is used for finding as, ld, etc. */
2517 if (!skip_multi_dir
2518 && pl->require_machine_suffix == 2)
2520 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2521 ret = callback (path, callback_info);
2522 if (ret)
2523 break;
2526 /* Now try the multiarch path. */
2527 if (!skip_multi_dir
2528 && !pl->require_machine_suffix && multiarch_dir)
2530 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2531 ret = callback (path, callback_info);
2532 if (ret)
2533 break;
2536 /* Now try the base path. */
2537 if (!pl->require_machine_suffix
2538 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2540 const char *this_multi;
2541 size_t this_multi_len;
2543 if (pl->os_multilib)
2545 this_multi = multi_os_dir;
2546 this_multi_len = multi_os_dir_len;
2548 else
2550 this_multi = multi_dir;
2551 this_multi_len = multi_dir_len;
2554 if (this_multi_len)
2555 memcpy (path + len, this_multi, this_multi_len + 1);
2556 else
2557 path[len] = '\0';
2559 ret = callback (path, callback_info);
2560 if (ret)
2561 break;
2564 if (pl)
2565 break;
2567 if (multi_dir == NULL && multi_os_dir == NULL)
2568 break;
2570 /* Run through the paths again, this time without multilibs.
2571 Don't repeat any we have already seen. */
2572 if (multi_dir)
2574 free (CONST_CAST (char *, multi_dir));
2575 multi_dir = NULL;
2576 free (CONST_CAST (char *, multi_suffix));
2577 multi_suffix = machine_suffix;
2578 free (CONST_CAST (char *, just_multi_suffix));
2579 just_multi_suffix = just_machine_suffix;
2581 else
2582 skip_multi_dir = true;
2583 if (multi_os_dir)
2585 free (CONST_CAST (char *, multi_os_dir));
2586 multi_os_dir = NULL;
2588 else
2589 skip_multi_os_dir = true;
2592 if (multi_dir)
2594 free (CONST_CAST (char *, multi_dir));
2595 free (CONST_CAST (char *, multi_suffix));
2596 free (CONST_CAST (char *, just_multi_suffix));
2598 if (multi_os_dir)
2599 free (CONST_CAST (char *, multi_os_dir));
2600 if (ret != path)
2601 free (path);
2602 return ret;
2605 /* Callback for build_search_list. Adds path to obstack being built. */
2607 struct add_to_obstack_info {
2608 struct obstack *ob;
2609 bool check_dir;
2610 bool first_time;
2613 static void *
2614 add_to_obstack (char *path, void *data)
2616 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2618 if (info->check_dir && !is_directory (path, false))
2619 return NULL;
2621 if (!info->first_time)
2622 obstack_1grow (info->ob, PATH_SEPARATOR);
2624 obstack_grow (info->ob, path, strlen (path));
2626 info->first_time = false;
2627 return NULL;
2630 /* Add or change the value of an environment variable, outputting the
2631 change to standard error if in verbose mode. */
2632 static void
2633 xputenv (const char *string)
2635 env.xput (string);
2638 /* Build a list of search directories from PATHS.
2639 PREFIX is a string to prepend to the list.
2640 If CHECK_DIR_P is true we ensure the directory exists.
2641 If DO_MULTI is true, multilib paths are output first, then
2642 non-multilib paths.
2643 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2644 It is also used by the --print-search-dirs flag. */
2646 static char *
2647 build_search_list (const struct path_prefix *paths, const char *prefix,
2648 bool check_dir, bool do_multi)
2650 struct add_to_obstack_info info;
2652 info.ob = &collect_obstack;
2653 info.check_dir = check_dir;
2654 info.first_time = true;
2656 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2657 obstack_1grow (&collect_obstack, '=');
2659 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2661 obstack_1grow (&collect_obstack, '\0');
2662 return XOBFINISH (&collect_obstack, char *);
2665 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2666 for collect. */
2668 static void
2669 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2670 bool do_multi)
2672 xputenv (build_search_list (paths, env_var, true, do_multi));
2675 /* Check whether NAME can be accessed in MODE. This is like access,
2676 except that it never considers directories to be executable. */
2678 static int
2679 access_check (const char *name, int mode)
2681 if (mode == X_OK)
2683 struct stat st;
2685 if (stat (name, &st) < 0
2686 || S_ISDIR (st.st_mode))
2687 return -1;
2690 return access (name, mode);
2693 /* Callback for find_a_file. Appends the file name to the directory
2694 path. If the resulting file exists in the right mode, return the
2695 full pathname to the file. */
2697 struct file_at_path_info {
2698 const char *name;
2699 const char *suffix;
2700 int name_len;
2701 int suffix_len;
2702 int mode;
2705 static void *
2706 file_at_path (char *path, void *data)
2708 struct file_at_path_info *info = (struct file_at_path_info *) data;
2709 size_t len = strlen (path);
2711 memcpy (path + len, info->name, info->name_len);
2712 len += info->name_len;
2714 /* Some systems have a suffix for executable files.
2715 So try appending that first. */
2716 if (info->suffix_len)
2718 memcpy (path + len, info->suffix, info->suffix_len + 1);
2719 if (access_check (path, info->mode) == 0)
2720 return path;
2723 path[len] = '\0';
2724 if (access_check (path, info->mode) == 0)
2725 return path;
2727 return NULL;
2730 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2731 access to check permissions. If DO_MULTI is true, search multilib
2732 paths then non-multilib paths, otherwise do not search multilib paths.
2733 Return 0 if not found, otherwise return its name, allocated with malloc. */
2735 static char *
2736 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2737 bool do_multi)
2739 struct file_at_path_info info;
2741 #ifdef DEFAULT_ASSEMBLER
2742 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2743 return xstrdup (DEFAULT_ASSEMBLER);
2744 #endif
2746 #ifdef DEFAULT_LINKER
2747 if (! strcmp (name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2748 return xstrdup (DEFAULT_LINKER);
2749 #endif
2751 /* Determine the filename to execute (special case for absolute paths). */
2753 if (IS_ABSOLUTE_PATH (name))
2755 if (access (name, mode) == 0)
2756 return xstrdup (name);
2758 return NULL;
2761 info.name = name;
2762 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2763 info.name_len = strlen (info.name);
2764 info.suffix_len = strlen (info.suffix);
2765 info.mode = mode;
2767 return (char*) for_each_path (pprefix, do_multi,
2768 info.name_len + info.suffix_len,
2769 file_at_path, &info);
2772 /* Ranking of prefixes in the sort list. -B prefixes are put before
2773 all others. */
2775 enum path_prefix_priority
2777 PREFIX_PRIORITY_B_OPT,
2778 PREFIX_PRIORITY_LAST
2781 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2782 order according to PRIORITY. Within each PRIORITY, new entries are
2783 appended.
2785 If WARN is nonzero, we will warn if no file is found
2786 through this prefix. WARN should point to an int
2787 which will be set to 1 if this entry is used.
2789 COMPONENT is the value to be passed to update_path.
2791 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2792 the complete value of machine_suffix.
2793 2 means try both machine_suffix and just_machine_suffix. */
2795 static void
2796 add_prefix (struct path_prefix *pprefix, const char *prefix,
2797 const char *component, /* enum prefix_priority */ int priority,
2798 int require_machine_suffix, int os_multilib)
2800 struct prefix_list *pl, **prev;
2801 int len;
2803 for (prev = &pprefix->plist;
2804 (*prev) != NULL && (*prev)->priority <= priority;
2805 prev = &(*prev)->next)
2808 /* Keep track of the longest prefix. */
2810 prefix = update_path (prefix, component);
2811 len = strlen (prefix);
2812 if (len > pprefix->max_len)
2813 pprefix->max_len = len;
2815 pl = XNEW (struct prefix_list);
2816 pl->prefix = prefix;
2817 pl->require_machine_suffix = require_machine_suffix;
2818 pl->priority = priority;
2819 pl->os_multilib = os_multilib;
2821 /* Insert after PREV. */
2822 pl->next = (*prev);
2823 (*prev) = pl;
2826 /* Same as add_prefix, but prepending target_system_root to prefix. */
2827 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2828 static void
2829 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2830 const char *component,
2831 /* enum prefix_priority */ int priority,
2832 int require_machine_suffix, int os_multilib)
2834 if (!IS_ABSOLUTE_PATH (prefix))
2835 fatal_error (input_location, "system path %qs is not absolute", prefix);
2837 if (target_system_root)
2839 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2840 size_t sysroot_len = strlen (target_system_root);
2842 if (sysroot_len > 0
2843 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2844 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2846 if (target_sysroot_suffix)
2847 prefix = concat (sysroot_no_trailing_dir_separator,
2848 target_sysroot_suffix, prefix, NULL);
2849 else
2850 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2852 free (sysroot_no_trailing_dir_separator);
2854 /* We have to override this because GCC's notion of sysroot
2855 moves along with GCC. */
2856 component = "GCC";
2859 add_prefix (pprefix, prefix, component, priority,
2860 require_machine_suffix, os_multilib);
2863 /* Execute the command specified by the arguments on the current line of spec.
2864 When using pipes, this includes several piped-together commands
2865 with `|' between them.
2867 Return 0 if successful, -1 if failed. */
2869 static int
2870 execute (void)
2872 int i;
2873 int n_commands; /* # of command. */
2874 char *string;
2875 struct pex_obj *pex;
2876 struct command
2878 const char *prog; /* program name. */
2879 const char **argv; /* vector of args. */
2881 const char *arg;
2883 struct command *commands; /* each command buffer with above info. */
2885 gcc_assert (!processing_spec_function);
2887 if (wrapper_string)
2889 string = find_a_file (&exec_prefixes,
2890 argbuf[0], X_OK, false);
2891 if (string)
2892 argbuf[0] = string;
2893 insert_wrapper (wrapper_string);
2896 /* Count # of piped commands. */
2897 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2898 if (strcmp (arg, "|") == 0)
2899 n_commands++;
2901 /* Get storage for each command. */
2902 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2904 /* Split argbuf into its separate piped processes,
2905 and record info about each one.
2906 Also search for the programs that are to be run. */
2908 argbuf.safe_push (0);
2910 commands[0].prog = argbuf[0]; /* first command. */
2911 commands[0].argv = argbuf.address ();
2913 if (!wrapper_string)
2915 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2916 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2919 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2920 if (arg && strcmp (arg, "|") == 0)
2921 { /* each command. */
2922 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2923 fatal_error (input_location, "-pipe not supported");
2924 #endif
2925 argbuf[i] = 0; /* Termination of
2926 command args. */
2927 commands[n_commands].prog = argbuf[i + 1];
2928 commands[n_commands].argv
2929 = &(argbuf.address ())[i + 1];
2930 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2931 X_OK, false);
2932 if (string)
2933 commands[n_commands].argv[0] = string;
2934 n_commands++;
2937 /* If -v, print what we are about to do, and maybe query. */
2939 if (verbose_flag)
2941 /* For help listings, put a blank line between sub-processes. */
2942 if (print_help_list)
2943 fputc ('\n', stderr);
2945 /* Print each piped command as a separate line. */
2946 for (i = 0; i < n_commands; i++)
2948 const char *const *j;
2950 if (verbose_only_flag)
2952 for (j = commands[i].argv; *j; j++)
2954 const char *p;
2955 for (p = *j; *p; ++p)
2956 if (!ISALNUM ((unsigned char) *p)
2957 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2958 break;
2959 if (*p || !*j)
2961 fprintf (stderr, " \"");
2962 for (p = *j; *p; ++p)
2964 if (*p == '"' || *p == '\\' || *p == '$')
2965 fputc ('\\', stderr);
2966 fputc (*p, stderr);
2968 fputc ('"', stderr);
2970 /* If it's empty, print "". */
2971 else if (!**j)
2972 fprintf (stderr, " \"\"");
2973 else
2974 fprintf (stderr, " %s", *j);
2977 else
2978 for (j = commands[i].argv; *j; j++)
2979 /* If it's empty, print "". */
2980 if (!**j)
2981 fprintf (stderr, " \"\"");
2982 else
2983 fprintf (stderr, " %s", *j);
2985 /* Print a pipe symbol after all but the last command. */
2986 if (i + 1 != n_commands)
2987 fprintf (stderr, " |");
2988 fprintf (stderr, "\n");
2990 fflush (stderr);
2991 if (verbose_only_flag != 0)
2993 /* verbose_only_flag should act as if the spec was
2994 executed, so increment execution_count before
2995 returning. This prevents spurious warnings about
2996 unused linker input files, etc. */
2997 execution_count++;
2998 return 0;
3000 #ifdef DEBUG
3001 fnotice (stderr, "\nGo ahead? (y or n) ");
3002 fflush (stderr);
3003 i = getchar ();
3004 if (i != '\n')
3005 while (getchar () != '\n')
3008 if (i != 'y' && i != 'Y')
3009 return 0;
3010 #endif /* DEBUG */
3013 #ifdef ENABLE_VALGRIND_CHECKING
3014 /* Run the each command through valgrind. To simplify prepending the
3015 path to valgrind and the option "-q" (for quiet operation unless
3016 something triggers), we allocate a separate argv array. */
3018 for (i = 0; i < n_commands; i++)
3020 const char **argv;
3021 int argc;
3022 int j;
3024 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
3027 argv = XALLOCAVEC (const char *, argc + 3);
3029 argv[0] = VALGRIND_PATH;
3030 argv[1] = "-q";
3031 for (j = 2; j < argc + 2; j++)
3032 argv[j] = commands[i].argv[j - 2];
3033 argv[j] = NULL;
3035 commands[i].argv = argv;
3036 commands[i].prog = argv[0];
3038 #endif
3040 /* Run each piped subprocess. */
3042 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
3043 ? PEX_RECORD_TIMES : 0),
3044 progname, temp_filename);
3045 if (pex == NULL)
3046 fatal_error (input_location, "pex_init failed: %m");
3048 for (i = 0; i < n_commands; i++)
3050 const char *errmsg;
3051 int err;
3052 const char *string = commands[i].argv[0];
3054 errmsg = pex_run (pex,
3055 ((i + 1 == n_commands ? PEX_LAST : 0)
3056 | (string == commands[i].prog ? PEX_SEARCH : 0)),
3057 string, CONST_CAST (char **, commands[i].argv),
3058 NULL, NULL, &err);
3059 if (errmsg != NULL)
3061 if (err == 0)
3062 fatal_error (input_location, errmsg);
3063 else
3065 errno = err;
3066 pfatal_with_name (errmsg);
3070 if (i && string != commands[i].prog)
3071 free (CONST_CAST (char *, string));
3074 execution_count++;
3076 /* Wait for all the subprocesses to finish. */
3079 int *statuses;
3080 struct pex_time *times = NULL;
3081 int ret_code = 0;
3083 statuses = (int *) alloca (n_commands * sizeof (int));
3084 if (!pex_get_status (pex, n_commands, statuses))
3085 fatal_error (input_location, "failed to get exit status: %m");
3087 if (report_times || report_times_to_file)
3089 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
3090 if (!pex_get_times (pex, n_commands, times))
3091 fatal_error (input_location, "failed to get process times: %m");
3094 pex_free (pex);
3096 for (i = 0; i < n_commands; ++i)
3098 int status = statuses[i];
3100 if (WIFSIGNALED (status))
3102 #ifdef SIGPIPE
3103 /* SIGPIPE is a special case. It happens in -pipe mode
3104 when the compiler dies before the preprocessor is done,
3105 or the assembler dies before the compiler is done.
3106 There's generally been an error already, and this is
3107 just fallout. So don't generate another error unless
3108 we would otherwise have succeeded. */
3109 if (WTERMSIG (status) == SIGPIPE
3110 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
3112 signal_count++;
3113 ret_code = -1;
3115 else
3116 #endif
3117 internal_error_no_backtrace ("%s (program %s)",
3118 strsignal (WTERMSIG (status)),
3119 commands[i].prog);
3121 else if (WIFEXITED (status)
3122 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
3124 /* For ICEs in cc1, cc1obj, cc1plus see if it is
3125 reproducible or not. */
3126 const char *p;
3127 if (flag_report_bug
3128 && WEXITSTATUS (status) == ICE_EXIT_CODE
3129 && i == 0
3130 && (p = strrchr (commands[0].argv[0], DIR_SEPARATOR))
3131 && ! strncmp (p + 1, "cc1", 3))
3132 try_generate_repro (commands[0].argv);
3133 if (WEXITSTATUS (status) > greatest_status)
3134 greatest_status = WEXITSTATUS (status);
3135 ret_code = -1;
3138 if (report_times || report_times_to_file)
3140 struct pex_time *pt = &times[i];
3141 double ut, st;
3143 ut = ((double) pt->user_seconds
3144 + (double) pt->user_microseconds / 1.0e6);
3145 st = ((double) pt->system_seconds
3146 + (double) pt->system_microseconds / 1.0e6);
3148 if (ut + st != 0)
3150 if (report_times)
3151 fnotice (stderr, "# %s %.2f %.2f\n",
3152 commands[i].prog, ut, st);
3154 if (report_times_to_file)
3156 int c = 0;
3157 const char *const *j;
3159 fprintf (report_times_to_file, "%g %g", ut, st);
3161 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
3163 const char *p;
3164 for (p = *j; *p; ++p)
3165 if (*p == '"' || *p == '\\' || *p == '$'
3166 || ISSPACE (*p))
3167 break;
3169 if (*p)
3171 fprintf (report_times_to_file, " \"");
3172 for (p = *j; *p; ++p)
3174 if (*p == '"' || *p == '\\' || *p == '$')
3175 fputc ('\\', report_times_to_file);
3176 fputc (*p, report_times_to_file);
3178 fputc ('"', report_times_to_file);
3180 else
3181 fprintf (report_times_to_file, " %s", *j);
3184 fputc ('\n', report_times_to_file);
3190 if (commands[0].argv[0] != commands[0].prog)
3191 free (CONST_CAST (char *, commands[0].argv[0]));
3193 return ret_code;
3197 /* Find all the switches given to us
3198 and make a vector describing them.
3199 The elements of the vector are strings, one per switch given.
3200 If a switch uses following arguments, then the `part1' field
3201 is the switch itself and the `args' field
3202 is a null-terminated vector containing the following arguments.
3203 Bits in the `live_cond' field are:
3204 SWITCH_LIVE to indicate this switch is true in a conditional spec.
3205 SWITCH_FALSE to indicate this switch is overridden by a later switch.
3206 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
3207 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored.
3208 SWITCH_KEEP_FOR_GCC to indicate that this switch, otherwise ignored,
3209 should be included in COLLECT_GCC_OPTIONS.
3210 in all do_spec calls afterwards. Used for %<S from self specs.
3211 The `known' field describes whether this is an internal switch.
3212 The `validated' field describes whether any spec has looked at this switch;
3213 if it remains false at the end of the run, the switch must be meaningless.
3214 The `ordering' field is used to temporarily mark switches that have to be
3215 kept in a specific order. */
3217 #define SWITCH_LIVE (1 << 0)
3218 #define SWITCH_FALSE (1 << 1)
3219 #define SWITCH_IGNORE (1 << 2)
3220 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
3221 #define SWITCH_KEEP_FOR_GCC (1 << 4)
3223 struct switchstr
3225 const char *part1;
3226 const char **args;
3227 unsigned int live_cond;
3228 bool known;
3229 bool validated;
3230 bool ordering;
3233 static struct switchstr *switches;
3235 static int n_switches;
3237 static int n_switches_alloc;
3239 /* Set to zero if -fcompare-debug is disabled, positive if it's
3240 enabled and we're running the first compilation, negative if it's
3241 enabled and we're running the second compilation. For most of the
3242 time, it's in the range -1..1, but it can be temporarily set to 2
3243 or 3 to indicate that the -fcompare-debug flags didn't come from
3244 the command-line, but rather from the GCC_COMPARE_DEBUG environment
3245 variable, until a synthesized -fcompare-debug flag is added to the
3246 command line. */
3247 int compare_debug;
3249 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
3250 int compare_debug_second;
3252 /* Set to the flags that should be passed to the second compilation in
3253 a -fcompare-debug compilation. */
3254 const char *compare_debug_opt;
3256 static struct switchstr *switches_debug_check[2];
3258 static int n_switches_debug_check[2];
3260 static int n_switches_alloc_debug_check[2];
3262 static char *debug_check_temp_file[2];
3264 /* Language is one of three things:
3266 1) The name of a real programming language.
3267 2) NULL, indicating that no one has figured out
3268 what it is yet.
3269 3) '*', indicating that the file should be passed
3270 to the linker. */
3271 struct infile
3273 const char *name;
3274 const char *language;
3275 struct compiler *incompiler;
3276 bool compiled;
3277 bool preprocessed;
3280 /* Also a vector of input files specified. */
3282 static struct infile *infiles;
3284 int n_infiles;
3286 static int n_infiles_alloc;
3288 /* True if multiple input files are being compiled to a single
3289 assembly file. */
3291 static bool combine_inputs;
3293 /* This counts the number of libraries added by lang_specific_driver, so that
3294 we can tell if there were any user supplied any files or libraries. */
3296 static int added_libraries;
3298 /* And a vector of corresponding output files is made up later. */
3300 const char **outfiles;
3302 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3304 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3305 is true if we should look for an executable suffix. DO_OBJ
3306 is true if we should look for an object suffix. */
3308 static const char *
3309 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3310 int do_obj ATTRIBUTE_UNUSED)
3312 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3313 int i;
3314 #endif
3315 int len;
3317 if (name == NULL)
3318 return NULL;
3320 len = strlen (name);
3322 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3323 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3324 if (do_obj && len > 2
3325 && name[len - 2] == '.'
3326 && name[len - 1] == 'o')
3328 obstack_grow (&obstack, name, len - 2);
3329 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3330 name = XOBFINISH (&obstack, const char *);
3332 #endif
3334 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3335 /* If there is no filetype, make it the executable suffix (which includes
3336 the "."). But don't get confused if we have just "-o". */
3337 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3338 return name;
3340 for (i = len - 1; i >= 0; i--)
3341 if (IS_DIR_SEPARATOR (name[i]))
3342 break;
3344 for (i++; i < len; i++)
3345 if (name[i] == '.')
3346 return name;
3348 obstack_grow (&obstack, name, len);
3349 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3350 strlen (TARGET_EXECUTABLE_SUFFIX));
3351 name = XOBFINISH (&obstack, const char *);
3352 #endif
3354 return name;
3356 #endif
3358 /* Display the command line switches accepted by gcc. */
3359 static void
3360 display_help (void)
3362 printf (_("Usage: %s [options] file...\n"), progname);
3363 fputs (_("Options:\n"), stdout);
3365 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3366 fputs (_(" --help Display this information\n"), stdout);
3367 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3368 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...]\n"), stdout);
3369 fputs (_(" Display specific types of command line options\n"), stdout);
3370 if (! verbose_flag)
3371 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3372 fputs (_(" --version Display compiler version information\n"), stdout);
3373 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3374 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3375 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3376 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3377 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3378 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3379 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3380 fputs (_("\
3381 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3382 a component in the library path\n"), stdout);
3383 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3384 fputs (_("\
3385 -print-multi-lib Display the mapping between command line options and\n\
3386 multiple library search directories\n"), stdout);
3387 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3388 fputs (_(" -print-sysroot Display the target libraries directory\n"), stdout);
3389 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
3390 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3391 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3392 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3393 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3394 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3395 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3396 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3397 fputs (_(" -save-temps=<arg> Do not delete intermediate files\n"), stdout);
3398 fputs (_("\
3399 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3400 prefixes to other gcc components\n"), stdout);
3401 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3402 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3403 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3404 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3405 fputs (_("\
3406 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3407 and libraries\n"), stdout);
3408 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3409 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3410 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3411 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3412 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3413 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3414 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3415 fputs (_(" -pie Create a position independent executable\n"), stdout);
3416 fputs (_(" -shared Create a shared library\n"), stdout);
3417 fputs (_("\
3418 -x <language> Specify the language of the following input files\n\
3419 Permissible languages include: c c++ assembler none\n\
3420 'none' means revert to the default behavior of\n\
3421 guessing the language based on the file's extension\n\
3422 "), stdout);
3424 printf (_("\
3425 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3426 passed on to the various sub-processes invoked by %s. In order to pass\n\
3427 other options on to these processes the -W<letter> options must be used.\n\
3428 "), progname);
3430 /* The rest of the options are displayed by invocations of the various
3431 sub-processes. */
3434 static void
3435 add_preprocessor_option (const char *option, int len)
3437 preprocessor_options.safe_push (save_string (option, len));
3440 static void
3441 add_assembler_option (const char *option, int len)
3443 assembler_options.safe_push (save_string (option, len));
3446 static void
3447 add_linker_option (const char *option, int len)
3449 linker_options.safe_push (save_string (option, len));
3452 /* Allocate space for an input file in infiles. */
3454 static void
3455 alloc_infile (void)
3457 if (n_infiles_alloc == 0)
3459 n_infiles_alloc = 16;
3460 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3462 else if (n_infiles_alloc == n_infiles)
3464 n_infiles_alloc *= 2;
3465 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3469 /* Store an input file with the given NAME and LANGUAGE in
3470 infiles. */
3472 static void
3473 add_infile (const char *name, const char *language)
3475 alloc_infile ();
3476 infiles[n_infiles].name = name;
3477 infiles[n_infiles++].language = language;
3480 /* Allocate space for a switch in switches. */
3482 static void
3483 alloc_switch (void)
3485 if (n_switches_alloc == 0)
3487 n_switches_alloc = 16;
3488 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3490 else if (n_switches_alloc == n_switches)
3492 n_switches_alloc *= 2;
3493 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3497 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3498 as validated if VALIDATED and KNOWN if it is an internal switch. */
3500 static void
3501 save_switch (const char *opt, size_t n_args, const char *const *args,
3502 bool validated, bool known)
3504 alloc_switch ();
3505 switches[n_switches].part1 = opt + 1;
3506 if (n_args == 0)
3507 switches[n_switches].args = 0;
3508 else
3510 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3511 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3512 switches[n_switches].args[n_args] = NULL;
3515 switches[n_switches].live_cond = 0;
3516 switches[n_switches].validated = validated;
3517 switches[n_switches].known = known;
3518 switches[n_switches].ordering = 0;
3519 n_switches++;
3522 /* Handle an option DECODED that is unknown to the option-processing
3523 machinery. */
3525 static bool
3526 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3528 const char *opt = decoded->arg;
3529 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3530 && !(decoded->errors & CL_ERR_NEGATIVE))
3532 /* Leave unknown -Wno-* options for the compiler proper, to be
3533 diagnosed only if there are warnings. */
3534 save_switch (decoded->canonical_option[0],
3535 decoded->canonical_option_num_elements - 1,
3536 &decoded->canonical_option[1], false, true);
3537 return false;
3539 if (decoded->opt_index == OPT_SPECIAL_unknown)
3541 /* Give it a chance to define it a spec file. */
3542 save_switch (decoded->canonical_option[0],
3543 decoded->canonical_option_num_elements - 1,
3544 &decoded->canonical_option[1], false, false);
3545 return false;
3547 else
3548 return true;
3551 /* Handle an option DECODED that is not marked as CL_DRIVER.
3552 LANG_MASK will always be CL_DRIVER. */
3554 static void
3555 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3556 unsigned int lang_mask ATTRIBUTE_UNUSED)
3558 /* At this point, non-driver options are accepted (and expected to
3559 be passed down by specs) unless marked to be rejected by the
3560 driver. Options to be rejected by the driver but accepted by the
3561 compilers proper are treated just like completely unknown
3562 options. */
3563 const struct cl_option *option = &cl_options[decoded->opt_index];
3565 if (option->cl_reject_driver)
3566 error ("unrecognized command line option %qs",
3567 decoded->orig_option_with_args_text);
3568 else
3569 save_switch (decoded->canonical_option[0],
3570 decoded->canonical_option_num_elements - 1,
3571 &decoded->canonical_option[1], false, true);
3574 static const char *spec_lang = 0;
3575 static int last_language_n_infiles;
3577 /* Parse -foffload option argument. */
3579 static void
3580 handle_foffload_option (const char *arg)
3582 const char *c, *cur, *n, *next, *end;
3583 char *target;
3585 /* If option argument starts with '-' then no target is specified and we
3586 do not need to parse it. */
3587 if (arg[0] == '-')
3588 return;
3590 end = strchr (arg, '=');
3591 if (end == NULL)
3592 end = strchr (arg, '\0');
3593 cur = arg;
3595 while (cur < end)
3597 next = strchr (cur, ',');
3598 if (next == NULL)
3599 next = end;
3600 next = (next > end) ? end : next;
3602 target = XNEWVEC (char, next - cur + 1);
3603 memcpy (target, cur, next - cur);
3604 target[next - cur] = '\0';
3606 /* If 'disable' is passed to the option, stop parsing the option and clean
3607 the list of offload targets. */
3608 if (strcmp (target, "disable") == 0)
3610 free (offload_targets);
3611 offload_targets = xstrdup ("");
3612 break;
3615 /* Check that GCC is configured to support the offload target. */
3616 c = OFFLOAD_TARGETS;
3617 while (c)
3619 n = strchr (c, ',');
3620 if (n == NULL)
3621 n = strchr (c, '\0');
3623 if (next - cur == n - c && strncmp (target, c, n - c) == 0)
3624 break;
3626 c = *n ? n + 1 : NULL;
3629 if (!c)
3630 fatal_error (input_location,
3631 "GCC is not configured to support %s as offload target",
3632 target);
3634 if (!offload_targets)
3636 offload_targets = target;
3637 target = NULL;
3639 else
3641 /* Check that the target hasn't already presented in the list. */
3642 c = offload_targets;
3645 n = strchr (c, ':');
3646 if (n == NULL)
3647 n = strchr (c, '\0');
3649 if (next - cur == n - c && strncmp (c, target, n - c) == 0)
3650 break;
3652 c = n + 1;
3654 while (*n);
3656 /* If duplicate is not found, append the target to the list. */
3657 if (c > n)
3659 size_t offload_targets_len = strlen (offload_targets);
3660 offload_targets
3661 = XRESIZEVEC (char, offload_targets,
3662 offload_targets_len + 1 + next - cur + 1);
3663 offload_targets[offload_targets_len++] = ':';
3664 memcpy (offload_targets + offload_targets_len, target, next - cur + 1);
3668 cur = next + 1;
3669 XDELETEVEC (target);
3673 /* Handle a driver option; arguments and return value as for
3674 handle_option. */
3676 static bool
3677 driver_handle_option (struct gcc_options *opts,
3678 struct gcc_options *opts_set,
3679 const struct cl_decoded_option *decoded,
3680 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3681 location_t loc,
3682 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3683 diagnostic_context *dc)
3685 size_t opt_index = decoded->opt_index;
3686 const char *arg = decoded->arg;
3687 const char *compare_debug_replacement_opt;
3688 int value = decoded->value;
3689 bool validated = false;
3690 bool do_save = true;
3692 gcc_assert (opts == &global_options);
3693 gcc_assert (opts_set == &global_options_set);
3694 gcc_assert (kind == DK_UNSPECIFIED);
3695 gcc_assert (loc == UNKNOWN_LOCATION);
3696 gcc_assert (dc == global_dc);
3698 switch (opt_index)
3700 case OPT_dumpspecs:
3702 struct spec_list *sl;
3703 init_spec ();
3704 for (sl = specs; sl; sl = sl->next)
3705 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3706 if (link_command_spec)
3707 printf ("*link_command:\n%s\n\n", link_command_spec);
3708 exit (0);
3711 case OPT_dumpversion:
3712 printf ("%s\n", spec_version);
3713 exit (0);
3715 case OPT_dumpmachine:
3716 printf ("%s\n", spec_machine);
3717 exit (0);
3719 case OPT__version:
3720 print_version = 1;
3722 /* CPP driver cannot obtain switch from cc1_options. */
3723 if (is_cpp_driver)
3724 add_preprocessor_option ("--version", strlen ("--version"));
3725 add_assembler_option ("--version", strlen ("--version"));
3726 add_linker_option ("--version", strlen ("--version"));
3727 break;
3729 case OPT__help:
3730 print_help_list = 1;
3732 /* CPP driver cannot obtain switch from cc1_options. */
3733 if (is_cpp_driver)
3734 add_preprocessor_option ("--help", 6);
3735 add_assembler_option ("--help", 6);
3736 add_linker_option ("--help", 6);
3737 break;
3739 case OPT__help_:
3740 print_subprocess_help = 2;
3741 break;
3743 case OPT__target_help:
3744 print_subprocess_help = 1;
3746 /* CPP driver cannot obtain switch from cc1_options. */
3747 if (is_cpp_driver)
3748 add_preprocessor_option ("--target-help", 13);
3749 add_assembler_option ("--target-help", 13);
3750 add_linker_option ("--target-help", 13);
3751 break;
3753 case OPT__no_sysroot_suffix:
3754 case OPT_pass_exit_codes:
3755 case OPT_print_search_dirs:
3756 case OPT_print_file_name_:
3757 case OPT_print_prog_name_:
3758 case OPT_print_multi_lib:
3759 case OPT_print_multi_directory:
3760 case OPT_print_sysroot:
3761 case OPT_print_multi_os_directory:
3762 case OPT_print_multiarch:
3763 case OPT_print_sysroot_headers_suffix:
3764 case OPT_time:
3765 case OPT_wrapper:
3766 /* These options set the variables specified in common.opt
3767 automatically, and do not need to be saved for spec
3768 processing. */
3769 do_save = false;
3770 break;
3772 case OPT_print_libgcc_file_name:
3773 print_file_name = "libgcc.a";
3774 do_save = false;
3775 break;
3777 case OPT_fuse_ld_bfd:
3778 use_ld = ".bfd";
3779 break;
3781 case OPT_fuse_ld_gold:
3782 use_ld = ".gold";
3783 break;
3785 case OPT_fcompare_debug_second:
3786 compare_debug_second = 1;
3787 break;
3789 case OPT_fcompare_debug:
3790 switch (value)
3792 case 0:
3793 compare_debug_replacement_opt = "-fcompare-debug=";
3794 arg = "";
3795 goto compare_debug_with_arg;
3797 case 1:
3798 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3799 arg = "-gtoggle";
3800 goto compare_debug_with_arg;
3802 default:
3803 gcc_unreachable ();
3805 break;
3807 case OPT_fcompare_debug_:
3808 compare_debug_replacement_opt = decoded->canonical_option[0];
3809 compare_debug_with_arg:
3810 gcc_assert (decoded->canonical_option_num_elements == 1);
3811 gcc_assert (arg != NULL);
3812 if (*arg)
3813 compare_debug = 1;
3814 else
3815 compare_debug = -1;
3816 if (compare_debug < 0)
3817 compare_debug_opt = NULL;
3818 else
3819 compare_debug_opt = arg;
3820 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3821 return true;
3823 case OPT_fdiagnostics_color_:
3824 diagnostic_color_init (dc, value);
3825 break;
3827 case OPT_Wa_:
3829 int prev, j;
3830 /* Pass the rest of this option to the assembler. */
3832 /* Split the argument at commas. */
3833 prev = 0;
3834 for (j = 0; arg[j]; j++)
3835 if (arg[j] == ',')
3837 add_assembler_option (arg + prev, j - prev);
3838 prev = j + 1;
3841 /* Record the part after the last comma. */
3842 add_assembler_option (arg + prev, j - prev);
3844 do_save = false;
3845 break;
3847 case OPT_Wp_:
3849 int prev, j;
3850 /* Pass the rest of this option to the preprocessor. */
3852 /* Split the argument at commas. */
3853 prev = 0;
3854 for (j = 0; arg[j]; j++)
3855 if (arg[j] == ',')
3857 add_preprocessor_option (arg + prev, j - prev);
3858 prev = j + 1;
3861 /* Record the part after the last comma. */
3862 add_preprocessor_option (arg + prev, j - prev);
3864 do_save = false;
3865 break;
3867 case OPT_Wl_:
3869 int prev, j;
3870 /* Split the argument at commas. */
3871 prev = 0;
3872 for (j = 0; arg[j]; j++)
3873 if (arg[j] == ',')
3875 add_infile (save_string (arg + prev, j - prev), "*");
3876 prev = j + 1;
3878 /* Record the part after the last comma. */
3879 add_infile (arg + prev, "*");
3881 do_save = false;
3882 break;
3884 case OPT_Xlinker:
3885 add_infile (arg, "*");
3886 do_save = false;
3887 break;
3889 case OPT_Xpreprocessor:
3890 add_preprocessor_option (arg, strlen (arg));
3891 do_save = false;
3892 break;
3894 case OPT_Xassembler:
3895 add_assembler_option (arg, strlen (arg));
3896 do_save = false;
3897 break;
3899 case OPT_l:
3900 /* POSIX allows separation of -l and the lib arg; canonicalize
3901 by concatenating -l with its arg */
3902 add_infile (concat ("-l", arg, NULL), "*");
3903 do_save = false;
3904 break;
3906 case OPT_L:
3907 /* Similarly, canonicalize -L for linkers that may not accept
3908 separate arguments. */
3909 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
3910 return true;
3912 case OPT_F:
3913 /* Likewise -F. */
3914 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
3915 return true;
3917 case OPT_save_temps:
3918 save_temps_flag = SAVE_TEMPS_CWD;
3919 validated = true;
3920 break;
3922 case OPT_save_temps_:
3923 if (strcmp (arg, "cwd") == 0)
3924 save_temps_flag = SAVE_TEMPS_CWD;
3925 else if (strcmp (arg, "obj") == 0
3926 || strcmp (arg, "object") == 0)
3927 save_temps_flag = SAVE_TEMPS_OBJ;
3928 else
3929 fatal_error (input_location, "%qs is an unknown -save-temps option",
3930 decoded->orig_option_with_args_text);
3931 break;
3933 case OPT_no_canonical_prefixes:
3934 /* Already handled as a special case, so ignored here. */
3935 do_save = false;
3936 break;
3938 case OPT_pipe:
3939 validated = true;
3940 /* These options set the variables specified in common.opt
3941 automatically, but do need to be saved for spec
3942 processing. */
3943 break;
3945 case OPT_specs_:
3947 struct user_specs *user = XNEW (struct user_specs);
3949 user->next = (struct user_specs *) 0;
3950 user->filename = arg;
3951 if (user_specs_tail)
3952 user_specs_tail->next = user;
3953 else
3954 user_specs_head = user;
3955 user_specs_tail = user;
3957 validated = true;
3958 break;
3960 case OPT__sysroot_:
3961 target_system_root = arg;
3962 target_system_root_changed = 1;
3963 do_save = false;
3964 break;
3966 case OPT_time_:
3967 if (report_times_to_file)
3968 fclose (report_times_to_file);
3969 report_times_to_file = fopen (arg, "a");
3970 do_save = false;
3971 break;
3973 case OPT____:
3974 /* "-###"
3975 This is similar to -v except that there is no execution
3976 of the commands and the echoed arguments are quoted. It
3977 is intended for use in shell scripts to capture the
3978 driver-generated command line. */
3979 verbose_only_flag++;
3980 verbose_flag = 1;
3981 do_save = false;
3982 break;
3984 case OPT_B:
3986 size_t len = strlen (arg);
3988 /* Catch the case where the user has forgotten to append a
3989 directory separator to the path. Note, they may be using
3990 -B to add an executable name prefix, eg "i386-elf-", in
3991 order to distinguish between multiple installations of
3992 GCC in the same directory. Hence we must check to see
3993 if appending a directory separator actually makes a
3994 valid directory name. */
3995 if (!IS_DIR_SEPARATOR (arg[len - 1])
3996 && is_directory (arg, false))
3998 char *tmp = XNEWVEC (char, len + 2);
3999 strcpy (tmp, arg);
4000 tmp[len] = DIR_SEPARATOR;
4001 tmp[++len] = 0;
4002 arg = tmp;
4005 add_prefix (&exec_prefixes, arg, NULL,
4006 PREFIX_PRIORITY_B_OPT, 0, 0);
4007 add_prefix (&startfile_prefixes, arg, NULL,
4008 PREFIX_PRIORITY_B_OPT, 0, 0);
4009 add_prefix (&include_prefixes, arg, NULL,
4010 PREFIX_PRIORITY_B_OPT, 0, 0);
4012 validated = true;
4013 break;
4015 case OPT_x:
4016 spec_lang = arg;
4017 if (!strcmp (spec_lang, "none"))
4018 /* Suppress the warning if -xnone comes after the last input
4019 file, because alternate command interfaces like g++ might
4020 find it useful to place -xnone after each input file. */
4021 spec_lang = 0;
4022 else
4023 last_language_n_infiles = n_infiles;
4024 do_save = false;
4025 break;
4027 case OPT_o:
4028 have_o = 1;
4029 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
4030 arg = convert_filename (arg, ! have_c, 0);
4031 #endif
4032 output_file = arg;
4033 /* Save the output name in case -save-temps=obj was used. */
4034 save_temps_prefix = xstrdup (arg);
4035 /* On some systems, ld cannot handle "-o" without a space. So
4036 split the option from its argument. */
4037 save_switch ("-o", 1, &arg, validated, true);
4038 return true;
4040 #ifdef ENABLE_DEFAULT_PIE
4041 case OPT_pie:
4042 /* -pie is turned on by default. */
4043 #endif
4045 case OPT_static_libgcc:
4046 case OPT_shared_libgcc:
4047 case OPT_static_libgfortran:
4048 case OPT_static_libstdc__:
4049 /* These are always valid, since gcc.c itself understands the
4050 first two, gfortranspec.c understands -static-libgfortran and
4051 g++spec.c understands -static-libstdc++ */
4052 validated = true;
4053 break;
4055 case OPT_fwpa:
4056 flag_wpa = "";
4057 break;
4059 case OPT_foffload_:
4060 handle_foffload_option (arg);
4061 break;
4063 default:
4064 /* Various driver options need no special processing at this
4065 point, having been handled in a prescan above or being
4066 handled by specs. */
4067 break;
4070 if (do_save)
4071 save_switch (decoded->canonical_option[0],
4072 decoded->canonical_option_num_elements - 1,
4073 &decoded->canonical_option[1], validated, true);
4074 return true;
4077 /* Put the driver's standard set of option handlers in *HANDLERS. */
4079 static void
4080 set_option_handlers (struct cl_option_handlers *handlers)
4082 handlers->unknown_option_callback = driver_unknown_option_callback;
4083 handlers->wrong_lang_callback = driver_wrong_lang_callback;
4084 handlers->num_handlers = 3;
4085 handlers->handlers[0].handler = driver_handle_option;
4086 handlers->handlers[0].mask = CL_DRIVER;
4087 handlers->handlers[1].handler = common_handle_option;
4088 handlers->handlers[1].mask = CL_COMMON;
4089 handlers->handlers[2].handler = target_handle_option;
4090 handlers->handlers[2].mask = CL_TARGET;
4093 /* Create the vector `switches' and its contents.
4094 Store its length in `n_switches'. */
4096 static void
4097 process_command (unsigned int decoded_options_count,
4098 struct cl_decoded_option *decoded_options)
4100 const char *temp;
4101 char *temp1;
4102 char *tooldir_prefix, *tooldir_prefix2;
4103 char *(*get_relative_prefix) (const char *, const char *,
4104 const char *) = NULL;
4105 struct cl_option_handlers handlers;
4106 unsigned int j;
4108 gcc_exec_prefix = env.get ("GCC_EXEC_PREFIX");
4110 n_switches = 0;
4111 n_infiles = 0;
4112 added_libraries = 0;
4114 /* Figure compiler version from version string. */
4116 compiler_version = temp1 = xstrdup (version_string);
4118 for (; *temp1; ++temp1)
4120 if (*temp1 == ' ')
4122 *temp1 = '\0';
4123 break;
4127 /* Handle any -no-canonical-prefixes flag early, to assign the function
4128 that builds relative prefixes. This function creates default search
4129 paths that are needed later in normal option handling. */
4131 for (j = 1; j < decoded_options_count; j++)
4133 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
4135 get_relative_prefix = make_relative_prefix_ignore_links;
4136 break;
4139 if (! get_relative_prefix)
4140 get_relative_prefix = make_relative_prefix;
4142 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
4143 see if we can create it from the pathname specified in
4144 decoded_options[0].arg. */
4146 gcc_libexec_prefix = standard_libexec_prefix;
4147 #ifndef VMS
4148 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
4149 if (!gcc_exec_prefix)
4151 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
4152 standard_bindir_prefix,
4153 standard_exec_prefix);
4154 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
4155 standard_bindir_prefix,
4156 standard_libexec_prefix);
4157 if (gcc_exec_prefix)
4158 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
4160 else
4162 /* make_relative_prefix requires a program name, but
4163 GCC_EXEC_PREFIX is typically a directory name with a trailing
4164 / (which is ignored by make_relative_prefix), so append a
4165 program name. */
4166 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
4167 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
4168 standard_exec_prefix,
4169 standard_libexec_prefix);
4171 /* The path is unrelocated, so fallback to the original setting. */
4172 if (!gcc_libexec_prefix)
4173 gcc_libexec_prefix = standard_libexec_prefix;
4175 free (tmp_prefix);
4177 #else
4178 #endif
4179 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
4180 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
4181 or an automatically created GCC_EXEC_PREFIX from
4182 decoded_options[0].arg. */
4184 /* Do language-specific adjustment/addition of flags. */
4185 lang_specific_driver (&decoded_options, &decoded_options_count,
4186 &added_libraries);
4188 if (gcc_exec_prefix)
4190 int len = strlen (gcc_exec_prefix);
4192 if (len > (int) sizeof ("/lib/gcc/") - 1
4193 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
4195 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
4196 if (IS_DIR_SEPARATOR (*temp)
4197 && filename_ncmp (temp + 1, "lib", 3) == 0
4198 && IS_DIR_SEPARATOR (temp[4])
4199 && filename_ncmp (temp + 5, "gcc", 3) == 0)
4200 len -= sizeof ("/lib/gcc/") - 1;
4203 set_std_prefix (gcc_exec_prefix, len);
4204 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
4205 PREFIX_PRIORITY_LAST, 0, 0);
4206 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
4207 PREFIX_PRIORITY_LAST, 0, 0);
4210 /* COMPILER_PATH and LIBRARY_PATH have values
4211 that are lists of directory names with colons. */
4213 temp = env.get ("COMPILER_PATH");
4214 if (temp)
4216 const char *startp, *endp;
4217 char *nstore = (char *) alloca (strlen (temp) + 3);
4219 startp = endp = temp;
4220 while (1)
4222 if (*endp == PATH_SEPARATOR || *endp == 0)
4224 strncpy (nstore, startp, endp - startp);
4225 if (endp == startp)
4226 strcpy (nstore, concat (".", dir_separator_str, NULL));
4227 else if (!IS_DIR_SEPARATOR (endp[-1]))
4229 nstore[endp - startp] = DIR_SEPARATOR;
4230 nstore[endp - startp + 1] = 0;
4232 else
4233 nstore[endp - startp] = 0;
4234 add_prefix (&exec_prefixes, nstore, 0,
4235 PREFIX_PRIORITY_LAST, 0, 0);
4236 add_prefix (&include_prefixes, nstore, 0,
4237 PREFIX_PRIORITY_LAST, 0, 0);
4238 if (*endp == 0)
4239 break;
4240 endp = startp = endp + 1;
4242 else
4243 endp++;
4247 temp = env.get (LIBRARY_PATH_ENV);
4248 if (temp && *cross_compile == '0')
4250 const char *startp, *endp;
4251 char *nstore = (char *) alloca (strlen (temp) + 3);
4253 startp = endp = temp;
4254 while (1)
4256 if (*endp == PATH_SEPARATOR || *endp == 0)
4258 strncpy (nstore, startp, endp - startp);
4259 if (endp == startp)
4260 strcpy (nstore, concat (".", dir_separator_str, NULL));
4261 else if (!IS_DIR_SEPARATOR (endp[-1]))
4263 nstore[endp - startp] = DIR_SEPARATOR;
4264 nstore[endp - startp + 1] = 0;
4266 else
4267 nstore[endp - startp] = 0;
4268 add_prefix (&startfile_prefixes, nstore, NULL,
4269 PREFIX_PRIORITY_LAST, 0, 1);
4270 if (*endp == 0)
4271 break;
4272 endp = startp = endp + 1;
4274 else
4275 endp++;
4279 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
4280 temp = env.get ("LPATH");
4281 if (temp && *cross_compile == '0')
4283 const char *startp, *endp;
4284 char *nstore = (char *) alloca (strlen (temp) + 3);
4286 startp = endp = temp;
4287 while (1)
4289 if (*endp == PATH_SEPARATOR || *endp == 0)
4291 strncpy (nstore, startp, endp - startp);
4292 if (endp == startp)
4293 strcpy (nstore, concat (".", dir_separator_str, NULL));
4294 else if (!IS_DIR_SEPARATOR (endp[-1]))
4296 nstore[endp - startp] = DIR_SEPARATOR;
4297 nstore[endp - startp + 1] = 0;
4299 else
4300 nstore[endp - startp] = 0;
4301 add_prefix (&startfile_prefixes, nstore, NULL,
4302 PREFIX_PRIORITY_LAST, 0, 1);
4303 if (*endp == 0)
4304 break;
4305 endp = startp = endp + 1;
4307 else
4308 endp++;
4312 /* Process the options and store input files and switches in their
4313 vectors. */
4315 last_language_n_infiles = -1;
4317 set_option_handlers (&handlers);
4319 for (j = 1; j < decoded_options_count; j++)
4321 switch (decoded_options[j].opt_index)
4323 case OPT_S:
4324 case OPT_c:
4325 case OPT_E:
4326 have_c = 1;
4327 break;
4329 if (have_c)
4330 break;
4333 for (j = 1; j < decoded_options_count; j++)
4335 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
4337 const char *arg = decoded_options[j].arg;
4338 const char *p = strrchr (arg, '@');
4339 char *fname;
4340 long offset;
4341 int consumed;
4342 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4343 arg = convert_filename (arg, 0, access (arg, F_OK));
4344 #endif
4345 /* For LTO static archive support we handle input file
4346 specifications that are composed of a filename and
4347 an offset like FNAME@OFFSET. */
4348 if (p
4349 && p != arg
4350 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
4351 && strlen (p) == (unsigned int)consumed)
4353 fname = (char *)xmalloc (p - arg + 1);
4354 memcpy (fname, arg, p - arg);
4355 fname[p - arg] = '\0';
4356 /* Only accept non-stdin and existing FNAME parts, otherwise
4357 try with the full name. */
4358 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
4360 free (fname);
4361 fname = xstrdup (arg);
4364 else
4365 fname = xstrdup (arg);
4367 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
4368 perror_with_name (fname);
4369 else
4370 add_infile (arg, spec_lang);
4372 free (fname);
4373 continue;
4376 read_cmdline_option (&global_options, &global_options_set,
4377 decoded_options + j, UNKNOWN_LOCATION,
4378 CL_DRIVER, &handlers, global_dc);
4381 #ifdef ENABLE_OFFLOADING
4382 /* If the user didn't specify any, default to all configured offload
4383 targets. */
4384 if (offload_targets == NULL)
4385 handle_foffload_option (OFFLOAD_TARGETS);
4386 #endif
4388 if (output_file
4389 && strcmp (output_file, "-") != 0
4390 && strcmp (output_file, HOST_BIT_BUCKET) != 0)
4392 int i;
4393 for (i = 0; i < n_infiles; i++)
4394 if ((!infiles[i].language || infiles[i].language[0] != '*')
4395 && canonical_filename_eq (infiles[i].name, output_file))
4396 fatal_error (input_location,
4397 "input file %qs is the same as output file",
4398 output_file);
4401 /* If -save-temps=obj and -o name, create the prefix to use for %b.
4402 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
4403 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
4405 save_temps_length = strlen (save_temps_prefix);
4406 temp = strrchr (lbasename (save_temps_prefix), '.');
4407 if (temp)
4409 save_temps_length -= strlen (temp);
4410 save_temps_prefix[save_temps_length] = '\0';
4414 else if (save_temps_prefix != NULL)
4416 free (save_temps_prefix);
4417 save_temps_prefix = NULL;
4420 if (save_temps_flag && use_pipes)
4422 /* -save-temps overrides -pipe, so that temp files are produced */
4423 if (save_temps_flag)
4424 warning (0, "-pipe ignored because -save-temps specified");
4425 use_pipes = 0;
4428 if (!compare_debug)
4430 const char *gcd = env.get ("GCC_COMPARE_DEBUG");
4432 if (gcd && gcd[0] == '-')
4434 compare_debug = 2;
4435 compare_debug_opt = gcd;
4437 else if (gcd && *gcd && strcmp (gcd, "0"))
4439 compare_debug = 3;
4440 compare_debug_opt = "-gtoggle";
4443 else if (compare_debug < 0)
4445 compare_debug = 0;
4446 gcc_assert (!compare_debug_opt);
4449 /* Set up the search paths. We add directories that we expect to
4450 contain GNU Toolchain components before directories specified by
4451 the machine description so that we will find GNU components (like
4452 the GNU assembler) before those of the host system. */
4454 /* If we don't know where the toolchain has been installed, use the
4455 configured-in locations. */
4456 if (!gcc_exec_prefix)
4458 #ifndef OS2
4459 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
4460 PREFIX_PRIORITY_LAST, 1, 0);
4461 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
4462 PREFIX_PRIORITY_LAST, 2, 0);
4463 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
4464 PREFIX_PRIORITY_LAST, 2, 0);
4465 #endif
4466 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
4467 PREFIX_PRIORITY_LAST, 1, 0);
4470 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
4471 tooldir_prefix2 = concat (tooldir_base_prefix, spec_host_machine,
4472 dir_separator_str, NULL);
4474 /* Look for tools relative to the location from which the driver is
4475 running, or, if that is not available, the configured prefix. */
4476 tooldir_prefix
4477 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4478 spec_host_machine, dir_separator_str, spec_version,
4479 accel_dir_suffix, dir_separator_str, tooldir_prefix2, NULL);
4480 free (tooldir_prefix2);
4482 add_prefix (&exec_prefixes,
4483 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4484 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4485 add_prefix (&startfile_prefixes,
4486 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4487 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4488 free (tooldir_prefix);
4490 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4491 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4492 then consider it to relocate with the rest of the GCC installation
4493 if GCC_EXEC_PREFIX is set.
4494 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4495 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
4497 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
4498 standard_bindir_prefix,
4499 target_system_root);
4500 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4502 target_system_root = tmp_prefix;
4503 target_system_root_changed = 1;
4506 #endif
4508 /* More prefixes are enabled in main, after we read the specs file
4509 and determine whether this is cross-compilation or not. */
4511 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4512 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
4514 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
4515 environment variable. */
4516 if (compare_debug == 2 || compare_debug == 3)
4518 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
4519 save_switch (opt, 0, NULL, false, true);
4520 compare_debug = 1;
4523 /* Ensure we only invoke each subprocess once. */
4524 if (print_subprocess_help || print_help_list || print_version)
4526 n_infiles = 0;
4528 /* Create a dummy input file, so that we can pass
4529 the help option on to the various sub-processes. */
4530 add_infile ("help-dummy", "c");
4533 alloc_switch ();
4534 switches[n_switches].part1 = 0;
4535 alloc_infile ();
4536 infiles[n_infiles].name = 0;
4539 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4540 and place that in the environment. */
4542 static void
4543 set_collect_gcc_options (void)
4545 int i;
4546 int first_time;
4548 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4549 the compiler. */
4550 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4551 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4553 first_time = TRUE;
4554 for (i = 0; (int) i < n_switches; i++)
4556 const char *const *args;
4557 const char *p, *q;
4558 if (!first_time)
4559 obstack_grow (&collect_obstack, " ", 1);
4561 first_time = FALSE;
4563 /* Ignore elided switches. */
4564 if ((switches[i].live_cond
4565 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4566 == SWITCH_IGNORE)
4567 continue;
4569 obstack_grow (&collect_obstack, "'-", 2);
4570 q = switches[i].part1;
4571 while ((p = strchr (q, '\'')))
4573 obstack_grow (&collect_obstack, q, p - q);
4574 obstack_grow (&collect_obstack, "'\\''", 4);
4575 q = ++p;
4577 obstack_grow (&collect_obstack, q, strlen (q));
4578 obstack_grow (&collect_obstack, "'", 1);
4580 for (args = switches[i].args; args && *args; args++)
4582 obstack_grow (&collect_obstack, " '", 2);
4583 q = *args;
4584 while ((p = strchr (q, '\'')))
4586 obstack_grow (&collect_obstack, q, p - q);
4587 obstack_grow (&collect_obstack, "'\\''", 4);
4588 q = ++p;
4590 obstack_grow (&collect_obstack, q, strlen (q));
4591 obstack_grow (&collect_obstack, "'", 1);
4594 obstack_grow (&collect_obstack, "\0", 1);
4595 xputenv (XOBFINISH (&collect_obstack, char *));
4598 /* Process a spec string, accumulating and running commands. */
4600 /* These variables describe the input file name.
4601 input_file_number is the index on outfiles of this file,
4602 so that the output file name can be stored for later use by %o.
4603 input_basename is the start of the part of the input file
4604 sans all directory names, and basename_length is the number
4605 of characters starting there excluding the suffix .c or whatever. */
4607 static const char *gcc_input_filename;
4608 static int input_file_number;
4609 size_t input_filename_length;
4610 static int basename_length;
4611 static int suffixed_basename_length;
4612 static const char *input_basename;
4613 static const char *input_suffix;
4614 #ifndef HOST_LACKS_INODE_NUMBERS
4615 static struct stat input_stat;
4616 #endif
4617 static int input_stat_set;
4619 /* The compiler used to process the current input file. */
4620 static struct compiler *input_file_compiler;
4622 /* These are variables used within do_spec and do_spec_1. */
4624 /* Nonzero if an arg has been started and not yet terminated
4625 (with space, tab or newline). */
4626 static int arg_going;
4628 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4629 is a temporary file name. */
4630 static int delete_this_arg;
4632 /* Nonzero means %w has been seen; the next arg to be terminated
4633 is the output file name of this compilation. */
4634 static int this_is_output_file;
4636 /* Nonzero means %s has been seen; the next arg to be terminated
4637 is the name of a library file and we should try the standard
4638 search dirs for it. */
4639 static int this_is_library_file;
4641 /* Nonzero means %T has been seen; the next arg to be terminated
4642 is the name of a linker script and we should try all of the
4643 standard search dirs for it. If it is found insert a --script
4644 command line switch and then substitute the full path in place,
4645 otherwise generate an error message. */
4646 static int this_is_linker_script;
4648 /* Nonzero means that the input of this command is coming from a pipe. */
4649 static int input_from_pipe;
4651 /* Nonnull means substitute this for any suffix when outputting a switches
4652 arguments. */
4653 static const char *suffix_subst;
4655 /* If there is an argument being accumulated, terminate it and store it. */
4657 static void
4658 end_going_arg (void)
4660 if (arg_going)
4662 const char *string;
4664 obstack_1grow (&obstack, 0);
4665 string = XOBFINISH (&obstack, const char *);
4666 if (this_is_library_file)
4667 string = find_file (string);
4668 if (this_is_linker_script)
4670 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4672 if (full_script_path == NULL)
4674 error ("unable to locate default linker script %qs in the library search paths", string);
4675 /* Script was not found on search path. */
4676 return;
4678 store_arg ("--script", false, false);
4679 string = full_script_path;
4681 store_arg (string, delete_this_arg, this_is_output_file);
4682 if (this_is_output_file)
4683 outfiles[input_file_number] = string;
4684 arg_going = 0;
4689 /* Parse the WRAPPER string which is a comma separated list of the command line
4690 and insert them into the beginning of argbuf. */
4692 static void
4693 insert_wrapper (const char *wrapper)
4695 int n = 0;
4696 int i;
4697 char *buf = xstrdup (wrapper);
4698 char *p = buf;
4699 unsigned int old_length = argbuf.length ();
4703 n++;
4704 while (*p == ',')
4705 p++;
4707 while ((p = strchr (p, ',')) != NULL);
4709 argbuf.safe_grow (old_length + n);
4710 memmove (argbuf.address () + n,
4711 argbuf.address (),
4712 old_length * sizeof (const_char_p));
4714 i = 0;
4715 p = buf;
4718 while (*p == ',')
4720 *p = 0;
4721 p++;
4723 argbuf[i] = p;
4724 i++;
4726 while ((p = strchr (p, ',')) != NULL);
4727 gcc_assert (i == n);
4730 /* Process the spec SPEC and run the commands specified therein.
4731 Returns 0 if the spec is successfully processed; -1 if failed. */
4734 do_spec (const char *spec)
4736 int value;
4738 value = do_spec_2 (spec);
4740 /* Force out any unfinished command.
4741 If -pipe, this forces out the last command if it ended in `|'. */
4742 if (value == 0)
4744 if (argbuf.length () > 0
4745 && !strcmp (argbuf.last (), "|"))
4746 argbuf.pop ();
4748 set_collect_gcc_options ();
4750 if (argbuf.length () > 0)
4751 value = execute ();
4754 return value;
4757 static int
4758 do_spec_2 (const char *spec)
4760 int result;
4762 clear_args ();
4763 arg_going = 0;
4764 delete_this_arg = 0;
4765 this_is_output_file = 0;
4766 this_is_library_file = 0;
4767 this_is_linker_script = 0;
4768 input_from_pipe = 0;
4769 suffix_subst = NULL;
4771 result = do_spec_1 (spec, 0, NULL);
4773 end_going_arg ();
4775 return result;
4779 /* Process the given spec string and add any new options to the end
4780 of the switches/n_switches array. */
4782 static void
4783 do_option_spec (const char *name, const char *spec)
4785 unsigned int i, value_count, value_len;
4786 const char *p, *q, *value;
4787 char *tmp_spec, *tmp_spec_p;
4789 if (configure_default_options[0].name == NULL)
4790 return;
4792 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4793 if (strcmp (configure_default_options[i].name, name) == 0)
4794 break;
4795 if (i == ARRAY_SIZE (configure_default_options))
4796 return;
4798 value = configure_default_options[i].value;
4799 value_len = strlen (value);
4801 /* Compute the size of the final spec. */
4802 value_count = 0;
4803 p = spec;
4804 while ((p = strstr (p, "%(VALUE)")) != NULL)
4806 p ++;
4807 value_count ++;
4810 /* Replace each %(VALUE) by the specified value. */
4811 tmp_spec = (char *) alloca (strlen (spec) + 1
4812 + value_count * (value_len - strlen ("%(VALUE)")));
4813 tmp_spec_p = tmp_spec;
4814 q = spec;
4815 while ((p = strstr (q, "%(VALUE)")) != NULL)
4817 memcpy (tmp_spec_p, q, p - q);
4818 tmp_spec_p = tmp_spec_p + (p - q);
4819 memcpy (tmp_spec_p, value, value_len);
4820 tmp_spec_p += value_len;
4821 q = p + strlen ("%(VALUE)");
4823 strcpy (tmp_spec_p, q);
4825 do_self_spec (tmp_spec);
4828 /* Process the given spec string and add any new options to the end
4829 of the switches/n_switches array. */
4831 static void
4832 do_self_spec (const char *spec)
4834 int i;
4836 do_spec_2 (spec);
4837 do_spec_1 (" ", 0, NULL);
4839 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4840 do_self_specs adds the replacements to switches array, so it shouldn't
4841 be processed afterwards. */
4842 for (i = 0; i < n_switches; i++)
4843 if ((switches[i].live_cond & SWITCH_IGNORE))
4844 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4846 if (argbuf.length () > 0)
4848 const char **argbuf_copy;
4849 struct cl_decoded_option *decoded_options;
4850 struct cl_option_handlers handlers;
4851 unsigned int decoded_options_count;
4852 unsigned int j;
4854 /* Create a copy of argbuf with a dummy argv[0] entry for
4855 decode_cmdline_options_to_array. */
4856 argbuf_copy = XNEWVEC (const char *,
4857 argbuf.length () + 1);
4858 argbuf_copy[0] = "";
4859 memcpy (argbuf_copy + 1, argbuf.address (),
4860 argbuf.length () * sizeof (const char *));
4862 decode_cmdline_options_to_array (argbuf.length () + 1,
4863 argbuf_copy,
4864 CL_DRIVER, &decoded_options,
4865 &decoded_options_count);
4866 free (argbuf_copy);
4868 set_option_handlers (&handlers);
4870 for (j = 1; j < decoded_options_count; j++)
4872 switch (decoded_options[j].opt_index)
4874 case OPT_SPECIAL_input_file:
4875 /* Specs should only generate options, not input
4876 files. */
4877 if (strcmp (decoded_options[j].arg, "-") != 0)
4878 fatal_error (input_location,
4879 "switch %qs does not start with %<-%>",
4880 decoded_options[j].arg);
4881 else
4882 fatal_error (input_location,
4883 "spec-generated switch is just %<-%>");
4884 break;
4886 case OPT_fcompare_debug_second:
4887 case OPT_fcompare_debug:
4888 case OPT_fcompare_debug_:
4889 case OPT_o:
4890 /* Avoid duplicate processing of some options from
4891 compare-debug specs; just save them here. */
4892 save_switch (decoded_options[j].canonical_option[0],
4893 (decoded_options[j].canonical_option_num_elements
4894 - 1),
4895 &decoded_options[j].canonical_option[1], false, true);
4896 break;
4898 default:
4899 read_cmdline_option (&global_options, &global_options_set,
4900 decoded_options + j, UNKNOWN_LOCATION,
4901 CL_DRIVER, &handlers, global_dc);
4902 break;
4906 free (decoded_options);
4908 alloc_switch ();
4909 switches[n_switches].part1 = 0;
4913 /* Callback for processing %D and %I specs. */
4915 struct spec_path_info {
4916 const char *option;
4917 const char *append;
4918 size_t append_len;
4919 bool omit_relative;
4920 bool separate_options;
4923 static void *
4924 spec_path (char *path, void *data)
4926 struct spec_path_info *info = (struct spec_path_info *) data;
4927 size_t len = 0;
4928 char save = 0;
4930 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4931 return NULL;
4933 if (info->append_len != 0)
4935 len = strlen (path);
4936 memcpy (path + len, info->append, info->append_len + 1);
4939 if (!is_directory (path, true))
4940 return NULL;
4942 do_spec_1 (info->option, 1, NULL);
4943 if (info->separate_options)
4944 do_spec_1 (" ", 0, NULL);
4946 if (info->append_len == 0)
4948 len = strlen (path);
4949 save = path[len - 1];
4950 if (IS_DIR_SEPARATOR (path[len - 1]))
4951 path[len - 1] = '\0';
4954 do_spec_1 (path, 1, NULL);
4955 do_spec_1 (" ", 0, NULL);
4957 /* Must not damage the original path. */
4958 if (info->append_len == 0)
4959 path[len - 1] = save;
4961 return NULL;
4964 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
4965 argument list. */
4967 static void
4968 create_at_file (char **argv)
4970 char *temp_file = make_temp_file ("");
4971 char *at_argument = concat ("@", temp_file, NULL);
4972 FILE *f = fopen (temp_file, "w");
4973 int status;
4975 if (f == NULL)
4976 fatal_error (input_location, "could not open temporary response file %s",
4977 temp_file);
4979 status = writeargv (argv, f);
4981 if (status)
4982 fatal_error (input_location,
4983 "could not write to temporary response file %s",
4984 temp_file);
4986 status = fclose (f);
4988 if (EOF == status)
4989 fatal_error (input_location, "could not close temporary response file %s",
4990 temp_file);
4992 store_arg (at_argument, 0, 0);
4994 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
4997 /* True if we should compile INFILE. */
4999 static bool
5000 compile_input_file_p (struct infile *infile)
5002 if ((!infile->language) || (infile->language[0] != '*'))
5003 if (infile->incompiler == input_file_compiler)
5004 return true;
5005 return false;
5008 /* Process each member of VEC as a spec. */
5010 static void
5011 do_specs_vec (vec<char_p> vec)
5013 unsigned ix;
5014 char *opt;
5016 FOR_EACH_VEC_ELT (vec, ix, opt)
5018 do_spec_1 (opt, 1, NULL);
5019 /* Make each accumulated option a separate argument. */
5020 do_spec_1 (" ", 0, NULL);
5024 /* Process the sub-spec SPEC as a portion of a larger spec.
5025 This is like processing a whole spec except that we do
5026 not initialize at the beginning and we do not supply a
5027 newline by default at the end.
5028 INSWITCH nonzero means don't process %-sequences in SPEC;
5029 in this case, % is treated as an ordinary character.
5030 This is used while substituting switches.
5031 INSWITCH nonzero also causes SPC not to terminate an argument.
5033 Value is zero unless a line was finished
5034 and the command on that line reported an error. */
5036 static int
5037 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
5039 const char *p = spec;
5040 int c;
5041 int i;
5042 int value;
5044 /* If it's an empty string argument to a switch, keep it as is. */
5045 if (inswitch && !*p)
5046 arg_going = 1;
5048 while ((c = *p++))
5049 /* If substituting a switch, treat all chars like letters.
5050 Otherwise, NL, SPC, TAB and % are special. */
5051 switch (inswitch ? 'a' : c)
5053 case '\n':
5054 end_going_arg ();
5056 if (argbuf.length () > 0
5057 && !strcmp (argbuf.last (), "|"))
5059 /* A `|' before the newline means use a pipe here,
5060 but only if -pipe was specified.
5061 Otherwise, execute now and don't pass the `|' as an arg. */
5062 if (use_pipes)
5064 input_from_pipe = 1;
5065 break;
5067 else
5068 argbuf.pop ();
5071 set_collect_gcc_options ();
5073 if (argbuf.length () > 0)
5075 value = execute ();
5076 if (value)
5077 return value;
5079 /* Reinitialize for a new command, and for a new argument. */
5080 clear_args ();
5081 arg_going = 0;
5082 delete_this_arg = 0;
5083 this_is_output_file = 0;
5084 this_is_library_file = 0;
5085 this_is_linker_script = 0;
5086 input_from_pipe = 0;
5087 break;
5089 case '|':
5090 end_going_arg ();
5092 /* Use pipe */
5093 obstack_1grow (&obstack, c);
5094 arg_going = 1;
5095 break;
5097 case '\t':
5098 case ' ':
5099 end_going_arg ();
5101 /* Reinitialize for a new argument. */
5102 delete_this_arg = 0;
5103 this_is_output_file = 0;
5104 this_is_library_file = 0;
5105 this_is_linker_script = 0;
5106 break;
5108 case '%':
5109 switch (c = *p++)
5111 case 0:
5112 fatal_error (input_location, "spec %qs invalid", spec);
5114 case 'b':
5115 if (save_temps_length)
5116 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
5117 else
5118 obstack_grow (&obstack, input_basename, basename_length);
5119 if (compare_debug < 0)
5120 obstack_grow (&obstack, ".gk", 3);
5121 arg_going = 1;
5122 break;
5124 case 'B':
5125 if (save_temps_length)
5126 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
5127 else
5128 obstack_grow (&obstack, input_basename, suffixed_basename_length);
5129 if (compare_debug < 0)
5130 obstack_grow (&obstack, ".gk", 3);
5131 arg_going = 1;
5132 break;
5134 case 'd':
5135 delete_this_arg = 2;
5136 break;
5138 /* Dump out the directories specified with LIBRARY_PATH,
5139 followed by the absolute directories
5140 that we search for startfiles. */
5141 case 'D':
5143 struct spec_path_info info;
5145 info.option = "-L";
5146 info.append_len = 0;
5147 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
5148 /* Used on systems which record the specified -L dirs
5149 and use them to search for dynamic linking.
5150 Relative directories always come from -B,
5151 and it is better not to use them for searching
5152 at run time. In particular, stage1 loses. */
5153 info.omit_relative = true;
5154 #else
5155 info.omit_relative = false;
5156 #endif
5157 info.separate_options = false;
5159 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
5161 break;
5163 case 'e':
5164 /* %efoo means report an error with `foo' as error message
5165 and don't execute any more commands for this file. */
5167 const char *q = p;
5168 char *buf;
5169 while (*p != 0 && *p != '\n')
5170 p++;
5171 buf = (char *) alloca (p - q + 1);
5172 strncpy (buf, q, p - q);
5173 buf[p - q] = 0;
5174 error ("%s", _(buf));
5175 return -1;
5177 break;
5178 case 'n':
5179 /* %nfoo means report a notice with `foo' on stderr. */
5181 const char *q = p;
5182 char *buf;
5183 while (*p != 0 && *p != '\n')
5184 p++;
5185 buf = (char *) alloca (p - q + 1);
5186 strncpy (buf, q, p - q);
5187 buf[p - q] = 0;
5188 inform (0, "%s", _(buf));
5189 if (*p)
5190 p++;
5192 break;
5194 case 'j':
5196 struct stat st;
5198 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
5199 defined, and it is not a directory, and it is
5200 writable, use it. Otherwise, treat this like any
5201 other temporary file. */
5203 if ((!save_temps_flag)
5204 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
5205 && (access (HOST_BIT_BUCKET, W_OK) == 0))
5207 obstack_grow (&obstack, HOST_BIT_BUCKET,
5208 strlen (HOST_BIT_BUCKET));
5209 delete_this_arg = 0;
5210 arg_going = 1;
5211 break;
5214 goto create_temp_file;
5215 case '|':
5216 if (use_pipes)
5218 obstack_1grow (&obstack, '-');
5219 delete_this_arg = 0;
5220 arg_going = 1;
5222 /* consume suffix */
5223 while (*p == '.' || ISALNUM ((unsigned char) *p))
5224 p++;
5225 if (p[0] == '%' && p[1] == 'O')
5226 p += 2;
5228 break;
5230 goto create_temp_file;
5231 case 'm':
5232 if (use_pipes)
5234 /* consume suffix */
5235 while (*p == '.' || ISALNUM ((unsigned char) *p))
5236 p++;
5237 if (p[0] == '%' && p[1] == 'O')
5238 p += 2;
5240 break;
5242 goto create_temp_file;
5243 case 'g':
5244 case 'u':
5245 case 'U':
5246 create_temp_file:
5248 struct temp_name *t;
5249 int suffix_length;
5250 const char *suffix = p;
5251 char *saved_suffix = NULL;
5253 while (*p == '.' || ISALNUM ((unsigned char) *p))
5254 p++;
5255 suffix_length = p - suffix;
5256 if (p[0] == '%' && p[1] == 'O')
5258 p += 2;
5259 /* We don't support extra suffix characters after %O. */
5260 if (*p == '.' || ISALNUM ((unsigned char) *p))
5261 fatal_error (input_location,
5262 "spec %qs has invalid %<%%0%c%>", spec, *p);
5263 if (suffix_length == 0)
5264 suffix = TARGET_OBJECT_SUFFIX;
5265 else
5267 saved_suffix
5268 = XNEWVEC (char, suffix_length
5269 + strlen (TARGET_OBJECT_SUFFIX) + 1);
5270 strncpy (saved_suffix, suffix, suffix_length);
5271 strcpy (saved_suffix + suffix_length,
5272 TARGET_OBJECT_SUFFIX);
5274 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
5277 if (compare_debug < 0)
5279 suffix = concat (".gk", suffix, NULL);
5280 suffix_length += 3;
5283 /* If -save-temps=obj and -o were specified, use that for the
5284 temp file. */
5285 if (save_temps_length)
5287 char *tmp;
5288 temp_filename_length
5289 = save_temps_length + suffix_length + 1;
5290 tmp = (char *) alloca (temp_filename_length);
5291 memcpy (tmp, save_temps_prefix, save_temps_length);
5292 memcpy (tmp + save_temps_length, suffix, suffix_length);
5293 tmp[save_temps_length + suffix_length] = '\0';
5294 temp_filename = save_string (tmp, save_temps_length
5295 + suffix_length);
5296 obstack_grow (&obstack, temp_filename,
5297 temp_filename_length);
5298 arg_going = 1;
5299 delete_this_arg = 0;
5300 break;
5303 /* If the gcc_input_filename has the same suffix specified
5304 for the %g, %u, or %U, and -save-temps is specified,
5305 we could end up using that file as an intermediate
5306 thus clobbering the user's source file (.e.g.,
5307 gcc -save-temps foo.s would clobber foo.s with the
5308 output of cpp0). So check for this condition and
5309 generate a temp file as the intermediate. */
5311 if (save_temps_flag)
5313 char *tmp;
5314 temp_filename_length = basename_length + suffix_length + 1;
5315 tmp = (char *) alloca (temp_filename_length);
5316 memcpy (tmp, input_basename, basename_length);
5317 memcpy (tmp + basename_length, suffix, suffix_length);
5318 tmp[basename_length + suffix_length] = '\0';
5319 temp_filename = tmp;
5321 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
5323 #ifndef HOST_LACKS_INODE_NUMBERS
5324 struct stat st_temp;
5326 /* Note, set_input() resets input_stat_set to 0. */
5327 if (input_stat_set == 0)
5329 input_stat_set = stat (gcc_input_filename,
5330 &input_stat);
5331 if (input_stat_set >= 0)
5332 input_stat_set = 1;
5335 /* If we have the stat for the gcc_input_filename
5336 and we can do the stat for the temp_filename
5337 then the they could still refer to the same
5338 file if st_dev/st_ino's are the same. */
5339 if (input_stat_set != 1
5340 || stat (temp_filename, &st_temp) < 0
5341 || input_stat.st_dev != st_temp.st_dev
5342 || input_stat.st_ino != st_temp.st_ino)
5343 #else
5344 /* Just compare canonical pathnames. */
5345 char* input_realname = lrealpath (gcc_input_filename);
5346 char* temp_realname = lrealpath (temp_filename);
5347 bool files_differ = filename_cmp (input_realname, temp_realname);
5348 free (input_realname);
5349 free (temp_realname);
5350 if (files_differ)
5351 #endif
5353 temp_filename = save_string (temp_filename,
5354 temp_filename_length + 1);
5355 obstack_grow (&obstack, temp_filename,
5356 temp_filename_length);
5357 arg_going = 1;
5358 delete_this_arg = 0;
5359 break;
5364 /* See if we already have an association of %g/%u/%U and
5365 suffix. */
5366 for (t = temp_names; t; t = t->next)
5367 if (t->length == suffix_length
5368 && strncmp (t->suffix, suffix, suffix_length) == 0
5369 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
5370 break;
5372 /* Make a new association if needed. %u and %j
5373 require one. */
5374 if (t == 0 || c == 'u' || c == 'j')
5376 if (t == 0)
5378 t = XNEW (struct temp_name);
5379 t->next = temp_names;
5380 temp_names = t;
5382 t->length = suffix_length;
5383 if (saved_suffix)
5385 t->suffix = saved_suffix;
5386 saved_suffix = NULL;
5388 else
5389 t->suffix = save_string (suffix, suffix_length);
5390 t->unique = (c == 'u' || c == 'U' || c == 'j');
5391 temp_filename = make_temp_file (t->suffix);
5392 temp_filename_length = strlen (temp_filename);
5393 t->filename = temp_filename;
5394 t->filename_length = temp_filename_length;
5397 free (saved_suffix);
5399 obstack_grow (&obstack, t->filename, t->filename_length);
5400 delete_this_arg = 1;
5402 arg_going = 1;
5403 break;
5405 case 'i':
5406 if (combine_inputs)
5408 if (at_file_supplied)
5410 /* We are going to expand `%i' to `@FILE', where FILE
5411 is a newly-created temporary filename. The filenames
5412 that would usually be expanded in place of %o will be
5413 written to the temporary file. */
5414 char **argv;
5415 int n_files = 0;
5416 int j;
5418 for (i = 0; i < n_infiles; i++)
5419 if (compile_input_file_p (&infiles[i]))
5420 n_files++;
5422 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5424 /* Copy the strings over. */
5425 for (i = 0, j = 0; i < n_infiles; i++)
5426 if (compile_input_file_p (&infiles[i]))
5428 argv[j] = CONST_CAST (char *, infiles[i].name);
5429 infiles[i].compiled = true;
5430 j++;
5432 argv[j] = NULL;
5434 create_at_file (argv);
5436 else
5437 for (i = 0; (int) i < n_infiles; i++)
5438 if (compile_input_file_p (&infiles[i]))
5440 store_arg (infiles[i].name, 0, 0);
5441 infiles[i].compiled = true;
5444 else
5446 obstack_grow (&obstack, gcc_input_filename,
5447 input_filename_length);
5448 arg_going = 1;
5450 break;
5452 case 'I':
5454 struct spec_path_info info;
5456 if (multilib_dir)
5458 do_spec_1 ("-imultilib", 1, NULL);
5459 /* Make this a separate argument. */
5460 do_spec_1 (" ", 0, NULL);
5461 do_spec_1 (multilib_dir, 1, NULL);
5462 do_spec_1 (" ", 0, NULL);
5465 if (multiarch_dir)
5467 do_spec_1 ("-imultiarch", 1, NULL);
5468 /* Make this a separate argument. */
5469 do_spec_1 (" ", 0, NULL);
5470 do_spec_1 (multiarch_dir, 1, NULL);
5471 do_spec_1 (" ", 0, NULL);
5474 if (gcc_exec_prefix)
5476 do_spec_1 ("-iprefix", 1, NULL);
5477 /* Make this a separate argument. */
5478 do_spec_1 (" ", 0, NULL);
5479 do_spec_1 (gcc_exec_prefix, 1, NULL);
5480 do_spec_1 (" ", 0, NULL);
5483 if (target_system_root_changed ||
5484 (target_system_root && target_sysroot_hdrs_suffix))
5486 do_spec_1 ("-isysroot", 1, NULL);
5487 /* Make this a separate argument. */
5488 do_spec_1 (" ", 0, NULL);
5489 do_spec_1 (target_system_root, 1, NULL);
5490 if (target_sysroot_hdrs_suffix)
5491 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
5492 do_spec_1 (" ", 0, NULL);
5495 info.option = "-isystem";
5496 info.append = "include";
5497 info.append_len = strlen (info.append);
5498 info.omit_relative = false;
5499 info.separate_options = true;
5501 for_each_path (&include_prefixes, false, info.append_len,
5502 spec_path, &info);
5504 info.append = "include-fixed";
5505 if (*sysroot_hdrs_suffix_spec)
5506 info.append = concat (info.append, dir_separator_str,
5507 multilib_dir, NULL);
5508 info.append_len = strlen (info.append);
5509 for_each_path (&include_prefixes, false, info.append_len,
5510 spec_path, &info);
5512 break;
5514 case 'o':
5516 int max = n_infiles;
5517 max += lang_specific_extra_outfiles;
5519 if (HAVE_GNU_LD && at_file_supplied)
5521 /* We are going to expand `%o' to `@FILE', where FILE
5522 is a newly-created temporary filename. The filenames
5523 that would usually be expanded in place of %o will be
5524 written to the temporary file. */
5526 char **argv;
5527 int n_files, j;
5529 /* Convert OUTFILES into a form suitable for writeargv. */
5531 /* Determine how many are non-NULL. */
5532 for (n_files = 0, i = 0; i < max; i++)
5533 n_files += outfiles[i] != NULL;
5535 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5537 /* Copy the strings over. */
5538 for (i = 0, j = 0; i < max; i++)
5539 if (outfiles[i])
5541 argv[j] = CONST_CAST (char *, outfiles[i]);
5542 j++;
5544 argv[j] = NULL;
5546 create_at_file (argv);
5548 else
5549 for (i = 0; i < max; i++)
5550 if (outfiles[i])
5551 store_arg (outfiles[i], 0, 0);
5552 break;
5555 case 'O':
5556 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5557 arg_going = 1;
5558 break;
5560 case 's':
5561 this_is_library_file = 1;
5562 break;
5564 case 'T':
5565 this_is_linker_script = 1;
5566 break;
5568 case 'V':
5569 outfiles[input_file_number] = NULL;
5570 break;
5572 case 'w':
5573 this_is_output_file = 1;
5574 break;
5576 case 'W':
5578 unsigned int cur_index = argbuf.length ();
5579 /* Handle the {...} following the %W. */
5580 if (*p != '{')
5581 fatal_error (input_location,
5582 "spec %qs has invalid %<%%W%c%>", spec, *p);
5583 p = handle_braces (p + 1);
5584 if (p == 0)
5585 return -1;
5586 end_going_arg ();
5587 /* If any args were output, mark the last one for deletion
5588 on failure. */
5589 if (argbuf.length () != cur_index)
5590 record_temp_file (argbuf.last (), 0, 1);
5591 break;
5594 /* %x{OPTION} records OPTION for %X to output. */
5595 case 'x':
5597 const char *p1 = p;
5598 char *string;
5599 char *opt;
5600 unsigned ix;
5602 /* Skip past the option value and make a copy. */
5603 if (*p != '{')
5604 fatal_error (input_location,
5605 "spec %qs has invalid %<%%x%c%>", spec, *p);
5606 while (*p++ != '}')
5608 string = save_string (p1 + 1, p - p1 - 2);
5610 /* See if we already recorded this option. */
5611 FOR_EACH_VEC_ELT (linker_options, ix, opt)
5612 if (! strcmp (string, opt))
5614 free (string);
5615 return 0;
5618 /* This option is new; add it. */
5619 add_linker_option (string, strlen (string));
5620 free (string);
5622 break;
5624 /* Dump out the options accumulated previously using %x. */
5625 case 'X':
5626 do_specs_vec (linker_options);
5627 break;
5629 /* Dump out the options accumulated previously using -Wa,. */
5630 case 'Y':
5631 do_specs_vec (assembler_options);
5632 break;
5634 /* Dump out the options accumulated previously using -Wp,. */
5635 case 'Z':
5636 do_specs_vec (preprocessor_options);
5637 break;
5639 /* Here are digits and numbers that just process
5640 a certain constant string as a spec. */
5642 case '1':
5643 value = do_spec_1 (cc1_spec, 0, NULL);
5644 if (value != 0)
5645 return value;
5646 break;
5648 case '2':
5649 value = do_spec_1 (cc1plus_spec, 0, NULL);
5650 if (value != 0)
5651 return value;
5652 break;
5654 case 'a':
5655 value = do_spec_1 (asm_spec, 0, NULL);
5656 if (value != 0)
5657 return value;
5658 break;
5660 case 'A':
5661 value = do_spec_1 (asm_final_spec, 0, NULL);
5662 if (value != 0)
5663 return value;
5664 break;
5666 case 'C':
5668 const char *const spec
5669 = (input_file_compiler->cpp_spec
5670 ? input_file_compiler->cpp_spec
5671 : cpp_spec);
5672 value = do_spec_1 (spec, 0, NULL);
5673 if (value != 0)
5674 return value;
5676 break;
5678 case 'E':
5679 value = do_spec_1 (endfile_spec, 0, NULL);
5680 if (value != 0)
5681 return value;
5682 break;
5684 case 'l':
5685 value = do_spec_1 (link_spec, 0, NULL);
5686 if (value != 0)
5687 return value;
5688 break;
5690 case 'L':
5691 value = do_spec_1 (lib_spec, 0, NULL);
5692 if (value != 0)
5693 return value;
5694 break;
5696 case 'M':
5697 if (multilib_os_dir == NULL)
5698 obstack_1grow (&obstack, '.');
5699 else
5700 obstack_grow (&obstack, multilib_os_dir,
5701 strlen (multilib_os_dir));
5702 break;
5704 case 'G':
5705 value = do_spec_1 (libgcc_spec, 0, NULL);
5706 if (value != 0)
5707 return value;
5708 break;
5710 case 'R':
5711 /* We assume there is a directory
5712 separator at the end of this string. */
5713 if (target_system_root)
5715 obstack_grow (&obstack, target_system_root,
5716 strlen (target_system_root));
5717 if (target_sysroot_suffix)
5718 obstack_grow (&obstack, target_sysroot_suffix,
5719 strlen (target_sysroot_suffix));
5721 break;
5723 case 'S':
5724 value = do_spec_1 (startfile_spec, 0, NULL);
5725 if (value != 0)
5726 return value;
5727 break;
5729 /* Here we define characters other than letters and digits. */
5731 case '{':
5732 p = handle_braces (p);
5733 if (p == 0)
5734 return -1;
5735 break;
5737 case ':':
5738 p = handle_spec_function (p, NULL);
5739 if (p == 0)
5740 return -1;
5741 break;
5743 case '%':
5744 obstack_1grow (&obstack, '%');
5745 break;
5747 case '.':
5749 unsigned len = 0;
5751 while (p[len] && p[len] != ' ' && p[len] != '%')
5752 len++;
5753 suffix_subst = save_string (p - 1, len + 1);
5754 p += len;
5756 break;
5758 /* Henceforth ignore the option(s) matching the pattern
5759 after the %<. */
5760 case '<':
5761 case '>':
5763 unsigned len = 0;
5764 int have_wildcard = 0;
5765 int i;
5766 int switch_option;
5768 if (c == '>')
5769 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5770 else
5771 switch_option = SWITCH_IGNORE;
5773 while (p[len] && p[len] != ' ' && p[len] != '\t')
5774 len++;
5776 if (p[len-1] == '*')
5777 have_wildcard = 1;
5779 for (i = 0; i < n_switches; i++)
5780 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5781 && (have_wildcard || switches[i].part1[len] == '\0'))
5783 switches[i].live_cond |= switch_option;
5784 /* User switch be validated from validate_all_switches.
5785 when the definition is seen from the spec file.
5786 If not defined anywhere, will be rejected. */
5787 if (switches[i].known)
5788 switches[i].validated = true;
5791 p += len;
5793 break;
5795 case '*':
5796 if (soft_matched_part)
5798 if (soft_matched_part[0])
5799 do_spec_1 (soft_matched_part, 1, NULL);
5800 /* Only insert a space after the substitution if it is at the
5801 end of the current sequence. So if:
5803 "%{foo=*:bar%*}%{foo=*:one%*two}"
5805 matches -foo=hello then it will produce:
5807 barhello onehellotwo
5809 if (*p == 0 || *p == '}')
5810 do_spec_1 (" ", 0, NULL);
5812 else
5813 /* Catch the case where a spec string contains something like
5814 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5815 hand side of the :. */
5816 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5817 break;
5819 /* Process a string found as the value of a spec given by name.
5820 This feature allows individual machine descriptions
5821 to add and use their own specs. */
5822 case '(':
5824 const char *name = p;
5825 struct spec_list *sl;
5826 int len;
5828 /* The string after the S/P is the name of a spec that is to be
5829 processed. */
5830 while (*p && *p != ')')
5831 p++;
5833 /* See if it's in the list. */
5834 for (len = p - name, sl = specs; sl; sl = sl->next)
5835 if (sl->name_len == len && !strncmp (sl->name, name, len))
5837 name = *(sl->ptr_spec);
5838 #ifdef DEBUG_SPECS
5839 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5840 sl->name, name);
5841 #endif
5842 break;
5845 if (sl)
5847 value = do_spec_1 (name, 0, NULL);
5848 if (value != 0)
5849 return value;
5852 /* Discard the closing paren. */
5853 if (*p)
5854 p++;
5856 break;
5858 default:
5859 error ("spec failure: unrecognized spec option %qc", c);
5860 break;
5862 break;
5864 case '\\':
5865 /* Backslash: treat next character as ordinary. */
5866 c = *p++;
5868 /* Fall through. */
5869 default:
5870 /* Ordinary character: put it into the current argument. */
5871 obstack_1grow (&obstack, c);
5872 arg_going = 1;
5875 /* End of string. If we are processing a spec function, we need to
5876 end any pending argument. */
5877 if (processing_spec_function)
5878 end_going_arg ();
5880 return 0;
5883 /* Look up a spec function. */
5885 static const struct spec_function *
5886 lookup_spec_function (const char *name)
5888 const struct spec_function *sf;
5890 for (sf = static_spec_functions; sf->name != NULL; sf++)
5891 if (strcmp (sf->name, name) == 0)
5892 return sf;
5894 return NULL;
5897 /* Evaluate a spec function. */
5899 static const char *
5900 eval_spec_function (const char *func, const char *args)
5902 const struct spec_function *sf;
5903 const char *funcval;
5905 /* Saved spec processing context. */
5906 vec<const_char_p> save_argbuf;
5908 int save_arg_going;
5909 int save_delete_this_arg;
5910 int save_this_is_output_file;
5911 int save_this_is_library_file;
5912 int save_input_from_pipe;
5913 int save_this_is_linker_script;
5914 const char *save_suffix_subst;
5916 int save_growing_size;
5917 void *save_growing_value = NULL;
5919 sf = lookup_spec_function (func);
5920 if (sf == NULL)
5921 fatal_error (input_location, "unknown spec function %qs", func);
5923 /* Push the spec processing context. */
5924 save_argbuf = argbuf;
5926 save_arg_going = arg_going;
5927 save_delete_this_arg = delete_this_arg;
5928 save_this_is_output_file = this_is_output_file;
5929 save_this_is_library_file = this_is_library_file;
5930 save_this_is_linker_script = this_is_linker_script;
5931 save_input_from_pipe = input_from_pipe;
5932 save_suffix_subst = suffix_subst;
5934 /* If we have some object growing now, finalize it so the args and function
5935 eval proceed from a cleared context. This is needed to prevent the first
5936 constructed arg from mistakenly including the growing value. We'll push
5937 this value back on the obstack once the function evaluation is done, to
5938 restore a consistent processing context for our caller. This is fine as
5939 the address of growing objects isn't guaranteed to remain stable until
5940 they are finalized, and we expect this situation to be rare enough for
5941 the extra copy not to be an issue. */
5942 save_growing_size = obstack_object_size (&obstack);
5943 if (save_growing_size > 0)
5944 save_growing_value = obstack_finish (&obstack);
5946 /* Create a new spec processing context, and build the function
5947 arguments. */
5949 alloc_args ();
5950 if (do_spec_2 (args) < 0)
5951 fatal_error (input_location, "error in args to spec function %qs", func);
5953 /* argbuf_index is an index for the next argument to be inserted, and
5954 so contains the count of the args already inserted. */
5956 funcval = (*sf->func) (argbuf.length (),
5957 argbuf.address ());
5959 /* Pop the spec processing context. */
5960 argbuf.release ();
5961 argbuf = save_argbuf;
5963 arg_going = save_arg_going;
5964 delete_this_arg = save_delete_this_arg;
5965 this_is_output_file = save_this_is_output_file;
5966 this_is_library_file = save_this_is_library_file;
5967 this_is_linker_script = save_this_is_linker_script;
5968 input_from_pipe = save_input_from_pipe;
5969 suffix_subst = save_suffix_subst;
5971 if (save_growing_size > 0)
5972 obstack_grow (&obstack, save_growing_value, save_growing_size);
5974 return funcval;
5977 /* Handle a spec function call of the form:
5979 %:function(args)
5981 ARGS is processed as a spec in a separate context and split into an
5982 argument vector in the normal fashion. The function returns a string
5983 containing a spec which we then process in the caller's context, or
5984 NULL if no processing is required.
5986 If RETVAL_NONNULL is not NULL, then store a bool whether function
5987 returned non-NULL. */
5989 static const char *
5990 handle_spec_function (const char *p, bool *retval_nonnull)
5992 char *func, *args;
5993 const char *endp, *funcval;
5994 int count;
5996 processing_spec_function++;
5998 /* Get the function name. */
5999 for (endp = p; *endp != '\0'; endp++)
6001 if (*endp == '(') /* ) */
6002 break;
6003 /* Only allow [A-Za-z0-9], -, and _ in function names. */
6004 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
6005 fatal_error (input_location, "malformed spec function name");
6007 if (*endp != '(') /* ) */
6008 fatal_error (input_location, "no arguments for spec function");
6009 func = save_string (p, endp - p);
6010 p = ++endp;
6012 /* Get the arguments. */
6013 for (count = 0; *endp != '\0'; endp++)
6015 /* ( */
6016 if (*endp == ')')
6018 if (count == 0)
6019 break;
6020 count--;
6022 else if (*endp == '(') /* ) */
6023 count++;
6025 /* ( */
6026 if (*endp != ')')
6027 fatal_error (input_location, "malformed spec function arguments");
6028 args = save_string (p, endp - p);
6029 p = ++endp;
6031 /* p now points to just past the end of the spec function expression. */
6033 funcval = eval_spec_function (func, args);
6034 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
6035 p = NULL;
6036 if (retval_nonnull)
6037 *retval_nonnull = funcval != NULL;
6039 free (func);
6040 free (args);
6042 processing_spec_function--;
6044 return p;
6047 /* Inline subroutine of handle_braces. Returns true if the current
6048 input suffix matches the atom bracketed by ATOM and END_ATOM. */
6049 static inline bool
6050 input_suffix_matches (const char *atom, const char *end_atom)
6052 return (input_suffix
6053 && !strncmp (input_suffix, atom, end_atom - atom)
6054 && input_suffix[end_atom - atom] == '\0');
6057 /* Subroutine of handle_braces. Returns true if the current
6058 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
6059 static bool
6060 input_spec_matches (const char *atom, const char *end_atom)
6062 return (input_file_compiler
6063 && input_file_compiler->suffix
6064 && input_file_compiler->suffix[0] != '\0'
6065 && !strncmp (input_file_compiler->suffix + 1, atom,
6066 end_atom - atom)
6067 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
6070 /* Subroutine of handle_braces. Returns true if a switch
6071 matching the atom bracketed by ATOM and END_ATOM appeared on the
6072 command line. */
6073 static bool
6074 switch_matches (const char *atom, const char *end_atom, int starred)
6076 int i;
6077 int len = end_atom - atom;
6078 int plen = starred ? len : -1;
6080 for (i = 0; i < n_switches; i++)
6081 if (!strncmp (switches[i].part1, atom, len)
6082 && (starred || switches[i].part1[len] == '\0')
6083 && check_live_switch (i, plen))
6084 return true;
6086 /* Check if a switch with separated form matching the atom.
6087 We check -D and -U switches. */
6088 else if (switches[i].args != 0)
6090 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
6091 && *switches[i].part1 == atom[0])
6093 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
6094 && (starred || (switches[i].part1[1] == '\0'
6095 && switches[i].args[0][len - 1] == '\0'))
6096 && check_live_switch (i, (starred ? 1 : -1)))
6097 return true;
6101 return false;
6104 /* Inline subroutine of handle_braces. Mark all of the switches which
6105 match ATOM (extends to END_ATOM; STARRED indicates whether there
6106 was a star after the atom) for later processing. */
6107 static inline void
6108 mark_matching_switches (const char *atom, const char *end_atom, int starred)
6110 int i;
6111 int len = end_atom - atom;
6112 int plen = starred ? len : -1;
6114 for (i = 0; i < n_switches; i++)
6115 if (!strncmp (switches[i].part1, atom, len)
6116 && (starred || switches[i].part1[len] == '\0')
6117 && check_live_switch (i, plen))
6118 switches[i].ordering = 1;
6121 /* Inline subroutine of handle_braces. Process all the currently
6122 marked switches through give_switch, and clear the marks. */
6123 static inline void
6124 process_marked_switches (void)
6126 int i;
6128 for (i = 0; i < n_switches; i++)
6129 if (switches[i].ordering == 1)
6131 switches[i].ordering = 0;
6132 give_switch (i, 0);
6136 /* Handle a %{ ... } construct. P points just inside the leading {.
6137 Returns a pointer one past the end of the brace block, or 0
6138 if we call do_spec_1 and that returns -1. */
6140 static const char *
6141 handle_braces (const char *p)
6143 const char *atom, *end_atom;
6144 const char *d_atom = NULL, *d_end_atom = NULL;
6145 const char *orig = p;
6147 bool a_is_suffix;
6148 bool a_is_spectype;
6149 bool a_is_starred;
6150 bool a_is_negated;
6151 bool a_matched;
6153 bool a_must_be_last = false;
6154 bool ordered_set = false;
6155 bool disjunct_set = false;
6156 bool disj_matched = false;
6157 bool disj_starred = true;
6158 bool n_way_choice = false;
6159 bool n_way_matched = false;
6161 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
6165 if (a_must_be_last)
6166 goto invalid;
6168 /* Scan one "atom" (S in the description above of %{}, possibly
6169 with '!', '.', '@', ',', or '*' modifiers). */
6170 a_matched = false;
6171 a_is_suffix = false;
6172 a_is_starred = false;
6173 a_is_negated = false;
6174 a_is_spectype = false;
6176 SKIP_WHITE ();
6177 if (*p == '!')
6178 p++, a_is_negated = true;
6180 SKIP_WHITE ();
6181 if (*p == '%' && p[1] == ':')
6183 atom = NULL;
6184 end_atom = NULL;
6185 p = handle_spec_function (p + 2, &a_matched);
6187 else
6189 if (*p == '.')
6190 p++, a_is_suffix = true;
6191 else if (*p == ',')
6192 p++, a_is_spectype = true;
6194 atom = p;
6195 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
6196 || *p == ',' || *p == '.' || *p == '@')
6197 p++;
6198 end_atom = p;
6200 if (*p == '*')
6201 p++, a_is_starred = 1;
6204 SKIP_WHITE ();
6205 switch (*p)
6207 case '&': case '}':
6208 /* Substitute the switch(es) indicated by the current atom. */
6209 ordered_set = true;
6210 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
6211 || a_is_spectype || atom == end_atom)
6212 goto invalid;
6214 mark_matching_switches (atom, end_atom, a_is_starred);
6216 if (*p == '}')
6217 process_marked_switches ();
6218 break;
6220 case '|': case ':':
6221 /* Substitute some text if the current atom appears as a switch
6222 or suffix. */
6223 disjunct_set = true;
6224 if (ordered_set)
6225 goto invalid;
6227 if (atom && atom == end_atom)
6229 if (!n_way_choice || disj_matched || *p == '|'
6230 || a_is_negated || a_is_suffix || a_is_spectype
6231 || a_is_starred)
6232 goto invalid;
6234 /* An empty term may appear as the last choice of an
6235 N-way choice set; it means "otherwise". */
6236 a_must_be_last = true;
6237 disj_matched = !n_way_matched;
6238 disj_starred = false;
6240 else
6242 if ((a_is_suffix || a_is_spectype) && a_is_starred)
6243 goto invalid;
6245 if (!a_is_starred)
6246 disj_starred = false;
6248 /* Don't bother testing this atom if we already have a
6249 match. */
6250 if (!disj_matched && !n_way_matched)
6252 if (atom == NULL)
6253 /* a_matched is already set by handle_spec_function. */;
6254 else if (a_is_suffix)
6255 a_matched = input_suffix_matches (atom, end_atom);
6256 else if (a_is_spectype)
6257 a_matched = input_spec_matches (atom, end_atom);
6258 else
6259 a_matched = switch_matches (atom, end_atom, a_is_starred);
6261 if (a_matched != a_is_negated)
6263 disj_matched = true;
6264 d_atom = atom;
6265 d_end_atom = end_atom;
6270 if (*p == ':')
6272 /* Found the body, that is, the text to substitute if the
6273 current disjunction matches. */
6274 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
6275 disj_matched && !n_way_matched);
6276 if (p == 0)
6277 return 0;
6279 /* If we have an N-way choice, reset state for the next
6280 disjunction. */
6281 if (*p == ';')
6283 n_way_choice = true;
6284 n_way_matched |= disj_matched;
6285 disj_matched = false;
6286 disj_starred = true;
6287 d_atom = d_end_atom = NULL;
6290 break;
6292 default:
6293 goto invalid;
6296 while (*p++ != '}');
6298 return p;
6300 invalid:
6301 fatal_error (input_location, "braced spec %qs is invalid at %qc", orig, *p);
6303 #undef SKIP_WHITE
6306 /* Subroutine of handle_braces. Scan and process a brace substitution body
6307 (X in the description of %{} syntax). P points one past the colon;
6308 ATOM and END_ATOM bracket the first atom which was found to be true
6309 (present) in the current disjunction; STARRED indicates whether all
6310 the atoms in the current disjunction were starred (for syntax validation);
6311 MATCHED indicates whether the disjunction matched or not, and therefore
6312 whether or not the body is to be processed through do_spec_1 or just
6313 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
6314 returns -1. */
6316 static const char *
6317 process_brace_body (const char *p, const char *atom, const char *end_atom,
6318 int starred, int matched)
6320 const char *body, *end_body;
6321 unsigned int nesting_level;
6322 bool have_subst = false;
6324 /* Locate the closing } or ;, honoring nested braces.
6325 Trim trailing whitespace. */
6326 body = p;
6327 nesting_level = 1;
6328 for (;;)
6330 if (*p == '{')
6331 nesting_level++;
6332 else if (*p == '}')
6334 if (!--nesting_level)
6335 break;
6337 else if (*p == ';' && nesting_level == 1)
6338 break;
6339 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
6340 have_subst = true;
6341 else if (*p == '\0')
6342 goto invalid;
6343 p++;
6346 end_body = p;
6347 while (end_body[-1] == ' ' || end_body[-1] == '\t')
6348 end_body--;
6350 if (have_subst && !starred)
6351 goto invalid;
6353 if (matched)
6355 /* Copy the substitution body to permanent storage and execute it.
6356 If have_subst is false, this is a simple matter of running the
6357 body through do_spec_1... */
6358 char *string = save_string (body, end_body - body);
6359 if (!have_subst)
6361 if (do_spec_1 (string, 0, NULL) < 0)
6363 free (string);
6364 return 0;
6367 else
6369 /* ... but if have_subst is true, we have to process the
6370 body once for each matching switch, with %* set to the
6371 variant part of the switch. */
6372 unsigned int hard_match_len = end_atom - atom;
6373 int i;
6375 for (i = 0; i < n_switches; i++)
6376 if (!strncmp (switches[i].part1, atom, hard_match_len)
6377 && check_live_switch (i, hard_match_len))
6379 if (do_spec_1 (string, 0,
6380 &switches[i].part1[hard_match_len]) < 0)
6382 free (string);
6383 return 0;
6385 /* Pass any arguments this switch has. */
6386 give_switch (i, 1);
6387 suffix_subst = NULL;
6390 free (string);
6393 return p;
6395 invalid:
6396 fatal_error (input_location, "braced spec body %qs is invalid", body);
6399 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
6400 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
6401 spec, or -1 if either exact match or %* is used.
6403 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
6404 whose value does not begin with "no-" is obsoleted by the same value
6405 with the "no-", similarly for a switch with the "no-" prefix. */
6407 static int
6408 check_live_switch (int switchnum, int prefix_length)
6410 const char *name = switches[switchnum].part1;
6411 int i;
6413 /* If we already processed this switch and determined if it was
6414 live or not, return our past determination. */
6415 if (switches[switchnum].live_cond != 0)
6416 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
6417 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
6418 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
6419 == 0);
6421 /* In the common case of {<at-most-one-letter>*}, a negating
6422 switch would always match, so ignore that case. We will just
6423 send the conflicting switches to the compiler phase. */
6424 if (prefix_length >= 0 && prefix_length <= 1)
6425 return 1;
6427 /* Now search for duplicate in a manner that depends on the name. */
6428 switch (*name)
6430 case 'O':
6431 for (i = switchnum + 1; i < n_switches; i++)
6432 if (switches[i].part1[0] == 'O')
6434 switches[switchnum].validated = true;
6435 switches[switchnum].live_cond = SWITCH_FALSE;
6436 return 0;
6438 break;
6440 case 'W': case 'f': case 'm': case 'g':
6441 if (! strncmp (name + 1, "no-", 3))
6443 /* We have Xno-YYY, search for XYYY. */
6444 for (i = switchnum + 1; i < n_switches; i++)
6445 if (switches[i].part1[0] == name[0]
6446 && ! strcmp (&switches[i].part1[1], &name[4]))
6448 /* --specs are validated with the validate_switches mechanism. */
6449 if (switches[switchnum].known)
6450 switches[switchnum].validated = true;
6451 switches[switchnum].live_cond = SWITCH_FALSE;
6452 return 0;
6455 else
6457 /* We have XYYY, search for Xno-YYY. */
6458 for (i = switchnum + 1; i < n_switches; i++)
6459 if (switches[i].part1[0] == name[0]
6460 && switches[i].part1[1] == 'n'
6461 && switches[i].part1[2] == 'o'
6462 && switches[i].part1[3] == '-'
6463 && !strcmp (&switches[i].part1[4], &name[1]))
6465 /* --specs are validated with the validate_switches mechanism. */
6466 if (switches[switchnum].known)
6467 switches[switchnum].validated = true;
6468 switches[switchnum].live_cond = SWITCH_FALSE;
6469 return 0;
6472 break;
6475 /* Otherwise the switch is live. */
6476 switches[switchnum].live_cond |= SWITCH_LIVE;
6477 return 1;
6480 /* Pass a switch to the current accumulating command
6481 in the same form that we received it.
6482 SWITCHNUM identifies the switch; it is an index into
6483 the vector of switches gcc received, which is `switches'.
6484 This cannot fail since it never finishes a command line.
6486 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
6488 static void
6489 give_switch (int switchnum, int omit_first_word)
6491 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
6492 return;
6494 if (!omit_first_word)
6496 do_spec_1 ("-", 0, NULL);
6497 do_spec_1 (switches[switchnum].part1, 1, NULL);
6500 if (switches[switchnum].args != 0)
6502 const char **p;
6503 for (p = switches[switchnum].args; *p; p++)
6505 const char *arg = *p;
6507 do_spec_1 (" ", 0, NULL);
6508 if (suffix_subst)
6510 unsigned length = strlen (arg);
6511 int dot = 0;
6513 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
6514 if (arg[length] == '.')
6516 (CONST_CAST (char *, arg))[length] = 0;
6517 dot = 1;
6518 break;
6520 do_spec_1 (arg, 1, NULL);
6521 if (dot)
6522 (CONST_CAST (char *, arg))[length] = '.';
6523 do_spec_1 (suffix_subst, 1, NULL);
6525 else
6526 do_spec_1 (arg, 1, NULL);
6530 do_spec_1 (" ", 0, NULL);
6531 switches[switchnum].validated = true;
6534 /* Print GCC configuration (e.g. version, thread model, target,
6535 configuration_arguments) to a given FILE. */
6537 static void
6538 print_configuration (FILE *file)
6540 int n;
6541 const char *thrmod;
6543 fnotice (file, "Target: %s\n", spec_machine);
6544 fnotice (file, "Configured with: %s\n", configuration_arguments);
6546 #ifdef THREAD_MODEL_SPEC
6547 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6548 but there's no point in doing all this processing just to get
6549 thread_model back. */
6550 obstack_init (&obstack);
6551 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6552 obstack_1grow (&obstack, '\0');
6553 thrmod = XOBFINISH (&obstack, const char *);
6554 #else
6555 thrmod = thread_model;
6556 #endif
6558 fnotice (file, "Thread model: %s\n", thrmod);
6560 /* compiler_version is truncated at the first space when initialized
6561 from version string, so truncate version_string at the first space
6562 before comparing. */
6563 for (n = 0; version_string[n]; n++)
6564 if (version_string[n] == ' ')
6565 break;
6567 if (! strncmp (version_string, compiler_version, n)
6568 && compiler_version[n] == 0)
6569 fnotice (file, "gcc version %s %s\n", version_string,
6570 pkgversion_string);
6571 else
6572 fnotice (file, "gcc driver version %s %sexecuting gcc version %s\n",
6573 version_string, pkgversion_string, compiler_version);
6577 #define RETRY_ICE_ATTEMPTS 3
6579 /* Returns true if FILE1 and FILE2 contain equivalent data, 0 otherwise. */
6581 static bool
6582 files_equal_p (char *file1, char *file2)
6584 struct stat st1, st2;
6585 off_t n, len;
6586 int fd1, fd2;
6587 const int bufsize = 8192;
6588 char *buf = XNEWVEC (char, bufsize);
6590 fd1 = open (file1, O_RDONLY);
6591 fd2 = open (file2, O_RDONLY);
6593 if (fd1 < 0 || fd2 < 0)
6594 goto error;
6596 if (fstat (fd1, &st1) < 0 || fstat (fd2, &st2) < 0)
6597 goto error;
6599 if (st1.st_size != st2.st_size)
6600 goto error;
6602 for (n = st1.st_size; n; n -= len)
6604 len = n;
6605 if ((int) len > bufsize / 2)
6606 len = bufsize / 2;
6608 if (read (fd1, buf, len) != (int) len
6609 || read (fd2, buf + bufsize / 2, len) != (int) len)
6611 goto error;
6614 if (memcmp (buf, buf + bufsize / 2, len) != 0)
6615 goto error;
6618 free (buf);
6619 close (fd1);
6620 close (fd2);
6622 return 1;
6624 error:
6625 free (buf);
6626 close (fd1);
6627 close (fd2);
6628 return 0;
6631 /* Check that compiler's output doesn't differ across runs.
6632 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are arrays of files, containing
6633 stdout and stderr for each compiler run. Return true if all of
6634 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are equivalent. */
6636 static bool
6637 check_repro (char **temp_stdout_files, char **temp_stderr_files)
6639 int i;
6640 for (i = 0; i < RETRY_ICE_ATTEMPTS - 2; ++i)
6642 if (!files_equal_p (temp_stdout_files[i], temp_stdout_files[i + 1])
6643 || !files_equal_p (temp_stderr_files[i], temp_stderr_files[i + 1]))
6645 fnotice (stderr, "The bug is not reproducible, so it is"
6646 " likely a hardware or OS problem.\n");
6647 break;
6650 return i == RETRY_ICE_ATTEMPTS - 2;
6653 enum attempt_status {
6654 ATTEMPT_STATUS_FAIL_TO_RUN,
6655 ATTEMPT_STATUS_SUCCESS,
6656 ATTEMPT_STATUS_ICE
6660 /* Run compiler with arguments NEW_ARGV to reproduce the ICE, storing stdout
6661 to OUT_TEMP and stderr to ERR_TEMP. If APPEND is TRUE, append to OUT_TEMP
6662 and ERR_TEMP instead of truncating. If EMIT_SYSTEM_INFO is TRUE, also write
6663 GCC configuration into to ERR_TEMP. Return ATTEMPT_STATUS_FAIL_TO_RUN if
6664 compiler failed to run, ATTEMPT_STATUS_ICE if compiled ICE-ed and
6665 ATTEMPT_STATUS_SUCCESS otherwise. */
6667 static enum attempt_status
6668 run_attempt (const char **new_argv, const char *out_temp,
6669 const char *err_temp, int emit_system_info, int append)
6672 if (emit_system_info)
6674 FILE *file_out = fopen (err_temp, "a");
6675 print_configuration (file_out);
6676 fputs ("\n", file_out);
6677 fclose (file_out);
6680 int exit_status;
6681 const char *errmsg;
6682 struct pex_obj *pex;
6683 int err;
6684 int pex_flags = PEX_USE_PIPES | PEX_LAST;
6685 enum attempt_status status = ATTEMPT_STATUS_FAIL_TO_RUN;
6687 if (append)
6688 pex_flags |= PEX_STDOUT_APPEND | PEX_STDERR_APPEND;
6690 pex = pex_init (PEX_USE_PIPES, new_argv[0], NULL);
6691 if (!pex)
6692 fatal_error (input_location, "pex_init failed: %m");
6694 errmsg = pex_run (pex, pex_flags, new_argv[0],
6695 CONST_CAST2 (char *const *, const char **, &new_argv[1]), out_temp,
6696 err_temp, &err);
6697 if (errmsg != NULL)
6699 if (err == 0)
6700 fatal_error (input_location, errmsg);
6701 else
6703 errno = err;
6704 pfatal_with_name (errmsg);
6708 if (!pex_get_status (pex, 1, &exit_status))
6709 goto out;
6711 switch (WEXITSTATUS (exit_status))
6713 case ICE_EXIT_CODE:
6714 status = ATTEMPT_STATUS_ICE;
6715 break;
6717 case SUCCESS_EXIT_CODE:
6718 status = ATTEMPT_STATUS_SUCCESS;
6719 break;
6721 default:
6725 out:
6726 pex_free (pex);
6727 return status;
6730 /* This routine reads lines from IN file, adds C++ style comments
6731 at the begining of each line and writes result into OUT. */
6733 static void
6734 insert_comments (const char *file_in, const char *file_out)
6736 FILE *in = fopen (file_in, "rb");
6737 FILE *out = fopen (file_out, "wb");
6738 char line[256];
6740 bool add_comment = true;
6741 while (fgets (line, sizeof (line), in))
6743 if (add_comment)
6744 fputs ("// ", out);
6745 fputs (line, out);
6746 add_comment = strchr (line, '\n') != NULL;
6749 fclose (in);
6750 fclose (out);
6753 /* This routine adds preprocessed source code into the given ERR_FILE.
6754 To do this, it adds "-E" to NEW_ARGV and execute RUN_ATTEMPT routine to
6755 add information in report file. RUN_ATTEMPT should return
6756 ATTEMPT_STATUS_SUCCESS, in other case we cannot generate the report. */
6758 static void
6759 do_report_bug (const char **new_argv, const int nargs,
6760 char **out_file, char **err_file)
6762 int i, status;
6763 int fd = open (*out_file, O_RDWR | O_APPEND);
6764 if (fd < 0)
6765 return;
6766 write (fd, "\n//", 3);
6767 for (i = 0; i < nargs; i++)
6769 write (fd, " ", 1);
6770 write (fd, new_argv[i], strlen (new_argv[i]));
6772 write (fd, "\n\n", 2);
6773 close (fd);
6774 new_argv[nargs] = "-E";
6775 new_argv[nargs + 1] = NULL;
6777 status = run_attempt (new_argv, *out_file, *err_file, 0, 1);
6779 if (status == ATTEMPT_STATUS_SUCCESS)
6781 fnotice (stderr, "Preprocessed source stored into %s file,"
6782 " please attach this to your bugreport.\n", *out_file);
6783 /* Make sure it is not deleted. */
6784 free (*out_file);
6785 *out_file = NULL;
6789 /* Try to reproduce ICE. If bug is reproducible, generate report .err file
6790 containing GCC configuration, backtrace, compiler's command line options
6791 and preprocessed source code. */
6793 static void
6794 try_generate_repro (const char **argv)
6796 int i, nargs, out_arg = -1, quiet = 0, attempt;
6797 const char **new_argv;
6798 char *temp_files[RETRY_ICE_ATTEMPTS * 2];
6799 char **temp_stdout_files = &temp_files[0];
6800 char **temp_stderr_files = &temp_files[RETRY_ICE_ATTEMPTS];
6802 if (gcc_input_filename == NULL || ! strcmp (gcc_input_filename, "-"))
6803 return;
6805 for (nargs = 0; argv[nargs] != NULL; ++nargs)
6806 /* Only retry compiler ICEs, not preprocessor ones. */
6807 if (! strcmp (argv[nargs], "-E"))
6808 return;
6809 else if (argv[nargs][0] == '-' && argv[nargs][1] == 'o')
6811 if (out_arg == -1)
6812 out_arg = nargs;
6813 else
6814 return;
6816 /* If the compiler is going to output any time information,
6817 it might varry between invocations. */
6818 else if (! strcmp (argv[nargs], "-quiet"))
6819 quiet = 1;
6820 else if (! strcmp (argv[nargs], "-ftime-report"))
6821 return;
6823 if (out_arg == -1 || !quiet)
6824 return;
6826 memset (temp_files, '\0', sizeof (temp_files));
6827 new_argv = XALLOCAVEC (const char *, nargs + 4);
6828 memcpy (new_argv, argv, (nargs + 1) * sizeof (const char *));
6829 new_argv[nargs++] = "-frandom-seed=0";
6830 new_argv[nargs++] = "-fdump-noaddr";
6831 new_argv[nargs] = NULL;
6832 if (new_argv[out_arg][2] == '\0')
6833 new_argv[out_arg + 1] = "-";
6834 else
6835 new_argv[out_arg] = "-o-";
6837 int status;
6838 for (attempt = 0; attempt < RETRY_ICE_ATTEMPTS; ++attempt)
6840 int emit_system_info = 0;
6841 int append = 0;
6842 temp_stdout_files[attempt] = make_temp_file (".out");
6843 temp_stderr_files[attempt] = make_temp_file (".err");
6845 if (attempt == RETRY_ICE_ATTEMPTS - 1)
6847 append = 1;
6848 emit_system_info = 1;
6851 status = run_attempt (new_argv, temp_stdout_files[attempt],
6852 temp_stderr_files[attempt], emit_system_info,
6853 append);
6855 if (status != ATTEMPT_STATUS_ICE)
6857 fnotice (stderr, "The bug is not reproducible, so it is"
6858 " likely a hardware or OS problem.\n");
6859 goto out;
6863 if (!check_repro (temp_stdout_files, temp_stderr_files))
6864 goto out;
6867 /* Insert commented out backtrace into report file. */
6868 char **stderr_commented = &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1];
6869 insert_comments (temp_stderr_files[RETRY_ICE_ATTEMPTS - 1],
6870 *stderr_commented);
6872 /* In final attempt we append compiler options and preprocesssed code to last
6873 generated .out file with configuration and backtrace. */
6874 char **output = &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1];
6875 do_report_bug (new_argv, nargs, stderr_commented, output);
6878 out:
6879 for (i = 0; i < RETRY_ICE_ATTEMPTS * 2; i++)
6880 if (temp_files[i])
6882 unlink (temp_stdout_files[i]);
6883 free (temp_stdout_files[i]);
6887 /* Search for a file named NAME trying various prefixes including the
6888 user's -B prefix and some standard ones.
6889 Return the absolute file name found. If nothing is found, return NAME. */
6891 static const char *
6892 find_file (const char *name)
6894 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
6895 return newname ? newname : name;
6898 /* Determine whether a directory exists. If LINKER, return 0 for
6899 certain fixed names not needed by the linker. */
6901 static int
6902 is_directory (const char *path1, bool linker)
6904 int len1;
6905 char *path;
6906 char *cp;
6907 struct stat st;
6909 /* Ensure the string ends with "/.". The resulting path will be a
6910 directory even if the given path is a symbolic link. */
6911 len1 = strlen (path1);
6912 path = (char *) alloca (3 + len1);
6913 memcpy (path, path1, len1);
6914 cp = path + len1;
6915 if (!IS_DIR_SEPARATOR (cp[-1]))
6916 *cp++ = DIR_SEPARATOR;
6917 *cp++ = '.';
6918 *cp = '\0';
6920 /* Exclude directories that the linker is known to search. */
6921 if (linker
6922 && IS_DIR_SEPARATOR (path[0])
6923 && ((cp - path == 6
6924 && filename_ncmp (path + 1, "lib", 3) == 0)
6925 || (cp - path == 10
6926 && filename_ncmp (path + 1, "usr", 3) == 0
6927 && IS_DIR_SEPARATOR (path[4])
6928 && filename_ncmp (path + 5, "lib", 3) == 0)))
6929 return 0;
6931 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
6934 /* Set up the various global variables to indicate that we're processing
6935 the input file named FILENAME. */
6937 void
6938 set_input (const char *filename)
6940 const char *p;
6942 gcc_input_filename = filename;
6943 input_filename_length = strlen (gcc_input_filename);
6944 input_basename = lbasename (gcc_input_filename);
6946 /* Find a suffix starting with the last period,
6947 and set basename_length to exclude that suffix. */
6948 basename_length = strlen (input_basename);
6949 suffixed_basename_length = basename_length;
6950 p = input_basename + basename_length;
6951 while (p != input_basename && *p != '.')
6952 --p;
6953 if (*p == '.' && p != input_basename)
6955 basename_length = p - input_basename;
6956 input_suffix = p + 1;
6958 else
6959 input_suffix = "";
6961 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6962 we will need to do a stat on the gcc_input_filename. The
6963 INPUT_STAT_SET signals that the stat is needed. */
6964 input_stat_set = 0;
6967 /* On fatal signals, delete all the temporary files. */
6969 static void
6970 fatal_signal (int signum)
6972 signal (signum, SIG_DFL);
6973 delete_failure_queue ();
6974 delete_temp_files ();
6975 /* Get the same signal again, this time not handled,
6976 so its normal effect occurs. */
6977 kill (getpid (), signum);
6980 /* Compare the contents of the two files named CMPFILE[0] and
6981 CMPFILE[1]. Return zero if they're identical, nonzero
6982 otherwise. */
6984 static int
6985 compare_files (char *cmpfile[])
6987 int ret = 0;
6988 FILE *temp[2] = { NULL, NULL };
6989 int i;
6991 #if HAVE_MMAP_FILE
6993 size_t length[2];
6994 void *map[2] = { NULL, NULL };
6996 for (i = 0; i < 2; i++)
6998 struct stat st;
7000 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
7002 error ("%s: could not determine length of compare-debug file %s",
7003 gcc_input_filename, cmpfile[i]);
7004 ret = 1;
7005 break;
7008 length[i] = st.st_size;
7011 if (!ret && length[0] != length[1])
7013 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
7014 ret = 1;
7017 if (!ret)
7018 for (i = 0; i < 2; i++)
7020 int fd = open (cmpfile[i], O_RDONLY);
7021 if (fd < 0)
7023 error ("%s: could not open compare-debug file %s",
7024 gcc_input_filename, cmpfile[i]);
7025 ret = 1;
7026 break;
7029 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
7030 close (fd);
7032 if (map[i] == (void *) MAP_FAILED)
7034 ret = -1;
7035 break;
7039 if (!ret)
7041 if (memcmp (map[0], map[1], length[0]) != 0)
7043 error ("%s: -fcompare-debug failure", gcc_input_filename);
7044 ret = 1;
7048 for (i = 0; i < 2; i++)
7049 if (map[i])
7050 munmap ((caddr_t) map[i], length[i]);
7052 if (ret >= 0)
7053 return ret;
7055 ret = 0;
7057 #endif
7059 for (i = 0; i < 2; i++)
7061 temp[i] = fopen (cmpfile[i], "r");
7062 if (!temp[i])
7064 error ("%s: could not open compare-debug file %s",
7065 gcc_input_filename, cmpfile[i]);
7066 ret = 1;
7067 break;
7071 if (!ret && temp[0] && temp[1])
7072 for (;;)
7074 int c0, c1;
7075 c0 = fgetc (temp[0]);
7076 c1 = fgetc (temp[1]);
7078 if (c0 != c1)
7080 error ("%s: -fcompare-debug failure",
7081 gcc_input_filename);
7082 ret = 1;
7083 break;
7086 if (c0 == EOF)
7087 break;
7090 for (i = 1; i >= 0; i--)
7092 if (temp[i])
7093 fclose (temp[i]);
7096 return ret;
7099 driver::driver (bool can_finalize, bool debug) :
7100 explicit_link_files (NULL),
7101 decoded_options (NULL)
7103 env.init (can_finalize, debug);
7106 driver::~driver ()
7108 XDELETEVEC (explicit_link_files);
7109 XDELETEVEC (decoded_options);
7112 /* driver::main is implemented as a series of driver:: method calls. */
7115 driver::main (int argc, char **argv)
7117 bool early_exit;
7119 set_progname (argv[0]);
7120 expand_at_files (&argc, &argv);
7121 decode_argv (argc, const_cast <const char **> (argv));
7122 global_initializations ();
7123 build_multilib_strings ();
7124 set_up_specs ();
7125 putenv_COLLECT_GCC (argv[0]);
7126 maybe_putenv_COLLECT_LTO_WRAPPER ();
7127 maybe_putenv_OFFLOAD_TARGETS ();
7128 handle_unrecognized_options ();
7130 if (!maybe_print_and_exit ())
7131 return 0;
7133 early_exit = prepare_infiles ();
7134 if (early_exit)
7135 return get_exit_code ();
7137 do_spec_on_infiles ();
7138 maybe_run_linker (argv[0]);
7139 final_actions ();
7140 return get_exit_code ();
7143 /* Locate the final component of argv[0] after any leading path, and set
7144 the program name accordingly. */
7146 void
7147 driver::set_progname (const char *argv0) const
7149 const char *p = argv0 + strlen (argv0);
7150 while (p != argv0 && !IS_DIR_SEPARATOR (p[-1]))
7151 --p;
7152 progname = p;
7154 xmalloc_set_program_name (progname);
7157 /* Expand any @ files within the command-line args,
7158 setting at_file_supplied if any were expanded. */
7160 void
7161 driver::expand_at_files (int *argc, char ***argv) const
7163 char **old_argv = *argv;
7165 expandargv (argc, argv);
7167 /* Determine if any expansions were made. */
7168 if (*argv != old_argv)
7169 at_file_supplied = true;
7172 /* Decode the command-line arguments from argc/argv into the
7173 decoded_options array. */
7175 void
7176 driver::decode_argv (int argc, const char **argv)
7178 /* Register the language-independent parameters. */
7179 global_init_params ();
7180 finish_params ();
7182 init_options_struct (&global_options, &global_options_set);
7184 decode_cmdline_options_to_array (argc, argv,
7185 CL_DRIVER,
7186 &decoded_options, &decoded_options_count);
7189 /* Perform various initializations and setup. */
7191 void
7192 driver::global_initializations ()
7194 /* Unlock the stdio streams. */
7195 unlock_std_streams ();
7197 gcc_init_libintl ();
7199 diagnostic_initialize (global_dc, 0);
7200 diagnostic_color_init (global_dc);
7202 #ifdef GCC_DRIVER_HOST_INITIALIZATION
7203 /* Perform host dependent initialization when needed. */
7204 GCC_DRIVER_HOST_INITIALIZATION;
7205 #endif
7207 if (atexit (delete_temp_files) != 0)
7208 fatal_error (input_location, "atexit failed");
7210 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
7211 signal (SIGINT, fatal_signal);
7212 #ifdef SIGHUP
7213 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
7214 signal (SIGHUP, fatal_signal);
7215 #endif
7216 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
7217 signal (SIGTERM, fatal_signal);
7218 #ifdef SIGPIPE
7219 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
7220 signal (SIGPIPE, fatal_signal);
7221 #endif
7222 #ifdef SIGCHLD
7223 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
7224 receive the signal. A different setting is inheritable */
7225 signal (SIGCHLD, SIG_DFL);
7226 #endif
7228 /* Parsing and gimplification sometimes need quite large stack.
7229 Increase stack size limits if possible. */
7230 stack_limit_increase (64 * 1024 * 1024);
7232 /* Allocate the argument vector. */
7233 alloc_args ();
7235 obstack_init (&obstack);
7238 /* Build multilib_select, et. al from the separate lines that make up each
7239 multilib selection. */
7241 void
7242 driver::build_multilib_strings () const
7245 const char *p;
7246 const char *const *q = multilib_raw;
7247 int need_space;
7249 obstack_init (&multilib_obstack);
7250 while ((p = *q++) != (char *) 0)
7251 obstack_grow (&multilib_obstack, p, strlen (p));
7253 obstack_1grow (&multilib_obstack, 0);
7254 multilib_select = XOBFINISH (&multilib_obstack, const char *);
7256 q = multilib_matches_raw;
7257 while ((p = *q++) != (char *) 0)
7258 obstack_grow (&multilib_obstack, p, strlen (p));
7260 obstack_1grow (&multilib_obstack, 0);
7261 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
7263 q = multilib_exclusions_raw;
7264 while ((p = *q++) != (char *) 0)
7265 obstack_grow (&multilib_obstack, p, strlen (p));
7267 obstack_1grow (&multilib_obstack, 0);
7268 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
7270 q = multilib_reuse_raw;
7271 while ((p = *q++) != (char *) 0)
7272 obstack_grow (&multilib_obstack, p, strlen (p));
7274 obstack_1grow (&multilib_obstack, 0);
7275 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
7277 need_space = FALSE;
7278 for (size_t i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
7280 if (need_space)
7281 obstack_1grow (&multilib_obstack, ' ');
7282 obstack_grow (&multilib_obstack,
7283 multilib_defaults_raw[i],
7284 strlen (multilib_defaults_raw[i]));
7285 need_space = TRUE;
7288 obstack_1grow (&multilib_obstack, 0);
7289 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
7293 /* Set up the spec-handling machinery. */
7295 void
7296 driver::set_up_specs () const
7298 const char *spec_machine_suffix;
7299 char *specs_file;
7300 size_t i;
7302 #ifdef INIT_ENVIRONMENT
7303 /* Set up any other necessary machine specific environment variables. */
7304 xputenv (INIT_ENVIRONMENT);
7305 #endif
7307 /* Make a table of what switches there are (switches, n_switches).
7308 Make a table of specified input files (infiles, n_infiles).
7309 Decode switches that are handled locally. */
7311 process_command (decoded_options_count, decoded_options);
7313 /* Initialize the vector of specs to just the default.
7314 This means one element containing 0s, as a terminator. */
7316 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
7317 memcpy (compilers, default_compilers, sizeof default_compilers);
7318 n_compilers = n_default_compilers;
7320 /* Read specs from a file if there is one. */
7322 machine_suffix = concat (spec_host_machine, dir_separator_str, spec_version,
7323 accel_dir_suffix, dir_separator_str, NULL);
7324 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
7326 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
7327 /* Read the specs file unless it is a default one. */
7328 if (specs_file != 0 && strcmp (specs_file, "specs"))
7329 read_specs (specs_file, true, false);
7330 else
7331 init_spec ();
7333 #ifdef ACCEL_COMPILER
7334 spec_machine_suffix = machine_suffix;
7335 #else
7336 spec_machine_suffix = just_machine_suffix;
7337 #endif
7339 /* We need to check standard_exec_prefix/spec_machine_suffix/specs
7340 for any override of as, ld and libraries. */
7341 specs_file = (char *) alloca (strlen (standard_exec_prefix)
7342 + strlen (spec_machine_suffix) + sizeof ("specs"));
7343 strcpy (specs_file, standard_exec_prefix);
7344 strcat (specs_file, spec_machine_suffix);
7345 strcat (specs_file, "specs");
7346 if (access (specs_file, R_OK) == 0)
7347 read_specs (specs_file, true, false);
7349 /* Process any configure-time defaults specified for the command line
7350 options, via OPTION_DEFAULT_SPECS. */
7351 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
7352 do_option_spec (option_default_specs[i].name,
7353 option_default_specs[i].spec);
7355 /* Process DRIVER_SELF_SPECS, adding any new options to the end
7356 of the command line. */
7358 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
7359 do_self_spec (driver_self_specs[i]);
7361 /* If not cross-compiling, look for executables in the standard
7362 places. */
7363 if (*cross_compile == '0')
7365 if (*md_exec_prefix)
7367 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
7368 PREFIX_PRIORITY_LAST, 0, 0);
7372 /* Process sysroot_suffix_spec. */
7373 if (*sysroot_suffix_spec != 0
7374 && !no_sysroot_suffix
7375 && do_spec_2 (sysroot_suffix_spec) == 0)
7377 if (argbuf.length () > 1)
7378 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
7379 else if (argbuf.length () == 1)
7380 target_sysroot_suffix = xstrdup (argbuf.last ());
7383 #ifdef HAVE_LD_SYSROOT
7384 /* Pass the --sysroot option to the linker, if it supports that. If
7385 there is a sysroot_suffix_spec, it has already been processed by
7386 this point, so target_system_root really is the system root we
7387 should be using. */
7388 if (target_system_root)
7390 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
7391 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
7392 set_spec ("link", XOBFINISH (&obstack, const char *), false);
7394 #endif
7396 /* Process sysroot_hdrs_suffix_spec. */
7397 if (*sysroot_hdrs_suffix_spec != 0
7398 && !no_sysroot_suffix
7399 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
7401 if (argbuf.length () > 1)
7402 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
7403 else if (argbuf.length () == 1)
7404 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
7407 /* Look for startfiles in the standard places. */
7408 if (*startfile_prefix_spec != 0
7409 && do_spec_2 (startfile_prefix_spec) == 0
7410 && do_spec_1 (" ", 0, NULL) == 0)
7412 const char *arg;
7413 int ndx;
7414 FOR_EACH_VEC_ELT (argbuf, ndx, arg)
7415 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
7416 PREFIX_PRIORITY_LAST, 0, 1);
7418 /* We should eventually get rid of all these and stick to
7419 startfile_prefix_spec exclusively. */
7420 else if (*cross_compile == '0' || target_system_root)
7422 if (*md_startfile_prefix)
7423 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
7424 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7426 if (*md_startfile_prefix_1)
7427 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
7428 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7430 /* If standard_startfile_prefix is relative, base it on
7431 standard_exec_prefix. This lets us move the installed tree
7432 as a unit. If GCC_EXEC_PREFIX is defined, base
7433 standard_startfile_prefix on that as well.
7435 If the prefix is relative, only search it for native compilers;
7436 otherwise we will search a directory containing host libraries. */
7437 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
7438 add_sysrooted_prefix (&startfile_prefixes,
7439 standard_startfile_prefix, "BINUTILS",
7440 PREFIX_PRIORITY_LAST, 0, 1);
7441 else if (*cross_compile == '0')
7443 add_prefix (&startfile_prefixes,
7444 concat (gcc_exec_prefix
7445 ? gcc_exec_prefix : standard_exec_prefix,
7446 machine_suffix,
7447 standard_startfile_prefix, NULL),
7448 NULL, PREFIX_PRIORITY_LAST, 0, 1);
7451 /* Sysrooted prefixes are relocated because target_system_root is
7452 also relocated by gcc_exec_prefix. */
7453 if (*standard_startfile_prefix_1)
7454 add_sysrooted_prefix (&startfile_prefixes,
7455 standard_startfile_prefix_1, "BINUTILS",
7456 PREFIX_PRIORITY_LAST, 0, 1);
7457 if (*standard_startfile_prefix_2)
7458 add_sysrooted_prefix (&startfile_prefixes,
7459 standard_startfile_prefix_2, "BINUTILS",
7460 PREFIX_PRIORITY_LAST, 0, 1);
7463 /* Process any user specified specs in the order given on the command
7464 line. */
7465 for (struct user_specs *uptr = user_specs_head; uptr; uptr = uptr->next)
7467 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
7468 R_OK, true);
7469 read_specs (filename ? filename : uptr->filename, false, true);
7472 /* Process any user self specs. */
7474 struct spec_list *sl;
7475 for (sl = specs; sl; sl = sl->next)
7476 if (sl->name_len == sizeof "self_spec" - 1
7477 && !strcmp (sl->name, "self_spec"))
7478 do_self_spec (*sl->ptr_spec);
7481 if (compare_debug)
7483 enum save_temps save;
7485 if (!compare_debug_second)
7487 n_switches_debug_check[1] = n_switches;
7488 n_switches_alloc_debug_check[1] = n_switches_alloc;
7489 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
7490 n_switches_alloc);
7492 do_self_spec ("%:compare-debug-self-opt()");
7493 n_switches_debug_check[0] = n_switches;
7494 n_switches_alloc_debug_check[0] = n_switches_alloc;
7495 switches_debug_check[0] = switches;
7497 n_switches = n_switches_debug_check[1];
7498 n_switches_alloc = n_switches_alloc_debug_check[1];
7499 switches = switches_debug_check[1];
7502 /* Avoid crash when computing %j in this early. */
7503 save = save_temps_flag;
7504 save_temps_flag = SAVE_TEMPS_NONE;
7506 compare_debug = -compare_debug;
7507 do_self_spec ("%:compare-debug-self-opt()");
7509 save_temps_flag = save;
7511 if (!compare_debug_second)
7513 n_switches_debug_check[1] = n_switches;
7514 n_switches_alloc_debug_check[1] = n_switches_alloc;
7515 switches_debug_check[1] = switches;
7516 compare_debug = -compare_debug;
7517 n_switches = n_switches_debug_check[0];
7518 n_switches_alloc = n_switches_debug_check[0];
7519 switches = switches_debug_check[0];
7524 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
7525 if (gcc_exec_prefix)
7526 gcc_exec_prefix = concat (gcc_exec_prefix, spec_host_machine,
7527 dir_separator_str, spec_version,
7528 accel_dir_suffix, dir_separator_str, NULL);
7530 /* Now we have the specs.
7531 Set the `valid' bits for switches that match anything in any spec. */
7533 validate_all_switches ();
7535 /* Now that we have the switches and the specs, set
7536 the subdirectory based on the options. */
7537 set_multilib_dir ();
7540 /* Set up to remember the pathname of gcc and any options
7541 needed for collect. We use argv[0] instead of progname because
7542 we need the complete pathname. */
7544 void
7545 driver::putenv_COLLECT_GCC (const char *argv0) const
7547 obstack_init (&collect_obstack);
7548 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
7549 obstack_grow (&collect_obstack, argv0, strlen (argv0) + 1);
7550 xputenv (XOBFINISH (&collect_obstack, char *));
7553 /* Set up to remember the pathname of the lto wrapper. */
7555 void
7556 driver::maybe_putenv_COLLECT_LTO_WRAPPER () const
7558 char *lto_wrapper_file;
7560 if (have_c)
7561 lto_wrapper_file = NULL;
7562 else
7563 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
7564 X_OK, false);
7565 if (lto_wrapper_file)
7567 lto_wrapper_file = convert_white_space (lto_wrapper_file);
7568 lto_wrapper_spec = lto_wrapper_file;
7569 obstack_init (&collect_obstack);
7570 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
7571 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
7572 obstack_grow (&collect_obstack, lto_wrapper_spec,
7573 strlen (lto_wrapper_spec) + 1);
7574 xputenv (XOBFINISH (&collect_obstack, char *));
7579 /* Set up to remember the names of offload targets. */
7581 void
7582 driver::maybe_putenv_OFFLOAD_TARGETS () const
7584 if (offload_targets && offload_targets[0] != '\0')
7586 obstack_grow (&collect_obstack, "OFFLOAD_TARGET_NAMES=",
7587 sizeof ("OFFLOAD_TARGET_NAMES=") - 1);
7588 obstack_grow (&collect_obstack, offload_targets,
7589 strlen (offload_targets) + 1);
7590 xputenv (XOBFINISH (&collect_obstack, char *));
7593 free (offload_targets);
7594 offload_targets = NULL;
7597 /* Reject switches that no pass was interested in. */
7599 void
7600 driver::handle_unrecognized_options () const
7602 for (size_t i = 0; (int) i < n_switches; i++)
7603 if (! switches[i].validated)
7604 error ("unrecognized command line option %<-%s%>", switches[i].part1);
7607 /* Handle the various -print-* options, returning 0 if the driver
7608 should exit, or nonzero if the driver should continue. */
7611 driver::maybe_print_and_exit () const
7613 if (print_search_dirs)
7615 printf (_("install: %s%s\n"),
7616 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
7617 gcc_exec_prefix ? "" : machine_suffix);
7618 printf (_("programs: %s\n"),
7619 build_search_list (&exec_prefixes, "", false, false));
7620 printf (_("libraries: %s\n"),
7621 build_search_list (&startfile_prefixes, "", false, true));
7622 return (0);
7625 if (print_file_name)
7627 printf ("%s\n", find_file (print_file_name));
7628 return (0);
7631 if (print_prog_name)
7633 if (use_ld != NULL && ! strcmp (print_prog_name, "ld"))
7635 /* Append USE_LD to the default linker. */
7636 #ifdef DEFAULT_LINKER
7637 char *ld;
7638 # ifdef HAVE_HOST_EXECUTABLE_SUFFIX
7639 int len = (sizeof (DEFAULT_LINKER)
7640 - sizeof (HOST_EXECUTABLE_SUFFIX));
7641 ld = NULL;
7642 if (len > 0)
7644 char *default_linker = xstrdup (DEFAULT_LINKER);
7645 /* Strip HOST_EXECUTABLE_SUFFIX if DEFAULT_LINKER contains
7646 HOST_EXECUTABLE_SUFFIX. */
7647 if (! strcmp (&default_linker[len], HOST_EXECUTABLE_SUFFIX))
7649 default_linker[len] = '\0';
7650 ld = concat (default_linker, use_ld,
7651 HOST_EXECUTABLE_SUFFIX, NULL);
7654 if (ld == NULL)
7655 # endif
7656 ld = concat (DEFAULT_LINKER, use_ld, NULL);
7657 if (access (ld, X_OK) == 0)
7659 printf ("%s\n", ld);
7660 return (0);
7662 #endif
7663 print_prog_name = concat (print_prog_name, use_ld, NULL);
7665 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
7666 printf ("%s\n", (newname ? newname : print_prog_name));
7667 return (0);
7670 if (print_multi_lib)
7672 print_multilib_info ();
7673 return (0);
7676 if (print_multi_directory)
7678 if (multilib_dir == NULL)
7679 printf (".\n");
7680 else
7681 printf ("%s\n", multilib_dir);
7682 return (0);
7685 if (print_multiarch)
7687 if (multiarch_dir == NULL)
7688 printf ("\n");
7689 else
7690 printf ("%s\n", multiarch_dir);
7691 return (0);
7694 if (print_sysroot)
7696 if (target_system_root)
7698 if (target_sysroot_suffix)
7699 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
7700 else
7701 printf ("%s\n", target_system_root);
7703 return (0);
7706 if (print_multi_os_directory)
7708 if (multilib_os_dir == NULL)
7709 printf (".\n");
7710 else
7711 printf ("%s\n", multilib_os_dir);
7712 return (0);
7715 if (print_sysroot_headers_suffix)
7717 if (*sysroot_hdrs_suffix_spec)
7719 printf("%s\n", (target_sysroot_hdrs_suffix
7720 ? target_sysroot_hdrs_suffix
7721 : ""));
7722 return (0);
7724 else
7725 /* The error status indicates that only one set of fixed
7726 headers should be built. */
7727 fatal_error (input_location,
7728 "not configured with sysroot headers suffix");
7731 if (print_help_list)
7733 display_help ();
7735 if (! verbose_flag)
7737 printf (_("\nFor bug reporting instructions, please see:\n"));
7738 printf ("%s.\n", bug_report_url);
7740 return (0);
7743 /* We do not exit here. Instead we have created a fake input file
7744 called 'help-dummy' which needs to be compiled, and we pass this
7745 on the various sub-processes, along with the --help switch.
7746 Ensure their output appears after ours. */
7747 fputc ('\n', stdout);
7748 fflush (stdout);
7751 if (print_version)
7753 printf (_("%s %s%s\n"), progname, pkgversion_string,
7754 version_string);
7755 printf ("Copyright %s 2015 Free Software Foundation, Inc.\n",
7756 _("(C)"));
7757 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
7758 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
7759 stdout);
7760 if (! verbose_flag)
7761 return 0;
7763 /* We do not exit here. We use the same mechanism of --help to print
7764 the version of the sub-processes. */
7765 fputc ('\n', stdout);
7766 fflush (stdout);
7769 if (verbose_flag)
7771 print_configuration (stderr);
7772 if (n_infiles == 0)
7773 return (0);
7776 return 1;
7779 /* Figure out what to do with each input file.
7780 Return true if we need to exit early from "main", false otherwise. */
7782 bool
7783 driver::prepare_infiles ()
7785 size_t i;
7786 int lang_n_infiles = 0;
7788 if (n_infiles == added_libraries)
7789 fatal_error (input_location, "no input files");
7791 if (seen_error ())
7792 /* Early exit needed from main. */
7793 return true;
7795 /* Make a place to record the compiler output file names
7796 that correspond to the input files. */
7798 i = n_infiles;
7799 i += lang_specific_extra_outfiles;
7800 outfiles = XCNEWVEC (const char *, i);
7802 /* Record which files were specified explicitly as link input. */
7804 explicit_link_files = XCNEWVEC (char, n_infiles);
7806 combine_inputs = have_o || flag_wpa;
7808 for (i = 0; (int) i < n_infiles; i++)
7810 const char *name = infiles[i].name;
7811 struct compiler *compiler = lookup_compiler (name,
7812 strlen (name),
7813 infiles[i].language);
7815 if (compiler && !(compiler->combinable))
7816 combine_inputs = false;
7818 if (lang_n_infiles > 0 && compiler != input_file_compiler
7819 && infiles[i].language && infiles[i].language[0] != '*')
7820 infiles[i].incompiler = compiler;
7821 else if (compiler)
7823 lang_n_infiles++;
7824 input_file_compiler = compiler;
7825 infiles[i].incompiler = compiler;
7827 else
7829 /* Since there is no compiler for this input file, assume it is a
7830 linker file. */
7831 explicit_link_files[i] = 1;
7832 infiles[i].incompiler = NULL;
7834 infiles[i].compiled = false;
7835 infiles[i].preprocessed = false;
7838 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
7839 fatal_error (input_location,
7840 "cannot specify -o with -c, -S or -E with multiple files");
7842 /* No early exit needed from main; we can continue. */
7843 return false;
7846 /* Run the spec machinery on each input file. */
7848 void
7849 driver::do_spec_on_infiles () const
7851 size_t i;
7853 for (i = 0; (int) i < n_infiles; i++)
7855 int this_file_error = 0;
7857 /* Tell do_spec what to substitute for %i. */
7859 input_file_number = i;
7860 set_input (infiles[i].name);
7862 if (infiles[i].compiled)
7863 continue;
7865 /* Use the same thing in %o, unless cp->spec says otherwise. */
7867 outfiles[i] = gcc_input_filename;
7869 /* Figure out which compiler from the file's suffix. */
7871 input_file_compiler
7872 = lookup_compiler (infiles[i].name, input_filename_length,
7873 infiles[i].language);
7875 if (input_file_compiler)
7877 /* Ok, we found an applicable compiler. Run its spec. */
7879 if (input_file_compiler->spec[0] == '#')
7881 error ("%s: %s compiler not installed on this system",
7882 gcc_input_filename, &input_file_compiler->spec[1]);
7883 this_file_error = 1;
7885 else
7887 int value;
7889 if (compare_debug)
7891 free (debug_check_temp_file[0]);
7892 debug_check_temp_file[0] = NULL;
7894 free (debug_check_temp_file[1]);
7895 debug_check_temp_file[1] = NULL;
7898 value = do_spec (input_file_compiler->spec);
7899 infiles[i].compiled = true;
7900 if (value < 0)
7901 this_file_error = 1;
7902 else if (compare_debug && debug_check_temp_file[0])
7904 if (verbose_flag)
7905 inform (0, "recompiling with -fcompare-debug");
7907 compare_debug = -compare_debug;
7908 n_switches = n_switches_debug_check[1];
7909 n_switches_alloc = n_switches_alloc_debug_check[1];
7910 switches = switches_debug_check[1];
7912 value = do_spec (input_file_compiler->spec);
7914 compare_debug = -compare_debug;
7915 n_switches = n_switches_debug_check[0];
7916 n_switches_alloc = n_switches_alloc_debug_check[0];
7917 switches = switches_debug_check[0];
7919 if (value < 0)
7921 error ("during -fcompare-debug recompilation");
7922 this_file_error = 1;
7925 gcc_assert (debug_check_temp_file[1]
7926 && filename_cmp (debug_check_temp_file[0],
7927 debug_check_temp_file[1]));
7929 if (verbose_flag)
7930 inform (0, "comparing final insns dumps");
7932 if (compare_files (debug_check_temp_file))
7933 this_file_error = 1;
7936 if (compare_debug)
7938 free (debug_check_temp_file[0]);
7939 debug_check_temp_file[0] = NULL;
7941 free (debug_check_temp_file[1]);
7942 debug_check_temp_file[1] = NULL;
7947 /* If this file's name does not contain a recognized suffix,
7948 record it as explicit linker input. */
7950 else
7951 explicit_link_files[i] = 1;
7953 /* Clear the delete-on-failure queue, deleting the files in it
7954 if this compilation failed. */
7956 if (this_file_error)
7958 delete_failure_queue ();
7959 errorcount++;
7961 /* If this compilation succeeded, don't delete those files later. */
7962 clear_failure_queue ();
7965 /* Reset the input file name to the first compile/object file name, for use
7966 with %b in LINK_SPEC. We use the first input file that we can find
7967 a compiler to compile it instead of using infiles.language since for
7968 languages other than C we use aliases that we then lookup later. */
7969 if (n_infiles > 0)
7971 int i;
7973 for (i = 0; i < n_infiles ; i++)
7974 if (infiles[i].incompiler
7975 || (infiles[i].language && infiles[i].language[0] != '*'))
7977 set_input (infiles[i].name);
7978 break;
7982 if (!seen_error ())
7984 /* Make sure INPUT_FILE_NUMBER points to first available open
7985 slot. */
7986 input_file_number = n_infiles;
7987 if (lang_specific_pre_link ())
7988 errorcount++;
7992 /* If we have to run the linker, do it now. */
7994 void
7995 driver::maybe_run_linker (const char *argv0) const
7997 size_t i;
7998 int linker_was_run = 0;
7999 int num_linker_inputs;
8001 /* Determine if there are any linker input files. */
8002 num_linker_inputs = 0;
8003 for (i = 0; (int) i < n_infiles; i++)
8004 if (explicit_link_files[i] || outfiles[i] != NULL)
8005 num_linker_inputs++;
8007 /* Run ld to link all the compiler output files. */
8009 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
8011 int tmp = execution_count;
8013 if (! have_c)
8015 #if HAVE_LTO_PLUGIN > 0
8016 #if HAVE_LTO_PLUGIN == 2
8017 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
8018 #else
8019 const char *fuse_linker_plugin = "fuse-linker-plugin";
8020 #endif
8021 #endif
8023 /* We'll use ld if we can't find collect2. */
8024 if (! strcmp (linker_name_spec, "collect2"))
8026 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
8027 if (s == NULL)
8028 linker_name_spec = "ld";
8031 #if HAVE_LTO_PLUGIN > 0
8032 #if HAVE_LTO_PLUGIN == 2
8033 if (!switch_matches (fno_use_linker_plugin,
8034 fno_use_linker_plugin
8035 + strlen (fno_use_linker_plugin), 0))
8036 #else
8037 if (switch_matches (fuse_linker_plugin,
8038 fuse_linker_plugin
8039 + strlen (fuse_linker_plugin), 0))
8040 #endif
8042 char *temp_spec = find_a_file (&exec_prefixes,
8043 LTOPLUGINSONAME, R_OK,
8044 false);
8045 if (!temp_spec)
8046 fatal_error (input_location,
8047 "-fuse-linker-plugin, but %s not found",
8048 LTOPLUGINSONAME);
8049 linker_plugin_file_spec = convert_white_space (temp_spec);
8051 #endif
8052 lto_gcc_spec = argv0;
8055 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
8056 for collect. */
8057 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
8058 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
8060 if (print_subprocess_help == 1)
8062 printf (_("\nLinker options\n==============\n\n"));
8063 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
8064 " to the linker.\n\n"));
8065 fflush (stdout);
8067 int value = do_spec (link_command_spec);
8068 if (value < 0)
8069 errorcount = 1;
8070 linker_was_run = (tmp != execution_count);
8073 /* If options said don't run linker,
8074 complain about input files to be given to the linker. */
8076 if (! linker_was_run && !seen_error ())
8077 for (i = 0; (int) i < n_infiles; i++)
8078 if (explicit_link_files[i]
8079 && !(infiles[i].language && infiles[i].language[0] == '*'))
8080 warning (0, "%s: linker input file unused because linking not done",
8081 outfiles[i]);
8084 /* The end of "main". */
8086 void
8087 driver::final_actions () const
8089 /* Delete some or all of the temporary files we made. */
8091 if (seen_error ())
8092 delete_failure_queue ();
8093 delete_temp_files ();
8095 if (print_help_list)
8097 printf (("\nFor bug reporting instructions, please see:\n"));
8098 printf ("%s\n", bug_report_url);
8102 /* Determine what the exit code of the driver should be. */
8105 driver::get_exit_code () const
8107 return (signal_count != 0 ? 2
8108 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
8109 : 0);
8112 /* Find the proper compilation spec for the file name NAME,
8113 whose length is LENGTH. LANGUAGE is the specified language,
8114 or 0 if this file is to be passed to the linker. */
8116 static struct compiler *
8117 lookup_compiler (const char *name, size_t length, const char *language)
8119 struct compiler *cp;
8121 /* If this was specified by the user to be a linker input, indicate that. */
8122 if (language != 0 && language[0] == '*')
8123 return 0;
8125 /* Otherwise, look for the language, if one is spec'd. */
8126 if (language != 0)
8128 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8129 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
8130 return cp;
8132 error ("language %s not recognized", language);
8133 return 0;
8136 /* Look for a suffix. */
8137 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8139 if (/* The suffix `-' matches only the file name `-'. */
8140 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
8141 || (strlen (cp->suffix) < length
8142 /* See if the suffix matches the end of NAME. */
8143 && !strcmp (cp->suffix,
8144 name + length - strlen (cp->suffix))
8146 break;
8149 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
8150 /* Look again, but case-insensitively this time. */
8151 if (cp < compilers)
8152 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8154 if (/* The suffix `-' matches only the file name `-'. */
8155 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
8156 || (strlen (cp->suffix) < length
8157 /* See if the suffix matches the end of NAME. */
8158 && ((!strcmp (cp->suffix,
8159 name + length - strlen (cp->suffix))
8160 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
8161 && !strcasecmp (cp->suffix,
8162 name + length - strlen (cp->suffix)))
8164 break;
8166 #endif
8168 if (cp >= compilers)
8170 if (cp->spec[0] != '@')
8171 /* A non-alias entry: return it. */
8172 return cp;
8174 /* An alias entry maps a suffix to a language.
8175 Search for the language; pass 0 for NAME and LENGTH
8176 to avoid infinite recursion if language not found. */
8177 return lookup_compiler (NULL, 0, cp->spec + 1);
8179 return 0;
8182 static char *
8183 save_string (const char *s, int len)
8185 char *result = XNEWVEC (char, len + 1);
8187 memcpy (result, s, len);
8188 result[len] = 0;
8189 return result;
8192 void
8193 pfatal_with_name (const char *name)
8195 perror_with_name (name);
8196 delete_temp_files ();
8197 exit (1);
8200 static void
8201 perror_with_name (const char *name)
8203 error ("%s: %m", name);
8206 static inline void
8207 validate_switches_from_spec (const char *spec, bool user)
8209 const char *p = spec;
8210 char c;
8211 while ((c = *p++))
8212 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
8213 /* We have a switch spec. */
8214 p = validate_switches (p + 1, user);
8217 static void
8218 validate_all_switches (void)
8220 struct compiler *comp;
8221 struct spec_list *spec;
8223 for (comp = compilers; comp->spec; comp++)
8224 validate_switches_from_spec (comp->spec, false);
8226 /* Look through the linked list of specs read from the specs file. */
8227 for (spec = specs; spec; spec = spec->next)
8228 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
8230 validate_switches_from_spec (link_command_spec, false);
8233 /* Look at the switch-name that comes after START
8234 and mark as valid all supplied switches that match it. */
8236 static const char *
8237 validate_switches (const char *start, bool user_spec)
8239 const char *p = start;
8240 const char *atom;
8241 size_t len;
8242 int i;
8243 bool suffix = false;
8244 bool starred = false;
8246 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
8248 next_member:
8249 SKIP_WHITE ();
8251 if (*p == '!')
8252 p++;
8254 SKIP_WHITE ();
8255 if (*p == '.' || *p == ',')
8256 suffix = true, p++;
8258 atom = p;
8259 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
8260 || *p == ',' || *p == '.' || *p == '@')
8261 p++;
8262 len = p - atom;
8264 if (*p == '*')
8265 starred = true, p++;
8267 SKIP_WHITE ();
8269 if (!suffix)
8271 /* Mark all matching switches as valid. */
8272 for (i = 0; i < n_switches; i++)
8273 if (!strncmp (switches[i].part1, atom, len)
8274 && (starred || switches[i].part1[len] == '\0')
8275 && (switches[i].known || user_spec))
8276 switches[i].validated = true;
8279 if (*p) p++;
8280 if (*p && (p[-1] == '|' || p[-1] == '&'))
8281 goto next_member;
8283 if (*p && p[-1] == ':')
8285 while (*p && *p != ';' && *p != '}')
8287 if (*p == '%')
8289 p++;
8290 if (*p == '{' || *p == '<')
8291 p = validate_switches (p+1, user_spec);
8292 else if (p[0] == 'W' && p[1] == '{')
8293 p = validate_switches (p+2, user_spec);
8295 else
8296 p++;
8299 if (*p) p++;
8300 if (*p && p[-1] == ';')
8301 goto next_member;
8304 return p;
8305 #undef SKIP_WHITE
8308 struct mdswitchstr
8310 const char *str;
8311 int len;
8314 static struct mdswitchstr *mdswitches;
8315 static int n_mdswitches;
8317 /* Check whether a particular argument was used. The first time we
8318 canonicalize the switches to keep only the ones we care about. */
8320 class used_arg_t
8322 public:
8323 int operator () (const char *p, int len);
8324 void finalize ();
8326 private:
8327 struct mswitchstr
8329 const char *str;
8330 const char *replace;
8331 int len;
8332 int rep_len;
8335 mswitchstr *mswitches;
8336 int n_mswitches;
8340 used_arg_t used_arg;
8343 used_arg_t::operator () (const char *p, int len)
8345 int i, j;
8347 if (!mswitches)
8349 struct mswitchstr *matches;
8350 const char *q;
8351 int cnt = 0;
8353 /* Break multilib_matches into the component strings of string
8354 and replacement string. */
8355 for (q = multilib_matches; *q != '\0'; q++)
8356 if (*q == ';')
8357 cnt++;
8359 matches
8360 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
8361 i = 0;
8362 q = multilib_matches;
8363 while (*q != '\0')
8365 matches[i].str = q;
8366 while (*q != ' ')
8368 if (*q == '\0')
8370 invalid_matches:
8371 fatal_error (input_location, "multilib spec %qs is invalid",
8372 multilib_matches);
8374 q++;
8376 matches[i].len = q - matches[i].str;
8378 matches[i].replace = ++q;
8379 while (*q != ';' && *q != '\0')
8381 if (*q == ' ')
8382 goto invalid_matches;
8383 q++;
8385 matches[i].rep_len = q - matches[i].replace;
8386 i++;
8387 if (*q == ';')
8388 q++;
8391 /* Now build a list of the replacement string for switches that we care
8392 about. Make sure we allocate at least one entry. This prevents
8393 xmalloc from calling fatal, and prevents us from re-executing this
8394 block of code. */
8395 mswitches
8396 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
8397 for (i = 0; i < n_switches; i++)
8398 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
8400 int xlen = strlen (switches[i].part1);
8401 for (j = 0; j < cnt; j++)
8402 if (xlen == matches[j].len
8403 && ! strncmp (switches[i].part1, matches[j].str, xlen))
8405 mswitches[n_mswitches].str = matches[j].replace;
8406 mswitches[n_mswitches].len = matches[j].rep_len;
8407 mswitches[n_mswitches].replace = (char *) 0;
8408 mswitches[n_mswitches].rep_len = 0;
8409 n_mswitches++;
8410 break;
8414 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
8415 on the command line nor any options mutually incompatible with
8416 them. */
8417 for (i = 0; i < n_mdswitches; i++)
8419 const char *r;
8421 for (q = multilib_options; *q != '\0'; *q && q++)
8423 while (*q == ' ')
8424 q++;
8426 r = q;
8427 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
8428 || strchr (" /", q[mdswitches[i].len]) == NULL)
8430 while (*q != ' ' && *q != '/' && *q != '\0')
8431 q++;
8432 if (*q != '/')
8433 break;
8434 q++;
8437 if (*q != ' ' && *q != '\0')
8439 while (*r != ' ' && *r != '\0')
8441 q = r;
8442 while (*q != ' ' && *q != '/' && *q != '\0')
8443 q++;
8445 if (used_arg (r, q - r))
8446 break;
8448 if (*q != '/')
8450 mswitches[n_mswitches].str = mdswitches[i].str;
8451 mswitches[n_mswitches].len = mdswitches[i].len;
8452 mswitches[n_mswitches].replace = (char *) 0;
8453 mswitches[n_mswitches].rep_len = 0;
8454 n_mswitches++;
8455 break;
8458 r = q + 1;
8460 break;
8466 for (i = 0; i < n_mswitches; i++)
8467 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
8468 return 1;
8470 return 0;
8473 void used_arg_t::finalize ()
8475 XDELETEVEC (mswitches);
8476 mswitches = NULL;
8477 n_mswitches = 0;
8481 static int
8482 default_arg (const char *p, int len)
8484 int i;
8486 for (i = 0; i < n_mdswitches; i++)
8487 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
8488 return 1;
8490 return 0;
8493 /* Work out the subdirectory to use based on the options. The format of
8494 multilib_select is a list of elements. Each element is a subdirectory
8495 name followed by a list of options followed by a semicolon. The format
8496 of multilib_exclusions is the same, but without the preceding
8497 directory. First gcc will check the exclusions, if none of the options
8498 beginning with an exclamation point are present, and all of the other
8499 options are present, then we will ignore this completely. Passing
8500 that, gcc will consider each multilib_select in turn using the same
8501 rules for matching the options. If a match is found, that subdirectory
8502 will be used.
8503 A subdirectory name is optionally followed by a colon and the corresponding
8504 multiarch name. */
8506 static void
8507 set_multilib_dir (void)
8509 const char *p;
8510 unsigned int this_path_len;
8511 const char *this_path, *this_arg;
8512 const char *start, *end;
8513 int not_arg;
8514 int ok, ndfltok, first;
8516 n_mdswitches = 0;
8517 start = multilib_defaults;
8518 while (*start == ' ' || *start == '\t')
8519 start++;
8520 while (*start != '\0')
8522 n_mdswitches++;
8523 while (*start != ' ' && *start != '\t' && *start != '\0')
8524 start++;
8525 while (*start == ' ' || *start == '\t')
8526 start++;
8529 if (n_mdswitches)
8531 int i = 0;
8533 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
8534 for (start = multilib_defaults; *start != '\0'; start = end + 1)
8536 while (*start == ' ' || *start == '\t')
8537 start++;
8539 if (*start == '\0')
8540 break;
8542 for (end = start + 1;
8543 *end != ' ' && *end != '\t' && *end != '\0'; end++)
8546 obstack_grow (&multilib_obstack, start, end - start);
8547 obstack_1grow (&multilib_obstack, 0);
8548 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
8549 mdswitches[i++].len = end - start;
8551 if (*end == '\0')
8552 break;
8556 p = multilib_exclusions;
8557 while (*p != '\0')
8559 /* Ignore newlines. */
8560 if (*p == '\n')
8562 ++p;
8563 continue;
8566 /* Check the arguments. */
8567 ok = 1;
8568 while (*p != ';')
8570 if (*p == '\0')
8572 invalid_exclusions:
8573 fatal_error (input_location, "multilib exclusions %qs is invalid",
8574 multilib_exclusions);
8577 if (! ok)
8579 ++p;
8580 continue;
8583 this_arg = p;
8584 while (*p != ' ' && *p != ';')
8586 if (*p == '\0')
8587 goto invalid_exclusions;
8588 ++p;
8591 if (*this_arg != '!')
8592 not_arg = 0;
8593 else
8595 not_arg = 1;
8596 ++this_arg;
8599 ok = used_arg (this_arg, p - this_arg);
8600 if (not_arg)
8601 ok = ! ok;
8603 if (*p == ' ')
8604 ++p;
8607 if (ok)
8608 return;
8610 ++p;
8613 first = 1;
8614 p = multilib_select;
8616 /* Append multilib reuse rules if any. With those rules, we can reuse
8617 one multilib for certain different options sets. */
8618 if (strlen (multilib_reuse) > 0)
8619 p = concat (p, multilib_reuse, NULL);
8621 while (*p != '\0')
8623 /* Ignore newlines. */
8624 if (*p == '\n')
8626 ++p;
8627 continue;
8630 /* Get the initial path. */
8631 this_path = p;
8632 while (*p != ' ')
8634 if (*p == '\0')
8636 invalid_select:
8637 fatal_error (input_location, "multilib select %qs %qs is invalid",
8638 multilib_select, multilib_reuse);
8640 ++p;
8642 this_path_len = p - this_path;
8644 /* Check the arguments. */
8645 ok = 1;
8646 ndfltok = 1;
8647 ++p;
8648 while (*p != ';')
8650 if (*p == '\0')
8651 goto invalid_select;
8653 if (! ok)
8655 ++p;
8656 continue;
8659 this_arg = p;
8660 while (*p != ' ' && *p != ';')
8662 if (*p == '\0')
8663 goto invalid_select;
8664 ++p;
8667 if (*this_arg != '!')
8668 not_arg = 0;
8669 else
8671 not_arg = 1;
8672 ++this_arg;
8675 /* If this is a default argument, we can just ignore it.
8676 This is true even if this_arg begins with '!'. Beginning
8677 with '!' does not mean that this argument is necessarily
8678 inappropriate for this library: it merely means that
8679 there is a more specific library which uses this
8680 argument. If this argument is a default, we need not
8681 consider that more specific library. */
8682 ok = used_arg (this_arg, p - this_arg);
8683 if (not_arg)
8684 ok = ! ok;
8686 if (! ok)
8687 ndfltok = 0;
8689 if (default_arg (this_arg, p - this_arg))
8690 ok = 1;
8692 if (*p == ' ')
8693 ++p;
8696 if (ok && first)
8698 if (this_path_len != 1
8699 || this_path[0] != '.')
8701 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
8702 char *q;
8704 strncpy (new_multilib_dir, this_path, this_path_len);
8705 new_multilib_dir[this_path_len] = '\0';
8706 q = strchr (new_multilib_dir, ':');
8707 if (q != NULL)
8708 *q = '\0';
8709 multilib_dir = new_multilib_dir;
8711 first = 0;
8714 if (ndfltok)
8716 const char *q = this_path, *end = this_path + this_path_len;
8718 while (q < end && *q != ':')
8719 q++;
8720 if (q < end)
8722 const char *q2 = q + 1, *ml_end = end;
8723 char *new_multilib_os_dir;
8725 while (q2 < end && *q2 != ':')
8726 q2++;
8727 if (*q2 == ':')
8728 ml_end = q2;
8729 if (ml_end - q == 1)
8730 multilib_os_dir = xstrdup (".");
8731 else
8733 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
8734 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
8735 new_multilib_os_dir[ml_end - q - 1] = '\0';
8736 multilib_os_dir = new_multilib_os_dir;
8739 if (q2 < end && *q2 == ':')
8741 char *new_multiarch_dir = XNEWVEC (char, end - q2);
8742 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
8743 new_multiarch_dir[end - q2 - 1] = '\0';
8744 multiarch_dir = new_multiarch_dir;
8746 break;
8750 ++p;
8753 if (multilib_dir == NULL && multilib_os_dir != NULL
8754 && strcmp (multilib_os_dir, ".") == 0)
8756 free (CONST_CAST (char *, multilib_os_dir));
8757 multilib_os_dir = NULL;
8759 else if (multilib_dir != NULL && multilib_os_dir == NULL)
8760 multilib_os_dir = multilib_dir;
8763 /* Print out the multiple library subdirectory selection
8764 information. This prints out a series of lines. Each line looks
8765 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
8766 required. Only the desired options are printed out, the negative
8767 matches. The options are print without a leading dash. There are
8768 no spaces to make it easy to use the information in the shell.
8769 Each subdirectory is printed only once. This assumes the ordering
8770 generated by the genmultilib script. Also, we leave out ones that match
8771 the exclusions. */
8773 static void
8774 print_multilib_info (void)
8776 const char *p = multilib_select;
8777 const char *last_path = 0, *this_path;
8778 int skip;
8779 unsigned int last_path_len = 0;
8781 while (*p != '\0')
8783 skip = 0;
8784 /* Ignore newlines. */
8785 if (*p == '\n')
8787 ++p;
8788 continue;
8791 /* Get the initial path. */
8792 this_path = p;
8793 while (*p != ' ')
8795 if (*p == '\0')
8797 invalid_select:
8798 fatal_error (input_location,
8799 "multilib select %qs is invalid", multilib_select);
8802 ++p;
8805 /* When --disable-multilib was used but target defines
8806 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
8807 with .:: for multiarch configurations) are there just to find
8808 multilib_os_dir, so skip them from output. */
8809 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
8810 skip = 1;
8812 /* Check for matches with the multilib_exclusions. We don't bother
8813 with the '!' in either list. If any of the exclusion rules match
8814 all of its options with the select rule, we skip it. */
8816 const char *e = multilib_exclusions;
8817 const char *this_arg;
8819 while (*e != '\0')
8821 int m = 1;
8822 /* Ignore newlines. */
8823 if (*e == '\n')
8825 ++e;
8826 continue;
8829 /* Check the arguments. */
8830 while (*e != ';')
8832 const char *q;
8833 int mp = 0;
8835 if (*e == '\0')
8837 invalid_exclusion:
8838 fatal_error (input_location,
8839 "multilib exclusion %qs is invalid",
8840 multilib_exclusions);
8843 if (! m)
8845 ++e;
8846 continue;
8849 this_arg = e;
8851 while (*e != ' ' && *e != ';')
8853 if (*e == '\0')
8854 goto invalid_exclusion;
8855 ++e;
8858 q = p + 1;
8859 while (*q != ';')
8861 const char *arg;
8862 int len = e - this_arg;
8864 if (*q == '\0')
8865 goto invalid_select;
8867 arg = q;
8869 while (*q != ' ' && *q != ';')
8871 if (*q == '\0')
8872 goto invalid_select;
8873 ++q;
8876 if (! strncmp (arg, this_arg,
8877 (len < q - arg) ? q - arg : len)
8878 || default_arg (this_arg, e - this_arg))
8880 mp = 1;
8881 break;
8884 if (*q == ' ')
8885 ++q;
8888 if (! mp)
8889 m = 0;
8891 if (*e == ' ')
8892 ++e;
8895 if (m)
8897 skip = 1;
8898 break;
8901 if (*e != '\0')
8902 ++e;
8906 if (! skip)
8908 /* If this is a duplicate, skip it. */
8909 skip = (last_path != 0
8910 && (unsigned int) (p - this_path) == last_path_len
8911 && ! filename_ncmp (last_path, this_path, last_path_len));
8913 last_path = this_path;
8914 last_path_len = p - this_path;
8917 /* If this directory requires any default arguments, we can skip
8918 it. We will already have printed a directory identical to
8919 this one which does not require that default argument. */
8920 if (! skip)
8922 const char *q;
8924 q = p + 1;
8925 while (*q != ';')
8927 const char *arg;
8929 if (*q == '\0')
8930 goto invalid_select;
8932 if (*q == '!')
8933 arg = NULL;
8934 else
8935 arg = q;
8937 while (*q != ' ' && *q != ';')
8939 if (*q == '\0')
8940 goto invalid_select;
8941 ++q;
8944 if (arg != NULL
8945 && default_arg (arg, q - arg))
8947 skip = 1;
8948 break;
8951 if (*q == ' ')
8952 ++q;
8956 if (! skip)
8958 const char *p1;
8960 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
8961 putchar (*p1);
8962 putchar (';');
8965 ++p;
8966 while (*p != ';')
8968 int use_arg;
8970 if (*p == '\0')
8971 goto invalid_select;
8973 if (skip)
8975 ++p;
8976 continue;
8979 use_arg = *p != '!';
8981 if (use_arg)
8982 putchar ('@');
8984 while (*p != ' ' && *p != ';')
8986 if (*p == '\0')
8987 goto invalid_select;
8988 if (use_arg)
8989 putchar (*p);
8990 ++p;
8993 if (*p == ' ')
8994 ++p;
8997 if (! skip)
8999 /* If there are extra options, print them now. */
9000 if (multilib_extra && *multilib_extra)
9002 int print_at = TRUE;
9003 const char *q;
9005 for (q = multilib_extra; *q != '\0'; q++)
9007 if (*q == ' ')
9008 print_at = TRUE;
9009 else
9011 if (print_at)
9012 putchar ('@');
9013 putchar (*q);
9014 print_at = FALSE;
9019 putchar ('\n');
9022 ++p;
9026 /* getenv built-in spec function.
9028 Returns the value of the environment variable given by its first
9029 argument, concatenated with the second argument. If the
9030 environment variable is not defined, a fatal error is issued. */
9032 static const char *
9033 getenv_spec_function (int argc, const char **argv)
9035 const char *value;
9036 char *result;
9037 char *ptr;
9038 size_t len;
9040 if (argc != 2)
9041 return NULL;
9043 value = env.get (argv[0]);
9044 if (!value)
9045 fatal_error (input_location,
9046 "environment variable %qs not defined", argv[0]);
9048 /* We have to escape every character of the environment variable so
9049 they are not interpreted as active spec characters. A
9050 particularly painful case is when we are reading a variable
9051 holding a windows path complete with \ separators. */
9052 len = strlen (value) * 2 + strlen (argv[1]) + 1;
9053 result = XNEWVAR (char, len);
9054 for (ptr = result; *value; ptr += 2)
9056 ptr[0] = '\\';
9057 ptr[1] = *value++;
9060 strcpy (ptr, argv[1]);
9062 return result;
9065 /* if-exists built-in spec function.
9067 Checks to see if the file specified by the absolute pathname in
9068 ARGS exists. Returns that pathname if found.
9070 The usual use for this function is to check for a library file
9071 (whose name has been expanded with %s). */
9073 static const char *
9074 if_exists_spec_function (int argc, const char **argv)
9076 /* Must have only one argument. */
9077 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
9078 return argv[0];
9080 return NULL;
9083 /* if-exists-else built-in spec function.
9085 This is like if-exists, but takes an additional argument which
9086 is returned if the first argument does not exist. */
9088 static const char *
9089 if_exists_else_spec_function (int argc, const char **argv)
9091 /* Must have exactly two arguments. */
9092 if (argc != 2)
9093 return NULL;
9095 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
9096 return argv[0];
9098 return argv[1];
9101 /* sanitize built-in spec function.
9103 This returns non-NULL, if sanitizing address, thread or
9104 any of the undefined behavior sanitizers. */
9106 static const char *
9107 sanitize_spec_function (int argc, const char **argv)
9109 if (argc != 1)
9110 return NULL;
9112 if (strcmp (argv[0], "address") == 0)
9113 return (flag_sanitize & SANITIZE_USER_ADDRESS) ? "" : NULL;
9114 if (strcmp (argv[0], "kernel-address") == 0)
9115 return (flag_sanitize & SANITIZE_KERNEL_ADDRESS) ? "" : NULL;
9116 if (strcmp (argv[0], "thread") == 0)
9117 return (flag_sanitize & SANITIZE_THREAD) ? "" : NULL;
9118 if (strcmp (argv[0], "undefined") == 0)
9119 return ((flag_sanitize & (SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT))
9120 && !flag_sanitize_undefined_trap_on_error) ? "" : NULL;
9121 if (strcmp (argv[0], "leak") == 0)
9122 return ((flag_sanitize
9123 & (SANITIZE_ADDRESS | SANITIZE_LEAK | SANITIZE_THREAD))
9124 == SANITIZE_LEAK) ? "" : NULL;
9125 return NULL;
9128 /* replace-outfile built-in spec function.
9130 This looks for the first argument in the outfiles array's name and
9131 replaces it with the second argument. */
9133 static const char *
9134 replace_outfile_spec_function (int argc, const char **argv)
9136 int i;
9137 /* Must have exactly two arguments. */
9138 if (argc != 2)
9139 abort ();
9141 for (i = 0; i < n_infiles; i++)
9143 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
9144 outfiles[i] = xstrdup (argv[1]);
9146 return NULL;
9149 /* remove-outfile built-in spec function.
9151 * This looks for the first argument in the outfiles array's name and
9152 * removes it. */
9154 static const char *
9155 remove_outfile_spec_function (int argc, const char **argv)
9157 int i;
9158 /* Must have exactly one argument. */
9159 if (argc != 1)
9160 abort ();
9162 for (i = 0; i < n_infiles; i++)
9164 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
9165 outfiles[i] = NULL;
9167 return NULL;
9170 /* Given two version numbers, compares the two numbers.
9171 A version number must match the regular expression
9172 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
9174 static int
9175 compare_version_strings (const char *v1, const char *v2)
9177 int rresult;
9178 regex_t r;
9180 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
9181 REG_EXTENDED | REG_NOSUB) != 0)
9182 abort ();
9183 rresult = regexec (&r, v1, 0, NULL, 0);
9184 if (rresult == REG_NOMATCH)
9185 fatal_error (input_location, "invalid version number %qs", v1);
9186 else if (rresult != 0)
9187 abort ();
9188 rresult = regexec (&r, v2, 0, NULL, 0);
9189 if (rresult == REG_NOMATCH)
9190 fatal_error (input_location, "invalid version number %qs", v2);
9191 else if (rresult != 0)
9192 abort ();
9194 return strverscmp (v1, v2);
9198 /* version_compare built-in spec function.
9200 This takes an argument of the following form:
9202 <comparison-op> <arg1> [<arg2>] <switch> <result>
9204 and produces "result" if the comparison evaluates to true,
9205 and nothing if it doesn't.
9207 The supported <comparison-op> values are:
9209 >= true if switch is a later (or same) version than arg1
9210 !> opposite of >=
9211 < true if switch is an earlier version than arg1
9212 !< opposite of <
9213 >< true if switch is arg1 or later, and earlier than arg2
9214 <> true if switch is earlier than arg1 or is arg2 or later
9216 If the switch is not present, the condition is false unless
9217 the first character of the <comparison-op> is '!'.
9219 For example,
9220 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
9221 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
9223 static const char *
9224 version_compare_spec_function (int argc, const char **argv)
9226 int comp1, comp2;
9227 size_t switch_len;
9228 const char *switch_value = NULL;
9229 int nargs = 1, i;
9230 bool result;
9232 if (argc < 3)
9233 fatal_error (input_location, "too few arguments to %%:version-compare");
9234 if (argv[0][0] == '\0')
9235 abort ();
9236 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
9237 nargs = 2;
9238 if (argc != nargs + 3)
9239 fatal_error (input_location, "too many arguments to %%:version-compare");
9241 switch_len = strlen (argv[nargs + 1]);
9242 for (i = 0; i < n_switches; i++)
9243 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
9244 && check_live_switch (i, switch_len))
9245 switch_value = switches[i].part1 + switch_len;
9247 if (switch_value == NULL)
9248 comp1 = comp2 = -1;
9249 else
9251 comp1 = compare_version_strings (switch_value, argv[1]);
9252 if (nargs == 2)
9253 comp2 = compare_version_strings (switch_value, argv[2]);
9254 else
9255 comp2 = -1; /* This value unused. */
9258 switch (argv[0][0] << 8 | argv[0][1])
9260 case '>' << 8 | '=':
9261 result = comp1 >= 0;
9262 break;
9263 case '!' << 8 | '<':
9264 result = comp1 >= 0 || switch_value == NULL;
9265 break;
9266 case '<' << 8:
9267 result = comp1 < 0;
9268 break;
9269 case '!' << 8 | '>':
9270 result = comp1 < 0 || switch_value == NULL;
9271 break;
9272 case '>' << 8 | '<':
9273 result = comp1 >= 0 && comp2 < 0;
9274 break;
9275 case '<' << 8 | '>':
9276 result = comp1 < 0 || comp2 >= 0;
9277 break;
9279 default:
9280 fatal_error (input_location,
9281 "unknown operator %qs in %%:version-compare", argv[0]);
9283 if (! result)
9284 return NULL;
9286 return argv[nargs + 2];
9289 /* %:include builtin spec function. This differs from %include in that it
9290 can be nested inside a spec, and thus be conditionalized. It takes
9291 one argument, the filename, and looks for it in the startfile path.
9292 The result is always NULL, i.e. an empty expansion. */
9294 static const char *
9295 include_spec_function (int argc, const char **argv)
9297 char *file;
9299 if (argc != 1)
9300 abort ();
9302 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
9303 read_specs (file ? file : argv[0], false, false);
9305 return NULL;
9308 /* %:find-file spec function. This function replaces its argument by
9309 the file found through find_file, that is the -print-file-name gcc
9310 program option. */
9311 static const char *
9312 find_file_spec_function (int argc, const char **argv)
9314 const char *file;
9316 if (argc != 1)
9317 abort ();
9319 file = find_file (argv[0]);
9320 return file;
9324 /* %:find-plugindir spec function. This function replaces its argument
9325 by the -iplugindir=<dir> option. `dir' is found through find_file, that
9326 is the -print-file-name gcc program option. */
9327 static const char *
9328 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
9330 const char *option;
9332 if (argc != 0)
9333 abort ();
9335 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
9336 return option;
9340 /* %:print-asm-header spec function. Print a banner to say that the
9341 following output is from the assembler. */
9343 static const char *
9344 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
9345 const char **argv ATTRIBUTE_UNUSED)
9347 printf (_("Assembler options\n=================\n\n"));
9348 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
9349 fflush (stdout);
9350 return NULL;
9353 /* Get a random number for -frandom-seed */
9355 static unsigned HOST_WIDE_INT
9356 get_random_number (void)
9358 unsigned HOST_WIDE_INT ret = 0;
9359 int fd;
9361 fd = open ("/dev/urandom", O_RDONLY);
9362 if (fd >= 0)
9364 read (fd, &ret, sizeof (HOST_WIDE_INT));
9365 close (fd);
9366 if (ret)
9367 return ret;
9370 /* Get some more or less random data. */
9371 #ifdef HAVE_GETTIMEOFDAY
9373 struct timeval tv;
9375 gettimeofday (&tv, NULL);
9376 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
9378 #else
9380 time_t now = time (NULL);
9382 if (now != (time_t)-1)
9383 ret = (unsigned) now;
9385 #endif
9387 return ret ^ getpid ();
9390 /* %:compare-debug-dump-opt spec function. Save the last argument,
9391 expected to be the last -fdump-final-insns option, or generate a
9392 temporary. */
9394 static const char *
9395 compare_debug_dump_opt_spec_function (int arg,
9396 const char **argv ATTRIBUTE_UNUSED)
9398 char *ret;
9399 char *name;
9400 int which;
9401 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
9403 if (arg != 0)
9404 fatal_error (input_location,
9405 "too many arguments to %%:compare-debug-dump-opt");
9407 do_spec_2 ("%{fdump-final-insns=*:%*}");
9408 do_spec_1 (" ", 0, NULL);
9410 if (argbuf.length () > 0
9411 && strcmp (argv[argbuf.length () - 1], "."))
9413 if (!compare_debug)
9414 return NULL;
9416 name = xstrdup (argv[argbuf.length () - 1]);
9417 ret = NULL;
9419 else
9421 const char *ext = NULL;
9423 if (argbuf.length () > 0)
9425 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
9426 ext = ".gkd";
9428 else if (!compare_debug)
9429 return NULL;
9430 else
9431 do_spec_2 ("%g.gkd");
9433 do_spec_1 (" ", 0, NULL);
9435 gcc_assert (argbuf.length () > 0);
9437 name = concat (argbuf.last (), ext, NULL);
9439 ret = concat ("-fdump-final-insns=", name, NULL);
9442 which = compare_debug < 0;
9443 debug_check_temp_file[which] = name;
9445 if (!which)
9447 unsigned HOST_WIDE_INT value = get_random_number ();
9449 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
9452 if (*random_seed)
9454 char *tmp = ret;
9455 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
9456 ret, NULL);
9457 free (tmp);
9460 if (which)
9461 *random_seed = 0;
9463 return ret;
9466 static const char *debug_auxbase_opt;
9468 /* %:compare-debug-self-opt spec function. Expands to the options
9469 that are to be passed in the second compilation of
9470 compare-debug. */
9472 static const char *
9473 compare_debug_self_opt_spec_function (int arg,
9474 const char **argv ATTRIBUTE_UNUSED)
9476 if (arg != 0)
9477 fatal_error (input_location,
9478 "too many arguments to %%:compare-debug-self-opt");
9480 if (compare_debug >= 0)
9481 return NULL;
9483 do_spec_2 ("%{c|S:%{o*:%*}}");
9484 do_spec_1 (" ", 0, NULL);
9486 if (argbuf.length () > 0)
9487 debug_auxbase_opt = concat ("-auxbase-strip ",
9488 argbuf.last (),
9489 NULL);
9490 else
9491 debug_auxbase_opt = NULL;
9493 return concat ("\
9494 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
9495 %<fdump-final-insns=* -w -S -o %j \
9496 %{!fcompare-debug-second:-fcompare-debug-second} \
9497 ", compare_debug_opt, NULL);
9500 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
9501 options that are to be passed in the second compilation of
9502 compare-debug. It expects, as an argument, the basename of the
9503 current input file name, with the .gk suffix appended to it. */
9505 static const char *
9506 compare_debug_auxbase_opt_spec_function (int arg,
9507 const char **argv)
9509 char *name;
9510 int len;
9512 if (arg == 0)
9513 fatal_error (input_location,
9514 "too few arguments to %%:compare-debug-auxbase-opt");
9516 if (arg != 1)
9517 fatal_error (input_location,
9518 "too many arguments to %%:compare-debug-auxbase-opt");
9520 if (compare_debug >= 0)
9521 return NULL;
9523 len = strlen (argv[0]);
9524 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
9525 fatal_error (input_location, "argument to %%:compare-debug-auxbase-opt "
9526 "does not end in .gk");
9528 if (debug_auxbase_opt)
9529 return debug_auxbase_opt;
9531 #define OPT "-auxbase "
9533 len -= 3;
9534 name = (char*) xmalloc (sizeof (OPT) + len);
9535 memcpy (name, OPT, sizeof (OPT) - 1);
9536 memcpy (name + sizeof (OPT) - 1, argv[0], len);
9537 name[sizeof (OPT) - 1 + len] = '\0';
9539 #undef OPT
9541 return name;
9544 /* %:pass-through-libs spec function. Finds all -l options and input
9545 file names in the lib spec passed to it, and makes a list of them
9546 prepended with the plugin option to cause them to be passed through
9547 to the final link after all the new object files have been added. */
9549 const char *
9550 pass_through_libs_spec_func (int argc, const char **argv)
9552 char *prepended = xstrdup (" ");
9553 int n;
9554 /* Shlemiel the painter's algorithm. Innately horrible, but at least
9555 we know that there will never be more than a handful of strings to
9556 concat, and it's only once per run, so it's not worth optimising. */
9557 for (n = 0; n < argc; n++)
9559 char *old = prepended;
9560 /* Anything that isn't an option is a full path to an output
9561 file; pass it through if it ends in '.a'. Among options,
9562 pass only -l. */
9563 if (argv[n][0] == '-' && argv[n][1] == 'l')
9565 const char *lopt = argv[n] + 2;
9566 /* Handle both joined and non-joined -l options. If for any
9567 reason there's a trailing -l with no joined or following
9568 arg just discard it. */
9569 if (!*lopt && ++n >= argc)
9570 break;
9571 else if (!*lopt)
9572 lopt = argv[n];
9573 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
9574 lopt, " ", NULL);
9576 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
9578 prepended = concat (prepended, "-plugin-opt=-pass-through=",
9579 argv[n], " ", NULL);
9581 if (prepended != old)
9582 free (old);
9584 return prepended;
9587 /* %:replace-extension spec function. Replaces the extension of the
9588 first argument with the second argument. */
9590 const char *
9591 replace_extension_spec_func (int argc, const char **argv)
9593 char *name;
9594 char *p;
9595 char *result;
9596 int i;
9598 if (argc != 2)
9599 fatal_error (input_location, "too few arguments to %%:replace-extension");
9601 name = xstrdup (argv[0]);
9603 for (i = strlen (name) - 1; i >= 0; i--)
9604 if (IS_DIR_SEPARATOR (name[i]))
9605 break;
9607 p = strrchr (name + i + 1, '.');
9608 if (p != NULL)
9609 *p = '\0';
9611 result = concat (name, argv[1], NULL);
9613 free (name);
9614 return result;
9617 /* Returns "" if the n in ARGV[1] == -opt=<n> is greater than ARGV[2].
9618 Otherwise, return NULL. */
9620 static const char *
9621 greater_than_spec_func (int argc, const char **argv)
9623 char *converted;
9625 if (argc == 1)
9626 return NULL;
9628 gcc_assert (argc == 3);
9629 gcc_assert (argv[0][0] == '-');
9630 gcc_assert (argv[0][1] == '\0');
9632 /* Point p to <n> in in -opt=<n>. */
9633 const char *p = argv[1];
9634 while (true)
9636 char c = *p;
9637 if (c == '\0')
9638 gcc_unreachable ();
9640 ++p;
9642 if (c == '=')
9643 break;
9646 long arg = strtol (p, &converted, 10);
9647 gcc_assert (converted != p);
9649 long lim = strtol (argv[2], &converted, 10);
9650 gcc_assert (converted != argv[2]);
9652 if (arg > lim)
9653 return "";
9655 return NULL;
9658 /* Insert backslash before spaces in ORIG (usually a file path), to
9659 avoid being broken by spec parser.
9661 This function is needed as do_spec_1 treats white space (' ' and '\t')
9662 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
9663 the file name should be treated as a single argument rather than being
9664 broken into multiple. Solution is to insert '\\' before the space in a
9665 file name.
9667 This function converts and only converts all occurrence of ' '
9668 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
9669 "a b" -> "a\\ b"
9670 "a b" -> "a\\ \\ b"
9671 "a\tb" -> "a\\\tb"
9672 "a\\ b" -> "a\\\\ b"
9674 orig: input null-terminating string that was allocated by xalloc. The
9675 memory it points to might be freed in this function. Behavior undefined
9676 if ORIG wasn't xalloced or was freed already at entry.
9678 Return: ORIG if no conversion needed. Otherwise a newly allocated string
9679 that was converted from ORIG. */
9681 static char *
9682 convert_white_space (char *orig)
9684 int len, number_of_space = 0;
9686 for (len = 0; orig[len]; len++)
9687 if (orig[len] == ' ' || orig[len] == '\t') number_of_space++;
9689 if (number_of_space)
9691 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
9692 int j, k;
9693 for (j = 0, k = 0; j <= len; j++, k++)
9695 if (orig[j] == ' ' || orig[j] == '\t')
9696 new_spec[k++] = '\\';
9697 new_spec[k] = orig[j];
9699 free (orig);
9700 return new_spec;
9702 else
9703 return orig;
9706 static void
9707 path_prefix_reset (path_prefix *prefix)
9709 struct prefix_list *iter, *next;
9710 iter = prefix->plist;
9711 while (iter)
9713 next = iter->next;
9714 free (const_cast <char *> (iter->prefix));
9715 XDELETE (iter);
9716 iter = next;
9718 prefix->plist = 0;
9719 prefix->max_len = 0;
9722 /* Restore all state within gcc.c to the initial state, so that the driver
9723 code can be safely re-run in-process.
9725 Many const char * variables are referenced by static specs (see
9726 INIT_STATIC_SPEC above). These variables are restored to their default
9727 values by a simple loop over the static specs.
9729 For other variables, we directly restore them all to their initial
9730 values (often implicitly 0).
9732 Free the various obstacks in this file, along with "opts_obstack"
9733 from opts.c.
9735 This function also restores any environment variables that were changed. */
9737 void
9738 driver::finalize ()
9740 env.restore ();
9741 params_c_finalize ();
9742 diagnostic_finish (global_dc);
9744 is_cpp_driver = 0;
9745 at_file_supplied = 0;
9746 print_help_list = 0;
9747 print_version = 0;
9748 verbose_only_flag = 0;
9749 print_subprocess_help = 0;
9750 use_ld = NULL;
9751 report_times_to_file = NULL;
9752 target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
9753 target_system_root_changed = 0;
9754 target_sysroot_suffix = 0;
9755 target_sysroot_hdrs_suffix = 0;
9756 save_temps_flag = SAVE_TEMPS_NONE;
9757 save_temps_prefix = 0;
9758 save_temps_length = 0;
9759 spec_machine = DEFAULT_TARGET_MACHINE;
9760 greatest_status = 1;
9762 finalize_options_struct (&global_options);
9763 finalize_options_struct (&global_options_set);
9765 obstack_free (&obstack, NULL);
9766 obstack_free (&opts_obstack, NULL); /* in opts.c */
9767 obstack_free (&collect_obstack, NULL);
9769 link_command_spec = LINK_COMMAND_SPEC;
9771 obstack_free (&multilib_obstack, NULL);
9773 user_specs_head = NULL;
9774 user_specs_tail = NULL;
9776 /* Within the "compilers" vec, the fields "suffix" and "spec" were
9777 statically allocated for the default compilers, but dynamically
9778 allocated for additional compilers. Delete them for the latter. */
9779 for (int i = n_default_compilers; i < n_compilers; i++)
9781 free (const_cast <char *> (compilers[i].suffix));
9782 free (const_cast <char *> (compilers[i].spec));
9784 XDELETEVEC (compilers);
9785 compilers = NULL;
9786 n_compilers = 0;
9788 linker_options.truncate (0);
9789 assembler_options.truncate (0);
9790 preprocessor_options.truncate (0);
9792 path_prefix_reset (&exec_prefixes);
9793 path_prefix_reset (&startfile_prefixes);
9794 path_prefix_reset (&include_prefixes);
9796 machine_suffix = 0;
9797 just_machine_suffix = 0;
9798 gcc_exec_prefix = 0;
9799 gcc_libexec_prefix = 0;
9800 md_exec_prefix = MD_EXEC_PREFIX;
9801 md_startfile_prefix = MD_STARTFILE_PREFIX;
9802 md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
9803 multilib_dir = 0;
9804 multilib_os_dir = 0;
9805 multiarch_dir = 0;
9807 XDELETEVEC (specs);
9808 specs = 0;
9809 for (unsigned i = 0; i < ARRAY_SIZE (static_specs); i++)
9811 spec_list *sl = &static_specs[i];
9812 if (sl->alloc_p)
9814 if (0)
9815 free (const_cast <char *> (*(sl->ptr_spec)));
9816 sl->alloc_p = false;
9818 *(sl->ptr_spec) = sl->default_ptr;
9820 #ifdef EXTRA_SPECS
9821 extra_specs = NULL;
9822 #endif
9824 processing_spec_function = 0;
9826 argbuf.truncate (0);
9828 have_c = 0;
9829 have_o = 0;
9831 temp_names = NULL;
9832 execution_count = 0;
9833 signal_count = 0;
9835 temp_filename = NULL;
9836 temp_filename_length = 0;
9837 always_delete_queue = NULL;
9838 failure_delete_queue = NULL;
9840 XDELETEVEC (switches);
9841 switches = NULL;
9842 n_switches = 0;
9843 n_switches_alloc = 0;
9845 compare_debug = 0;
9846 compare_debug_second = 0;
9847 compare_debug_opt = NULL;
9848 for (int i = 0; i < 2; i++)
9850 switches_debug_check[i] = NULL;
9851 n_switches_debug_check[i] = 0;
9852 n_switches_alloc_debug_check[i] = 0;
9853 debug_check_temp_file[i] = NULL;
9856 XDELETEVEC (infiles);
9857 infiles = NULL;
9858 n_infiles = 0;
9859 n_infiles_alloc = 0;
9861 combine_inputs = false;
9862 added_libraries = 0;
9863 XDELETEVEC (outfiles);
9864 outfiles = NULL;
9865 spec_lang = 0;
9866 last_language_n_infiles = 0;
9867 gcc_input_filename = NULL;
9868 input_file_number = 0;
9869 input_filename_length = 0;
9870 basename_length = 0;
9871 suffixed_basename_length = 0;
9872 input_basename = NULL;
9873 input_suffix = NULL;
9874 /* We don't need to purge "input_stat", just to unset "input_stat_set". */
9875 input_stat_set = 0;
9876 input_file_compiler = NULL;
9877 arg_going = 0;
9878 delete_this_arg = 0;
9879 this_is_output_file = 0;
9880 this_is_library_file = 0;
9881 this_is_linker_script = 0;
9882 input_from_pipe = 0;
9883 suffix_subst = NULL;
9885 mdswitches = NULL;
9886 n_mdswitches = 0;
9888 debug_auxbase_opt = NULL;
9890 used_arg.finalize ();
9893 /* PR jit/64810.
9894 Targets can provide configure-time default options in
9895 OPTION_DEFAULT_SPECS. The jit needs to access these, but
9896 they are expressed in the spec language.
9898 Run just enough of the driver to be able to expand these
9899 specs, and then call the callback CB on each
9900 such option. The options strings are *without* a leading
9901 '-' character e.g. ("march=x86-64"). Finally, clean up. */
9903 void
9904 driver_get_configure_time_options (void (*cb) (const char *option,
9905 void *user_data),
9906 void *user_data)
9908 size_t i;
9910 obstack_init (&obstack);
9911 gcc_obstack_init (&opts_obstack);
9912 n_switches = 0;
9914 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
9915 do_option_spec (option_default_specs[i].name,
9916 option_default_specs[i].spec);
9918 for (i = 0; (int) i < n_switches; i++)
9920 gcc_assert (switches[i].part1);
9921 (*cb) (switches[i].part1, user_data);
9924 obstack_free (&opts_obstack, NULL);
9925 obstack_free (&obstack, NULL);
9926 n_switches = 0;