* c-parser.c (c_parser_postfix_expression): Remove unused code. Update
[official-gcc.git] / gcc / gcc.c
blob96152dec87278f7f9491db4dbd2a03124547c42b
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987-2017 Free Software Foundation, Inc.
4 This file is part of GCC.
6 GCC is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 3, or (at your option) any later
9 version.
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14 for more details.
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING3. If not see
18 <http://www.gnu.org/licenses/>. */
20 /* This program is the user interface to the C compiler and possibly to
21 other compilers. It is used because compilation is a complicated procedure
22 which involves running several programs and passing temporary files between
23 them, forwarding the users switches to those programs selectively,
24 and deleting the temporary files at the end.
26 CC recognizes how to compile each input file by suffixes in the file names.
27 Once it knows which kind of compilation to perform, the procedure for
28 compilation is specified by a string called a "spec". */
30 #include "config.h"
31 #include "system.h"
32 #include "coretypes.h"
33 #include "multilib.h" /* before tm.h */
34 #include "tm.h"
35 #include "xregex.h"
36 #include "obstack.h"
37 #include "intl.h"
38 #include "prefix.h"
39 #include "gcc.h"
40 #include "diagnostic.h"
41 #include "flags.h"
42 #include "opts.h"
43 #include "params.h"
44 #include "filenames.h"
45 #include "spellcheck.h"
49 /* Manage the manipulation of env vars.
51 We poison "getenv" and "putenv", so that all enviroment-handling is
52 done through this class. Note that poisoning happens in the
53 preprocessor at the identifier level, and doesn't distinguish between
54 env.getenv ();
55 and
56 getenv ();
57 Hence we need to use "get" for the accessor method, not "getenv". */
59 class env_manager
61 public:
62 void init (bool can_restore, bool debug);
63 const char *get (const char *name);
64 void xput (const char *string);
65 void restore ();
67 private:
68 bool m_can_restore;
69 bool m_debug;
70 struct kv
72 char *m_key;
73 char *m_value;
75 vec<kv> m_keys;
79 /* The singleton instance of class env_manager. */
81 static env_manager env;
83 /* Initializer for class env_manager.
85 We can't do this as a constructor since we have a statically
86 allocated instance ("env" above). */
88 void
89 env_manager::init (bool can_restore, bool debug)
91 m_can_restore = can_restore;
92 m_debug = debug;
95 /* Get the value of NAME within the environment. Essentially
96 a wrapper for ::getenv, but adding logging, and the possibility
97 of caching results. */
99 const char *
100 env_manager::get (const char *name)
102 const char *result = ::getenv (name);
103 if (m_debug)
104 fprintf (stderr, "env_manager::getenv (%s) -> %s\n", name, result);
105 return result;
108 /* Put the given KEY=VALUE entry STRING into the environment.
109 If the env_manager was initialized with CAN_RESTORE set, then
110 also record the old value of KEY within the environment, so that it
111 can be later restored. */
113 void
114 env_manager::xput (const char *string)
116 if (m_debug)
117 fprintf (stderr, "env_manager::xput (%s)\n", string);
118 if (verbose_flag)
119 fnotice (stderr, "%s\n", string);
121 if (m_can_restore)
123 char *equals = strchr (const_cast <char *> (string), '=');
124 gcc_assert (equals);
126 struct kv kv;
127 kv.m_key = xstrndup (string, equals - string);
128 const char *cur_value = ::getenv (kv.m_key);
129 if (m_debug)
130 fprintf (stderr, "saving old value: %s\n",cur_value);
131 kv.m_value = cur_value ? xstrdup (cur_value) : NULL;
132 m_keys.safe_push (kv);
135 ::putenv (CONST_CAST (char *, string));
138 /* Undo any xputenv changes made since last restore.
139 Can only be called if the env_manager was initialized with
140 CAN_RESTORE enabled. */
142 void
143 env_manager::restore ()
145 unsigned int i;
146 struct kv *item;
148 gcc_assert (m_can_restore);
150 FOR_EACH_VEC_ELT_REVERSE (m_keys, i, item)
152 if (m_debug)
153 printf ("restoring saved key: %s value: %s\n", item->m_key, item->m_value);
154 if (item->m_value)
155 ::setenv (item->m_key, item->m_value, 1);
156 else
157 ::unsetenv (item->m_key);
158 free (item->m_key);
159 free (item->m_value);
162 m_keys.truncate (0);
165 /* Forbid other uses of getenv and putenv. */
166 #if (GCC_VERSION >= 3000)
167 #pragma GCC poison getenv putenv
168 #endif
172 /* By default there is no special suffix for target executables. */
173 /* FIXME: when autoconf is fixed, remove the host check - dj */
174 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
175 #define HAVE_TARGET_EXECUTABLE_SUFFIX
176 #endif
178 /* By default there is no special suffix for host executables. */
179 #ifdef HOST_EXECUTABLE_SUFFIX
180 #define HAVE_HOST_EXECUTABLE_SUFFIX
181 #else
182 #define HOST_EXECUTABLE_SUFFIX ""
183 #endif
185 /* By default, the suffix for target object files is ".o". */
186 #ifdef TARGET_OBJECT_SUFFIX
187 #define HAVE_TARGET_OBJECT_SUFFIX
188 #else
189 #define TARGET_OBJECT_SUFFIX ".o"
190 #endif
192 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
194 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
195 #ifndef LIBRARY_PATH_ENV
196 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
197 #endif
199 /* If a stage of compilation returns an exit status >= 1,
200 compilation of that file ceases. */
202 #define MIN_FATAL_STATUS 1
204 /* Flag set by cppspec.c to 1. */
205 int is_cpp_driver;
207 /* Flag set to nonzero if an @file argument has been supplied to gcc. */
208 static bool at_file_supplied;
210 /* Definition of string containing the arguments given to configure. */
211 #include "configargs.h"
213 /* Flag saying to print the command line options understood by gcc and its
214 sub-processes. */
216 static int print_help_list;
218 /* Flag saying to print the version of gcc and its sub-processes. */
220 static int print_version;
222 /* Flag indicating whether we should ONLY print the command and
223 arguments (like verbose_flag) without executing the command.
224 Displayed arguments are quoted so that the generated command
225 line is suitable for execution. This is intended for use in
226 shell scripts to capture the driver-generated command line. */
227 static int verbose_only_flag;
229 /* Flag indicating how to print command line options of sub-processes. */
231 static int print_subprocess_help;
233 /* Linker suffix passed to -fuse-ld=... */
234 static const char *use_ld;
236 /* Whether we should report subprocess execution times to a file. */
238 FILE *report_times_to_file = NULL;
240 /* Nonzero means place this string before uses of /, so that include
241 and library files can be found in an alternate location. */
243 #ifdef TARGET_SYSTEM_ROOT
244 #define DEFAULT_TARGET_SYSTEM_ROOT (TARGET_SYSTEM_ROOT)
245 #else
246 #define DEFAULT_TARGET_SYSTEM_ROOT (0)
247 #endif
248 static const char *target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
250 /* Nonzero means pass the updated target_system_root to the compiler. */
252 static int target_system_root_changed;
254 /* Nonzero means append this string to target_system_root. */
256 static const char *target_sysroot_suffix = 0;
258 /* Nonzero means append this string to target_system_root for headers. */
260 static const char *target_sysroot_hdrs_suffix = 0;
262 /* Nonzero means write "temp" files in source directory
263 and use the source file's name in them, and don't delete them. */
265 static enum save_temps {
266 SAVE_TEMPS_NONE, /* no -save-temps */
267 SAVE_TEMPS_CWD, /* -save-temps in current directory */
268 SAVE_TEMPS_OBJ /* -save-temps in object directory */
269 } save_temps_flag;
271 /* Output file to use to get the object directory for -save-temps=obj */
272 static char *save_temps_prefix = 0;
273 static size_t save_temps_length = 0;
275 /* The compiler version. */
277 static const char *compiler_version;
279 /* The target version. */
281 static const char *const spec_version = DEFAULT_TARGET_VERSION;
283 /* The target machine. */
285 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
286 static const char *spec_host_machine = DEFAULT_REAL_TARGET_MACHINE;
288 /* List of offload targets. Separated by colon. Empty string for
289 -foffload=disable. */
291 static char *offload_targets = NULL;
293 /* Nonzero if cross-compiling.
294 When -b is used, the value comes from the `specs' file. */
296 #ifdef CROSS_DIRECTORY_STRUCTURE
297 static const char *cross_compile = "1";
298 #else
299 static const char *cross_compile = "0";
300 #endif
302 /* Greatest exit code of sub-processes that has been encountered up to
303 now. */
304 static int greatest_status = 1;
306 /* This is the obstack which we use to allocate many strings. */
308 static struct obstack obstack;
310 /* This is the obstack to build an environment variable to pass to
311 collect2 that describes all of the relevant switches of what to
312 pass the compiler in building the list of pointers to constructors
313 and destructors. */
315 static struct obstack collect_obstack;
317 /* Forward declaration for prototypes. */
318 struct path_prefix;
319 struct prefix_list;
321 static void init_spec (void);
322 static void store_arg (const char *, int, int);
323 static void insert_wrapper (const char *);
324 static char *load_specs (const char *);
325 static void read_specs (const char *, bool, bool);
326 static void set_spec (const char *, const char *, bool);
327 static struct compiler *lookup_compiler (const char *, size_t, const char *);
328 static char *build_search_list (const struct path_prefix *, const char *,
329 bool, bool);
330 static void xputenv (const char *);
331 static void putenv_from_prefixes (const struct path_prefix *, const char *,
332 bool);
333 static int access_check (const char *, int);
334 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
335 static void add_prefix (struct path_prefix *, const char *, const char *,
336 int, int, int);
337 static void add_sysrooted_prefix (struct path_prefix *, const char *,
338 const char *, int, int, int);
339 static char *skip_whitespace (char *);
340 static void delete_if_ordinary (const char *);
341 static void delete_temp_files (void);
342 static void delete_failure_queue (void);
343 static void clear_failure_queue (void);
344 static int check_live_switch (int, int);
345 static const char *handle_braces (const char *);
346 static inline bool input_suffix_matches (const char *, const char *);
347 static inline bool switch_matches (const char *, const char *, int);
348 static inline void mark_matching_switches (const char *, const char *, int);
349 static inline void process_marked_switches (void);
350 static const char *process_brace_body (const char *, const char *, const char *, int, int);
351 static const struct spec_function *lookup_spec_function (const char *);
352 static const char *eval_spec_function (const char *, const char *);
353 static const char *handle_spec_function (const char *, bool *);
354 static char *save_string (const char *, int);
355 static void set_collect_gcc_options (void);
356 static int do_spec_1 (const char *, int, const char *);
357 static int do_spec_2 (const char *);
358 static void do_option_spec (const char *, const char *);
359 static void do_self_spec (const char *);
360 static const char *find_file (const char *);
361 static int is_directory (const char *, bool);
362 static const char *validate_switches (const char *, bool);
363 static void validate_all_switches (void);
364 static inline void validate_switches_from_spec (const char *, bool);
365 static void give_switch (int, int);
366 static int default_arg (const char *, int);
367 static void set_multilib_dir (void);
368 static void print_multilib_info (void);
369 static void perror_with_name (const char *);
370 static void display_help (void);
371 static void add_preprocessor_option (const char *, int);
372 static void add_assembler_option (const char *, int);
373 static void add_linker_option (const char *, int);
374 static void process_command (unsigned int, struct cl_decoded_option *);
375 static int execute (void);
376 static void alloc_args (void);
377 static void clear_args (void);
378 static void fatal_signal (int);
379 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
380 static void init_gcc_specs (struct obstack *, const char *, const char *,
381 const char *);
382 #endif
383 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
384 static const char *convert_filename (const char *, int, int);
385 #endif
387 static void try_generate_repro (const char **argv);
388 static const char *getenv_spec_function (int, const char **);
389 static const char *if_exists_spec_function (int, const char **);
390 static const char *if_exists_else_spec_function (int, const char **);
391 static const char *sanitize_spec_function (int, const char **);
392 static const char *replace_outfile_spec_function (int, const char **);
393 static const char *remove_outfile_spec_function (int, const char **);
394 static const char *version_compare_spec_function (int, const char **);
395 static const char *include_spec_function (int, const char **);
396 static const char *find_file_spec_function (int, const char **);
397 static const char *find_plugindir_spec_function (int, const char **);
398 static const char *print_asm_header_spec_function (int, const char **);
399 static const char *compare_debug_dump_opt_spec_function (int, const char **);
400 static const char *compare_debug_self_opt_spec_function (int, const char **);
401 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
402 static const char *pass_through_libs_spec_func (int, const char **);
403 static const char *replace_extension_spec_func (int, const char **);
404 static const char *greater_than_spec_func (int, const char **);
405 static const char *debug_level_greater_than_spec_func (int, const char **);
406 static char *convert_white_space (char *);
408 /* The Specs Language
410 Specs are strings containing lines, each of which (if not blank)
411 is made up of a program name, and arguments separated by spaces.
412 The program name must be exact and start from root, since no path
413 is searched and it is unreliable to depend on the current working directory.
414 Redirection of input or output is not supported; the subprograms must
415 accept filenames saying what files to read and write.
417 In addition, the specs can contain %-sequences to substitute variable text
418 or for conditional text. Here is a table of all defined %-sequences.
419 Note that spaces are not generated automatically around the results of
420 expanding these sequences; therefore, you can concatenate them together
421 or with constant text in a single argument.
423 %% substitute one % into the program name or argument.
424 %i substitute the name of the input file being processed.
425 %b substitute the basename of the input file being processed.
426 This is the substring up to (and not including) the last period
427 and not including the directory unless -save-temps was specified
428 to put temporaries in a different location.
429 %B same as %b, but include the file suffix (text after the last period).
430 %gSUFFIX
431 substitute a file name that has suffix SUFFIX and is chosen
432 once per compilation, and mark the argument a la %d. To reduce
433 exposure to denial-of-service attacks, the file name is now
434 chosen in a way that is hard to predict even when previously
435 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
436 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
437 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
438 had been pre-processed. Previously, %g was simply substituted
439 with a file name chosen once per compilation, without regard
440 to any appended suffix (which was therefore treated just like
441 ordinary text), making such attacks more likely to succeed.
442 %|SUFFIX
443 like %g, but if -pipe is in effect, expands simply to "-".
444 %mSUFFIX
445 like %g, but if -pipe is in effect, expands to nothing. (We have both
446 %| and %m to accommodate differences between system assemblers; see
447 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
448 %uSUFFIX
449 like %g, but generates a new temporary file name even if %uSUFFIX
450 was already seen.
451 %USUFFIX
452 substitutes the last file name generated with %uSUFFIX, generating a
453 new one if there is no such last file name. In the absence of any
454 %uSUFFIX, this is just like %gSUFFIX, except they don't share
455 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
456 would involve the generation of two distinct file names, one
457 for each `%g.s' and another for each `%U.s'. Previously, %U was
458 simply substituted with a file name chosen for the previous %u,
459 without regard to any appended suffix.
460 %jSUFFIX
461 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
462 writable, and if save-temps is off; otherwise, substitute the name
463 of a temporary file, just like %u. This temporary file is not
464 meant for communication between processes, but rather as a junk
465 disposal mechanism.
466 %.SUFFIX
467 substitutes .SUFFIX for the suffixes of a matched switch's args when
468 it is subsequently output with %*. SUFFIX is terminated by the next
469 space or %.
470 %d marks the argument containing or following the %d as a
471 temporary file name, so that file will be deleted if GCC exits
472 successfully. Unlike %g, this contributes no text to the argument.
473 %w marks the argument containing or following the %w as the
474 "output file" of this compilation. This puts the argument
475 into the sequence of arguments that %o will substitute later.
476 %V indicates that this compilation produces no "output file".
477 %W{...}
478 like %{...} but mark last argument supplied within
479 as a file to be deleted on failure.
480 %o substitutes the names of all the output files, with spaces
481 automatically placed around them. You should write spaces
482 around the %o as well or the results are undefined.
483 %o is for use in the specs for running the linker.
484 Input files whose names have no recognized suffix are not compiled
485 at all, but they are included among the output files, so they will
486 be linked.
487 %O substitutes the suffix for object files. Note that this is
488 handled specially when it immediately follows %g, %u, or %U
489 (with or without a suffix argument) because of the need for
490 those to form complete file names. The handling is such that
491 %O is treated exactly as if it had already been substituted,
492 except that %g, %u, and %U do not currently support additional
493 SUFFIX characters following %O as they would following, for
494 example, `.o'.
495 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
496 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
497 and -B options) and -imultilib as necessary.
498 %s current argument is the name of a library or startup file of some sort.
499 Search for that file in a standard list of directories
500 and substitute the full name found.
501 %eSTR Print STR as an error message. STR is terminated by a newline.
502 Use this when inconsistent options are detected.
503 %nSTR Print STR as a notice. STR is terminated by a newline.
504 %x{OPTION} Accumulate an option for %X.
505 %X Output the accumulated linker options specified by compilations.
506 %Y Output the accumulated assembler options specified by compilations.
507 %Z Output the accumulated preprocessor options specified by compilations.
508 %a process ASM_SPEC as a spec.
509 This allows config.h to specify part of the spec for running as.
510 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
511 used here. This can be used to run a post-processor after the
512 assembler has done its job.
513 %D Dump out a -L option for each directory in startfile_prefixes.
514 If multilib_dir is set, extra entries are generated with it affixed.
515 %l process LINK_SPEC as a spec.
516 %L process LIB_SPEC as a spec.
517 %M Output multilib_os_dir.
518 %G process LIBGCC_SPEC as a spec.
519 %R Output the concatenation of target_system_root and
520 target_sysroot_suffix.
521 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
522 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
523 %C process CPP_SPEC as a spec.
524 %1 process CC1_SPEC as a spec.
525 %2 process CC1PLUS_SPEC as a spec.
526 %* substitute the variable part of a matched option. (See below.)
527 Note that each comma in the substituted string is replaced by
528 a single space. A space is appended after the last substition
529 unless there is more text in current sequence.
530 %<S remove all occurrences of -S from the command line.
531 Note - this command is position dependent. % commands in the
532 spec string before this one will see -S, % commands in the
533 spec string after this one will not.
534 %>S Similar to "%<S", but keep it in the GCC command line.
535 %<S* remove all occurrences of all switches beginning with -S from the
536 command line.
537 %:function(args)
538 Call the named function FUNCTION, passing it ARGS. ARGS is
539 first processed as a nested spec string, then split into an
540 argument vector in the usual fashion. The function returns
541 a string which is processed as if it had appeared literally
542 as part of the current spec.
543 %{S} substitutes the -S switch, if that switch was given to GCC.
544 If that switch was not specified, this substitutes nothing.
545 Here S is a metasyntactic variable.
546 %{S*} substitutes all the switches specified to GCC whose names start
547 with -S. This is used for -o, -I, etc; switches that take
548 arguments. GCC considers `-o foo' as being one switch whose
549 name starts with `o'. %{o*} would substitute this text,
550 including the space; thus, two arguments would be generated.
551 %{S*&T*} likewise, but preserve order of S and T options (the order
552 of S and T in the spec is not significant). Can be any number
553 of ampersand-separated variables; for each the wild card is
554 optional. Useful for CPP as %{D*&U*&A*}.
556 %{S:X} substitutes X, if the -S switch was given to GCC.
557 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
558 %{S*:X} substitutes X if one or more switches whose names start
559 with -S was given to GCC. Normally X is substituted only
560 once, no matter how many such switches appeared. However,
561 if %* appears somewhere in X, then X will be substituted
562 once for each matching switch, with the %* replaced by the
563 part of that switch that matched the '*'. A space will be
564 appended after the last substition unless there is more
565 text in current sequence.
566 %{.S:X} substitutes X, if processing a file with suffix S.
567 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
568 %{,S:X} substitutes X, if processing a file which will use spec S.
569 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
571 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
572 combined with '!', '.', ',', and '*' as above binding stronger
573 than the OR.
574 If %* appears in X, all of the alternatives must be starred, and
575 only the first matching alternative is substituted.
576 %{%:function(args):X}
577 Call function named FUNCTION with args ARGS. If the function
578 returns non-NULL, then X is substituted, if it returns
579 NULL, it isn't substituted.
580 %{S:X; if S was given to GCC, substitutes X;
581 T:Y; else if T was given to GCC, substitutes Y;
582 :D} else substitutes D. There can be as many clauses as you need.
583 This may be combined with '.', '!', ',', '|', and '*' as above.
585 %(Spec) processes a specification defined in a specs file as *Spec:
587 The switch matching text S in a %{S}, %{S:X}, or similar construct can use
588 a backslash to ignore the special meaning of the character following it,
589 thus allowing literal matching of a character that is otherwise specially
590 treated. For example, %{std=iso9899\:1999:X} substitutes X if the
591 -std=iso9899:1999 option is given.
593 The conditional text X in a %{S:X} or similar construct may contain
594 other nested % constructs or spaces, or even newlines. They are
595 processed as usual, as described above. Trailing white space in X is
596 ignored. White space may also appear anywhere on the left side of the
597 colon in these constructs, except between . or * and the corresponding
598 word.
600 The -O, -f, -g, -m, and -W switches are handled specifically in these
601 constructs. If another value of -O or the negated form of a -f, -m, or
602 -W switch is found later in the command line, the earlier switch
603 value is ignored, except with {S*} where S is just one letter; this
604 passes all matching options.
606 The character | at the beginning of the predicate text is used to indicate
607 that a command should be piped to the following command, but only if -pipe
608 is specified.
610 Note that it is built into GCC which switches take arguments and which
611 do not. You might think it would be useful to generalize this to
612 allow each compiler's spec to say which switches take arguments. But
613 this cannot be done in a consistent fashion. GCC cannot even decide
614 which input files have been specified without knowing which switches
615 take arguments, and it must know which input files to compile in order
616 to tell which compilers to run.
618 GCC also knows implicitly that arguments starting in `-l' are to be
619 treated as compiler output files, and passed to the linker in their
620 proper position among the other output files. */
622 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
624 /* config.h can define ASM_SPEC to provide extra args to the assembler
625 or extra switch-translations. */
626 #ifndef ASM_SPEC
627 #define ASM_SPEC ""
628 #endif
630 /* config.h can define ASM_FINAL_SPEC to run a post processor after
631 the assembler has run. */
632 #ifndef ASM_FINAL_SPEC
633 #define ASM_FINAL_SPEC \
634 "%{gsplit-dwarf: \n\
635 objcopy --extract-dwo \
636 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
637 %{c:%{o*:%:replace-extension(%{o*:%*} .dwo)}%{!o*:%b.dwo}}%{!c:%b.dwo} \n\
638 objcopy --strip-dwo \
639 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
641 #endif
643 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
644 or extra switch-translations. */
645 #ifndef CPP_SPEC
646 #define CPP_SPEC ""
647 #endif
649 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
650 or extra switch-translations. */
651 #ifndef CC1_SPEC
652 #define CC1_SPEC ""
653 #endif
655 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
656 or extra switch-translations. */
657 #ifndef CC1PLUS_SPEC
658 #define CC1PLUS_SPEC ""
659 #endif
661 /* config.h can define LINK_SPEC to provide extra args to the linker
662 or extra switch-translations. */
663 #ifndef LINK_SPEC
664 #define LINK_SPEC ""
665 #endif
667 /* config.h can define LIB_SPEC to override the default libraries. */
668 #ifndef LIB_SPEC
669 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
670 #endif
672 /* When using -fsplit-stack we need to wrap pthread_create, in order
673 to initialize the stack guard. We always use wrapping, rather than
674 shared library ordering, and we keep the wrapper function in
675 libgcc. This is not yet a real spec, though it could become one;
676 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
677 only works with GNU ld and gold. */
678 #ifdef HAVE_GOLD_NON_DEFAULT_SPLIT_STACK
679 #define STACK_SPLIT_SPEC " %{fsplit-stack: -fuse-ld=gold --wrap=pthread_create}"
680 #else
681 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
682 #endif
684 #ifndef LIBASAN_SPEC
685 #define STATIC_LIBASAN_LIBS \
686 " %{static-libasan:%:include(libsanitizer.spec)%(link_libasan)}"
687 #ifdef LIBASAN_EARLY_SPEC
688 #define LIBASAN_SPEC STATIC_LIBASAN_LIBS
689 #elif defined(HAVE_LD_STATIC_DYNAMIC)
690 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
691 "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
692 STATIC_LIBASAN_LIBS
693 #else
694 #define LIBASAN_SPEC "-lasan" STATIC_LIBASAN_LIBS
695 #endif
696 #endif
698 #ifndef LIBASAN_EARLY_SPEC
699 #define LIBASAN_EARLY_SPEC ""
700 #endif
702 #ifndef LIBTSAN_SPEC
703 #define STATIC_LIBTSAN_LIBS \
704 " %{static-libtsan:%:include(libsanitizer.spec)%(link_libtsan)}"
705 #ifdef LIBTSAN_EARLY_SPEC
706 #define LIBTSAN_SPEC STATIC_LIBTSAN_LIBS
707 #elif defined(HAVE_LD_STATIC_DYNAMIC)
708 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
709 "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}" \
710 STATIC_LIBTSAN_LIBS
711 #else
712 #define LIBTSAN_SPEC "-ltsan" STATIC_LIBTSAN_LIBS
713 #endif
714 #endif
716 #ifndef LIBTSAN_EARLY_SPEC
717 #define LIBTSAN_EARLY_SPEC ""
718 #endif
720 #ifndef LIBLSAN_SPEC
721 #define STATIC_LIBLSAN_LIBS \
722 " %{static-liblsan:%:include(libsanitizer.spec)%(link_liblsan)}"
723 #ifdef LIBLSAN_EARLY_SPEC
724 #define LIBLSAN_SPEC STATIC_LIBLSAN_LIBS
725 #elif defined(HAVE_LD_STATIC_DYNAMIC)
726 #define LIBLSAN_SPEC "%{static-liblsan:" LD_STATIC_OPTION \
727 "} -llsan %{static-liblsan:" LD_DYNAMIC_OPTION "}" \
728 STATIC_LIBLSAN_LIBS
729 #else
730 #define LIBLSAN_SPEC "-llsan" STATIC_LIBLSAN_LIBS
731 #endif
732 #endif
734 #ifndef LIBLSAN_EARLY_SPEC
735 #define LIBLSAN_EARLY_SPEC ""
736 #endif
738 #ifndef LIBUBSAN_SPEC
739 #define STATIC_LIBUBSAN_LIBS \
740 " %{static-libubsan:%:include(libsanitizer.spec)%(link_libubsan)}"
741 #ifdef HAVE_LD_STATIC_DYNAMIC
742 #define LIBUBSAN_SPEC "%{static-libubsan:" LD_STATIC_OPTION \
743 "} -lubsan %{static-libubsan:" LD_DYNAMIC_OPTION "}" \
744 STATIC_LIBUBSAN_LIBS
745 #else
746 #define LIBUBSAN_SPEC "-lubsan" STATIC_LIBUBSAN_LIBS
747 #endif
748 #endif
750 /* Linker options for compressed debug sections. */
751 #if HAVE_LD_COMPRESS_DEBUG == 0
752 /* No linker support. */
753 #define LINK_COMPRESS_DEBUG_SPEC \
754 " %{gz*:%e-gz is not supported in this configuration} "
755 #elif HAVE_LD_COMPRESS_DEBUG == 1
756 /* GNU style on input, GNU ld options. Reject, not useful. */
757 #define LINK_COMPRESS_DEBUG_SPEC \
758 " %{gz*:%e-gz is not supported in this configuration} "
759 #elif HAVE_LD_COMPRESS_DEBUG == 2
760 /* GNU style, GNU gold options. */
761 #define LINK_COMPRESS_DEBUG_SPEC \
762 " %{gz|gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
763 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
764 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
765 #elif HAVE_LD_COMPRESS_DEBUG == 3
766 /* ELF gABI style. */
767 #define LINK_COMPRESS_DEBUG_SPEC \
768 " %{gz|gz=zlib:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
769 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
770 " %{gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
771 #else
772 #error Unknown value for HAVE_LD_COMPRESS_DEBUG.
773 #endif
775 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
776 included. */
777 #ifndef LIBGCC_SPEC
778 #if defined(REAL_LIBGCC_SPEC)
779 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
780 #elif defined(LINK_LIBGCC_SPECIAL_1)
781 /* Have gcc do the search for libgcc.a. */
782 #define LIBGCC_SPEC "libgcc.a%s"
783 #else
784 #define LIBGCC_SPEC "-lgcc"
785 #endif
786 #endif
788 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
789 #ifndef STARTFILE_SPEC
790 #define STARTFILE_SPEC \
791 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
792 #endif
794 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
795 #ifndef ENDFILE_SPEC
796 #define ENDFILE_SPEC ""
797 #endif
799 #ifndef LINKER_NAME
800 #define LINKER_NAME "collect2"
801 #endif
803 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
804 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
805 #else
806 #define ASM_MAP ""
807 #endif
809 /* Assembler options for compressed debug sections. */
810 #if HAVE_LD_COMPRESS_DEBUG < 2
811 /* Reject if the linker cannot write compressed debug sections. */
812 #define ASM_COMPRESS_DEBUG_SPEC \
813 " %{gz*:%e-gz is not supported in this configuration} "
814 #else /* HAVE_LD_COMPRESS_DEBUG >= 2 */
815 #if HAVE_AS_COMPRESS_DEBUG == 0
816 /* No assembler support. Ignore silently. */
817 #define ASM_COMPRESS_DEBUG_SPEC \
818 " %{gz*:} "
819 #elif HAVE_AS_COMPRESS_DEBUG == 1
820 /* GNU style, GNU as options. */
821 #define ASM_COMPRESS_DEBUG_SPEC \
822 " %{gz|gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "}" \
823 " %{gz=none:" AS_NO_COMPRESS_DEBUG_OPTION "}" \
824 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
825 #elif HAVE_AS_COMPRESS_DEBUG == 2
826 /* ELF gABI style. */
827 #define ASM_COMPRESS_DEBUG_SPEC \
828 " %{gz|gz=zlib:" AS_COMPRESS_DEBUG_OPTION "=zlib}" \
829 " %{gz=none:" AS_COMPRESS_DEBUG_OPTION "=none}" \
830 " %{gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
831 #else
832 #error Unknown value for HAVE_AS_COMPRESS_DEBUG.
833 #endif
834 #endif /* HAVE_LD_COMPRESS_DEBUG >= 2 */
836 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
837 to the assembler. */
838 #ifndef ASM_DEBUG_SPEC
839 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
840 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
841 # define ASM_DEBUG_SPEC \
842 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
843 ? "%{%:debug-level-gt(0):" \
844 "%{gdwarf*:--gdwarf2}%{!gdwarf*:%{g*:--gstabs}}}" ASM_MAP \
845 : "%{%:debug-level-gt(0):" \
846 "%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
847 # else
848 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
849 # define ASM_DEBUG_SPEC "%{g*:%{%:debug-level-gt(0):--gstabs}}" ASM_MAP
850 # endif
851 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
852 # define ASM_DEBUG_SPEC "%{g*:%{%:debug-level-gt(0):--gdwarf2}}" ASM_MAP
853 # endif
854 # endif
855 #endif
856 #ifndef ASM_DEBUG_SPEC
857 # define ASM_DEBUG_SPEC ""
858 #endif
860 /* Here is the spec for running the linker, after compiling all files. */
862 /* This is overridable by the target in case they need to specify the
863 -lgcc and -lc order specially, yet not require them to override all
864 of LINK_COMMAND_SPEC. */
865 #ifndef LINK_GCC_C_SEQUENCE_SPEC
866 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
867 #endif
869 #ifndef LINK_SSP_SPEC
870 #ifdef TARGET_LIBC_PROVIDES_SSP
871 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
872 "|fstack-protector-strong|fstack-protector-explicit:}"
873 #else
874 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
875 "|fstack-protector-strong|fstack-protector-explicit" \
876 ":-lssp_nonshared -lssp}"
877 #endif
878 #endif
880 #ifdef ENABLE_DEFAULT_PIE
881 #define PIE_SPEC "!no-pie"
882 #define NO_FPIE1_SPEC "fno-pie"
883 #define FPIE1_SPEC NO_FPIE1_SPEC ":;"
884 #define NO_FPIE2_SPEC "fno-PIE"
885 #define FPIE2_SPEC NO_FPIE2_SPEC ":;"
886 #define NO_FPIE_SPEC NO_FPIE1_SPEC "|" NO_FPIE2_SPEC
887 #define FPIE_SPEC NO_FPIE_SPEC ":;"
888 #define NO_FPIC1_SPEC "fno-pic"
889 #define FPIC1_SPEC NO_FPIC1_SPEC ":;"
890 #define NO_FPIC2_SPEC "fno-PIC"
891 #define FPIC2_SPEC NO_FPIC2_SPEC ":;"
892 #define NO_FPIC_SPEC NO_FPIC1_SPEC "|" NO_FPIC2_SPEC
893 #define FPIC_SPEC NO_FPIC_SPEC ":;"
894 #define NO_FPIE1_AND_FPIC1_SPEC NO_FPIE1_SPEC "|" NO_FPIC1_SPEC
895 #define FPIE1_OR_FPIC1_SPEC NO_FPIE1_AND_FPIC1_SPEC ":;"
896 #define NO_FPIE2_AND_FPIC2_SPEC NO_FPIE2_SPEC "|" NO_FPIC2_SPEC
897 #define FPIE2_OR_FPIC2_SPEC NO_FPIE2_AND_FPIC2_SPEC ":;"
898 #define NO_FPIE_AND_FPIC_SPEC NO_FPIE_SPEC "|" NO_FPIC_SPEC
899 #define FPIE_OR_FPIC_SPEC NO_FPIE_AND_FPIC_SPEC ":;"
900 #else
901 #define PIE_SPEC "pie"
902 #define FPIE1_SPEC "fpie"
903 #define NO_FPIE1_SPEC FPIE1_SPEC ":;"
904 #define FPIE2_SPEC "fPIE"
905 #define NO_FPIE2_SPEC FPIE2_SPEC ":;"
906 #define FPIE_SPEC FPIE1_SPEC "|" FPIE2_SPEC
907 #define NO_FPIE_SPEC FPIE_SPEC ":;"
908 #define FPIC1_SPEC "fpic"
909 #define NO_FPIC1_SPEC FPIC1_SPEC ":;"
910 #define FPIC2_SPEC "fPIC"
911 #define NO_FPIC2_SPEC FPIC2_SPEC ":;"
912 #define FPIC_SPEC FPIC1_SPEC "|" FPIC2_SPEC
913 #define NO_FPIC_SPEC FPIC_SPEC ":;"
914 #define FPIE1_OR_FPIC1_SPEC FPIE1_SPEC "|" FPIC1_SPEC
915 #define NO_FPIE1_AND_FPIC1_SPEC FPIE1_OR_FPIC1_SPEC ":;"
916 #define FPIE2_OR_FPIC2_SPEC FPIE2_SPEC "|" FPIC2_SPEC
917 #define NO_FPIE2_AND_FPIC2_SPEC FPIE1_OR_FPIC2_SPEC ":;"
918 #define FPIE_OR_FPIC_SPEC FPIE_SPEC "|" FPIC_SPEC
919 #define NO_FPIE_AND_FPIC_SPEC FPIE_OR_FPIC_SPEC ":;"
920 #endif
922 #ifndef LINK_PIE_SPEC
923 #ifdef HAVE_LD_PIE
924 #ifndef LD_PIE_SPEC
925 #define LD_PIE_SPEC "-pie"
926 #endif
927 #else
928 #define LD_PIE_SPEC ""
929 #endif
930 #define LINK_PIE_SPEC "%{static|shared|r:;" PIE_SPEC ":" LD_PIE_SPEC "} "
931 #endif
933 #ifndef LINK_BUILDID_SPEC
934 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
935 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
936 # endif
937 #endif
939 /* Conditional to test whether the LTO plugin is used or not.
940 FIXME: For slim LTO we will need to enable plugin unconditionally. This
941 still cause problems with PLUGIN_LD != LD and when plugin is built but
942 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
943 plugin only when LTO is enabled. We still honor explicit
944 -fuse-linker-plugin if the linker used understands -plugin. */
946 /* The linker has some plugin support. */
947 #if HAVE_LTO_PLUGIN > 0
948 /* The linker used has full plugin support, use LTO plugin by default. */
949 #if HAVE_LTO_PLUGIN == 2
950 #define PLUGIN_COND "!fno-use-linker-plugin:%{!fno-lto"
951 #define PLUGIN_COND_CLOSE "}"
952 #else
953 /* The linker used has limited plugin support, use LTO plugin with explicit
954 -fuse-linker-plugin. */
955 #define PLUGIN_COND "fuse-linker-plugin"
956 #define PLUGIN_COND_CLOSE ""
957 #endif
958 #define LINK_PLUGIN_SPEC \
959 "%{" PLUGIN_COND": \
960 -plugin %(linker_plugin_file) \
961 -plugin-opt=%(lto_wrapper) \
962 -plugin-opt=-fresolution=%u.res \
963 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
964 }" PLUGIN_COND_CLOSE
965 #else
966 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
967 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
968 %e-fuse-linker-plugin is not supported in this configuration}"
969 #endif
971 /* Linker command line options for -fsanitize= early on the command line. */
972 #ifndef SANITIZER_EARLY_SPEC
973 #define SANITIZER_EARLY_SPEC "\
974 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_EARLY_SPEC "} \
975 %{%:sanitize(thread):" LIBTSAN_EARLY_SPEC "} \
976 %{%:sanitize(leak):" LIBLSAN_EARLY_SPEC "}}}"
977 #endif
979 /* Linker command line options for -fsanitize= late on the command line. */
980 #ifndef SANITIZER_SPEC
981 #define SANITIZER_SPEC "\
982 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_SPEC "\
983 %{static:%ecannot specify -static with -fsanitize=address}}\
984 %{%:sanitize(thread):" LIBTSAN_SPEC "\
985 %{static:%ecannot specify -static with -fsanitize=thread}}\
986 %{%:sanitize(undefined):" LIBUBSAN_SPEC "}\
987 %{%:sanitize(leak):" LIBLSAN_SPEC "}}}"
988 #endif
990 #ifndef POST_LINK_SPEC
991 #define POST_LINK_SPEC ""
992 #endif
994 /* This is the spec to use, once the code for creating the vtable
995 verification runtime library, libvtv.so, has been created. Currently
996 the vtable verification runtime functions are in libstdc++, so we use
997 the spec just below this one. */
998 #ifndef VTABLE_VERIFICATION_SPEC
999 #if ENABLE_VTABLE_VERIFY
1000 #define VTABLE_VERIFICATION_SPEC "\
1001 %{!nostdlib:%{fvtable-verify=std: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}\
1002 %{fvtable-verify=preinit: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}}"
1003 #else
1004 #define VTABLE_VERIFICATION_SPEC "\
1005 %{fvtable-verify=none:} \
1006 %{fvtable-verify=std: \
1007 %e-fvtable-verify=std is not supported in this configuration} \
1008 %{fvtable-verify=preinit: \
1009 %e-fvtable-verify=preinit is not supported in this configuration}"
1010 #endif
1011 #endif
1013 #ifndef CHKP_SPEC
1014 #define CHKP_SPEC ""
1015 #endif
1017 /* -u* was put back because both BSD and SysV seem to support it. */
1018 /* %{static|no-pie:} simply prevents an error message:
1019 1. If the target machine doesn't handle -static.
1020 2. If PIE isn't enabled by default.
1022 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
1023 scripts which exist in user specified directories, or in standard
1024 directories. */
1025 /* We pass any -flto flags on to the linker, which is expected
1026 to understand them. In practice, this means it had better be collect2. */
1027 /* %{e*} includes -export-dynamic; see comment in common.opt. */
1028 #ifndef LINK_COMMAND_SPEC
1029 #define LINK_COMMAND_SPEC "\
1030 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
1031 %(linker) " \
1032 LINK_PLUGIN_SPEC \
1033 "%{flto|flto=*:%<fcompare-debug*} \
1034 %{flto} %{fno-lto} %{flto=*} %l " LINK_PIE_SPEC \
1035 "%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
1036 "%X %{o*} %{e*} %{N} %{n} %{r}\
1037 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}} \
1038 %{static|no-pie:} %{L*} %(mfwrap) %(link_libgcc) " \
1039 VTABLE_VERIFICATION_SPEC " " SANITIZER_EARLY_SPEC " %o " CHKP_SPEC " \
1040 %{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1):\
1041 %:include(libgomp.spec)%(link_gomp)}\
1042 %{fcilkplus:%:include(libcilkrts.spec)%(link_cilkrts)}\
1043 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
1044 %(mflib) " STACK_SPLIT_SPEC "\
1045 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
1046 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
1047 %{!nostdlib:%{!nostartfiles:%E}} %{T*} \n%(post_link) }}}}}}"
1048 #endif
1050 #ifndef LINK_LIBGCC_SPEC
1051 /* Generate -L options for startfile prefix list. */
1052 # define LINK_LIBGCC_SPEC "%D"
1053 #endif
1055 #ifndef STARTFILE_PREFIX_SPEC
1056 # define STARTFILE_PREFIX_SPEC ""
1057 #endif
1059 #ifndef SYSROOT_SPEC
1060 # define SYSROOT_SPEC "--sysroot=%R"
1061 #endif
1063 #ifndef SYSROOT_SUFFIX_SPEC
1064 # define SYSROOT_SUFFIX_SPEC ""
1065 #endif
1067 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
1068 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
1069 #endif
1071 static const char *asm_debug = ASM_DEBUG_SPEC;
1072 static const char *cpp_spec = CPP_SPEC;
1073 static const char *cc1_spec = CC1_SPEC;
1074 static const char *cc1plus_spec = CC1PLUS_SPEC;
1075 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
1076 static const char *link_ssp_spec = LINK_SSP_SPEC;
1077 static const char *asm_spec = ASM_SPEC;
1078 static const char *asm_final_spec = ASM_FINAL_SPEC;
1079 static const char *link_spec = LINK_SPEC;
1080 static const char *lib_spec = LIB_SPEC;
1081 static const char *link_gomp_spec = "";
1082 static const char *libgcc_spec = LIBGCC_SPEC;
1083 static const char *endfile_spec = ENDFILE_SPEC;
1084 static const char *startfile_spec = STARTFILE_SPEC;
1085 static const char *linker_name_spec = LINKER_NAME;
1086 static const char *linker_plugin_file_spec = "";
1087 static const char *lto_wrapper_spec = "";
1088 static const char *lto_gcc_spec = "";
1089 static const char *post_link_spec = POST_LINK_SPEC;
1090 static const char *link_command_spec = LINK_COMMAND_SPEC;
1091 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
1092 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
1093 static const char *sysroot_spec = SYSROOT_SPEC;
1094 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
1095 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
1096 static const char *self_spec = "";
1098 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
1099 There should be no need to override these in target dependent files,
1100 but we need to copy them to the specs file so that newer versions
1101 of the GCC driver can correctly drive older tool chains with the
1102 appropriate -B options. */
1104 /* When cpplib handles traditional preprocessing, get rid of this, and
1105 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
1106 that we default the front end language better. */
1107 static const char *trad_capable_cpp =
1108 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
1110 /* We don't wrap .d files in %W{} since a missing .d file, and
1111 therefore no dependency entry, confuses make into thinking a .o
1112 file that happens to exist is up-to-date. */
1113 static const char *cpp_unique_options =
1114 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
1115 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
1116 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
1117 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
1118 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
1119 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
1120 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1121 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
1122 %{E|M|MM:%W{o*}}";
1124 /* This contains cpp options which are common with cc1_options and are passed
1125 only when preprocessing only to avoid duplication. We pass the cc1 spec
1126 options to the preprocessor so that it the cc1 spec may manipulate
1127 options used to set target flags. Those special target flags settings may
1128 in turn cause preprocessor symbols to be defined specially. */
1129 static const char *cpp_options =
1130 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
1131 %{f*} %{g*:%{%:debug-level-gt(0):%{g*}\
1132 %{!fno-working-directory:-fworking-directory}}} %{O*}\
1133 %{undef} %{save-temps*:-fpch-preprocess}";
1135 /* This contains cpp options which are not passed when the preprocessor
1136 output will be used by another program. */
1137 static const char *cpp_debug_options = "%{d*}";
1139 /* NB: This is shared amongst all front-ends, except for Ada. */
1140 static const char *cc1_options =
1141 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
1142 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1143 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
1144 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
1145 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
1146 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
1147 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
1148 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
1149 %{-target-help:--target-help}\
1150 %{-version:--version}\
1151 %{-help=*:--help=%*}\
1152 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
1153 %{fsyntax-only:-o %j} %{-param*}\
1154 %{coverage:-fprofile-arcs -ftest-coverage}\
1155 %{fprofile-arcs|fprofile-generate*|coverage:\
1156 %{!fprofile-update=single:\
1157 %{pthread:-fprofile-update=prefer-atomic}}}";
1159 static const char *asm_options =
1160 "%{-target-help:%:print-asm-header()} "
1161 #if HAVE_GNU_AS
1162 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
1163 to the assembler equivalents. */
1164 "%{v} %{w:-W} %{I*} "
1165 #endif
1166 ASM_COMPRESS_DEBUG_SPEC
1167 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
1169 static const char *invoke_as =
1170 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1171 "%{!fwpa*:\
1172 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1173 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
1175 #else
1176 "%{!fwpa*:\
1177 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1178 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
1180 #endif
1182 /* Some compilers have limits on line lengths, and the multilib_select
1183 and/or multilib_matches strings can be very long, so we build them at
1184 run time. */
1185 static struct obstack multilib_obstack;
1186 static const char *multilib_select;
1187 static const char *multilib_matches;
1188 static const char *multilib_defaults;
1189 static const char *multilib_exclusions;
1190 static const char *multilib_reuse;
1192 /* Check whether a particular argument is a default argument. */
1194 #ifndef MULTILIB_DEFAULTS
1195 #define MULTILIB_DEFAULTS { "" }
1196 #endif
1198 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
1200 #ifndef DRIVER_SELF_SPECS
1201 #define DRIVER_SELF_SPECS ""
1202 #endif
1204 /* Linking to libgomp implies pthreads. This is particularly important
1205 for targets that use different start files and suchlike. */
1206 #ifndef GOMP_SELF_SPECS
1207 #define GOMP_SELF_SPECS \
1208 "%{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1): " \
1209 "-pthread}"
1210 #endif
1212 /* Likewise for -fgnu-tm. */
1213 #ifndef GTM_SELF_SPECS
1214 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
1215 #endif
1217 /* Likewise for -fcilkplus. */
1218 #ifndef CILK_SELF_SPECS
1219 #define CILK_SELF_SPECS "%{fcilkplus: -pthread}"
1220 #endif
1222 static const char *const driver_self_specs[] = {
1223 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
1224 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS,
1225 CILK_SELF_SPECS
1228 #ifndef OPTION_DEFAULT_SPECS
1229 #define OPTION_DEFAULT_SPECS { "", "" }
1230 #endif
1232 struct default_spec
1234 const char *name;
1235 const char *spec;
1238 static const struct default_spec
1239 option_default_specs[] = { OPTION_DEFAULT_SPECS };
1241 struct user_specs
1243 struct user_specs *next;
1244 const char *filename;
1247 static struct user_specs *user_specs_head, *user_specs_tail;
1250 /* Record the mapping from file suffixes for compilation specs. */
1252 struct compiler
1254 const char *suffix; /* Use this compiler for input files
1255 whose names end in this suffix. */
1257 const char *spec; /* To use this compiler, run this spec. */
1259 const char *cpp_spec; /* If non-NULL, substitute this spec
1260 for `%C', rather than the usual
1261 cpp_spec. */
1262 int combinable; /* If nonzero, compiler can deal with
1263 multiple source files at once (IMA). */
1264 int needs_preprocessing; /* If nonzero, source files need to
1265 be run through a preprocessor. */
1268 /* Pointer to a vector of `struct compiler' that gives the spec for
1269 compiling a file, based on its suffix.
1270 A file that does not end in any of these suffixes will be passed
1271 unchanged to the loader and nothing else will be done to it.
1273 An entry containing two 0s is used to terminate the vector.
1275 If multiple entries match a file, the last matching one is used. */
1277 static struct compiler *compilers;
1279 /* Number of entries in `compilers', not counting the null terminator. */
1281 static int n_compilers;
1283 /* The default list of file name suffixes and their compilation specs. */
1285 static const struct compiler default_compilers[] =
1287 /* Add lists of suffixes of known languages here. If those languages
1288 were not present when we built the driver, we will hit these copies
1289 and be given a more meaningful error than "file not used since
1290 linking is not done". */
1291 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
1292 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
1293 {".mii", "#Objective-C++", 0, 0, 0},
1294 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
1295 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
1296 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
1297 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
1298 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
1299 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
1300 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
1301 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
1302 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
1303 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
1304 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
1305 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1306 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1307 {".r", "#Ratfor", 0, 0, 0},
1308 {".go", "#Go", 0, 1, 0},
1309 /* Next come the entries for C. */
1310 {".c", "@c", 0, 0, 1},
1311 {"@c",
1312 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1313 external preprocessor if -save-temps is given. */
1314 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1315 %{!E:%{!M:%{!MM:\
1316 %{traditional:\
1317 %eGNU C no longer supports -traditional without -E}\
1318 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1319 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1320 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1321 %(cc1_options)}\
1322 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1323 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1324 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1325 {"-",
1326 "%{!E:%e-E or -x required when input is from standard input}\
1327 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1328 {".h", "@c-header", 0, 0, 0},
1329 {"@c-header",
1330 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1331 external preprocessor if -save-temps is given. */
1332 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1333 %{!E:%{!M:%{!MM:\
1334 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1335 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1336 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1337 %(cc1_options)\
1338 %{!fsyntax-only:%{!S:-o %g.s} \
1339 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1340 %W{o*:--output-pch=%*}}%V}}\
1341 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1342 cc1 %(cpp_unique_options) %(cc1_options)\
1343 %{!fsyntax-only:%{!S:-o %g.s} \
1344 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1345 %W{o*:--output-pch=%*}}%V}}}}}}}", 0, 0, 0},
1346 {".i", "@cpp-output", 0, 0, 0},
1347 {"@cpp-output",
1348 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1349 {".s", "@assembler", 0, 0, 0},
1350 {"@assembler",
1351 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1352 {".sx", "@assembler-with-cpp", 0, 0, 0},
1353 {".S", "@assembler-with-cpp", 0, 0, 0},
1354 {"@assembler-with-cpp",
1355 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1356 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1357 %{E|M|MM:%(cpp_debug_options)}\
1358 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1359 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1360 #else
1361 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1362 %{E|M|MM:%(cpp_debug_options)}\
1363 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1364 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1365 #endif
1366 , 0, 0, 0},
1368 #include "specs.h"
1369 /* Mark end of table. */
1370 {0, 0, 0, 0, 0}
1373 /* Number of elements in default_compilers, not counting the terminator. */
1375 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1377 typedef char *char_p; /* For DEF_VEC_P. */
1379 /* A vector of options to give to the linker.
1380 These options are accumulated by %x,
1381 and substituted into the linker command with %X. */
1382 static vec<char_p> linker_options;
1384 /* A vector of options to give to the assembler.
1385 These options are accumulated by -Wa,
1386 and substituted into the assembler command with %Y. */
1387 static vec<char_p> assembler_options;
1389 /* A vector of options to give to the preprocessor.
1390 These options are accumulated by -Wp,
1391 and substituted into the preprocessor command with %Z. */
1392 static vec<char_p> preprocessor_options;
1394 static char *
1395 skip_whitespace (char *p)
1397 while (1)
1399 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1400 be considered whitespace. */
1401 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1402 return p + 1;
1403 else if (*p == '\n' || *p == ' ' || *p == '\t')
1404 p++;
1405 else if (*p == '#')
1407 while (*p != '\n')
1408 p++;
1409 p++;
1411 else
1412 break;
1415 return p;
1417 /* Structures to keep track of prefixes to try when looking for files. */
1419 struct prefix_list
1421 const char *prefix; /* String to prepend to the path. */
1422 struct prefix_list *next; /* Next in linked list. */
1423 int require_machine_suffix; /* Don't use without machine_suffix. */
1424 /* 2 means try both machine_suffix and just_machine_suffix. */
1425 int priority; /* Sort key - priority within list. */
1426 int os_multilib; /* 1 if OS multilib scheme should be used,
1427 0 for GCC multilib scheme. */
1430 struct path_prefix
1432 struct prefix_list *plist; /* List of prefixes to try */
1433 int max_len; /* Max length of a prefix in PLIST */
1434 const char *name; /* Name of this list (used in config stuff) */
1437 /* List of prefixes to try when looking for executables. */
1439 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1441 /* List of prefixes to try when looking for startup (crt0) files. */
1443 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1445 /* List of prefixes to try when looking for include files. */
1447 static struct path_prefix include_prefixes = { 0, 0, "include" };
1449 /* Suffix to attach to directories searched for commands.
1450 This looks like `MACHINE/VERSION/'. */
1452 static const char *machine_suffix = 0;
1454 /* Suffix to attach to directories searched for commands.
1455 This is just `MACHINE/'. */
1457 static const char *just_machine_suffix = 0;
1459 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1461 static const char *gcc_exec_prefix;
1463 /* Adjusted value of standard_libexec_prefix. */
1465 static const char *gcc_libexec_prefix;
1467 /* Default prefixes to attach to command names. */
1469 #ifndef STANDARD_STARTFILE_PREFIX_1
1470 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1471 #endif
1472 #ifndef STANDARD_STARTFILE_PREFIX_2
1473 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1474 #endif
1476 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1477 #undef MD_EXEC_PREFIX
1478 #undef MD_STARTFILE_PREFIX
1479 #undef MD_STARTFILE_PREFIX_1
1480 #endif
1482 /* If no prefixes defined, use the null string, which will disable them. */
1483 #ifndef MD_EXEC_PREFIX
1484 #define MD_EXEC_PREFIX ""
1485 #endif
1486 #ifndef MD_STARTFILE_PREFIX
1487 #define MD_STARTFILE_PREFIX ""
1488 #endif
1489 #ifndef MD_STARTFILE_PREFIX_1
1490 #define MD_STARTFILE_PREFIX_1 ""
1491 #endif
1493 /* These directories are locations set at configure-time based on the
1494 --prefix option provided to configure. Their initializers are
1495 defined in Makefile.in. These paths are not *directly* used when
1496 gcc_exec_prefix is set because, in that case, we know where the
1497 compiler has been installed, and use paths relative to that
1498 location instead. */
1499 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1500 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1501 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1502 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1504 /* For native compilers, these are well-known paths containing
1505 components that may be provided by the system. For cross
1506 compilers, these paths are not used. */
1507 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1508 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1509 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1510 static const char *const standard_startfile_prefix_1
1511 = STANDARD_STARTFILE_PREFIX_1;
1512 static const char *const standard_startfile_prefix_2
1513 = STANDARD_STARTFILE_PREFIX_2;
1515 /* A relative path to be used in finding the location of tools
1516 relative to the driver. */
1517 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1519 /* A prefix to be used when this is an accelerator compiler. */
1520 static const char *const accel_dir_suffix = ACCEL_DIR_SUFFIX;
1522 /* Subdirectory to use for locating libraries. Set by
1523 set_multilib_dir based on the compilation options. */
1525 static const char *multilib_dir;
1527 /* Subdirectory to use for locating libraries in OS conventions. Set by
1528 set_multilib_dir based on the compilation options. */
1530 static const char *multilib_os_dir;
1532 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1533 set_multilib_dir based on the compilation options. */
1535 static const char *multiarch_dir;
1537 /* Structure to keep track of the specs that have been defined so far.
1538 These are accessed using %(specname) in a compiler or link
1539 spec. */
1541 struct spec_list
1543 /* The following 2 fields must be first */
1544 /* to allow EXTRA_SPECS to be initialized */
1545 const char *name; /* name of the spec. */
1546 const char *ptr; /* available ptr if no static pointer */
1548 /* The following fields are not initialized */
1549 /* by EXTRA_SPECS */
1550 const char **ptr_spec; /* pointer to the spec itself. */
1551 struct spec_list *next; /* Next spec in linked list. */
1552 int name_len; /* length of the name */
1553 bool user_p; /* whether string come from file spec. */
1554 bool alloc_p; /* whether string was allocated */
1555 const char *default_ptr; /* The default value of *ptr_spec. */
1558 #define INIT_STATIC_SPEC(NAME,PTR) \
1559 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false, \
1560 *PTR }
1562 /* List of statically defined specs. */
1563 static struct spec_list static_specs[] =
1565 INIT_STATIC_SPEC ("asm", &asm_spec),
1566 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1567 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1568 INIT_STATIC_SPEC ("asm_options", &asm_options),
1569 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1570 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1571 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1572 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1573 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1574 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1575 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1576 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1577 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1578 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1579 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1580 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1581 INIT_STATIC_SPEC ("link", &link_spec),
1582 INIT_STATIC_SPEC ("lib", &lib_spec),
1583 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1584 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1585 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1586 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1587 INIT_STATIC_SPEC ("version", &compiler_version),
1588 INIT_STATIC_SPEC ("multilib", &multilib_select),
1589 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1590 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1591 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1592 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1593 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1594 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1595 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1596 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1597 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1598 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1599 INIT_STATIC_SPEC ("post_link", &post_link_spec),
1600 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1601 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1602 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1603 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1604 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1605 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1606 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1607 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1608 INIT_STATIC_SPEC ("self_spec", &self_spec),
1611 #ifdef EXTRA_SPECS /* additional specs needed */
1612 /* Structure to keep track of just the first two args of a spec_list.
1613 That is all that the EXTRA_SPECS macro gives us. */
1614 struct spec_list_1
1616 const char *const name;
1617 const char *const ptr;
1620 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1621 static struct spec_list *extra_specs = (struct spec_list *) 0;
1622 #endif
1624 /* List of dynamically allocates specs that have been defined so far. */
1626 static struct spec_list *specs = (struct spec_list *) 0;
1628 /* List of static spec functions. */
1630 static const struct spec_function static_spec_functions[] =
1632 { "getenv", getenv_spec_function },
1633 { "if-exists", if_exists_spec_function },
1634 { "if-exists-else", if_exists_else_spec_function },
1635 { "sanitize", sanitize_spec_function },
1636 { "replace-outfile", replace_outfile_spec_function },
1637 { "remove-outfile", remove_outfile_spec_function },
1638 { "version-compare", version_compare_spec_function },
1639 { "include", include_spec_function },
1640 { "find-file", find_file_spec_function },
1641 { "find-plugindir", find_plugindir_spec_function },
1642 { "print-asm-header", print_asm_header_spec_function },
1643 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1644 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1645 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1646 { "pass-through-libs", pass_through_libs_spec_func },
1647 { "replace-extension", replace_extension_spec_func },
1648 { "gt", greater_than_spec_func },
1649 { "debug-level-gt", debug_level_greater_than_spec_func },
1650 #ifdef EXTRA_SPEC_FUNCTIONS
1651 EXTRA_SPEC_FUNCTIONS
1652 #endif
1653 { 0, 0 }
1656 static int processing_spec_function;
1658 /* Add appropriate libgcc specs to OBSTACK, taking into account
1659 various permutations of -shared-libgcc, -shared, and such. */
1661 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1663 #ifndef USE_LD_AS_NEEDED
1664 #define USE_LD_AS_NEEDED 0
1665 #endif
1667 static void
1668 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1669 const char *static_name, const char *eh_name)
1671 char *buf;
1673 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1674 "%{!static:%{!static-libgcc:"
1675 #if USE_LD_AS_NEEDED
1676 "%{!shared-libgcc:",
1677 static_name, " " LD_AS_NEEDED_OPTION " ",
1678 shared_name, " " LD_NO_AS_NEEDED_OPTION
1680 "%{shared-libgcc:",
1681 shared_name, "%{!shared: ", static_name, "}"
1683 #else
1684 "%{!shared:"
1685 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1686 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1688 #ifdef LINK_EH_SPEC
1689 "%{shared:"
1690 "%{shared-libgcc:", shared_name, "}"
1691 "%{!shared-libgcc:", static_name, "}"
1693 #else
1694 "%{shared:", shared_name, "}"
1695 #endif
1696 #endif
1697 "}}", NULL);
1699 obstack_grow (obstack, buf, strlen (buf));
1700 free (buf);
1702 #endif /* ENABLE_SHARED_LIBGCC */
1704 /* Initialize the specs lookup routines. */
1706 static void
1707 init_spec (void)
1709 struct spec_list *next = (struct spec_list *) 0;
1710 struct spec_list *sl = (struct spec_list *) 0;
1711 int i;
1713 if (specs)
1714 return; /* Already initialized. */
1716 if (verbose_flag)
1717 fnotice (stderr, "Using built-in specs.\n");
1719 #ifdef EXTRA_SPECS
1720 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1722 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1724 sl = &extra_specs[i];
1725 sl->name = extra_specs_1[i].name;
1726 sl->ptr = extra_specs_1[i].ptr;
1727 sl->next = next;
1728 sl->name_len = strlen (sl->name);
1729 sl->ptr_spec = &sl->ptr;
1730 gcc_assert (sl->ptr_spec != NULL);
1731 sl->default_ptr = sl->ptr;
1732 next = sl;
1734 #endif
1736 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1738 sl = &static_specs[i];
1739 sl->next = next;
1740 next = sl;
1743 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1744 /* ??? If neither -shared-libgcc nor --static-libgcc was
1745 seen, then we should be making an educated guess. Some proposed
1746 heuristics for ELF include:
1748 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1749 program will be doing dynamic loading, which will likely
1750 need the shared libgcc.
1752 (2) If "-ldl", then it's also a fair bet that we're doing
1753 dynamic loading.
1755 (3) For each ET_DYN we're linking against (either through -lfoo
1756 or /some/path/foo.so), check to see whether it or one of
1757 its dependencies depends on a shared libgcc.
1759 (4) If "-shared"
1761 If the runtime is fixed to look for program headers instead
1762 of calling __register_frame_info at all, for each object,
1763 use the shared libgcc if any EH symbol referenced.
1765 If crtstuff is fixed to not invoke __register_frame_info
1766 automatically, for each object, use the shared libgcc if
1767 any non-empty unwind section found.
1769 Doing any of this probably requires invoking an external program to
1770 do the actual object file scanning. */
1772 const char *p = libgcc_spec;
1773 int in_sep = 1;
1775 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1776 when given the proper command line arguments. */
1777 while (*p)
1779 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1781 init_gcc_specs (&obstack,
1782 "-lgcc_s"
1783 #ifdef USE_LIBUNWIND_EXCEPTIONS
1784 " -lunwind"
1785 #endif
1787 "-lgcc",
1788 "-lgcc_eh"
1789 #ifdef USE_LIBUNWIND_EXCEPTIONS
1790 # ifdef HAVE_LD_STATIC_DYNAMIC
1791 " %{!static:" LD_STATIC_OPTION "} -lunwind"
1792 " %{!static:" LD_DYNAMIC_OPTION "}"
1793 # else
1794 " -lunwind"
1795 # endif
1796 #endif
1799 p += 5;
1800 in_sep = 0;
1802 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1804 /* Ug. We don't know shared library extensions. Hope that
1805 systems that use this form don't do shared libraries. */
1806 init_gcc_specs (&obstack,
1807 "-lgcc_s",
1808 "libgcc.a%s",
1809 "libgcc_eh.a%s"
1810 #ifdef USE_LIBUNWIND_EXCEPTIONS
1811 " -lunwind"
1812 #endif
1814 p += 10;
1815 in_sep = 0;
1817 else
1819 obstack_1grow (&obstack, *p);
1820 in_sep = (*p == ' ');
1821 p += 1;
1825 obstack_1grow (&obstack, '\0');
1826 libgcc_spec = XOBFINISH (&obstack, const char *);
1828 #endif
1829 #ifdef USE_AS_TRADITIONAL_FORMAT
1830 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1832 static const char tf[] = "--traditional-format ";
1833 obstack_grow (&obstack, tf, sizeof (tf) - 1);
1834 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1835 asm_spec = XOBFINISH (&obstack, const char *);
1837 #endif
1839 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1840 defined LINKER_HASH_STYLE
1841 # ifdef LINK_BUILDID_SPEC
1842 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1843 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof (LINK_BUILDID_SPEC) - 1);
1844 # endif
1845 # ifdef LINK_EH_SPEC
1846 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1847 obstack_grow (&obstack, LINK_EH_SPEC, sizeof (LINK_EH_SPEC) - 1);
1848 # endif
1849 # ifdef LINKER_HASH_STYLE
1850 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1851 before. */
1853 static const char hash_style[] = "--hash-style=";
1854 obstack_grow (&obstack, hash_style, sizeof (hash_style) - 1);
1855 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof (LINKER_HASH_STYLE) - 1);
1856 obstack_1grow (&obstack, ' ');
1858 # endif
1859 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1860 link_spec = XOBFINISH (&obstack, const char *);
1861 #endif
1863 specs = sl;
1866 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1867 removed; If the spec starts with a + then SPEC is added to the end of the
1868 current spec. */
1870 static void
1871 set_spec (const char *name, const char *spec, bool user_p)
1873 struct spec_list *sl;
1874 const char *old_spec;
1875 int name_len = strlen (name);
1876 int i;
1878 /* If this is the first call, initialize the statically allocated specs. */
1879 if (!specs)
1881 struct spec_list *next = (struct spec_list *) 0;
1882 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1884 sl = &static_specs[i];
1885 sl->next = next;
1886 next = sl;
1888 specs = sl;
1891 /* See if the spec already exists. */
1892 for (sl = specs; sl; sl = sl->next)
1893 if (name_len == sl->name_len && !strcmp (sl->name, name))
1894 break;
1896 if (!sl)
1898 /* Not found - make it. */
1899 sl = XNEW (struct spec_list);
1900 sl->name = xstrdup (name);
1901 sl->name_len = name_len;
1902 sl->ptr_spec = &sl->ptr;
1903 sl->alloc_p = 0;
1904 *(sl->ptr_spec) = "";
1905 sl->next = specs;
1906 sl->default_ptr = NULL;
1907 specs = sl;
1910 old_spec = *(sl->ptr_spec);
1911 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1912 ? concat (old_spec, spec + 1, NULL)
1913 : xstrdup (spec));
1915 #ifdef DEBUG_SPECS
1916 if (verbose_flag)
1917 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1918 #endif
1920 /* Free the old spec. */
1921 if (old_spec && sl->alloc_p)
1922 free (CONST_CAST (char *, old_spec));
1924 sl->user_p = user_p;
1925 sl->alloc_p = true;
1928 /* Accumulate a command (program name and args), and run it. */
1930 typedef const char *const_char_p; /* For DEF_VEC_P. */
1932 /* Vector of pointers to arguments in the current line of specifications. */
1934 static vec<const_char_p> argbuf;
1936 /* Were the options -c, -S or -E passed. */
1937 static int have_c = 0;
1939 /* Was the option -o passed. */
1940 static int have_o = 0;
1942 /* Was the option -E passed. */
1943 static int have_E = 0;
1945 /* Pointer to output file name passed in with -o. */
1946 static const char *output_file = 0;
1948 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1949 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1950 it here. */
1952 static struct temp_name {
1953 const char *suffix; /* suffix associated with the code. */
1954 int length; /* strlen (suffix). */
1955 int unique; /* Indicates whether %g or %u/%U was used. */
1956 const char *filename; /* associated filename. */
1957 int filename_length; /* strlen (filename). */
1958 struct temp_name *next;
1959 } *temp_names;
1961 /* Number of commands executed so far. */
1963 static int execution_count;
1965 /* Number of commands that exited with a signal. */
1967 static int signal_count;
1969 /* Allocate the argument vector. */
1971 static void
1972 alloc_args (void)
1974 argbuf.create (10);
1977 /* Clear out the vector of arguments (after a command is executed). */
1979 static void
1980 clear_args (void)
1982 argbuf.truncate (0);
1985 /* Add one argument to the vector at the end.
1986 This is done when a space is seen or at the end of the line.
1987 If DELETE_ALWAYS is nonzero, the arg is a filename
1988 and the file should be deleted eventually.
1989 If DELETE_FAILURE is nonzero, the arg is a filename
1990 and the file should be deleted if this compilation fails. */
1992 static void
1993 store_arg (const char *arg, int delete_always, int delete_failure)
1995 argbuf.safe_push (arg);
1997 if (delete_always || delete_failure)
1999 const char *p;
2000 /* If the temporary file we should delete is specified as
2001 part of a joined argument extract the filename. */
2002 if (arg[0] == '-'
2003 && (p = strrchr (arg, '=')))
2004 arg = p + 1;
2005 record_temp_file (arg, delete_always, delete_failure);
2009 /* Load specs from a file name named FILENAME, replacing occurrences of
2010 various different types of line-endings, \r\n, \n\r and just \r, with
2011 a single \n. */
2013 static char *
2014 load_specs (const char *filename)
2016 int desc;
2017 int readlen;
2018 struct stat statbuf;
2019 char *buffer;
2020 char *buffer_p;
2021 char *specs;
2022 char *specs_p;
2024 if (verbose_flag)
2025 fnotice (stderr, "Reading specs from %s\n", filename);
2027 /* Open and stat the file. */
2028 desc = open (filename, O_RDONLY, 0);
2029 if (desc < 0)
2030 pfatal_with_name (filename);
2031 if (stat (filename, &statbuf) < 0)
2032 pfatal_with_name (filename);
2034 /* Read contents of file into BUFFER. */
2035 buffer = XNEWVEC (char, statbuf.st_size + 1);
2036 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
2037 if (readlen < 0)
2038 pfatal_with_name (filename);
2039 buffer[readlen] = 0;
2040 close (desc);
2042 specs = XNEWVEC (char, readlen + 1);
2043 specs_p = specs;
2044 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
2046 int skip = 0;
2047 char c = *buffer_p;
2048 if (c == '\r')
2050 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
2051 skip = 1;
2052 else if (*(buffer_p + 1) == '\n') /* \r\n */
2053 skip = 1;
2054 else /* \r */
2055 c = '\n';
2057 if (! skip)
2058 *specs_p++ = c;
2060 *specs_p = '\0';
2062 free (buffer);
2063 return (specs);
2066 /* Read compilation specs from a file named FILENAME,
2067 replacing the default ones.
2069 A suffix which starts with `*' is a definition for
2070 one of the machine-specific sub-specs. The "suffix" should be
2071 *asm, *cc1, *cpp, *link, *startfile, etc.
2072 The corresponding spec is stored in asm_spec, etc.,
2073 rather than in the `compilers' vector.
2075 Anything invalid in the file is a fatal error. */
2077 static void
2078 read_specs (const char *filename, bool main_p, bool user_p)
2080 char *buffer;
2081 char *p;
2083 buffer = load_specs (filename);
2085 /* Scan BUFFER for specs, putting them in the vector. */
2086 p = buffer;
2087 while (1)
2089 char *suffix;
2090 char *spec;
2091 char *in, *out, *p1, *p2, *p3;
2093 /* Advance P in BUFFER to the next nonblank nocomment line. */
2094 p = skip_whitespace (p);
2095 if (*p == 0)
2096 break;
2098 /* Is this a special command that starts with '%'? */
2099 /* Don't allow this for the main specs file, since it would
2100 encourage people to overwrite it. */
2101 if (*p == '%' && !main_p)
2103 p1 = p;
2104 while (*p && *p != '\n')
2105 p++;
2107 /* Skip '\n'. */
2108 p++;
2110 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
2111 && (p1[sizeof "%include" - 1] == ' '
2112 || p1[sizeof "%include" - 1] == '\t'))
2114 char *new_filename;
2116 p1 += sizeof ("%include");
2117 while (*p1 == ' ' || *p1 == '\t')
2118 p1++;
2120 if (*p1++ != '<' || p[-2] != '>')
2121 fatal_error (input_location,
2122 "specs %%include syntax malformed after "
2123 "%ld characters",
2124 (long) (p1 - buffer + 1));
2126 p[-2] = '\0';
2127 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2128 read_specs (new_filename ? new_filename : p1, false, user_p);
2129 continue;
2131 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
2132 && (p1[sizeof "%include_noerr" - 1] == ' '
2133 || p1[sizeof "%include_noerr" - 1] == '\t'))
2135 char *new_filename;
2137 p1 += sizeof "%include_noerr";
2138 while (*p1 == ' ' || *p1 == '\t')
2139 p1++;
2141 if (*p1++ != '<' || p[-2] != '>')
2142 fatal_error (input_location,
2143 "specs %%include syntax malformed after "
2144 "%ld characters",
2145 (long) (p1 - buffer + 1));
2147 p[-2] = '\0';
2148 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2149 if (new_filename)
2150 read_specs (new_filename, false, user_p);
2151 else if (verbose_flag)
2152 fnotice (stderr, "could not find specs file %s\n", p1);
2153 continue;
2155 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
2156 && (p1[sizeof "%rename" - 1] == ' '
2157 || p1[sizeof "%rename" - 1] == '\t'))
2159 int name_len;
2160 struct spec_list *sl;
2161 struct spec_list *newsl;
2163 /* Get original name. */
2164 p1 += sizeof "%rename";
2165 while (*p1 == ' ' || *p1 == '\t')
2166 p1++;
2168 if (! ISALPHA ((unsigned char) *p1))
2169 fatal_error (input_location,
2170 "specs %%rename syntax malformed after "
2171 "%ld characters",
2172 (long) (p1 - buffer));
2174 p2 = p1;
2175 while (*p2 && !ISSPACE ((unsigned char) *p2))
2176 p2++;
2178 if (*p2 != ' ' && *p2 != '\t')
2179 fatal_error (input_location,
2180 "specs %%rename syntax malformed after "
2181 "%ld characters",
2182 (long) (p2 - buffer));
2184 name_len = p2 - p1;
2185 *p2++ = '\0';
2186 while (*p2 == ' ' || *p2 == '\t')
2187 p2++;
2189 if (! ISALPHA ((unsigned char) *p2))
2190 fatal_error (input_location,
2191 "specs %%rename syntax malformed after "
2192 "%ld characters",
2193 (long) (p2 - buffer));
2195 /* Get new spec name. */
2196 p3 = p2;
2197 while (*p3 && !ISSPACE ((unsigned char) *p3))
2198 p3++;
2200 if (p3 != p - 1)
2201 fatal_error (input_location,
2202 "specs %%rename syntax malformed after "
2203 "%ld characters",
2204 (long) (p3 - buffer));
2205 *p3 = '\0';
2207 for (sl = specs; sl; sl = sl->next)
2208 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2209 break;
2211 if (!sl)
2212 fatal_error (input_location,
2213 "specs %s spec was not found to be renamed", p1);
2215 if (strcmp (p1, p2) == 0)
2216 continue;
2218 for (newsl = specs; newsl; newsl = newsl->next)
2219 if (strcmp (newsl->name, p2) == 0)
2220 fatal_error (input_location,
2221 "%s: attempt to rename spec %qs to "
2222 "already defined spec %qs",
2223 filename, p1, p2);
2225 if (verbose_flag)
2227 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
2228 #ifdef DEBUG_SPECS
2229 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
2230 #endif
2233 set_spec (p2, *(sl->ptr_spec), user_p);
2234 if (sl->alloc_p)
2235 free (CONST_CAST (char *, *(sl->ptr_spec)));
2237 *(sl->ptr_spec) = "";
2238 sl->alloc_p = 0;
2239 continue;
2241 else
2242 fatal_error (input_location,
2243 "specs unknown %% command after %ld characters",
2244 (long) (p1 - buffer));
2247 /* Find the colon that should end the suffix. */
2248 p1 = p;
2249 while (*p1 && *p1 != ':' && *p1 != '\n')
2250 p1++;
2252 /* The colon shouldn't be missing. */
2253 if (*p1 != ':')
2254 fatal_error (input_location,
2255 "specs file malformed after %ld characters",
2256 (long) (p1 - buffer));
2258 /* Skip back over trailing whitespace. */
2259 p2 = p1;
2260 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2261 p2--;
2263 /* Copy the suffix to a string. */
2264 suffix = save_string (p, p2 - p);
2265 /* Find the next line. */
2266 p = skip_whitespace (p1 + 1);
2267 if (p[1] == 0)
2268 fatal_error (input_location,
2269 "specs file malformed after %ld characters",
2270 (long) (p - buffer));
2272 p1 = p;
2273 /* Find next blank line or end of string. */
2274 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2275 p1++;
2277 /* Specs end at the blank line and do not include the newline. */
2278 spec = save_string (p, p1 - p);
2279 p = p1;
2281 /* Delete backslash-newline sequences from the spec. */
2282 in = spec;
2283 out = spec;
2284 while (*in != 0)
2286 if (in[0] == '\\' && in[1] == '\n')
2287 in += 2;
2288 else if (in[0] == '#')
2289 while (*in && *in != '\n')
2290 in++;
2292 else
2293 *out++ = *in++;
2295 *out = 0;
2297 if (suffix[0] == '*')
2299 if (! strcmp (suffix, "*link_command"))
2300 link_command_spec = spec;
2301 else
2303 set_spec (suffix + 1, spec, user_p);
2304 free (spec);
2307 else
2309 /* Add this pair to the vector. */
2310 compilers
2311 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
2313 compilers[n_compilers].suffix = suffix;
2314 compilers[n_compilers].spec = spec;
2315 n_compilers++;
2316 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2319 if (*suffix == 0)
2320 link_command_spec = spec;
2323 if (link_command_spec == 0)
2324 fatal_error (input_location, "spec file has no spec for linking");
2326 XDELETEVEC (buffer);
2329 /* Record the names of temporary files we tell compilers to write,
2330 and delete them at the end of the run. */
2332 /* This is the common prefix we use to make temp file names.
2333 It is chosen once for each run of this program.
2334 It is substituted into a spec by %g or %j.
2335 Thus, all temp file names contain this prefix.
2336 In practice, all temp file names start with this prefix.
2338 This prefix comes from the envvar TMPDIR if it is defined;
2339 otherwise, from the P_tmpdir macro if that is defined;
2340 otherwise, in /usr/tmp or /tmp;
2341 or finally the current directory if all else fails. */
2343 static const char *temp_filename;
2345 /* Length of the prefix. */
2347 static int temp_filename_length;
2349 /* Define the list of temporary files to delete. */
2351 struct temp_file
2353 const char *name;
2354 struct temp_file *next;
2357 /* Queue of files to delete on success or failure of compilation. */
2358 static struct temp_file *always_delete_queue;
2359 /* Queue of files to delete on failure of compilation. */
2360 static struct temp_file *failure_delete_queue;
2362 /* Record FILENAME as a file to be deleted automatically.
2363 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2364 otherwise delete it in any case.
2365 FAIL_DELETE nonzero means delete it if a compilation step fails;
2366 otherwise delete it in any case. */
2368 void
2369 record_temp_file (const char *filename, int always_delete, int fail_delete)
2371 char *const name = xstrdup (filename);
2373 if (always_delete)
2375 struct temp_file *temp;
2376 for (temp = always_delete_queue; temp; temp = temp->next)
2377 if (! filename_cmp (name, temp->name))
2379 free (name);
2380 goto already1;
2383 temp = XNEW (struct temp_file);
2384 temp->next = always_delete_queue;
2385 temp->name = name;
2386 always_delete_queue = temp;
2388 already1:;
2391 if (fail_delete)
2393 struct temp_file *temp;
2394 for (temp = failure_delete_queue; temp; temp = temp->next)
2395 if (! filename_cmp (name, temp->name))
2397 free (name);
2398 goto already2;
2401 temp = XNEW (struct temp_file);
2402 temp->next = failure_delete_queue;
2403 temp->name = name;
2404 failure_delete_queue = temp;
2406 already2:;
2410 /* Delete all the temporary files whose names we previously recorded. */
2412 #ifndef DELETE_IF_ORDINARY
2413 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2414 do \
2416 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2417 if (unlink (NAME) < 0) \
2418 if (VERBOSE_FLAG) \
2419 perror_with_name (NAME); \
2420 } while (0)
2421 #endif
2423 static void
2424 delete_if_ordinary (const char *name)
2426 struct stat st;
2427 #ifdef DEBUG
2428 int i, c;
2430 printf ("Delete %s? (y or n) ", name);
2431 fflush (stdout);
2432 i = getchar ();
2433 if (i != '\n')
2434 while ((c = getchar ()) != '\n' && c != EOF)
2437 if (i == 'y' || i == 'Y')
2438 #endif /* DEBUG */
2439 DELETE_IF_ORDINARY (name, st, verbose_flag);
2442 static void
2443 delete_temp_files (void)
2445 struct temp_file *temp;
2447 for (temp = always_delete_queue; temp; temp = temp->next)
2448 delete_if_ordinary (temp->name);
2449 always_delete_queue = 0;
2452 /* Delete all the files to be deleted on error. */
2454 static void
2455 delete_failure_queue (void)
2457 struct temp_file *temp;
2459 for (temp = failure_delete_queue; temp; temp = temp->next)
2460 delete_if_ordinary (temp->name);
2463 static void
2464 clear_failure_queue (void)
2466 failure_delete_queue = 0;
2469 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2470 returns non-NULL.
2471 If DO_MULTI is true iterate over the paths twice, first with multilib
2472 suffix then without, otherwise iterate over the paths once without
2473 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2474 to avoid visiting the same path twice, but we could do better. For
2475 instance, /usr/lib/../lib is considered different from /usr/lib.
2476 At least EXTRA_SPACE chars past the end of the path passed to
2477 CALLBACK are available for use by the callback.
2478 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2480 Returns the value returned by CALLBACK. */
2482 static void *
2483 for_each_path (const struct path_prefix *paths,
2484 bool do_multi,
2485 size_t extra_space,
2486 void *(*callback) (char *, void *),
2487 void *callback_info)
2489 struct prefix_list *pl;
2490 const char *multi_dir = NULL;
2491 const char *multi_os_dir = NULL;
2492 const char *multiarch_suffix = NULL;
2493 const char *multi_suffix;
2494 const char *just_multi_suffix;
2495 char *path = NULL;
2496 void *ret = NULL;
2497 bool skip_multi_dir = false;
2498 bool skip_multi_os_dir = false;
2500 multi_suffix = machine_suffix;
2501 just_multi_suffix = just_machine_suffix;
2502 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2504 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2505 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2506 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2508 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2509 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2510 if (multiarch_dir)
2511 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2513 while (1)
2515 size_t multi_dir_len = 0;
2516 size_t multi_os_dir_len = 0;
2517 size_t multiarch_len = 0;
2518 size_t suffix_len;
2519 size_t just_suffix_len;
2520 size_t len;
2522 if (multi_dir)
2523 multi_dir_len = strlen (multi_dir);
2524 if (multi_os_dir)
2525 multi_os_dir_len = strlen (multi_os_dir);
2526 if (multiarch_suffix)
2527 multiarch_len = strlen (multiarch_suffix);
2528 suffix_len = strlen (multi_suffix);
2529 just_suffix_len = strlen (just_multi_suffix);
2531 if (path == NULL)
2533 len = paths->max_len + extra_space + 1;
2534 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2535 path = XNEWVEC (char, len);
2538 for (pl = paths->plist; pl != 0; pl = pl->next)
2540 len = strlen (pl->prefix);
2541 memcpy (path, pl->prefix, len);
2543 /* Look first in MACHINE/VERSION subdirectory. */
2544 if (!skip_multi_dir)
2546 memcpy (path + len, multi_suffix, suffix_len + 1);
2547 ret = callback (path, callback_info);
2548 if (ret)
2549 break;
2552 /* Some paths are tried with just the machine (ie. target)
2553 subdir. This is used for finding as, ld, etc. */
2554 if (!skip_multi_dir
2555 && pl->require_machine_suffix == 2)
2557 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2558 ret = callback (path, callback_info);
2559 if (ret)
2560 break;
2563 /* Now try the multiarch path. */
2564 if (!skip_multi_dir
2565 && !pl->require_machine_suffix && multiarch_dir)
2567 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2568 ret = callback (path, callback_info);
2569 if (ret)
2570 break;
2573 /* Now try the base path. */
2574 if (!pl->require_machine_suffix
2575 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2577 const char *this_multi;
2578 size_t this_multi_len;
2580 if (pl->os_multilib)
2582 this_multi = multi_os_dir;
2583 this_multi_len = multi_os_dir_len;
2585 else
2587 this_multi = multi_dir;
2588 this_multi_len = multi_dir_len;
2591 if (this_multi_len)
2592 memcpy (path + len, this_multi, this_multi_len + 1);
2593 else
2594 path[len] = '\0';
2596 ret = callback (path, callback_info);
2597 if (ret)
2598 break;
2601 if (pl)
2602 break;
2604 if (multi_dir == NULL && multi_os_dir == NULL)
2605 break;
2607 /* Run through the paths again, this time without multilibs.
2608 Don't repeat any we have already seen. */
2609 if (multi_dir)
2611 free (CONST_CAST (char *, multi_dir));
2612 multi_dir = NULL;
2613 free (CONST_CAST (char *, multi_suffix));
2614 multi_suffix = machine_suffix;
2615 free (CONST_CAST (char *, just_multi_suffix));
2616 just_multi_suffix = just_machine_suffix;
2618 else
2619 skip_multi_dir = true;
2620 if (multi_os_dir)
2622 free (CONST_CAST (char *, multi_os_dir));
2623 multi_os_dir = NULL;
2625 else
2626 skip_multi_os_dir = true;
2629 if (multi_dir)
2631 free (CONST_CAST (char *, multi_dir));
2632 free (CONST_CAST (char *, multi_suffix));
2633 free (CONST_CAST (char *, just_multi_suffix));
2635 if (multi_os_dir)
2636 free (CONST_CAST (char *, multi_os_dir));
2637 if (ret != path)
2638 free (path);
2639 return ret;
2642 /* Callback for build_search_list. Adds path to obstack being built. */
2644 struct add_to_obstack_info {
2645 struct obstack *ob;
2646 bool check_dir;
2647 bool first_time;
2650 static void *
2651 add_to_obstack (char *path, void *data)
2653 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2655 if (info->check_dir && !is_directory (path, false))
2656 return NULL;
2658 if (!info->first_time)
2659 obstack_1grow (info->ob, PATH_SEPARATOR);
2661 obstack_grow (info->ob, path, strlen (path));
2663 info->first_time = false;
2664 return NULL;
2667 /* Add or change the value of an environment variable, outputting the
2668 change to standard error if in verbose mode. */
2669 static void
2670 xputenv (const char *string)
2672 env.xput (string);
2675 /* Build a list of search directories from PATHS.
2676 PREFIX is a string to prepend to the list.
2677 If CHECK_DIR_P is true we ensure the directory exists.
2678 If DO_MULTI is true, multilib paths are output first, then
2679 non-multilib paths.
2680 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2681 It is also used by the --print-search-dirs flag. */
2683 static char *
2684 build_search_list (const struct path_prefix *paths, const char *prefix,
2685 bool check_dir, bool do_multi)
2687 struct add_to_obstack_info info;
2689 info.ob = &collect_obstack;
2690 info.check_dir = check_dir;
2691 info.first_time = true;
2693 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2694 obstack_1grow (&collect_obstack, '=');
2696 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2698 obstack_1grow (&collect_obstack, '\0');
2699 return XOBFINISH (&collect_obstack, char *);
2702 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2703 for collect. */
2705 static void
2706 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2707 bool do_multi)
2709 xputenv (build_search_list (paths, env_var, true, do_multi));
2712 /* Check whether NAME can be accessed in MODE. This is like access,
2713 except that it never considers directories to be executable. */
2715 static int
2716 access_check (const char *name, int mode)
2718 if (mode == X_OK)
2720 struct stat st;
2722 if (stat (name, &st) < 0
2723 || S_ISDIR (st.st_mode))
2724 return -1;
2727 return access (name, mode);
2730 /* Callback for find_a_file. Appends the file name to the directory
2731 path. If the resulting file exists in the right mode, return the
2732 full pathname to the file. */
2734 struct file_at_path_info {
2735 const char *name;
2736 const char *suffix;
2737 int name_len;
2738 int suffix_len;
2739 int mode;
2742 static void *
2743 file_at_path (char *path, void *data)
2745 struct file_at_path_info *info = (struct file_at_path_info *) data;
2746 size_t len = strlen (path);
2748 memcpy (path + len, info->name, info->name_len);
2749 len += info->name_len;
2751 /* Some systems have a suffix for executable files.
2752 So try appending that first. */
2753 if (info->suffix_len)
2755 memcpy (path + len, info->suffix, info->suffix_len + 1);
2756 if (access_check (path, info->mode) == 0)
2757 return path;
2760 path[len] = '\0';
2761 if (access_check (path, info->mode) == 0)
2762 return path;
2764 return NULL;
2767 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2768 access to check permissions. If DO_MULTI is true, search multilib
2769 paths then non-multilib paths, otherwise do not search multilib paths.
2770 Return 0 if not found, otherwise return its name, allocated with malloc. */
2772 static char *
2773 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2774 bool do_multi)
2776 struct file_at_path_info info;
2778 #ifdef DEFAULT_ASSEMBLER
2779 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2780 return xstrdup (DEFAULT_ASSEMBLER);
2781 #endif
2783 #ifdef DEFAULT_LINKER
2784 if (! strcmp (name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2785 return xstrdup (DEFAULT_LINKER);
2786 #endif
2788 /* Determine the filename to execute (special case for absolute paths). */
2790 if (IS_ABSOLUTE_PATH (name))
2792 if (access (name, mode) == 0)
2793 return xstrdup (name);
2795 return NULL;
2798 info.name = name;
2799 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2800 info.name_len = strlen (info.name);
2801 info.suffix_len = strlen (info.suffix);
2802 info.mode = mode;
2804 return (char*) for_each_path (pprefix, do_multi,
2805 info.name_len + info.suffix_len,
2806 file_at_path, &info);
2809 /* Ranking of prefixes in the sort list. -B prefixes are put before
2810 all others. */
2812 enum path_prefix_priority
2814 PREFIX_PRIORITY_B_OPT,
2815 PREFIX_PRIORITY_LAST
2818 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2819 order according to PRIORITY. Within each PRIORITY, new entries are
2820 appended.
2822 If WARN is nonzero, we will warn if no file is found
2823 through this prefix. WARN should point to an int
2824 which will be set to 1 if this entry is used.
2826 COMPONENT is the value to be passed to update_path.
2828 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2829 the complete value of machine_suffix.
2830 2 means try both machine_suffix and just_machine_suffix. */
2832 static void
2833 add_prefix (struct path_prefix *pprefix, const char *prefix,
2834 const char *component, /* enum prefix_priority */ int priority,
2835 int require_machine_suffix, int os_multilib)
2837 struct prefix_list *pl, **prev;
2838 int len;
2840 for (prev = &pprefix->plist;
2841 (*prev) != NULL && (*prev)->priority <= priority;
2842 prev = &(*prev)->next)
2845 /* Keep track of the longest prefix. */
2847 prefix = update_path (prefix, component);
2848 len = strlen (prefix);
2849 if (len > pprefix->max_len)
2850 pprefix->max_len = len;
2852 pl = XNEW (struct prefix_list);
2853 pl->prefix = prefix;
2854 pl->require_machine_suffix = require_machine_suffix;
2855 pl->priority = priority;
2856 pl->os_multilib = os_multilib;
2858 /* Insert after PREV. */
2859 pl->next = (*prev);
2860 (*prev) = pl;
2863 /* Same as add_prefix, but prepending target_system_root to prefix. */
2864 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2865 static void
2866 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2867 const char *component,
2868 /* enum prefix_priority */ int priority,
2869 int require_machine_suffix, int os_multilib)
2871 if (!IS_ABSOLUTE_PATH (prefix))
2872 fatal_error (input_location, "system path %qs is not absolute", prefix);
2874 if (target_system_root)
2876 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2877 size_t sysroot_len = strlen (target_system_root);
2879 if (sysroot_len > 0
2880 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2881 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2883 if (target_sysroot_suffix)
2884 prefix = concat (sysroot_no_trailing_dir_separator,
2885 target_sysroot_suffix, prefix, NULL);
2886 else
2887 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2889 free (sysroot_no_trailing_dir_separator);
2891 /* We have to override this because GCC's notion of sysroot
2892 moves along with GCC. */
2893 component = "GCC";
2896 add_prefix (pprefix, prefix, component, priority,
2897 require_machine_suffix, os_multilib);
2900 /* Execute the command specified by the arguments on the current line of spec.
2901 When using pipes, this includes several piped-together commands
2902 with `|' between them.
2904 Return 0 if successful, -1 if failed. */
2906 static int
2907 execute (void)
2909 int i;
2910 int n_commands; /* # of command. */
2911 char *string;
2912 struct pex_obj *pex;
2913 struct command
2915 const char *prog; /* program name. */
2916 const char **argv; /* vector of args. */
2918 const char *arg;
2920 struct command *commands; /* each command buffer with above info. */
2922 gcc_assert (!processing_spec_function);
2924 if (wrapper_string)
2926 string = find_a_file (&exec_prefixes,
2927 argbuf[0], X_OK, false);
2928 if (string)
2929 argbuf[0] = string;
2930 insert_wrapper (wrapper_string);
2933 /* Count # of piped commands. */
2934 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2935 if (strcmp (arg, "|") == 0)
2936 n_commands++;
2938 /* Get storage for each command. */
2939 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2941 /* Split argbuf into its separate piped processes,
2942 and record info about each one.
2943 Also search for the programs that are to be run. */
2945 argbuf.safe_push (0);
2947 commands[0].prog = argbuf[0]; /* first command. */
2948 commands[0].argv = argbuf.address ();
2950 if (!wrapper_string)
2952 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2953 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2956 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2957 if (arg && strcmp (arg, "|") == 0)
2958 { /* each command. */
2959 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2960 fatal_error (input_location, "-pipe not supported");
2961 #endif
2962 argbuf[i] = 0; /* Termination of
2963 command args. */
2964 commands[n_commands].prog = argbuf[i + 1];
2965 commands[n_commands].argv
2966 = &(argbuf.address ())[i + 1];
2967 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2968 X_OK, false);
2969 if (string)
2970 commands[n_commands].argv[0] = string;
2971 n_commands++;
2974 /* If -v, print what we are about to do, and maybe query. */
2976 if (verbose_flag)
2978 /* For help listings, put a blank line between sub-processes. */
2979 if (print_help_list)
2980 fputc ('\n', stderr);
2982 /* Print each piped command as a separate line. */
2983 for (i = 0; i < n_commands; i++)
2985 const char *const *j;
2987 if (verbose_only_flag)
2989 for (j = commands[i].argv; *j; j++)
2991 const char *p;
2992 for (p = *j; *p; ++p)
2993 if (!ISALNUM ((unsigned char) *p)
2994 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2995 break;
2996 if (*p || !*j)
2998 fprintf (stderr, " \"");
2999 for (p = *j; *p; ++p)
3001 if (*p == '"' || *p == '\\' || *p == '$')
3002 fputc ('\\', stderr);
3003 fputc (*p, stderr);
3005 fputc ('"', stderr);
3007 /* If it's empty, print "". */
3008 else if (!**j)
3009 fprintf (stderr, " \"\"");
3010 else
3011 fprintf (stderr, " %s", *j);
3014 else
3015 for (j = commands[i].argv; *j; j++)
3016 /* If it's empty, print "". */
3017 if (!**j)
3018 fprintf (stderr, " \"\"");
3019 else
3020 fprintf (stderr, " %s", *j);
3022 /* Print a pipe symbol after all but the last command. */
3023 if (i + 1 != n_commands)
3024 fprintf (stderr, " |");
3025 fprintf (stderr, "\n");
3027 fflush (stderr);
3028 if (verbose_only_flag != 0)
3030 /* verbose_only_flag should act as if the spec was
3031 executed, so increment execution_count before
3032 returning. This prevents spurious warnings about
3033 unused linker input files, etc. */
3034 execution_count++;
3035 return 0;
3037 #ifdef DEBUG
3038 fnotice (stderr, "\nGo ahead? (y or n) ");
3039 fflush (stderr);
3040 i = getchar ();
3041 if (i != '\n')
3042 while (getchar () != '\n')
3045 if (i != 'y' && i != 'Y')
3046 return 0;
3047 #endif /* DEBUG */
3050 #ifdef ENABLE_VALGRIND_CHECKING
3051 /* Run the each command through valgrind. To simplify prepending the
3052 path to valgrind and the option "-q" (for quiet operation unless
3053 something triggers), we allocate a separate argv array. */
3055 for (i = 0; i < n_commands; i++)
3057 const char **argv;
3058 int argc;
3059 int j;
3061 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
3064 argv = XALLOCAVEC (const char *, argc + 3);
3066 argv[0] = VALGRIND_PATH;
3067 argv[1] = "-q";
3068 for (j = 2; j < argc + 2; j++)
3069 argv[j] = commands[i].argv[j - 2];
3070 argv[j] = NULL;
3072 commands[i].argv = argv;
3073 commands[i].prog = argv[0];
3075 #endif
3077 /* Run each piped subprocess. */
3079 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
3080 ? PEX_RECORD_TIMES : 0),
3081 progname, temp_filename);
3082 if (pex == NULL)
3083 fatal_error (input_location, "pex_init failed: %m");
3085 for (i = 0; i < n_commands; i++)
3087 const char *errmsg;
3088 int err;
3089 const char *string = commands[i].argv[0];
3091 errmsg = pex_run (pex,
3092 ((i + 1 == n_commands ? PEX_LAST : 0)
3093 | (string == commands[i].prog ? PEX_SEARCH : 0)),
3094 string, CONST_CAST (char **, commands[i].argv),
3095 NULL, NULL, &err);
3096 if (errmsg != NULL)
3098 if (err == 0)
3099 fatal_error (input_location, errmsg);
3100 else
3102 errno = err;
3103 pfatal_with_name (errmsg);
3107 if (i && string != commands[i].prog)
3108 free (CONST_CAST (char *, string));
3111 execution_count++;
3113 /* Wait for all the subprocesses to finish. */
3116 int *statuses;
3117 struct pex_time *times = NULL;
3118 int ret_code = 0;
3120 statuses = (int *) alloca (n_commands * sizeof (int));
3121 if (!pex_get_status (pex, n_commands, statuses))
3122 fatal_error (input_location, "failed to get exit status: %m");
3124 if (report_times || report_times_to_file)
3126 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
3127 if (!pex_get_times (pex, n_commands, times))
3128 fatal_error (input_location, "failed to get process times: %m");
3131 pex_free (pex);
3133 for (i = 0; i < n_commands; ++i)
3135 int status = statuses[i];
3137 if (WIFSIGNALED (status))
3139 #ifdef SIGPIPE
3140 /* SIGPIPE is a special case. It happens in -pipe mode
3141 when the compiler dies before the preprocessor is done,
3142 or the assembler dies before the compiler is done.
3143 There's generally been an error already, and this is
3144 just fallout. So don't generate another error unless
3145 we would otherwise have succeeded. */
3146 if (WTERMSIG (status) == SIGPIPE
3147 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
3149 signal_count++;
3150 ret_code = -1;
3152 else
3153 #endif
3154 switch (WTERMSIG (status))
3156 case SIGINT:
3157 case SIGQUIT:
3158 case SIGKILL:
3159 case SIGTERM:
3160 /* The user (or environment) did something to the
3161 inferior. Making this an ICE confuses the user
3162 into thinking there's a compiler bug. Much more
3163 likely is the user or OOM killer nuked it. */
3164 fatal_error (input_location,
3165 "%s signal terminated program %s",
3166 strsignal (WTERMSIG (status)),
3167 commands[i].prog);
3168 break;
3169 default:
3170 /* The inferior failed to catch the signal. */
3171 internal_error_no_backtrace ("%s (program %s)",
3172 strsignal (WTERMSIG (status)),
3173 commands[i].prog);
3176 else if (WIFEXITED (status)
3177 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
3179 /* For ICEs in cc1, cc1obj, cc1plus see if it is
3180 reproducible or not. */
3181 const char *p;
3182 if (flag_report_bug
3183 && WEXITSTATUS (status) == ICE_EXIT_CODE
3184 && i == 0
3185 && (p = strrchr (commands[0].argv[0], DIR_SEPARATOR))
3186 && ! strncmp (p + 1, "cc1", 3))
3187 try_generate_repro (commands[0].argv);
3188 if (WEXITSTATUS (status) > greatest_status)
3189 greatest_status = WEXITSTATUS (status);
3190 ret_code = -1;
3193 if (report_times || report_times_to_file)
3195 struct pex_time *pt = &times[i];
3196 double ut, st;
3198 ut = ((double) pt->user_seconds
3199 + (double) pt->user_microseconds / 1.0e6);
3200 st = ((double) pt->system_seconds
3201 + (double) pt->system_microseconds / 1.0e6);
3203 if (ut + st != 0)
3205 if (report_times)
3206 fnotice (stderr, "# %s %.2f %.2f\n",
3207 commands[i].prog, ut, st);
3209 if (report_times_to_file)
3211 int c = 0;
3212 const char *const *j;
3214 fprintf (report_times_to_file, "%g %g", ut, st);
3216 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
3218 const char *p;
3219 for (p = *j; *p; ++p)
3220 if (*p == '"' || *p == '\\' || *p == '$'
3221 || ISSPACE (*p))
3222 break;
3224 if (*p)
3226 fprintf (report_times_to_file, " \"");
3227 for (p = *j; *p; ++p)
3229 if (*p == '"' || *p == '\\' || *p == '$')
3230 fputc ('\\', report_times_to_file);
3231 fputc (*p, report_times_to_file);
3233 fputc ('"', report_times_to_file);
3235 else
3236 fprintf (report_times_to_file, " %s", *j);
3239 fputc ('\n', report_times_to_file);
3245 if (commands[0].argv[0] != commands[0].prog)
3246 free (CONST_CAST (char *, commands[0].argv[0]));
3248 return ret_code;
3252 /* Find all the switches given to us
3253 and make a vector describing them.
3254 The elements of the vector are strings, one per switch given.
3255 If a switch uses following arguments, then the `part1' field
3256 is the switch itself and the `args' field
3257 is a null-terminated vector containing the following arguments.
3258 Bits in the `live_cond' field are:
3259 SWITCH_LIVE to indicate this switch is true in a conditional spec.
3260 SWITCH_FALSE to indicate this switch is overridden by a later switch.
3261 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
3262 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored.
3263 SWITCH_KEEP_FOR_GCC to indicate that this switch, otherwise ignored,
3264 should be included in COLLECT_GCC_OPTIONS.
3265 in all do_spec calls afterwards. Used for %<S from self specs.
3266 The `known' field describes whether this is an internal switch.
3267 The `validated' field describes whether any spec has looked at this switch;
3268 if it remains false at the end of the run, the switch must be meaningless.
3269 The `ordering' field is used to temporarily mark switches that have to be
3270 kept in a specific order. */
3272 #define SWITCH_LIVE (1 << 0)
3273 #define SWITCH_FALSE (1 << 1)
3274 #define SWITCH_IGNORE (1 << 2)
3275 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
3276 #define SWITCH_KEEP_FOR_GCC (1 << 4)
3278 struct switchstr
3280 const char *part1;
3281 const char **args;
3282 unsigned int live_cond;
3283 bool known;
3284 bool validated;
3285 bool ordering;
3288 static struct switchstr *switches;
3290 static int n_switches;
3292 static int n_switches_alloc;
3294 /* Set to zero if -fcompare-debug is disabled, positive if it's
3295 enabled and we're running the first compilation, negative if it's
3296 enabled and we're running the second compilation. For most of the
3297 time, it's in the range -1..1, but it can be temporarily set to 2
3298 or 3 to indicate that the -fcompare-debug flags didn't come from
3299 the command-line, but rather from the GCC_COMPARE_DEBUG environment
3300 variable, until a synthesized -fcompare-debug flag is added to the
3301 command line. */
3302 int compare_debug;
3304 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
3305 int compare_debug_second;
3307 /* Set to the flags that should be passed to the second compilation in
3308 a -fcompare-debug compilation. */
3309 const char *compare_debug_opt;
3311 static struct switchstr *switches_debug_check[2];
3313 static int n_switches_debug_check[2];
3315 static int n_switches_alloc_debug_check[2];
3317 static char *debug_check_temp_file[2];
3319 /* Language is one of three things:
3321 1) The name of a real programming language.
3322 2) NULL, indicating that no one has figured out
3323 what it is yet.
3324 3) '*', indicating that the file should be passed
3325 to the linker. */
3326 struct infile
3328 const char *name;
3329 const char *language;
3330 struct compiler *incompiler;
3331 bool compiled;
3332 bool preprocessed;
3335 /* Also a vector of input files specified. */
3337 static struct infile *infiles;
3339 int n_infiles;
3341 static int n_infiles_alloc;
3343 /* True if undefined environment variables encountered during spec processing
3344 are ok to ignore, typically when we're running for --help or --version. */
3346 static bool spec_undefvar_allowed;
3348 /* True if multiple input files are being compiled to a single
3349 assembly file. */
3351 static bool combine_inputs;
3353 /* This counts the number of libraries added by lang_specific_driver, so that
3354 we can tell if there were any user supplied any files or libraries. */
3356 static int added_libraries;
3358 /* And a vector of corresponding output files is made up later. */
3360 const char **outfiles;
3362 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3364 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3365 is true if we should look for an executable suffix. DO_OBJ
3366 is true if we should look for an object suffix. */
3368 static const char *
3369 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3370 int do_obj ATTRIBUTE_UNUSED)
3372 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3373 int i;
3374 #endif
3375 int len;
3377 if (name == NULL)
3378 return NULL;
3380 len = strlen (name);
3382 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3383 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3384 if (do_obj && len > 2
3385 && name[len - 2] == '.'
3386 && name[len - 1] == 'o')
3388 obstack_grow (&obstack, name, len - 2);
3389 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3390 name = XOBFINISH (&obstack, const char *);
3392 #endif
3394 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3395 /* If there is no filetype, make it the executable suffix (which includes
3396 the "."). But don't get confused if we have just "-o". */
3397 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3398 return name;
3400 for (i = len - 1; i >= 0; i--)
3401 if (IS_DIR_SEPARATOR (name[i]))
3402 break;
3404 for (i++; i < len; i++)
3405 if (name[i] == '.')
3406 return name;
3408 obstack_grow (&obstack, name, len);
3409 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3410 strlen (TARGET_EXECUTABLE_SUFFIX));
3411 name = XOBFINISH (&obstack, const char *);
3412 #endif
3414 return name;
3416 #endif
3418 /* Display the command line switches accepted by gcc. */
3419 static void
3420 display_help (void)
3422 printf (_("Usage: %s [options] file...\n"), progname);
3423 fputs (_("Options:\n"), stdout);
3425 fputs (_(" -pass-exit-codes Exit with highest error code from a phase.\n"), stdout);
3426 fputs (_(" --help Display this information.\n"), stdout);
3427 fputs (_(" --target-help Display target specific command line options.\n"), stdout);
3428 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...].\n"), stdout);
3429 fputs (_(" Display specific types of command line options.\n"), stdout);
3430 if (! verbose_flag)
3431 fputs (_(" (Use '-v --help' to display command line options of sub-processes).\n"), stdout);
3432 fputs (_(" --version Display compiler version information.\n"), stdout);
3433 fputs (_(" -dumpspecs Display all of the built in spec strings.\n"), stdout);
3434 fputs (_(" -dumpversion Display the version of the compiler.\n"), stdout);
3435 fputs (_(" -dumpmachine Display the compiler's target processor.\n"), stdout);
3436 fputs (_(" -print-search-dirs Display the directories in the compiler's search path.\n"), stdout);
3437 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library.\n"), stdout);
3438 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>.\n"), stdout);
3439 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>.\n"), stdout);
3440 fputs (_("\
3441 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3442 a component in the library path.\n"), stdout);
3443 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc.\n"), stdout);
3444 fputs (_("\
3445 -print-multi-lib Display the mapping between command line options and\n\
3446 multiple library search directories.\n"), stdout);
3447 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries.\n"), stdout);
3448 fputs (_(" -print-sysroot Display the target libraries directory.\n"), stdout);
3449 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers.\n"), stdout);
3450 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler.\n"), stdout);
3451 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor.\n"), stdout);
3452 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker.\n"), stdout);
3453 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler.\n"), stdout);
3454 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor.\n"), stdout);
3455 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker.\n"), stdout);
3456 fputs (_(" -save-temps Do not delete intermediate files.\n"), stdout);
3457 fputs (_(" -save-temps=<arg> Do not delete intermediate files.\n"), stdout);
3458 fputs (_("\
3459 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3460 prefixes to other gcc components.\n"), stdout);
3461 fputs (_(" -pipe Use pipes rather than intermediate files.\n"), stdout);
3462 fputs (_(" -time Time the execution of each subprocess.\n"), stdout);
3463 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>.\n"), stdout);
3464 fputs (_(" -std=<standard> Assume that the input sources are for <standard>.\n"), stdout);
3465 fputs (_("\
3466 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3467 and libraries.\n"), stdout);
3468 fputs (_(" -B <directory> Add <directory> to the compiler's search paths.\n"), stdout);
3469 fputs (_(" -v Display the programs invoked by the compiler.\n"), stdout);
3470 fputs (_(" -### Like -v but options quoted and commands not executed.\n"), stdout);
3471 fputs (_(" -E Preprocess only; do not compile, assemble or link.\n"), stdout);
3472 fputs (_(" -S Compile only; do not assemble or link.\n"), stdout);
3473 fputs (_(" -c Compile and assemble, but do not link.\n"), stdout);
3474 fputs (_(" -o <file> Place the output into <file>.\n"), stdout);
3475 fputs (_(" -pie Create a position independent executable.\n"), stdout);
3476 fputs (_(" -shared Create a shared library.\n"), stdout);
3477 fputs (_("\
3478 -x <language> Specify the language of the following input files.\n\
3479 Permissible languages include: c c++ assembler none\n\
3480 'none' means revert to the default behavior of\n\
3481 guessing the language based on the file's extension.\n\
3482 "), stdout);
3484 printf (_("\
3485 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3486 passed on to the various sub-processes invoked by %s. In order to pass\n\
3487 other options on to these processes the -W<letter> options must be used.\n\
3488 "), progname);
3490 /* The rest of the options are displayed by invocations of the various
3491 sub-processes. */
3494 static void
3495 add_preprocessor_option (const char *option, int len)
3497 preprocessor_options.safe_push (save_string (option, len));
3500 static void
3501 add_assembler_option (const char *option, int len)
3503 assembler_options.safe_push (save_string (option, len));
3506 static void
3507 add_linker_option (const char *option, int len)
3509 linker_options.safe_push (save_string (option, len));
3512 /* Allocate space for an input file in infiles. */
3514 static void
3515 alloc_infile (void)
3517 if (n_infiles_alloc == 0)
3519 n_infiles_alloc = 16;
3520 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3522 else if (n_infiles_alloc == n_infiles)
3524 n_infiles_alloc *= 2;
3525 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3529 /* Store an input file with the given NAME and LANGUAGE in
3530 infiles. */
3532 static void
3533 add_infile (const char *name, const char *language)
3535 alloc_infile ();
3536 infiles[n_infiles].name = name;
3537 infiles[n_infiles++].language = language;
3540 /* Allocate space for a switch in switches. */
3542 static void
3543 alloc_switch (void)
3545 if (n_switches_alloc == 0)
3547 n_switches_alloc = 16;
3548 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3550 else if (n_switches_alloc == n_switches)
3552 n_switches_alloc *= 2;
3553 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3557 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3558 as validated if VALIDATED and KNOWN if it is an internal switch. */
3560 static void
3561 save_switch (const char *opt, size_t n_args, const char *const *args,
3562 bool validated, bool known)
3564 alloc_switch ();
3565 switches[n_switches].part1 = opt + 1;
3566 if (n_args == 0)
3567 switches[n_switches].args = 0;
3568 else
3570 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3571 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3572 switches[n_switches].args[n_args] = NULL;
3575 switches[n_switches].live_cond = 0;
3576 switches[n_switches].validated = validated;
3577 switches[n_switches].known = known;
3578 switches[n_switches].ordering = 0;
3579 n_switches++;
3582 /* Set the SOURCE_DATE_EPOCH environment variable to the current time if it is
3583 not set already. */
3585 static void
3586 set_source_date_epoch_envvar ()
3588 /* Array size is 21 = ceil(log_10(2^64)) + 1 to hold string representations
3589 of 64 bit integers. */
3590 char source_date_epoch[21];
3591 time_t tt;
3593 errno = 0;
3594 tt = time (NULL);
3595 if (tt < (time_t) 0 || errno != 0)
3596 tt = (time_t) 0;
3598 snprintf (source_date_epoch, 21, "%llu", (unsigned long long) tt);
3599 /* Using setenv instead of xputenv because we want the variable to remain
3600 after finalizing so that it's still set in the second run when using
3601 -fcompare-debug. */
3602 setenv ("SOURCE_DATE_EPOCH", source_date_epoch, 0);
3605 /* Handle an option DECODED that is unknown to the option-processing
3606 machinery. */
3608 static bool
3609 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3611 const char *opt = decoded->arg;
3612 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3613 && !(decoded->errors & CL_ERR_NEGATIVE))
3615 /* Leave unknown -Wno-* options for the compiler proper, to be
3616 diagnosed only if there are warnings. */
3617 save_switch (decoded->canonical_option[0],
3618 decoded->canonical_option_num_elements - 1,
3619 &decoded->canonical_option[1], false, true);
3620 return false;
3622 if (decoded->opt_index == OPT_SPECIAL_unknown)
3624 /* Give it a chance to define it a spec file. */
3625 save_switch (decoded->canonical_option[0],
3626 decoded->canonical_option_num_elements - 1,
3627 &decoded->canonical_option[1], false, false);
3628 return false;
3630 else
3631 return true;
3634 /* Handle an option DECODED that is not marked as CL_DRIVER.
3635 LANG_MASK will always be CL_DRIVER. */
3637 static void
3638 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3639 unsigned int lang_mask ATTRIBUTE_UNUSED)
3641 /* At this point, non-driver options are accepted (and expected to
3642 be passed down by specs) unless marked to be rejected by the
3643 driver. Options to be rejected by the driver but accepted by the
3644 compilers proper are treated just like completely unknown
3645 options. */
3646 const struct cl_option *option = &cl_options[decoded->opt_index];
3648 if (option->cl_reject_driver)
3649 error ("unrecognized command line option %qs",
3650 decoded->orig_option_with_args_text);
3651 else
3652 save_switch (decoded->canonical_option[0],
3653 decoded->canonical_option_num_elements - 1,
3654 &decoded->canonical_option[1], false, true);
3657 static const char *spec_lang = 0;
3658 static int last_language_n_infiles;
3660 /* Parse -foffload option argument. */
3662 static void
3663 handle_foffload_option (const char *arg)
3665 const char *c, *cur, *n, *next, *end;
3666 char *target;
3668 /* If option argument starts with '-' then no target is specified and we
3669 do not need to parse it. */
3670 if (arg[0] == '-')
3671 return;
3673 end = strchr (arg, '=');
3674 if (end == NULL)
3675 end = strchr (arg, '\0');
3676 cur = arg;
3678 while (cur < end)
3680 next = strchr (cur, ',');
3681 if (next == NULL)
3682 next = end;
3683 next = (next > end) ? end : next;
3685 target = XNEWVEC (char, next - cur + 1);
3686 memcpy (target, cur, next - cur);
3687 target[next - cur] = '\0';
3689 /* If 'disable' is passed to the option, stop parsing the option and clean
3690 the list of offload targets. */
3691 if (strcmp (target, "disable") == 0)
3693 free (offload_targets);
3694 offload_targets = xstrdup ("");
3695 break;
3698 /* Check that GCC is configured to support the offload target. */
3699 c = OFFLOAD_TARGETS;
3700 while (c)
3702 n = strchr (c, ',');
3703 if (n == NULL)
3704 n = strchr (c, '\0');
3706 if (next - cur == n - c && strncmp (target, c, n - c) == 0)
3707 break;
3709 c = *n ? n + 1 : NULL;
3712 if (!c)
3713 fatal_error (input_location,
3714 "GCC is not configured to support %s as offload target",
3715 target);
3717 if (!offload_targets)
3719 offload_targets = target;
3720 target = NULL;
3722 else
3724 /* Check that the target hasn't already presented in the list. */
3725 c = offload_targets;
3728 n = strchr (c, ':');
3729 if (n == NULL)
3730 n = strchr (c, '\0');
3732 if (next - cur == n - c && strncmp (c, target, n - c) == 0)
3733 break;
3735 c = n + 1;
3737 while (*n);
3739 /* If duplicate is not found, append the target to the list. */
3740 if (c > n)
3742 size_t offload_targets_len = strlen (offload_targets);
3743 offload_targets
3744 = XRESIZEVEC (char, offload_targets,
3745 offload_targets_len + 1 + next - cur + 1);
3746 offload_targets[offload_targets_len++] = ':';
3747 memcpy (offload_targets + offload_targets_len, target, next - cur + 1);
3751 cur = next + 1;
3752 XDELETEVEC (target);
3756 /* Handle a driver option; arguments and return value as for
3757 handle_option. */
3759 static bool
3760 driver_handle_option (struct gcc_options *opts,
3761 struct gcc_options *opts_set,
3762 const struct cl_decoded_option *decoded,
3763 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3764 location_t loc,
3765 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3766 diagnostic_context *dc)
3768 size_t opt_index = decoded->opt_index;
3769 const char *arg = decoded->arg;
3770 const char *compare_debug_replacement_opt;
3771 int value = decoded->value;
3772 bool validated = false;
3773 bool do_save = true;
3775 gcc_assert (opts == &global_options);
3776 gcc_assert (opts_set == &global_options_set);
3777 gcc_assert (kind == DK_UNSPECIFIED);
3778 gcc_assert (loc == UNKNOWN_LOCATION);
3779 gcc_assert (dc == global_dc);
3781 switch (opt_index)
3783 case OPT_dumpspecs:
3785 struct spec_list *sl;
3786 init_spec ();
3787 for (sl = specs; sl; sl = sl->next)
3788 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3789 if (link_command_spec)
3790 printf ("*link_command:\n%s\n\n", link_command_spec);
3791 exit (0);
3794 case OPT_dumpversion:
3795 printf ("%s\n", spec_version);
3796 exit (0);
3798 case OPT_dumpmachine:
3799 printf ("%s\n", spec_machine);
3800 exit (0);
3802 case OPT_dumpfullversion:
3803 printf ("%s\n", BASEVER);
3804 exit (0);
3806 case OPT__version:
3807 print_version = 1;
3809 /* CPP driver cannot obtain switch from cc1_options. */
3810 if (is_cpp_driver)
3811 add_preprocessor_option ("--version", strlen ("--version"));
3812 add_assembler_option ("--version", strlen ("--version"));
3813 add_linker_option ("--version", strlen ("--version"));
3814 break;
3816 case OPT__help:
3817 print_help_list = 1;
3819 /* CPP driver cannot obtain switch from cc1_options. */
3820 if (is_cpp_driver)
3821 add_preprocessor_option ("--help", 6);
3822 add_assembler_option ("--help", 6);
3823 add_linker_option ("--help", 6);
3824 break;
3826 case OPT__help_:
3827 print_subprocess_help = 2;
3828 break;
3830 case OPT__target_help:
3831 print_subprocess_help = 1;
3833 /* CPP driver cannot obtain switch from cc1_options. */
3834 if (is_cpp_driver)
3835 add_preprocessor_option ("--target-help", 13);
3836 add_assembler_option ("--target-help", 13);
3837 add_linker_option ("--target-help", 13);
3838 break;
3840 case OPT__no_sysroot_suffix:
3841 case OPT_pass_exit_codes:
3842 case OPT_print_search_dirs:
3843 case OPT_print_file_name_:
3844 case OPT_print_prog_name_:
3845 case OPT_print_multi_lib:
3846 case OPT_print_multi_directory:
3847 case OPT_print_sysroot:
3848 case OPT_print_multi_os_directory:
3849 case OPT_print_multiarch:
3850 case OPT_print_sysroot_headers_suffix:
3851 case OPT_time:
3852 case OPT_wrapper:
3853 /* These options set the variables specified in common.opt
3854 automatically, and do not need to be saved for spec
3855 processing. */
3856 do_save = false;
3857 break;
3859 case OPT_print_libgcc_file_name:
3860 print_file_name = "libgcc.a";
3861 do_save = false;
3862 break;
3864 case OPT_fuse_ld_bfd:
3865 use_ld = ".bfd";
3866 break;
3868 case OPT_fuse_ld_gold:
3869 use_ld = ".gold";
3870 break;
3872 case OPT_fcompare_debug_second:
3873 compare_debug_second = 1;
3874 break;
3876 case OPT_fcompare_debug:
3877 switch (value)
3879 case 0:
3880 compare_debug_replacement_opt = "-fcompare-debug=";
3881 arg = "";
3882 goto compare_debug_with_arg;
3884 case 1:
3885 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3886 arg = "-gtoggle";
3887 goto compare_debug_with_arg;
3889 default:
3890 gcc_unreachable ();
3892 break;
3894 case OPT_fcompare_debug_:
3895 compare_debug_replacement_opt = decoded->canonical_option[0];
3896 compare_debug_with_arg:
3897 gcc_assert (decoded->canonical_option_num_elements == 1);
3898 gcc_assert (arg != NULL);
3899 if (*arg)
3900 compare_debug = 1;
3901 else
3902 compare_debug = -1;
3903 if (compare_debug < 0)
3904 compare_debug_opt = NULL;
3905 else
3906 compare_debug_opt = arg;
3907 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3908 set_source_date_epoch_envvar ();
3909 return true;
3911 case OPT_fdiagnostics_color_:
3912 diagnostic_color_init (dc, value);
3913 break;
3915 case OPT_Wa_:
3917 int prev, j;
3918 /* Pass the rest of this option to the assembler. */
3920 /* Split the argument at commas. */
3921 prev = 0;
3922 for (j = 0; arg[j]; j++)
3923 if (arg[j] == ',')
3925 add_assembler_option (arg + prev, j - prev);
3926 prev = j + 1;
3929 /* Record the part after the last comma. */
3930 add_assembler_option (arg + prev, j - prev);
3932 do_save = false;
3933 break;
3935 case OPT_Wp_:
3937 int prev, j;
3938 /* Pass the rest of this option to the preprocessor. */
3940 /* Split the argument at commas. */
3941 prev = 0;
3942 for (j = 0; arg[j]; j++)
3943 if (arg[j] == ',')
3945 add_preprocessor_option (arg + prev, j - prev);
3946 prev = j + 1;
3949 /* Record the part after the last comma. */
3950 add_preprocessor_option (arg + prev, j - prev);
3952 do_save = false;
3953 break;
3955 case OPT_Wl_:
3957 int prev, j;
3958 /* Split the argument at commas. */
3959 prev = 0;
3960 for (j = 0; arg[j]; j++)
3961 if (arg[j] == ',')
3963 add_infile (save_string (arg + prev, j - prev), "*");
3964 prev = j + 1;
3966 /* Record the part after the last comma. */
3967 add_infile (arg + prev, "*");
3969 do_save = false;
3970 break;
3972 case OPT_Xlinker:
3973 add_infile (arg, "*");
3974 do_save = false;
3975 break;
3977 case OPT_Xpreprocessor:
3978 add_preprocessor_option (arg, strlen (arg));
3979 do_save = false;
3980 break;
3982 case OPT_Xassembler:
3983 add_assembler_option (arg, strlen (arg));
3984 do_save = false;
3985 break;
3987 case OPT_l:
3988 /* POSIX allows separation of -l and the lib arg; canonicalize
3989 by concatenating -l with its arg */
3990 add_infile (concat ("-l", arg, NULL), "*");
3991 do_save = false;
3992 break;
3994 case OPT_L:
3995 /* Similarly, canonicalize -L for linkers that may not accept
3996 separate arguments. */
3997 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
3998 return true;
4000 case OPT_F:
4001 /* Likewise -F. */
4002 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
4003 return true;
4005 case OPT_save_temps:
4006 save_temps_flag = SAVE_TEMPS_CWD;
4007 validated = true;
4008 break;
4010 case OPT_save_temps_:
4011 if (strcmp (arg, "cwd") == 0)
4012 save_temps_flag = SAVE_TEMPS_CWD;
4013 else if (strcmp (arg, "obj") == 0
4014 || strcmp (arg, "object") == 0)
4015 save_temps_flag = SAVE_TEMPS_OBJ;
4016 else
4017 fatal_error (input_location, "%qs is an unknown -save-temps option",
4018 decoded->orig_option_with_args_text);
4019 break;
4021 case OPT_no_canonical_prefixes:
4022 /* Already handled as a special case, so ignored here. */
4023 do_save = false;
4024 break;
4026 case OPT_pipe:
4027 validated = true;
4028 /* These options set the variables specified in common.opt
4029 automatically, but do need to be saved for spec
4030 processing. */
4031 break;
4033 case OPT_specs_:
4035 struct user_specs *user = XNEW (struct user_specs);
4037 user->next = (struct user_specs *) 0;
4038 user->filename = arg;
4039 if (user_specs_tail)
4040 user_specs_tail->next = user;
4041 else
4042 user_specs_head = user;
4043 user_specs_tail = user;
4045 validated = true;
4046 break;
4048 case OPT__sysroot_:
4049 target_system_root = arg;
4050 target_system_root_changed = 1;
4051 do_save = false;
4052 break;
4054 case OPT_time_:
4055 if (report_times_to_file)
4056 fclose (report_times_to_file);
4057 report_times_to_file = fopen (arg, "a");
4058 do_save = false;
4059 break;
4061 case OPT____:
4062 /* "-###"
4063 This is similar to -v except that there is no execution
4064 of the commands and the echoed arguments are quoted. It
4065 is intended for use in shell scripts to capture the
4066 driver-generated command line. */
4067 verbose_only_flag++;
4068 verbose_flag = 1;
4069 do_save = false;
4070 break;
4072 case OPT_B:
4074 size_t len = strlen (arg);
4076 /* Catch the case where the user has forgotten to append a
4077 directory separator to the path. Note, they may be using
4078 -B to add an executable name prefix, eg "i386-elf-", in
4079 order to distinguish between multiple installations of
4080 GCC in the same directory. Hence we must check to see
4081 if appending a directory separator actually makes a
4082 valid directory name. */
4083 if (!IS_DIR_SEPARATOR (arg[len - 1])
4084 && is_directory (arg, false))
4086 char *tmp = XNEWVEC (char, len + 2);
4087 strcpy (tmp, arg);
4088 tmp[len] = DIR_SEPARATOR;
4089 tmp[++len] = 0;
4090 arg = tmp;
4093 add_prefix (&exec_prefixes, arg, NULL,
4094 PREFIX_PRIORITY_B_OPT, 0, 0);
4095 add_prefix (&startfile_prefixes, arg, NULL,
4096 PREFIX_PRIORITY_B_OPT, 0, 0);
4097 add_prefix (&include_prefixes, arg, NULL,
4098 PREFIX_PRIORITY_B_OPT, 0, 0);
4100 validated = true;
4101 break;
4103 case OPT_E:
4104 have_E = true;
4105 break;
4107 case OPT_x:
4108 spec_lang = arg;
4109 if (!strcmp (spec_lang, "none"))
4110 /* Suppress the warning if -xnone comes after the last input
4111 file, because alternate command interfaces like g++ might
4112 find it useful to place -xnone after each input file. */
4113 spec_lang = 0;
4114 else
4115 last_language_n_infiles = n_infiles;
4116 do_save = false;
4117 break;
4119 case OPT_o:
4120 have_o = 1;
4121 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
4122 arg = convert_filename (arg, ! have_c, 0);
4123 #endif
4124 output_file = arg;
4125 /* Save the output name in case -save-temps=obj was used. */
4126 save_temps_prefix = xstrdup (arg);
4127 /* On some systems, ld cannot handle "-o" without a space. So
4128 split the option from its argument. */
4129 save_switch ("-o", 1, &arg, validated, true);
4130 return true;
4132 #ifdef ENABLE_DEFAULT_PIE
4133 case OPT_pie:
4134 /* -pie is turned on by default. */
4135 #endif
4137 case OPT_static_libgcc:
4138 case OPT_shared_libgcc:
4139 case OPT_static_libgfortran:
4140 case OPT_static_libstdc__:
4141 /* These are always valid, since gcc.c itself understands the
4142 first two, gfortranspec.c understands -static-libgfortran and
4143 g++spec.c understands -static-libstdc++ */
4144 validated = true;
4145 break;
4147 case OPT_fwpa:
4148 flag_wpa = "";
4149 break;
4151 case OPT_foffload_:
4152 handle_foffload_option (arg);
4153 break;
4155 default:
4156 /* Various driver options need no special processing at this
4157 point, having been handled in a prescan above or being
4158 handled by specs. */
4159 break;
4162 if (do_save)
4163 save_switch (decoded->canonical_option[0],
4164 decoded->canonical_option_num_elements - 1,
4165 &decoded->canonical_option[1], validated, true);
4166 return true;
4169 /* Put the driver's standard set of option handlers in *HANDLERS. */
4171 static void
4172 set_option_handlers (struct cl_option_handlers *handlers)
4174 handlers->unknown_option_callback = driver_unknown_option_callback;
4175 handlers->wrong_lang_callback = driver_wrong_lang_callback;
4176 handlers->num_handlers = 3;
4177 handlers->handlers[0].handler = driver_handle_option;
4178 handlers->handlers[0].mask = CL_DRIVER;
4179 handlers->handlers[1].handler = common_handle_option;
4180 handlers->handlers[1].mask = CL_COMMON;
4181 handlers->handlers[2].handler = target_handle_option;
4182 handlers->handlers[2].mask = CL_TARGET;
4185 /* Create the vector `switches' and its contents.
4186 Store its length in `n_switches'. */
4188 static void
4189 process_command (unsigned int decoded_options_count,
4190 struct cl_decoded_option *decoded_options)
4192 const char *temp;
4193 char *temp1;
4194 char *tooldir_prefix, *tooldir_prefix2;
4195 char *(*get_relative_prefix) (const char *, const char *,
4196 const char *) = NULL;
4197 struct cl_option_handlers handlers;
4198 unsigned int j;
4200 gcc_exec_prefix = env.get ("GCC_EXEC_PREFIX");
4202 n_switches = 0;
4203 n_infiles = 0;
4204 added_libraries = 0;
4206 /* Figure compiler version from version string. */
4208 compiler_version = temp1 = xstrdup (version_string);
4210 for (; *temp1; ++temp1)
4212 if (*temp1 == ' ')
4214 *temp1 = '\0';
4215 break;
4219 /* Handle any -no-canonical-prefixes flag early, to assign the function
4220 that builds relative prefixes. This function creates default search
4221 paths that are needed later in normal option handling. */
4223 for (j = 1; j < decoded_options_count; j++)
4225 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
4227 get_relative_prefix = make_relative_prefix_ignore_links;
4228 break;
4231 if (! get_relative_prefix)
4232 get_relative_prefix = make_relative_prefix;
4234 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
4235 see if we can create it from the pathname specified in
4236 decoded_options[0].arg. */
4238 gcc_libexec_prefix = standard_libexec_prefix;
4239 #ifndef VMS
4240 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
4241 if (!gcc_exec_prefix)
4243 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
4244 standard_bindir_prefix,
4245 standard_exec_prefix);
4246 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
4247 standard_bindir_prefix,
4248 standard_libexec_prefix);
4249 if (gcc_exec_prefix)
4250 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
4252 else
4254 /* make_relative_prefix requires a program name, but
4255 GCC_EXEC_PREFIX is typically a directory name with a trailing
4256 / (which is ignored by make_relative_prefix), so append a
4257 program name. */
4258 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
4259 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
4260 standard_exec_prefix,
4261 standard_libexec_prefix);
4263 /* The path is unrelocated, so fallback to the original setting. */
4264 if (!gcc_libexec_prefix)
4265 gcc_libexec_prefix = standard_libexec_prefix;
4267 free (tmp_prefix);
4269 #else
4270 #endif
4271 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
4272 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
4273 or an automatically created GCC_EXEC_PREFIX from
4274 decoded_options[0].arg. */
4276 /* Do language-specific adjustment/addition of flags. */
4277 lang_specific_driver (&decoded_options, &decoded_options_count,
4278 &added_libraries);
4280 if (gcc_exec_prefix)
4282 int len = strlen (gcc_exec_prefix);
4284 if (len > (int) sizeof ("/lib/gcc/") - 1
4285 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
4287 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
4288 if (IS_DIR_SEPARATOR (*temp)
4289 && filename_ncmp (temp + 1, "lib", 3) == 0
4290 && IS_DIR_SEPARATOR (temp[4])
4291 && filename_ncmp (temp + 5, "gcc", 3) == 0)
4292 len -= sizeof ("/lib/gcc/") - 1;
4295 set_std_prefix (gcc_exec_prefix, len);
4296 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
4297 PREFIX_PRIORITY_LAST, 0, 0);
4298 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
4299 PREFIX_PRIORITY_LAST, 0, 0);
4302 /* COMPILER_PATH and LIBRARY_PATH have values
4303 that are lists of directory names with colons. */
4305 temp = env.get ("COMPILER_PATH");
4306 if (temp)
4308 const char *startp, *endp;
4309 char *nstore = (char *) alloca (strlen (temp) + 3);
4311 startp = endp = temp;
4312 while (1)
4314 if (*endp == PATH_SEPARATOR || *endp == 0)
4316 strncpy (nstore, startp, endp - startp);
4317 if (endp == startp)
4318 strcpy (nstore, concat (".", dir_separator_str, NULL));
4319 else if (!IS_DIR_SEPARATOR (endp[-1]))
4321 nstore[endp - startp] = DIR_SEPARATOR;
4322 nstore[endp - startp + 1] = 0;
4324 else
4325 nstore[endp - startp] = 0;
4326 add_prefix (&exec_prefixes, nstore, 0,
4327 PREFIX_PRIORITY_LAST, 0, 0);
4328 add_prefix (&include_prefixes, nstore, 0,
4329 PREFIX_PRIORITY_LAST, 0, 0);
4330 if (*endp == 0)
4331 break;
4332 endp = startp = endp + 1;
4334 else
4335 endp++;
4339 temp = env.get (LIBRARY_PATH_ENV);
4340 if (temp && *cross_compile == '0')
4342 const char *startp, *endp;
4343 char *nstore = (char *) alloca (strlen (temp) + 3);
4345 startp = endp = temp;
4346 while (1)
4348 if (*endp == PATH_SEPARATOR || *endp == 0)
4350 strncpy (nstore, startp, endp - startp);
4351 if (endp == startp)
4352 strcpy (nstore, concat (".", dir_separator_str, NULL));
4353 else if (!IS_DIR_SEPARATOR (endp[-1]))
4355 nstore[endp - startp] = DIR_SEPARATOR;
4356 nstore[endp - startp + 1] = 0;
4358 else
4359 nstore[endp - startp] = 0;
4360 add_prefix (&startfile_prefixes, nstore, NULL,
4361 PREFIX_PRIORITY_LAST, 0, 1);
4362 if (*endp == 0)
4363 break;
4364 endp = startp = endp + 1;
4366 else
4367 endp++;
4371 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
4372 temp = env.get ("LPATH");
4373 if (temp && *cross_compile == '0')
4375 const char *startp, *endp;
4376 char *nstore = (char *) alloca (strlen (temp) + 3);
4378 startp = endp = temp;
4379 while (1)
4381 if (*endp == PATH_SEPARATOR || *endp == 0)
4383 strncpy (nstore, startp, endp - startp);
4384 if (endp == startp)
4385 strcpy (nstore, concat (".", dir_separator_str, NULL));
4386 else if (!IS_DIR_SEPARATOR (endp[-1]))
4388 nstore[endp - startp] = DIR_SEPARATOR;
4389 nstore[endp - startp + 1] = 0;
4391 else
4392 nstore[endp - startp] = 0;
4393 add_prefix (&startfile_prefixes, nstore, NULL,
4394 PREFIX_PRIORITY_LAST, 0, 1);
4395 if (*endp == 0)
4396 break;
4397 endp = startp = endp + 1;
4399 else
4400 endp++;
4404 /* Process the options and store input files and switches in their
4405 vectors. */
4407 last_language_n_infiles = -1;
4409 set_option_handlers (&handlers);
4411 for (j = 1; j < decoded_options_count; j++)
4413 switch (decoded_options[j].opt_index)
4415 case OPT_S:
4416 case OPT_c:
4417 case OPT_E:
4418 have_c = 1;
4419 break;
4421 if (have_c)
4422 break;
4425 for (j = 1; j < decoded_options_count; j++)
4427 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
4429 const char *arg = decoded_options[j].arg;
4430 const char *p = strrchr (arg, '@');
4431 char *fname;
4432 long offset;
4433 int consumed;
4434 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4435 arg = convert_filename (arg, 0, access (arg, F_OK));
4436 #endif
4437 /* For LTO static archive support we handle input file
4438 specifications that are composed of a filename and
4439 an offset like FNAME@OFFSET. */
4440 if (p
4441 && p != arg
4442 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
4443 && strlen (p) == (unsigned int)consumed)
4445 fname = (char *)xmalloc (p - arg + 1);
4446 memcpy (fname, arg, p - arg);
4447 fname[p - arg] = '\0';
4448 /* Only accept non-stdin and existing FNAME parts, otherwise
4449 try with the full name. */
4450 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
4452 free (fname);
4453 fname = xstrdup (arg);
4456 else
4457 fname = xstrdup (arg);
4459 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
4461 if (fname[0] == '@' && access (fname + 1, F_OK) < 0)
4462 perror_with_name (fname + 1);
4463 else
4464 perror_with_name (fname);
4466 else
4467 add_infile (arg, spec_lang);
4469 free (fname);
4470 continue;
4473 read_cmdline_option (&global_options, &global_options_set,
4474 decoded_options + j, UNKNOWN_LOCATION,
4475 CL_DRIVER, &handlers, global_dc);
4478 /* If the user didn't specify any, default to all configured offload
4479 targets. */
4480 if (ENABLE_OFFLOADING && offload_targets == NULL)
4481 handle_foffload_option (OFFLOAD_TARGETS);
4483 if (output_file
4484 && strcmp (output_file, "-") != 0
4485 && strcmp (output_file, HOST_BIT_BUCKET) != 0)
4487 int i;
4488 for (i = 0; i < n_infiles; i++)
4489 if ((!infiles[i].language || infiles[i].language[0] != '*')
4490 && canonical_filename_eq (infiles[i].name, output_file))
4491 fatal_error (input_location,
4492 "input file %qs is the same as output file",
4493 output_file);
4496 if (output_file != NULL && output_file[0] == '\0')
4497 fatal_error (input_location, "output filename may not be empty");
4499 /* If -save-temps=obj and -o name, create the prefix to use for %b.
4500 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
4501 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
4503 save_temps_length = strlen (save_temps_prefix);
4504 temp = strrchr (lbasename (save_temps_prefix), '.');
4505 if (temp)
4507 save_temps_length -= strlen (temp);
4508 save_temps_prefix[save_temps_length] = '\0';
4512 else if (save_temps_prefix != NULL)
4514 free (save_temps_prefix);
4515 save_temps_prefix = NULL;
4518 if (save_temps_flag && use_pipes)
4520 /* -save-temps overrides -pipe, so that temp files are produced */
4521 if (save_temps_flag)
4522 warning (0, "-pipe ignored because -save-temps specified");
4523 use_pipes = 0;
4526 if (!compare_debug)
4528 const char *gcd = env.get ("GCC_COMPARE_DEBUG");
4530 if (gcd && gcd[0] == '-')
4532 compare_debug = 2;
4533 compare_debug_opt = gcd;
4535 else if (gcd && *gcd && strcmp (gcd, "0"))
4537 compare_debug = 3;
4538 compare_debug_opt = "-gtoggle";
4541 else if (compare_debug < 0)
4543 compare_debug = 0;
4544 gcc_assert (!compare_debug_opt);
4547 /* Set up the search paths. We add directories that we expect to
4548 contain GNU Toolchain components before directories specified by
4549 the machine description so that we will find GNU components (like
4550 the GNU assembler) before those of the host system. */
4552 /* If we don't know where the toolchain has been installed, use the
4553 configured-in locations. */
4554 if (!gcc_exec_prefix)
4556 #ifndef OS2
4557 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
4558 PREFIX_PRIORITY_LAST, 1, 0);
4559 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
4560 PREFIX_PRIORITY_LAST, 2, 0);
4561 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
4562 PREFIX_PRIORITY_LAST, 2, 0);
4563 #endif
4564 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
4565 PREFIX_PRIORITY_LAST, 1, 0);
4568 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
4569 tooldir_prefix2 = concat (tooldir_base_prefix, spec_machine,
4570 dir_separator_str, NULL);
4572 /* Look for tools relative to the location from which the driver is
4573 running, or, if that is not available, the configured prefix. */
4574 tooldir_prefix
4575 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4576 spec_host_machine, dir_separator_str, spec_version,
4577 accel_dir_suffix, dir_separator_str, tooldir_prefix2, NULL);
4578 free (tooldir_prefix2);
4580 add_prefix (&exec_prefixes,
4581 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4582 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4583 add_prefix (&startfile_prefixes,
4584 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4585 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4586 free (tooldir_prefix);
4588 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4589 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4590 then consider it to relocate with the rest of the GCC installation
4591 if GCC_EXEC_PREFIX is set.
4592 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4593 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
4595 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
4596 standard_bindir_prefix,
4597 target_system_root);
4598 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4600 target_system_root = tmp_prefix;
4601 target_system_root_changed = 1;
4604 #endif
4606 /* More prefixes are enabled in main, after we read the specs file
4607 and determine whether this is cross-compilation or not. */
4609 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4610 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
4612 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
4613 environment variable. */
4614 if (compare_debug == 2 || compare_debug == 3)
4616 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
4617 save_switch (opt, 0, NULL, false, true);
4618 compare_debug = 1;
4621 /* Ensure we only invoke each subprocess once. */
4622 if (print_subprocess_help || print_help_list || print_version)
4624 n_infiles = 0;
4626 /* Create a dummy input file, so that we can pass
4627 the help option on to the various sub-processes. */
4628 add_infile ("help-dummy", "c");
4631 /* Decide if undefined variable references are allowed in specs. */
4633 /* -v alone is safe. --version and --help alone or together are safe. Note
4634 that -v would make them unsafe, as they'd then be run for subprocesses as
4635 well, the location of which might depend on variables possibly coming
4636 from self-specs. Note also that the command name is counted in
4637 decoded_options_count. */
4639 unsigned help_version_count = 0;
4641 if (print_version)
4642 help_version_count++;
4644 if (print_help_list)
4645 help_version_count++;
4647 spec_undefvar_allowed =
4648 ((verbose_flag && decoded_options_count == 2)
4649 || help_version_count == decoded_options_count - 1);
4651 alloc_switch ();
4652 switches[n_switches].part1 = 0;
4653 alloc_infile ();
4654 infiles[n_infiles].name = 0;
4657 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4658 and place that in the environment. */
4660 static void
4661 set_collect_gcc_options (void)
4663 int i;
4664 int first_time;
4666 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4667 the compiler. */
4668 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4669 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4671 first_time = TRUE;
4672 for (i = 0; (int) i < n_switches; i++)
4674 const char *const *args;
4675 const char *p, *q;
4676 if (!first_time)
4677 obstack_grow (&collect_obstack, " ", 1);
4679 first_time = FALSE;
4681 /* Ignore elided switches. */
4682 if ((switches[i].live_cond
4683 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4684 == SWITCH_IGNORE)
4685 continue;
4687 obstack_grow (&collect_obstack, "'-", 2);
4688 q = switches[i].part1;
4689 while ((p = strchr (q, '\'')))
4691 obstack_grow (&collect_obstack, q, p - q);
4692 obstack_grow (&collect_obstack, "'\\''", 4);
4693 q = ++p;
4695 obstack_grow (&collect_obstack, q, strlen (q));
4696 obstack_grow (&collect_obstack, "'", 1);
4698 for (args = switches[i].args; args && *args; args++)
4700 obstack_grow (&collect_obstack, " '", 2);
4701 q = *args;
4702 while ((p = strchr (q, '\'')))
4704 obstack_grow (&collect_obstack, q, p - q);
4705 obstack_grow (&collect_obstack, "'\\''", 4);
4706 q = ++p;
4708 obstack_grow (&collect_obstack, q, strlen (q));
4709 obstack_grow (&collect_obstack, "'", 1);
4712 obstack_grow (&collect_obstack, "\0", 1);
4713 xputenv (XOBFINISH (&collect_obstack, char *));
4716 /* Process a spec string, accumulating and running commands. */
4718 /* These variables describe the input file name.
4719 input_file_number is the index on outfiles of this file,
4720 so that the output file name can be stored for later use by %o.
4721 input_basename is the start of the part of the input file
4722 sans all directory names, and basename_length is the number
4723 of characters starting there excluding the suffix .c or whatever. */
4725 static const char *gcc_input_filename;
4726 static int input_file_number;
4727 size_t input_filename_length;
4728 static int basename_length;
4729 static int suffixed_basename_length;
4730 static const char *input_basename;
4731 static const char *input_suffix;
4732 #ifndef HOST_LACKS_INODE_NUMBERS
4733 static struct stat input_stat;
4734 #endif
4735 static int input_stat_set;
4737 /* The compiler used to process the current input file. */
4738 static struct compiler *input_file_compiler;
4740 /* These are variables used within do_spec and do_spec_1. */
4742 /* Nonzero if an arg has been started and not yet terminated
4743 (with space, tab or newline). */
4744 static int arg_going;
4746 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4747 is a temporary file name. */
4748 static int delete_this_arg;
4750 /* Nonzero means %w has been seen; the next arg to be terminated
4751 is the output file name of this compilation. */
4752 static int this_is_output_file;
4754 /* Nonzero means %s has been seen; the next arg to be terminated
4755 is the name of a library file and we should try the standard
4756 search dirs for it. */
4757 static int this_is_library_file;
4759 /* Nonzero means %T has been seen; the next arg to be terminated
4760 is the name of a linker script and we should try all of the
4761 standard search dirs for it. If it is found insert a --script
4762 command line switch and then substitute the full path in place,
4763 otherwise generate an error message. */
4764 static int this_is_linker_script;
4766 /* Nonzero means that the input of this command is coming from a pipe. */
4767 static int input_from_pipe;
4769 /* Nonnull means substitute this for any suffix when outputting a switches
4770 arguments. */
4771 static const char *suffix_subst;
4773 /* If there is an argument being accumulated, terminate it and store it. */
4775 static void
4776 end_going_arg (void)
4778 if (arg_going)
4780 const char *string;
4782 obstack_1grow (&obstack, 0);
4783 string = XOBFINISH (&obstack, const char *);
4784 if (this_is_library_file)
4785 string = find_file (string);
4786 if (this_is_linker_script)
4788 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4790 if (full_script_path == NULL)
4792 error ("unable to locate default linker script %qs in the library search paths", string);
4793 /* Script was not found on search path. */
4794 return;
4796 store_arg ("--script", false, false);
4797 string = full_script_path;
4799 store_arg (string, delete_this_arg, this_is_output_file);
4800 if (this_is_output_file)
4801 outfiles[input_file_number] = string;
4802 arg_going = 0;
4807 /* Parse the WRAPPER string which is a comma separated list of the command line
4808 and insert them into the beginning of argbuf. */
4810 static void
4811 insert_wrapper (const char *wrapper)
4813 int n = 0;
4814 int i;
4815 char *buf = xstrdup (wrapper);
4816 char *p = buf;
4817 unsigned int old_length = argbuf.length ();
4821 n++;
4822 while (*p == ',')
4823 p++;
4825 while ((p = strchr (p, ',')) != NULL);
4827 argbuf.safe_grow (old_length + n);
4828 memmove (argbuf.address () + n,
4829 argbuf.address (),
4830 old_length * sizeof (const_char_p));
4832 i = 0;
4833 p = buf;
4836 while (*p == ',')
4838 *p = 0;
4839 p++;
4841 argbuf[i] = p;
4842 i++;
4844 while ((p = strchr (p, ',')) != NULL);
4845 gcc_assert (i == n);
4848 /* Process the spec SPEC and run the commands specified therein.
4849 Returns 0 if the spec is successfully processed; -1 if failed. */
4852 do_spec (const char *spec)
4854 int value;
4856 value = do_spec_2 (spec);
4858 /* Force out any unfinished command.
4859 If -pipe, this forces out the last command if it ended in `|'. */
4860 if (value == 0)
4862 if (argbuf.length () > 0
4863 && !strcmp (argbuf.last (), "|"))
4864 argbuf.pop ();
4866 set_collect_gcc_options ();
4868 if (argbuf.length () > 0)
4869 value = execute ();
4872 return value;
4875 static int
4876 do_spec_2 (const char *spec)
4878 int result;
4880 clear_args ();
4881 arg_going = 0;
4882 delete_this_arg = 0;
4883 this_is_output_file = 0;
4884 this_is_library_file = 0;
4885 this_is_linker_script = 0;
4886 input_from_pipe = 0;
4887 suffix_subst = NULL;
4889 result = do_spec_1 (spec, 0, NULL);
4891 end_going_arg ();
4893 return result;
4897 /* Process the given spec string and add any new options to the end
4898 of the switches/n_switches array. */
4900 static void
4901 do_option_spec (const char *name, const char *spec)
4903 unsigned int i, value_count, value_len;
4904 const char *p, *q, *value;
4905 char *tmp_spec, *tmp_spec_p;
4907 if (configure_default_options[0].name == NULL)
4908 return;
4910 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4911 if (strcmp (configure_default_options[i].name, name) == 0)
4912 break;
4913 if (i == ARRAY_SIZE (configure_default_options))
4914 return;
4916 value = configure_default_options[i].value;
4917 value_len = strlen (value);
4919 /* Compute the size of the final spec. */
4920 value_count = 0;
4921 p = spec;
4922 while ((p = strstr (p, "%(VALUE)")) != NULL)
4924 p ++;
4925 value_count ++;
4928 /* Replace each %(VALUE) by the specified value. */
4929 tmp_spec = (char *) alloca (strlen (spec) + 1
4930 + value_count * (value_len - strlen ("%(VALUE)")));
4931 tmp_spec_p = tmp_spec;
4932 q = spec;
4933 while ((p = strstr (q, "%(VALUE)")) != NULL)
4935 memcpy (tmp_spec_p, q, p - q);
4936 tmp_spec_p = tmp_spec_p + (p - q);
4937 memcpy (tmp_spec_p, value, value_len);
4938 tmp_spec_p += value_len;
4939 q = p + strlen ("%(VALUE)");
4941 strcpy (tmp_spec_p, q);
4943 do_self_spec (tmp_spec);
4946 /* Process the given spec string and add any new options to the end
4947 of the switches/n_switches array. */
4949 static void
4950 do_self_spec (const char *spec)
4952 int i;
4954 do_spec_2 (spec);
4955 do_spec_1 (" ", 0, NULL);
4957 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4958 do_self_specs adds the replacements to switches array, so it shouldn't
4959 be processed afterwards. */
4960 for (i = 0; i < n_switches; i++)
4961 if ((switches[i].live_cond & SWITCH_IGNORE))
4962 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4964 if (argbuf.length () > 0)
4966 const char **argbuf_copy;
4967 struct cl_decoded_option *decoded_options;
4968 struct cl_option_handlers handlers;
4969 unsigned int decoded_options_count;
4970 unsigned int j;
4972 /* Create a copy of argbuf with a dummy argv[0] entry for
4973 decode_cmdline_options_to_array. */
4974 argbuf_copy = XNEWVEC (const char *,
4975 argbuf.length () + 1);
4976 argbuf_copy[0] = "";
4977 memcpy (argbuf_copy + 1, argbuf.address (),
4978 argbuf.length () * sizeof (const char *));
4980 decode_cmdline_options_to_array (argbuf.length () + 1,
4981 argbuf_copy,
4982 CL_DRIVER, &decoded_options,
4983 &decoded_options_count);
4984 free (argbuf_copy);
4986 set_option_handlers (&handlers);
4988 for (j = 1; j < decoded_options_count; j++)
4990 switch (decoded_options[j].opt_index)
4992 case OPT_SPECIAL_input_file:
4993 /* Specs should only generate options, not input
4994 files. */
4995 if (strcmp (decoded_options[j].arg, "-") != 0)
4996 fatal_error (input_location,
4997 "switch %qs does not start with %<-%>",
4998 decoded_options[j].arg);
4999 else
5000 fatal_error (input_location,
5001 "spec-generated switch is just %<-%>");
5002 break;
5004 case OPT_fcompare_debug_second:
5005 case OPT_fcompare_debug:
5006 case OPT_fcompare_debug_:
5007 case OPT_o:
5008 /* Avoid duplicate processing of some options from
5009 compare-debug specs; just save them here. */
5010 save_switch (decoded_options[j].canonical_option[0],
5011 (decoded_options[j].canonical_option_num_elements
5012 - 1),
5013 &decoded_options[j].canonical_option[1], false, true);
5014 break;
5016 default:
5017 read_cmdline_option (&global_options, &global_options_set,
5018 decoded_options + j, UNKNOWN_LOCATION,
5019 CL_DRIVER, &handlers, global_dc);
5020 break;
5024 free (decoded_options);
5026 alloc_switch ();
5027 switches[n_switches].part1 = 0;
5031 /* Callback for processing %D and %I specs. */
5033 struct spec_path_info {
5034 const char *option;
5035 const char *append;
5036 size_t append_len;
5037 bool omit_relative;
5038 bool separate_options;
5041 static void *
5042 spec_path (char *path, void *data)
5044 struct spec_path_info *info = (struct spec_path_info *) data;
5045 size_t len = 0;
5046 char save = 0;
5048 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
5049 return NULL;
5051 if (info->append_len != 0)
5053 len = strlen (path);
5054 memcpy (path + len, info->append, info->append_len + 1);
5057 if (!is_directory (path, true))
5058 return NULL;
5060 do_spec_1 (info->option, 1, NULL);
5061 if (info->separate_options)
5062 do_spec_1 (" ", 0, NULL);
5064 if (info->append_len == 0)
5066 len = strlen (path);
5067 save = path[len - 1];
5068 if (IS_DIR_SEPARATOR (path[len - 1]))
5069 path[len - 1] = '\0';
5072 do_spec_1 (path, 1, NULL);
5073 do_spec_1 (" ", 0, NULL);
5075 /* Must not damage the original path. */
5076 if (info->append_len == 0)
5077 path[len - 1] = save;
5079 return NULL;
5082 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
5083 argument list. */
5085 static void
5086 create_at_file (char **argv)
5088 char *temp_file = make_temp_file ("");
5089 char *at_argument = concat ("@", temp_file, NULL);
5090 FILE *f = fopen (temp_file, "w");
5091 int status;
5093 if (f == NULL)
5094 fatal_error (input_location, "could not open temporary response file %s",
5095 temp_file);
5097 status = writeargv (argv, f);
5099 if (status)
5100 fatal_error (input_location,
5101 "could not write to temporary response file %s",
5102 temp_file);
5104 status = fclose (f);
5106 if (EOF == status)
5107 fatal_error (input_location, "could not close temporary response file %s",
5108 temp_file);
5110 store_arg (at_argument, 0, 0);
5112 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
5115 /* True if we should compile INFILE. */
5117 static bool
5118 compile_input_file_p (struct infile *infile)
5120 if ((!infile->language) || (infile->language[0] != '*'))
5121 if (infile->incompiler == input_file_compiler)
5122 return true;
5123 return false;
5126 /* Process each member of VEC as a spec. */
5128 static void
5129 do_specs_vec (vec<char_p> vec)
5131 unsigned ix;
5132 char *opt;
5134 FOR_EACH_VEC_ELT (vec, ix, opt)
5136 do_spec_1 (opt, 1, NULL);
5137 /* Make each accumulated option a separate argument. */
5138 do_spec_1 (" ", 0, NULL);
5142 /* Process the sub-spec SPEC as a portion of a larger spec.
5143 This is like processing a whole spec except that we do
5144 not initialize at the beginning and we do not supply a
5145 newline by default at the end.
5146 INSWITCH nonzero means don't process %-sequences in SPEC;
5147 in this case, % is treated as an ordinary character.
5148 This is used while substituting switches.
5149 INSWITCH nonzero also causes SPC not to terminate an argument.
5151 Value is zero unless a line was finished
5152 and the command on that line reported an error. */
5154 static int
5155 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
5157 const char *p = spec;
5158 int c;
5159 int i;
5160 int value;
5162 /* If it's an empty string argument to a switch, keep it as is. */
5163 if (inswitch && !*p)
5164 arg_going = 1;
5166 while ((c = *p++))
5167 /* If substituting a switch, treat all chars like letters.
5168 Otherwise, NL, SPC, TAB and % are special. */
5169 switch (inswitch ? 'a' : c)
5171 case '\n':
5172 end_going_arg ();
5174 if (argbuf.length () > 0
5175 && !strcmp (argbuf.last (), "|"))
5177 /* A `|' before the newline means use a pipe here,
5178 but only if -pipe was specified.
5179 Otherwise, execute now and don't pass the `|' as an arg. */
5180 if (use_pipes)
5182 input_from_pipe = 1;
5183 break;
5185 else
5186 argbuf.pop ();
5189 set_collect_gcc_options ();
5191 if (argbuf.length () > 0)
5193 value = execute ();
5194 if (value)
5195 return value;
5197 /* Reinitialize for a new command, and for a new argument. */
5198 clear_args ();
5199 arg_going = 0;
5200 delete_this_arg = 0;
5201 this_is_output_file = 0;
5202 this_is_library_file = 0;
5203 this_is_linker_script = 0;
5204 input_from_pipe = 0;
5205 break;
5207 case '|':
5208 end_going_arg ();
5210 /* Use pipe */
5211 obstack_1grow (&obstack, c);
5212 arg_going = 1;
5213 break;
5215 case '\t':
5216 case ' ':
5217 end_going_arg ();
5219 /* Reinitialize for a new argument. */
5220 delete_this_arg = 0;
5221 this_is_output_file = 0;
5222 this_is_library_file = 0;
5223 this_is_linker_script = 0;
5224 break;
5226 case '%':
5227 switch (c = *p++)
5229 case 0:
5230 fatal_error (input_location, "spec %qs invalid", spec);
5232 case 'b':
5233 if (save_temps_length)
5234 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
5235 else
5236 obstack_grow (&obstack, input_basename, basename_length);
5237 if (compare_debug < 0)
5238 obstack_grow (&obstack, ".gk", 3);
5239 arg_going = 1;
5240 break;
5242 case 'B':
5243 if (save_temps_length)
5244 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
5245 else
5246 obstack_grow (&obstack, input_basename, suffixed_basename_length);
5247 if (compare_debug < 0)
5248 obstack_grow (&obstack, ".gk", 3);
5249 arg_going = 1;
5250 break;
5252 case 'd':
5253 delete_this_arg = 2;
5254 break;
5256 /* Dump out the directories specified with LIBRARY_PATH,
5257 followed by the absolute directories
5258 that we search for startfiles. */
5259 case 'D':
5261 struct spec_path_info info;
5263 info.option = "-L";
5264 info.append_len = 0;
5265 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
5266 /* Used on systems which record the specified -L dirs
5267 and use them to search for dynamic linking.
5268 Relative directories always come from -B,
5269 and it is better not to use them for searching
5270 at run time. In particular, stage1 loses. */
5271 info.omit_relative = true;
5272 #else
5273 info.omit_relative = false;
5274 #endif
5275 info.separate_options = false;
5277 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
5279 break;
5281 case 'e':
5282 /* %efoo means report an error with `foo' as error message
5283 and don't execute any more commands for this file. */
5285 const char *q = p;
5286 char *buf;
5287 while (*p != 0 && *p != '\n')
5288 p++;
5289 buf = (char *) alloca (p - q + 1);
5290 strncpy (buf, q, p - q);
5291 buf[p - q] = 0;
5292 error ("%s", _(buf));
5293 return -1;
5295 break;
5296 case 'n':
5297 /* %nfoo means report a notice with `foo' on stderr. */
5299 const char *q = p;
5300 char *buf;
5301 while (*p != 0 && *p != '\n')
5302 p++;
5303 buf = (char *) alloca (p - q + 1);
5304 strncpy (buf, q, p - q);
5305 buf[p - q] = 0;
5306 inform (0, "%s", _(buf));
5307 if (*p)
5308 p++;
5310 break;
5312 case 'j':
5314 struct stat st;
5316 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
5317 defined, and it is not a directory, and it is
5318 writable, use it. Otherwise, treat this like any
5319 other temporary file. */
5321 if ((!save_temps_flag)
5322 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
5323 && (access (HOST_BIT_BUCKET, W_OK) == 0))
5325 obstack_grow (&obstack, HOST_BIT_BUCKET,
5326 strlen (HOST_BIT_BUCKET));
5327 delete_this_arg = 0;
5328 arg_going = 1;
5329 break;
5332 goto create_temp_file;
5333 case '|':
5334 if (use_pipes)
5336 obstack_1grow (&obstack, '-');
5337 delete_this_arg = 0;
5338 arg_going = 1;
5340 /* consume suffix */
5341 while (*p == '.' || ISALNUM ((unsigned char) *p))
5342 p++;
5343 if (p[0] == '%' && p[1] == 'O')
5344 p += 2;
5346 break;
5348 goto create_temp_file;
5349 case 'm':
5350 if (use_pipes)
5352 /* consume suffix */
5353 while (*p == '.' || ISALNUM ((unsigned char) *p))
5354 p++;
5355 if (p[0] == '%' && p[1] == 'O')
5356 p += 2;
5358 break;
5360 goto create_temp_file;
5361 case 'g':
5362 case 'u':
5363 case 'U':
5364 create_temp_file:
5366 struct temp_name *t;
5367 int suffix_length;
5368 const char *suffix = p;
5369 char *saved_suffix = NULL;
5371 while (*p == '.' || ISALNUM ((unsigned char) *p))
5372 p++;
5373 suffix_length = p - suffix;
5374 if (p[0] == '%' && p[1] == 'O')
5376 p += 2;
5377 /* We don't support extra suffix characters after %O. */
5378 if (*p == '.' || ISALNUM ((unsigned char) *p))
5379 fatal_error (input_location,
5380 "spec %qs has invalid %<%%0%c%>", spec, *p);
5381 if (suffix_length == 0)
5382 suffix = TARGET_OBJECT_SUFFIX;
5383 else
5385 saved_suffix
5386 = XNEWVEC (char, suffix_length
5387 + strlen (TARGET_OBJECT_SUFFIX) + 1);
5388 strncpy (saved_suffix, suffix, suffix_length);
5389 strcpy (saved_suffix + suffix_length,
5390 TARGET_OBJECT_SUFFIX);
5392 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
5395 if (compare_debug < 0)
5397 suffix = concat (".gk", suffix, NULL);
5398 suffix_length += 3;
5401 /* If -save-temps=obj and -o were specified, use that for the
5402 temp file. */
5403 if (save_temps_length)
5405 char *tmp;
5406 temp_filename_length
5407 = save_temps_length + suffix_length + 1;
5408 tmp = (char *) alloca (temp_filename_length);
5409 memcpy (tmp, save_temps_prefix, save_temps_length);
5410 memcpy (tmp + save_temps_length, suffix, suffix_length);
5411 tmp[save_temps_length + suffix_length] = '\0';
5412 temp_filename = save_string (tmp, save_temps_length
5413 + suffix_length);
5414 obstack_grow (&obstack, temp_filename,
5415 temp_filename_length);
5416 arg_going = 1;
5417 delete_this_arg = 0;
5418 break;
5421 /* If the gcc_input_filename has the same suffix specified
5422 for the %g, %u, or %U, and -save-temps is specified,
5423 we could end up using that file as an intermediate
5424 thus clobbering the user's source file (.e.g.,
5425 gcc -save-temps foo.s would clobber foo.s with the
5426 output of cpp0). So check for this condition and
5427 generate a temp file as the intermediate. */
5429 if (save_temps_flag)
5431 char *tmp;
5432 temp_filename_length = basename_length + suffix_length + 1;
5433 tmp = (char *) alloca (temp_filename_length);
5434 memcpy (tmp, input_basename, basename_length);
5435 memcpy (tmp + basename_length, suffix, suffix_length);
5436 tmp[basename_length + suffix_length] = '\0';
5437 temp_filename = tmp;
5439 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
5441 #ifndef HOST_LACKS_INODE_NUMBERS
5442 struct stat st_temp;
5444 /* Note, set_input() resets input_stat_set to 0. */
5445 if (input_stat_set == 0)
5447 input_stat_set = stat (gcc_input_filename,
5448 &input_stat);
5449 if (input_stat_set >= 0)
5450 input_stat_set = 1;
5453 /* If we have the stat for the gcc_input_filename
5454 and we can do the stat for the temp_filename
5455 then the they could still refer to the same
5456 file if st_dev/st_ino's are the same. */
5457 if (input_stat_set != 1
5458 || stat (temp_filename, &st_temp) < 0
5459 || input_stat.st_dev != st_temp.st_dev
5460 || input_stat.st_ino != st_temp.st_ino)
5461 #else
5462 /* Just compare canonical pathnames. */
5463 char* input_realname = lrealpath (gcc_input_filename);
5464 char* temp_realname = lrealpath (temp_filename);
5465 bool files_differ = filename_cmp (input_realname, temp_realname);
5466 free (input_realname);
5467 free (temp_realname);
5468 if (files_differ)
5469 #endif
5471 temp_filename
5472 = save_string (temp_filename,
5473 temp_filename_length - 1);
5474 obstack_grow (&obstack, temp_filename,
5475 temp_filename_length);
5476 arg_going = 1;
5477 delete_this_arg = 0;
5478 break;
5483 /* See if we already have an association of %g/%u/%U and
5484 suffix. */
5485 for (t = temp_names; t; t = t->next)
5486 if (t->length == suffix_length
5487 && strncmp (t->suffix, suffix, suffix_length) == 0
5488 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
5489 break;
5491 /* Make a new association if needed. %u and %j
5492 require one. */
5493 if (t == 0 || c == 'u' || c == 'j')
5495 if (t == 0)
5497 t = XNEW (struct temp_name);
5498 t->next = temp_names;
5499 temp_names = t;
5501 t->length = suffix_length;
5502 if (saved_suffix)
5504 t->suffix = saved_suffix;
5505 saved_suffix = NULL;
5507 else
5508 t->suffix = save_string (suffix, suffix_length);
5509 t->unique = (c == 'u' || c == 'U' || c == 'j');
5510 temp_filename = make_temp_file (t->suffix);
5511 temp_filename_length = strlen (temp_filename);
5512 t->filename = temp_filename;
5513 t->filename_length = temp_filename_length;
5516 free (saved_suffix);
5518 obstack_grow (&obstack, t->filename, t->filename_length);
5519 delete_this_arg = 1;
5521 arg_going = 1;
5522 break;
5524 case 'i':
5525 if (combine_inputs)
5527 if (at_file_supplied)
5529 /* We are going to expand `%i' to `@FILE', where FILE
5530 is a newly-created temporary filename. The filenames
5531 that would usually be expanded in place of %o will be
5532 written to the temporary file. */
5533 char **argv;
5534 int n_files = 0;
5535 int j;
5537 for (i = 0; i < n_infiles; i++)
5538 if (compile_input_file_p (&infiles[i]))
5539 n_files++;
5541 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5543 /* Copy the strings over. */
5544 for (i = 0, j = 0; i < n_infiles; i++)
5545 if (compile_input_file_p (&infiles[i]))
5547 argv[j] = CONST_CAST (char *, infiles[i].name);
5548 infiles[i].compiled = true;
5549 j++;
5551 argv[j] = NULL;
5553 create_at_file (argv);
5555 else
5556 for (i = 0; (int) i < n_infiles; i++)
5557 if (compile_input_file_p (&infiles[i]))
5559 store_arg (infiles[i].name, 0, 0);
5560 infiles[i].compiled = true;
5563 else
5565 obstack_grow (&obstack, gcc_input_filename,
5566 input_filename_length);
5567 arg_going = 1;
5569 break;
5571 case 'I':
5573 struct spec_path_info info;
5575 if (multilib_dir)
5577 do_spec_1 ("-imultilib", 1, NULL);
5578 /* Make this a separate argument. */
5579 do_spec_1 (" ", 0, NULL);
5580 do_spec_1 (multilib_dir, 1, NULL);
5581 do_spec_1 (" ", 0, NULL);
5584 if (multiarch_dir)
5586 do_spec_1 ("-imultiarch", 1, NULL);
5587 /* Make this a separate argument. */
5588 do_spec_1 (" ", 0, NULL);
5589 do_spec_1 (multiarch_dir, 1, NULL);
5590 do_spec_1 (" ", 0, NULL);
5593 if (gcc_exec_prefix)
5595 do_spec_1 ("-iprefix", 1, NULL);
5596 /* Make this a separate argument. */
5597 do_spec_1 (" ", 0, NULL);
5598 do_spec_1 (gcc_exec_prefix, 1, NULL);
5599 do_spec_1 (" ", 0, NULL);
5602 if (target_system_root_changed ||
5603 (target_system_root && target_sysroot_hdrs_suffix))
5605 do_spec_1 ("-isysroot", 1, NULL);
5606 /* Make this a separate argument. */
5607 do_spec_1 (" ", 0, NULL);
5608 do_spec_1 (target_system_root, 1, NULL);
5609 if (target_sysroot_hdrs_suffix)
5610 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
5611 do_spec_1 (" ", 0, NULL);
5614 info.option = "-isystem";
5615 info.append = "include";
5616 info.append_len = strlen (info.append);
5617 info.omit_relative = false;
5618 info.separate_options = true;
5620 for_each_path (&include_prefixes, false, info.append_len,
5621 spec_path, &info);
5623 info.append = "include-fixed";
5624 if (*sysroot_hdrs_suffix_spec)
5625 info.append = concat (info.append, dir_separator_str,
5626 multilib_dir, NULL);
5627 info.append_len = strlen (info.append);
5628 for_each_path (&include_prefixes, false, info.append_len,
5629 spec_path, &info);
5631 break;
5633 case 'o':
5635 int max = n_infiles;
5636 max += lang_specific_extra_outfiles;
5638 if (HAVE_GNU_LD && at_file_supplied)
5640 /* We are going to expand `%o' to `@FILE', where FILE
5641 is a newly-created temporary filename. The filenames
5642 that would usually be expanded in place of %o will be
5643 written to the temporary file. */
5645 char **argv;
5646 int n_files, j;
5648 /* Convert OUTFILES into a form suitable for writeargv. */
5650 /* Determine how many are non-NULL. */
5651 for (n_files = 0, i = 0; i < max; i++)
5652 n_files += outfiles[i] != NULL;
5654 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5656 /* Copy the strings over. */
5657 for (i = 0, j = 0; i < max; i++)
5658 if (outfiles[i])
5660 argv[j] = CONST_CAST (char *, outfiles[i]);
5661 j++;
5663 argv[j] = NULL;
5665 create_at_file (argv);
5667 else
5668 for (i = 0; i < max; i++)
5669 if (outfiles[i])
5670 store_arg (outfiles[i], 0, 0);
5671 break;
5674 case 'O':
5675 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5676 arg_going = 1;
5677 break;
5679 case 's':
5680 this_is_library_file = 1;
5681 break;
5683 case 'T':
5684 this_is_linker_script = 1;
5685 break;
5687 case 'V':
5688 outfiles[input_file_number] = NULL;
5689 break;
5691 case 'w':
5692 this_is_output_file = 1;
5693 break;
5695 case 'W':
5697 unsigned int cur_index = argbuf.length ();
5698 /* Handle the {...} following the %W. */
5699 if (*p != '{')
5700 fatal_error (input_location,
5701 "spec %qs has invalid %<%%W%c%>", spec, *p);
5702 p = handle_braces (p + 1);
5703 if (p == 0)
5704 return -1;
5705 end_going_arg ();
5706 /* If any args were output, mark the last one for deletion
5707 on failure. */
5708 if (argbuf.length () != cur_index)
5709 record_temp_file (argbuf.last (), 0, 1);
5710 break;
5713 /* %x{OPTION} records OPTION for %X to output. */
5714 case 'x':
5716 const char *p1 = p;
5717 char *string;
5718 char *opt;
5719 unsigned ix;
5721 /* Skip past the option value and make a copy. */
5722 if (*p != '{')
5723 fatal_error (input_location,
5724 "spec %qs has invalid %<%%x%c%>", spec, *p);
5725 while (*p++ != '}')
5727 string = save_string (p1 + 1, p - p1 - 2);
5729 /* See if we already recorded this option. */
5730 FOR_EACH_VEC_ELT (linker_options, ix, opt)
5731 if (! strcmp (string, opt))
5733 free (string);
5734 return 0;
5737 /* This option is new; add it. */
5738 add_linker_option (string, strlen (string));
5739 free (string);
5741 break;
5743 /* Dump out the options accumulated previously using %x. */
5744 case 'X':
5745 do_specs_vec (linker_options);
5746 break;
5748 /* Dump out the options accumulated previously using -Wa,. */
5749 case 'Y':
5750 do_specs_vec (assembler_options);
5751 break;
5753 /* Dump out the options accumulated previously using -Wp,. */
5754 case 'Z':
5755 do_specs_vec (preprocessor_options);
5756 break;
5758 /* Here are digits and numbers that just process
5759 a certain constant string as a spec. */
5761 case '1':
5762 value = do_spec_1 (cc1_spec, 0, NULL);
5763 if (value != 0)
5764 return value;
5765 break;
5767 case '2':
5768 value = do_spec_1 (cc1plus_spec, 0, NULL);
5769 if (value != 0)
5770 return value;
5771 break;
5773 case 'a':
5774 value = do_spec_1 (asm_spec, 0, NULL);
5775 if (value != 0)
5776 return value;
5777 break;
5779 case 'A':
5780 value = do_spec_1 (asm_final_spec, 0, NULL);
5781 if (value != 0)
5782 return value;
5783 break;
5785 case 'C':
5787 const char *const spec
5788 = (input_file_compiler->cpp_spec
5789 ? input_file_compiler->cpp_spec
5790 : cpp_spec);
5791 value = do_spec_1 (spec, 0, NULL);
5792 if (value != 0)
5793 return value;
5795 break;
5797 case 'E':
5798 value = do_spec_1 (endfile_spec, 0, NULL);
5799 if (value != 0)
5800 return value;
5801 break;
5803 case 'l':
5804 value = do_spec_1 (link_spec, 0, NULL);
5805 if (value != 0)
5806 return value;
5807 break;
5809 case 'L':
5810 value = do_spec_1 (lib_spec, 0, NULL);
5811 if (value != 0)
5812 return value;
5813 break;
5815 case 'M':
5816 if (multilib_os_dir == NULL)
5817 obstack_1grow (&obstack, '.');
5818 else
5819 obstack_grow (&obstack, multilib_os_dir,
5820 strlen (multilib_os_dir));
5821 break;
5823 case 'G':
5824 value = do_spec_1 (libgcc_spec, 0, NULL);
5825 if (value != 0)
5826 return value;
5827 break;
5829 case 'R':
5830 /* We assume there is a directory
5831 separator at the end of this string. */
5832 if (target_system_root)
5834 obstack_grow (&obstack, target_system_root,
5835 strlen (target_system_root));
5836 if (target_sysroot_suffix)
5837 obstack_grow (&obstack, target_sysroot_suffix,
5838 strlen (target_sysroot_suffix));
5840 break;
5842 case 'S':
5843 value = do_spec_1 (startfile_spec, 0, NULL);
5844 if (value != 0)
5845 return value;
5846 break;
5848 /* Here we define characters other than letters and digits. */
5850 case '{':
5851 p = handle_braces (p);
5852 if (p == 0)
5853 return -1;
5854 break;
5856 case ':':
5857 p = handle_spec_function (p, NULL);
5858 if (p == 0)
5859 return -1;
5860 break;
5862 case '%':
5863 obstack_1grow (&obstack, '%');
5864 break;
5866 case '.':
5868 unsigned len = 0;
5870 while (p[len] && p[len] != ' ' && p[len] != '%')
5871 len++;
5872 suffix_subst = save_string (p - 1, len + 1);
5873 p += len;
5875 break;
5877 /* Henceforth ignore the option(s) matching the pattern
5878 after the %<. */
5879 case '<':
5880 case '>':
5882 unsigned len = 0;
5883 int have_wildcard = 0;
5884 int i;
5885 int switch_option;
5887 if (c == '>')
5888 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5889 else
5890 switch_option = SWITCH_IGNORE;
5892 while (p[len] && p[len] != ' ' && p[len] != '\t')
5893 len++;
5895 if (p[len-1] == '*')
5896 have_wildcard = 1;
5898 for (i = 0; i < n_switches; i++)
5899 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5900 && (have_wildcard || switches[i].part1[len] == '\0'))
5902 switches[i].live_cond |= switch_option;
5903 /* User switch be validated from validate_all_switches.
5904 when the definition is seen from the spec file.
5905 If not defined anywhere, will be rejected. */
5906 if (switches[i].known)
5907 switches[i].validated = true;
5910 p += len;
5912 break;
5914 case '*':
5915 if (soft_matched_part)
5917 if (soft_matched_part[0])
5918 do_spec_1 (soft_matched_part, 1, NULL);
5919 /* Only insert a space after the substitution if it is at the
5920 end of the current sequence. So if:
5922 "%{foo=*:bar%*}%{foo=*:one%*two}"
5924 matches -foo=hello then it will produce:
5926 barhello onehellotwo
5928 if (*p == 0 || *p == '}')
5929 do_spec_1 (" ", 0, NULL);
5931 else
5932 /* Catch the case where a spec string contains something like
5933 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5934 hand side of the :. */
5935 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5936 break;
5938 /* Process a string found as the value of a spec given by name.
5939 This feature allows individual machine descriptions
5940 to add and use their own specs. */
5941 case '(':
5943 const char *name = p;
5944 struct spec_list *sl;
5945 int len;
5947 /* The string after the S/P is the name of a spec that is to be
5948 processed. */
5949 while (*p && *p != ')')
5950 p++;
5952 /* See if it's in the list. */
5953 for (len = p - name, sl = specs; sl; sl = sl->next)
5954 if (sl->name_len == len && !strncmp (sl->name, name, len))
5956 name = *(sl->ptr_spec);
5957 #ifdef DEBUG_SPECS
5958 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5959 sl->name, name);
5960 #endif
5961 break;
5964 if (sl)
5966 value = do_spec_1 (name, 0, NULL);
5967 if (value != 0)
5968 return value;
5971 /* Discard the closing paren. */
5972 if (*p)
5973 p++;
5975 break;
5977 default:
5978 error ("spec failure: unrecognized spec option %qc", c);
5979 break;
5981 break;
5983 case '\\':
5984 /* Backslash: treat next character as ordinary. */
5985 c = *p++;
5987 /* Fall through. */
5988 default:
5989 /* Ordinary character: put it into the current argument. */
5990 obstack_1grow (&obstack, c);
5991 arg_going = 1;
5994 /* End of string. If we are processing a spec function, we need to
5995 end any pending argument. */
5996 if (processing_spec_function)
5997 end_going_arg ();
5999 return 0;
6002 /* Look up a spec function. */
6004 static const struct spec_function *
6005 lookup_spec_function (const char *name)
6007 const struct spec_function *sf;
6009 for (sf = static_spec_functions; sf->name != NULL; sf++)
6010 if (strcmp (sf->name, name) == 0)
6011 return sf;
6013 return NULL;
6016 /* Evaluate a spec function. */
6018 static const char *
6019 eval_spec_function (const char *func, const char *args)
6021 const struct spec_function *sf;
6022 const char *funcval;
6024 /* Saved spec processing context. */
6025 vec<const_char_p> save_argbuf;
6027 int save_arg_going;
6028 int save_delete_this_arg;
6029 int save_this_is_output_file;
6030 int save_this_is_library_file;
6031 int save_input_from_pipe;
6032 int save_this_is_linker_script;
6033 const char *save_suffix_subst;
6035 int save_growing_size;
6036 void *save_growing_value = NULL;
6038 sf = lookup_spec_function (func);
6039 if (sf == NULL)
6040 fatal_error (input_location, "unknown spec function %qs", func);
6042 /* Push the spec processing context. */
6043 save_argbuf = argbuf;
6045 save_arg_going = arg_going;
6046 save_delete_this_arg = delete_this_arg;
6047 save_this_is_output_file = this_is_output_file;
6048 save_this_is_library_file = this_is_library_file;
6049 save_this_is_linker_script = this_is_linker_script;
6050 save_input_from_pipe = input_from_pipe;
6051 save_suffix_subst = suffix_subst;
6053 /* If we have some object growing now, finalize it so the args and function
6054 eval proceed from a cleared context. This is needed to prevent the first
6055 constructed arg from mistakenly including the growing value. We'll push
6056 this value back on the obstack once the function evaluation is done, to
6057 restore a consistent processing context for our caller. This is fine as
6058 the address of growing objects isn't guaranteed to remain stable until
6059 they are finalized, and we expect this situation to be rare enough for
6060 the extra copy not to be an issue. */
6061 save_growing_size = obstack_object_size (&obstack);
6062 if (save_growing_size > 0)
6063 save_growing_value = obstack_finish (&obstack);
6065 /* Create a new spec processing context, and build the function
6066 arguments. */
6068 alloc_args ();
6069 if (do_spec_2 (args) < 0)
6070 fatal_error (input_location, "error in args to spec function %qs", func);
6072 /* argbuf_index is an index for the next argument to be inserted, and
6073 so contains the count of the args already inserted. */
6075 funcval = (*sf->func) (argbuf.length (),
6076 argbuf.address ());
6078 /* Pop the spec processing context. */
6079 argbuf.release ();
6080 argbuf = save_argbuf;
6082 arg_going = save_arg_going;
6083 delete_this_arg = save_delete_this_arg;
6084 this_is_output_file = save_this_is_output_file;
6085 this_is_library_file = save_this_is_library_file;
6086 this_is_linker_script = save_this_is_linker_script;
6087 input_from_pipe = save_input_from_pipe;
6088 suffix_subst = save_suffix_subst;
6090 if (save_growing_size > 0)
6091 obstack_grow (&obstack, save_growing_value, save_growing_size);
6093 return funcval;
6096 /* Handle a spec function call of the form:
6098 %:function(args)
6100 ARGS is processed as a spec in a separate context and split into an
6101 argument vector in the normal fashion. The function returns a string
6102 containing a spec which we then process in the caller's context, or
6103 NULL if no processing is required.
6105 If RETVAL_NONNULL is not NULL, then store a bool whether function
6106 returned non-NULL. */
6108 static const char *
6109 handle_spec_function (const char *p, bool *retval_nonnull)
6111 char *func, *args;
6112 const char *endp, *funcval;
6113 int count;
6115 processing_spec_function++;
6117 /* Get the function name. */
6118 for (endp = p; *endp != '\0'; endp++)
6120 if (*endp == '(') /* ) */
6121 break;
6122 /* Only allow [A-Za-z0-9], -, and _ in function names. */
6123 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
6124 fatal_error (input_location, "malformed spec function name");
6126 if (*endp != '(') /* ) */
6127 fatal_error (input_location, "no arguments for spec function");
6128 func = save_string (p, endp - p);
6129 p = ++endp;
6131 /* Get the arguments. */
6132 for (count = 0; *endp != '\0'; endp++)
6134 /* ( */
6135 if (*endp == ')')
6137 if (count == 0)
6138 break;
6139 count--;
6141 else if (*endp == '(') /* ) */
6142 count++;
6144 /* ( */
6145 if (*endp != ')')
6146 fatal_error (input_location, "malformed spec function arguments");
6147 args = save_string (p, endp - p);
6148 p = ++endp;
6150 /* p now points to just past the end of the spec function expression. */
6152 funcval = eval_spec_function (func, args);
6153 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
6154 p = NULL;
6155 if (retval_nonnull)
6156 *retval_nonnull = funcval != NULL;
6158 free (func);
6159 free (args);
6161 processing_spec_function--;
6163 return p;
6166 /* Inline subroutine of handle_braces. Returns true if the current
6167 input suffix matches the atom bracketed by ATOM and END_ATOM. */
6168 static inline bool
6169 input_suffix_matches (const char *atom, const char *end_atom)
6171 return (input_suffix
6172 && !strncmp (input_suffix, atom, end_atom - atom)
6173 && input_suffix[end_atom - atom] == '\0');
6176 /* Subroutine of handle_braces. Returns true if the current
6177 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
6178 static bool
6179 input_spec_matches (const char *atom, const char *end_atom)
6181 return (input_file_compiler
6182 && input_file_compiler->suffix
6183 && input_file_compiler->suffix[0] != '\0'
6184 && !strncmp (input_file_compiler->suffix + 1, atom,
6185 end_atom - atom)
6186 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
6189 /* Subroutine of handle_braces. Returns true if a switch
6190 matching the atom bracketed by ATOM and END_ATOM appeared on the
6191 command line. */
6192 static bool
6193 switch_matches (const char *atom, const char *end_atom, int starred)
6195 int i;
6196 int len = end_atom - atom;
6197 int plen = starred ? len : -1;
6199 for (i = 0; i < n_switches; i++)
6200 if (!strncmp (switches[i].part1, atom, len)
6201 && (starred || switches[i].part1[len] == '\0')
6202 && check_live_switch (i, plen))
6203 return true;
6205 /* Check if a switch with separated form matching the atom.
6206 We check -D and -U switches. */
6207 else if (switches[i].args != 0)
6209 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
6210 && *switches[i].part1 == atom[0])
6212 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
6213 && (starred || (switches[i].part1[1] == '\0'
6214 && switches[i].args[0][len - 1] == '\0'))
6215 && check_live_switch (i, (starred ? 1 : -1)))
6216 return true;
6220 return false;
6223 /* Inline subroutine of handle_braces. Mark all of the switches which
6224 match ATOM (extends to END_ATOM; STARRED indicates whether there
6225 was a star after the atom) for later processing. */
6226 static inline void
6227 mark_matching_switches (const char *atom, const char *end_atom, int starred)
6229 int i;
6230 int len = end_atom - atom;
6231 int plen = starred ? len : -1;
6233 for (i = 0; i < n_switches; i++)
6234 if (!strncmp (switches[i].part1, atom, len)
6235 && (starred || switches[i].part1[len] == '\0')
6236 && check_live_switch (i, plen))
6237 switches[i].ordering = 1;
6240 /* Inline subroutine of handle_braces. Process all the currently
6241 marked switches through give_switch, and clear the marks. */
6242 static inline void
6243 process_marked_switches (void)
6245 int i;
6247 for (i = 0; i < n_switches; i++)
6248 if (switches[i].ordering == 1)
6250 switches[i].ordering = 0;
6251 give_switch (i, 0);
6255 /* Handle a %{ ... } construct. P points just inside the leading {.
6256 Returns a pointer one past the end of the brace block, or 0
6257 if we call do_spec_1 and that returns -1. */
6259 static const char *
6260 handle_braces (const char *p)
6262 const char *atom, *end_atom;
6263 const char *d_atom = NULL, *d_end_atom = NULL;
6264 char *esc_buf = NULL, *d_esc_buf = NULL;
6265 int esc;
6266 const char *orig = p;
6268 bool a_is_suffix;
6269 bool a_is_spectype;
6270 bool a_is_starred;
6271 bool a_is_negated;
6272 bool a_matched;
6274 bool a_must_be_last = false;
6275 bool ordered_set = false;
6276 bool disjunct_set = false;
6277 bool disj_matched = false;
6278 bool disj_starred = true;
6279 bool n_way_choice = false;
6280 bool n_way_matched = false;
6282 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
6286 if (a_must_be_last)
6287 goto invalid;
6289 /* Scan one "atom" (S in the description above of %{}, possibly
6290 with '!', '.', '@', ',', or '*' modifiers). */
6291 a_matched = false;
6292 a_is_suffix = false;
6293 a_is_starred = false;
6294 a_is_negated = false;
6295 a_is_spectype = false;
6297 SKIP_WHITE ();
6298 if (*p == '!')
6299 p++, a_is_negated = true;
6301 SKIP_WHITE ();
6302 if (*p == '%' && p[1] == ':')
6304 atom = NULL;
6305 end_atom = NULL;
6306 p = handle_spec_function (p + 2, &a_matched);
6308 else
6310 if (*p == '.')
6311 p++, a_is_suffix = true;
6312 else if (*p == ',')
6313 p++, a_is_spectype = true;
6315 atom = p;
6316 esc = 0;
6317 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
6318 || *p == ',' || *p == '.' || *p == '@' || *p == '\\')
6320 if (*p == '\\')
6322 p++;
6323 if (!*p)
6324 fatal_error (input_location,
6325 "braced spec %qs ends in escape", orig);
6326 esc++;
6328 p++;
6330 end_atom = p;
6332 if (esc)
6334 const char *ap;
6335 char *ep;
6337 if (esc_buf && esc_buf != d_esc_buf)
6338 free (esc_buf);
6339 esc_buf = NULL;
6340 ep = esc_buf = (char *) xmalloc (end_atom - atom - esc + 1);
6341 for (ap = atom; ap != end_atom; ap++, ep++)
6343 if (*ap == '\\')
6344 ap++;
6345 *ep = *ap;
6347 *ep = '\0';
6348 atom = esc_buf;
6349 end_atom = ep;
6352 if (*p == '*')
6353 p++, a_is_starred = 1;
6356 SKIP_WHITE ();
6357 switch (*p)
6359 case '&': case '}':
6360 /* Substitute the switch(es) indicated by the current atom. */
6361 ordered_set = true;
6362 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
6363 || a_is_spectype || atom == end_atom)
6364 goto invalid;
6366 mark_matching_switches (atom, end_atom, a_is_starred);
6368 if (*p == '}')
6369 process_marked_switches ();
6370 break;
6372 case '|': case ':':
6373 /* Substitute some text if the current atom appears as a switch
6374 or suffix. */
6375 disjunct_set = true;
6376 if (ordered_set)
6377 goto invalid;
6379 if (atom && atom == end_atom)
6381 if (!n_way_choice || disj_matched || *p == '|'
6382 || a_is_negated || a_is_suffix || a_is_spectype
6383 || a_is_starred)
6384 goto invalid;
6386 /* An empty term may appear as the last choice of an
6387 N-way choice set; it means "otherwise". */
6388 a_must_be_last = true;
6389 disj_matched = !n_way_matched;
6390 disj_starred = false;
6392 else
6394 if ((a_is_suffix || a_is_spectype) && a_is_starred)
6395 goto invalid;
6397 if (!a_is_starred)
6398 disj_starred = false;
6400 /* Don't bother testing this atom if we already have a
6401 match. */
6402 if (!disj_matched && !n_way_matched)
6404 if (atom == NULL)
6405 /* a_matched is already set by handle_spec_function. */;
6406 else if (a_is_suffix)
6407 a_matched = input_suffix_matches (atom, end_atom);
6408 else if (a_is_spectype)
6409 a_matched = input_spec_matches (atom, end_atom);
6410 else
6411 a_matched = switch_matches (atom, end_atom, a_is_starred);
6413 if (a_matched != a_is_negated)
6415 disj_matched = true;
6416 d_atom = atom;
6417 d_end_atom = end_atom;
6418 d_esc_buf = esc_buf;
6423 if (*p == ':')
6425 /* Found the body, that is, the text to substitute if the
6426 current disjunction matches. */
6427 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
6428 disj_matched && !n_way_matched);
6429 if (p == 0)
6430 goto done;
6432 /* If we have an N-way choice, reset state for the next
6433 disjunction. */
6434 if (*p == ';')
6436 n_way_choice = true;
6437 n_way_matched |= disj_matched;
6438 disj_matched = false;
6439 disj_starred = true;
6440 d_atom = d_end_atom = NULL;
6443 break;
6445 default:
6446 goto invalid;
6449 while (*p++ != '}');
6451 done:
6452 if (d_esc_buf && d_esc_buf != esc_buf)
6453 free (d_esc_buf);
6454 if (esc_buf)
6455 free (esc_buf);
6457 return p;
6459 invalid:
6460 fatal_error (input_location, "braced spec %qs is invalid at %qc", orig, *p);
6462 #undef SKIP_WHITE
6465 /* Subroutine of handle_braces. Scan and process a brace substitution body
6466 (X in the description of %{} syntax). P points one past the colon;
6467 ATOM and END_ATOM bracket the first atom which was found to be true
6468 (present) in the current disjunction; STARRED indicates whether all
6469 the atoms in the current disjunction were starred (for syntax validation);
6470 MATCHED indicates whether the disjunction matched or not, and therefore
6471 whether or not the body is to be processed through do_spec_1 or just
6472 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
6473 returns -1. */
6475 static const char *
6476 process_brace_body (const char *p, const char *atom, const char *end_atom,
6477 int starred, int matched)
6479 const char *body, *end_body;
6480 unsigned int nesting_level;
6481 bool have_subst = false;
6483 /* Locate the closing } or ;, honoring nested braces.
6484 Trim trailing whitespace. */
6485 body = p;
6486 nesting_level = 1;
6487 for (;;)
6489 if (*p == '{')
6490 nesting_level++;
6491 else if (*p == '}')
6493 if (!--nesting_level)
6494 break;
6496 else if (*p == ';' && nesting_level == 1)
6497 break;
6498 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
6499 have_subst = true;
6500 else if (*p == '\0')
6501 goto invalid;
6502 p++;
6505 end_body = p;
6506 while (end_body[-1] == ' ' || end_body[-1] == '\t')
6507 end_body--;
6509 if (have_subst && !starred)
6510 goto invalid;
6512 if (matched)
6514 /* Copy the substitution body to permanent storage and execute it.
6515 If have_subst is false, this is a simple matter of running the
6516 body through do_spec_1... */
6517 char *string = save_string (body, end_body - body);
6518 if (!have_subst)
6520 if (do_spec_1 (string, 0, NULL) < 0)
6522 free (string);
6523 return 0;
6526 else
6528 /* ... but if have_subst is true, we have to process the
6529 body once for each matching switch, with %* set to the
6530 variant part of the switch. */
6531 unsigned int hard_match_len = end_atom - atom;
6532 int i;
6534 for (i = 0; i < n_switches; i++)
6535 if (!strncmp (switches[i].part1, atom, hard_match_len)
6536 && check_live_switch (i, hard_match_len))
6538 if (do_spec_1 (string, 0,
6539 &switches[i].part1[hard_match_len]) < 0)
6541 free (string);
6542 return 0;
6544 /* Pass any arguments this switch has. */
6545 give_switch (i, 1);
6546 suffix_subst = NULL;
6549 free (string);
6552 return p;
6554 invalid:
6555 fatal_error (input_location, "braced spec body %qs is invalid", body);
6558 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
6559 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
6560 spec, or -1 if either exact match or %* is used.
6562 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
6563 whose value does not begin with "no-" is obsoleted by the same value
6564 with the "no-", similarly for a switch with the "no-" prefix. */
6566 static int
6567 check_live_switch (int switchnum, int prefix_length)
6569 const char *name = switches[switchnum].part1;
6570 int i;
6572 /* If we already processed this switch and determined if it was
6573 live or not, return our past determination. */
6574 if (switches[switchnum].live_cond != 0)
6575 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
6576 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
6577 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
6578 == 0);
6580 /* In the common case of {<at-most-one-letter>*}, a negating
6581 switch would always match, so ignore that case. We will just
6582 send the conflicting switches to the compiler phase. */
6583 if (prefix_length >= 0 && prefix_length <= 1)
6584 return 1;
6586 /* Now search for duplicate in a manner that depends on the name. */
6587 switch (*name)
6589 case 'O':
6590 for (i = switchnum + 1; i < n_switches; i++)
6591 if (switches[i].part1[0] == 'O')
6593 switches[switchnum].validated = true;
6594 switches[switchnum].live_cond = SWITCH_FALSE;
6595 return 0;
6597 break;
6599 case 'W': case 'f': case 'm': case 'g':
6600 if (! strncmp (name + 1, "no-", 3))
6602 /* We have Xno-YYY, search for XYYY. */
6603 for (i = switchnum + 1; i < n_switches; i++)
6604 if (switches[i].part1[0] == name[0]
6605 && ! strcmp (&switches[i].part1[1], &name[4]))
6607 /* --specs are validated with the validate_switches mechanism. */
6608 if (switches[switchnum].known)
6609 switches[switchnum].validated = true;
6610 switches[switchnum].live_cond = SWITCH_FALSE;
6611 return 0;
6614 else
6616 /* We have XYYY, search for Xno-YYY. */
6617 for (i = switchnum + 1; i < n_switches; i++)
6618 if (switches[i].part1[0] == name[0]
6619 && switches[i].part1[1] == 'n'
6620 && switches[i].part1[2] == 'o'
6621 && switches[i].part1[3] == '-'
6622 && !strcmp (&switches[i].part1[4], &name[1]))
6624 /* --specs are validated with the validate_switches mechanism. */
6625 if (switches[switchnum].known)
6626 switches[switchnum].validated = true;
6627 switches[switchnum].live_cond = SWITCH_FALSE;
6628 return 0;
6631 break;
6634 /* Otherwise the switch is live. */
6635 switches[switchnum].live_cond |= SWITCH_LIVE;
6636 return 1;
6639 /* Pass a switch to the current accumulating command
6640 in the same form that we received it.
6641 SWITCHNUM identifies the switch; it is an index into
6642 the vector of switches gcc received, which is `switches'.
6643 This cannot fail since it never finishes a command line.
6645 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
6647 static void
6648 give_switch (int switchnum, int omit_first_word)
6650 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
6651 return;
6653 if (!omit_first_word)
6655 do_spec_1 ("-", 0, NULL);
6656 do_spec_1 (switches[switchnum].part1, 1, NULL);
6659 if (switches[switchnum].args != 0)
6661 const char **p;
6662 for (p = switches[switchnum].args; *p; p++)
6664 const char *arg = *p;
6666 do_spec_1 (" ", 0, NULL);
6667 if (suffix_subst)
6669 unsigned length = strlen (arg);
6670 int dot = 0;
6672 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
6673 if (arg[length] == '.')
6675 (CONST_CAST (char *, arg))[length] = 0;
6676 dot = 1;
6677 break;
6679 do_spec_1 (arg, 1, NULL);
6680 if (dot)
6681 (CONST_CAST (char *, arg))[length] = '.';
6682 do_spec_1 (suffix_subst, 1, NULL);
6684 else
6685 do_spec_1 (arg, 1, NULL);
6689 do_spec_1 (" ", 0, NULL);
6690 switches[switchnum].validated = true;
6693 /* Print GCC configuration (e.g. version, thread model, target,
6694 configuration_arguments) to a given FILE. */
6696 static void
6697 print_configuration (FILE *file)
6699 int n;
6700 const char *thrmod;
6702 fnotice (file, "Target: %s\n", spec_machine);
6703 fnotice (file, "Configured with: %s\n", configuration_arguments);
6705 #ifdef THREAD_MODEL_SPEC
6706 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6707 but there's no point in doing all this processing just to get
6708 thread_model back. */
6709 obstack_init (&obstack);
6710 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6711 obstack_1grow (&obstack, '\0');
6712 thrmod = XOBFINISH (&obstack, const char *);
6713 #else
6714 thrmod = thread_model;
6715 #endif
6717 fnotice (file, "Thread model: %s\n", thrmod);
6719 /* compiler_version is truncated at the first space when initialized
6720 from version string, so truncate version_string at the first space
6721 before comparing. */
6722 for (n = 0; version_string[n]; n++)
6723 if (version_string[n] == ' ')
6724 break;
6726 if (! strncmp (version_string, compiler_version, n)
6727 && compiler_version[n] == 0)
6728 fnotice (file, "gcc version %s %s\n", version_string,
6729 pkgversion_string);
6730 else
6731 fnotice (file, "gcc driver version %s %sexecuting gcc version %s\n",
6732 version_string, pkgversion_string, compiler_version);
6736 #define RETRY_ICE_ATTEMPTS 3
6738 /* Returns true if FILE1 and FILE2 contain equivalent data, 0 otherwise. */
6740 static bool
6741 files_equal_p (char *file1, char *file2)
6743 struct stat st1, st2;
6744 off_t n, len;
6745 int fd1, fd2;
6746 const int bufsize = 8192;
6747 char *buf = XNEWVEC (char, bufsize);
6749 fd1 = open (file1, O_RDONLY);
6750 fd2 = open (file2, O_RDONLY);
6752 if (fd1 < 0 || fd2 < 0)
6753 goto error;
6755 if (fstat (fd1, &st1) < 0 || fstat (fd2, &st2) < 0)
6756 goto error;
6758 if (st1.st_size != st2.st_size)
6759 goto error;
6761 for (n = st1.st_size; n; n -= len)
6763 len = n;
6764 if ((int) len > bufsize / 2)
6765 len = bufsize / 2;
6767 if (read (fd1, buf, len) != (int) len
6768 || read (fd2, buf + bufsize / 2, len) != (int) len)
6770 goto error;
6773 if (memcmp (buf, buf + bufsize / 2, len) != 0)
6774 goto error;
6777 free (buf);
6778 close (fd1);
6779 close (fd2);
6781 return 1;
6783 error:
6784 free (buf);
6785 close (fd1);
6786 close (fd2);
6787 return 0;
6790 /* Check that compiler's output doesn't differ across runs.
6791 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are arrays of files, containing
6792 stdout and stderr for each compiler run. Return true if all of
6793 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are equivalent. */
6795 static bool
6796 check_repro (char **temp_stdout_files, char **temp_stderr_files)
6798 int i;
6799 for (i = 0; i < RETRY_ICE_ATTEMPTS - 2; ++i)
6801 if (!files_equal_p (temp_stdout_files[i], temp_stdout_files[i + 1])
6802 || !files_equal_p (temp_stderr_files[i], temp_stderr_files[i + 1]))
6804 fnotice (stderr, "The bug is not reproducible, so it is"
6805 " likely a hardware or OS problem.\n");
6806 break;
6809 return i == RETRY_ICE_ATTEMPTS - 2;
6812 enum attempt_status {
6813 ATTEMPT_STATUS_FAIL_TO_RUN,
6814 ATTEMPT_STATUS_SUCCESS,
6815 ATTEMPT_STATUS_ICE
6819 /* Run compiler with arguments NEW_ARGV to reproduce the ICE, storing stdout
6820 to OUT_TEMP and stderr to ERR_TEMP. If APPEND is TRUE, append to OUT_TEMP
6821 and ERR_TEMP instead of truncating. If EMIT_SYSTEM_INFO is TRUE, also write
6822 GCC configuration into to ERR_TEMP. Return ATTEMPT_STATUS_FAIL_TO_RUN if
6823 compiler failed to run, ATTEMPT_STATUS_ICE if compiled ICE-ed and
6824 ATTEMPT_STATUS_SUCCESS otherwise. */
6826 static enum attempt_status
6827 run_attempt (const char **new_argv, const char *out_temp,
6828 const char *err_temp, int emit_system_info, int append)
6831 if (emit_system_info)
6833 FILE *file_out = fopen (err_temp, "a");
6834 print_configuration (file_out);
6835 fputs ("\n", file_out);
6836 fclose (file_out);
6839 int exit_status;
6840 const char *errmsg;
6841 struct pex_obj *pex;
6842 int err;
6843 int pex_flags = PEX_USE_PIPES | PEX_LAST;
6844 enum attempt_status status = ATTEMPT_STATUS_FAIL_TO_RUN;
6846 if (append)
6847 pex_flags |= PEX_STDOUT_APPEND | PEX_STDERR_APPEND;
6849 pex = pex_init (PEX_USE_PIPES, new_argv[0], NULL);
6850 if (!pex)
6851 fatal_error (input_location, "pex_init failed: %m");
6853 errmsg = pex_run (pex, pex_flags, new_argv[0],
6854 CONST_CAST2 (char *const *, const char **, &new_argv[1]), out_temp,
6855 err_temp, &err);
6856 if (errmsg != NULL)
6858 if (err == 0)
6859 fatal_error (input_location, errmsg);
6860 else
6862 errno = err;
6863 pfatal_with_name (errmsg);
6867 if (!pex_get_status (pex, 1, &exit_status))
6868 goto out;
6870 switch (WEXITSTATUS (exit_status))
6872 case ICE_EXIT_CODE:
6873 status = ATTEMPT_STATUS_ICE;
6874 break;
6876 case SUCCESS_EXIT_CODE:
6877 status = ATTEMPT_STATUS_SUCCESS;
6878 break;
6880 default:
6884 out:
6885 pex_free (pex);
6886 return status;
6889 /* This routine reads lines from IN file, adds C++ style comments
6890 at the begining of each line and writes result into OUT. */
6892 static void
6893 insert_comments (const char *file_in, const char *file_out)
6895 FILE *in = fopen (file_in, "rb");
6896 FILE *out = fopen (file_out, "wb");
6897 char line[256];
6899 bool add_comment = true;
6900 while (fgets (line, sizeof (line), in))
6902 if (add_comment)
6903 fputs ("// ", out);
6904 fputs (line, out);
6905 add_comment = strchr (line, '\n') != NULL;
6908 fclose (in);
6909 fclose (out);
6912 /* This routine adds preprocessed source code into the given ERR_FILE.
6913 To do this, it adds "-E" to NEW_ARGV and execute RUN_ATTEMPT routine to
6914 add information in report file. RUN_ATTEMPT should return
6915 ATTEMPT_STATUS_SUCCESS, in other case we cannot generate the report. */
6917 static void
6918 do_report_bug (const char **new_argv, const int nargs,
6919 char **out_file, char **err_file)
6921 int i, status;
6922 int fd = open (*out_file, O_RDWR | O_APPEND);
6923 if (fd < 0)
6924 return;
6925 write (fd, "\n//", 3);
6926 for (i = 0; i < nargs; i++)
6928 write (fd, " ", 1);
6929 write (fd, new_argv[i], strlen (new_argv[i]));
6931 write (fd, "\n\n", 2);
6932 close (fd);
6933 new_argv[nargs] = "-E";
6934 new_argv[nargs + 1] = NULL;
6936 status = run_attempt (new_argv, *out_file, *err_file, 0, 1);
6938 if (status == ATTEMPT_STATUS_SUCCESS)
6940 fnotice (stderr, "Preprocessed source stored into %s file,"
6941 " please attach this to your bugreport.\n", *out_file);
6942 /* Make sure it is not deleted. */
6943 free (*out_file);
6944 *out_file = NULL;
6948 /* Try to reproduce ICE. If bug is reproducible, generate report .err file
6949 containing GCC configuration, backtrace, compiler's command line options
6950 and preprocessed source code. */
6952 static void
6953 try_generate_repro (const char **argv)
6955 int i, nargs, out_arg = -1, quiet = 0, attempt;
6956 const char **new_argv;
6957 char *temp_files[RETRY_ICE_ATTEMPTS * 2];
6958 char **temp_stdout_files = &temp_files[0];
6959 char **temp_stderr_files = &temp_files[RETRY_ICE_ATTEMPTS];
6961 if (gcc_input_filename == NULL || ! strcmp (gcc_input_filename, "-"))
6962 return;
6964 for (nargs = 0; argv[nargs] != NULL; ++nargs)
6965 /* Only retry compiler ICEs, not preprocessor ones. */
6966 if (! strcmp (argv[nargs], "-E"))
6967 return;
6968 else if (argv[nargs][0] == '-' && argv[nargs][1] == 'o')
6970 if (out_arg == -1)
6971 out_arg = nargs;
6972 else
6973 return;
6975 /* If the compiler is going to output any time information,
6976 it might varry between invocations. */
6977 else if (! strcmp (argv[nargs], "-quiet"))
6978 quiet = 1;
6979 else if (! strcmp (argv[nargs], "-ftime-report"))
6980 return;
6982 if (out_arg == -1 || !quiet)
6983 return;
6985 memset (temp_files, '\0', sizeof (temp_files));
6986 new_argv = XALLOCAVEC (const char *, nargs + 4);
6987 memcpy (new_argv, argv, (nargs + 1) * sizeof (const char *));
6988 new_argv[nargs++] = "-frandom-seed=0";
6989 new_argv[nargs++] = "-fdump-noaddr";
6990 new_argv[nargs] = NULL;
6991 if (new_argv[out_arg][2] == '\0')
6992 new_argv[out_arg + 1] = "-";
6993 else
6994 new_argv[out_arg] = "-o-";
6996 int status;
6997 for (attempt = 0; attempt < RETRY_ICE_ATTEMPTS; ++attempt)
6999 int emit_system_info = 0;
7000 int append = 0;
7001 temp_stdout_files[attempt] = make_temp_file (".out");
7002 temp_stderr_files[attempt] = make_temp_file (".err");
7004 if (attempt == RETRY_ICE_ATTEMPTS - 1)
7006 append = 1;
7007 emit_system_info = 1;
7010 status = run_attempt (new_argv, temp_stdout_files[attempt],
7011 temp_stderr_files[attempt], emit_system_info,
7012 append);
7014 if (status != ATTEMPT_STATUS_ICE)
7016 fnotice (stderr, "The bug is not reproducible, so it is"
7017 " likely a hardware or OS problem.\n");
7018 goto out;
7022 if (!check_repro (temp_stdout_files, temp_stderr_files))
7023 goto out;
7026 /* Insert commented out backtrace into report file. */
7027 char **stderr_commented = &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1];
7028 insert_comments (temp_stderr_files[RETRY_ICE_ATTEMPTS - 1],
7029 *stderr_commented);
7031 /* In final attempt we append compiler options and preprocesssed code to last
7032 generated .out file with configuration and backtrace. */
7033 char **output = &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1];
7034 do_report_bug (new_argv, nargs, stderr_commented, output);
7037 out:
7038 for (i = 0; i < RETRY_ICE_ATTEMPTS * 2; i++)
7039 if (temp_files[i])
7041 unlink (temp_stdout_files[i]);
7042 free (temp_stdout_files[i]);
7046 /* Search for a file named NAME trying various prefixes including the
7047 user's -B prefix and some standard ones.
7048 Return the absolute file name found. If nothing is found, return NAME. */
7050 static const char *
7051 find_file (const char *name)
7053 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
7054 return newname ? newname : name;
7057 /* Determine whether a directory exists. If LINKER, return 0 for
7058 certain fixed names not needed by the linker. */
7060 static int
7061 is_directory (const char *path1, bool linker)
7063 int len1;
7064 char *path;
7065 char *cp;
7066 struct stat st;
7068 /* Ensure the string ends with "/.". The resulting path will be a
7069 directory even if the given path is a symbolic link. */
7070 len1 = strlen (path1);
7071 path = (char *) alloca (3 + len1);
7072 memcpy (path, path1, len1);
7073 cp = path + len1;
7074 if (!IS_DIR_SEPARATOR (cp[-1]))
7075 *cp++ = DIR_SEPARATOR;
7076 *cp++ = '.';
7077 *cp = '\0';
7079 /* Exclude directories that the linker is known to search. */
7080 if (linker
7081 && IS_DIR_SEPARATOR (path[0])
7082 && ((cp - path == 6
7083 && filename_ncmp (path + 1, "lib", 3) == 0)
7084 || (cp - path == 10
7085 && filename_ncmp (path + 1, "usr", 3) == 0
7086 && IS_DIR_SEPARATOR (path[4])
7087 && filename_ncmp (path + 5, "lib", 3) == 0)))
7088 return 0;
7090 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
7093 /* Set up the various global variables to indicate that we're processing
7094 the input file named FILENAME. */
7096 void
7097 set_input (const char *filename)
7099 const char *p;
7101 gcc_input_filename = filename;
7102 input_filename_length = strlen (gcc_input_filename);
7103 input_basename = lbasename (gcc_input_filename);
7105 /* Find a suffix starting with the last period,
7106 and set basename_length to exclude that suffix. */
7107 basename_length = strlen (input_basename);
7108 suffixed_basename_length = basename_length;
7109 p = input_basename + basename_length;
7110 while (p != input_basename && *p != '.')
7111 --p;
7112 if (*p == '.' && p != input_basename)
7114 basename_length = p - input_basename;
7115 input_suffix = p + 1;
7117 else
7118 input_suffix = "";
7120 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
7121 we will need to do a stat on the gcc_input_filename. The
7122 INPUT_STAT_SET signals that the stat is needed. */
7123 input_stat_set = 0;
7126 /* On fatal signals, delete all the temporary files. */
7128 static void
7129 fatal_signal (int signum)
7131 signal (signum, SIG_DFL);
7132 delete_failure_queue ();
7133 delete_temp_files ();
7134 /* Get the same signal again, this time not handled,
7135 so its normal effect occurs. */
7136 kill (getpid (), signum);
7139 /* Compare the contents of the two files named CMPFILE[0] and
7140 CMPFILE[1]. Return zero if they're identical, nonzero
7141 otherwise. */
7143 static int
7144 compare_files (char *cmpfile[])
7146 int ret = 0;
7147 FILE *temp[2] = { NULL, NULL };
7148 int i;
7150 #if HAVE_MMAP_FILE
7152 size_t length[2];
7153 void *map[2] = { NULL, NULL };
7155 for (i = 0; i < 2; i++)
7157 struct stat st;
7159 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
7161 error ("%s: could not determine length of compare-debug file %s",
7162 gcc_input_filename, cmpfile[i]);
7163 ret = 1;
7164 break;
7167 length[i] = st.st_size;
7170 if (!ret && length[0] != length[1])
7172 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
7173 ret = 1;
7176 if (!ret)
7177 for (i = 0; i < 2; i++)
7179 int fd = open (cmpfile[i], O_RDONLY);
7180 if (fd < 0)
7182 error ("%s: could not open compare-debug file %s",
7183 gcc_input_filename, cmpfile[i]);
7184 ret = 1;
7185 break;
7188 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
7189 close (fd);
7191 if (map[i] == (void *) MAP_FAILED)
7193 ret = -1;
7194 break;
7198 if (!ret)
7200 if (memcmp (map[0], map[1], length[0]) != 0)
7202 error ("%s: -fcompare-debug failure", gcc_input_filename);
7203 ret = 1;
7207 for (i = 0; i < 2; i++)
7208 if (map[i])
7209 munmap ((caddr_t) map[i], length[i]);
7211 if (ret >= 0)
7212 return ret;
7214 ret = 0;
7216 #endif
7218 for (i = 0; i < 2; i++)
7220 temp[i] = fopen (cmpfile[i], "r");
7221 if (!temp[i])
7223 error ("%s: could not open compare-debug file %s",
7224 gcc_input_filename, cmpfile[i]);
7225 ret = 1;
7226 break;
7230 if (!ret && temp[0] && temp[1])
7231 for (;;)
7233 int c0, c1;
7234 c0 = fgetc (temp[0]);
7235 c1 = fgetc (temp[1]);
7237 if (c0 != c1)
7239 error ("%s: -fcompare-debug failure",
7240 gcc_input_filename);
7241 ret = 1;
7242 break;
7245 if (c0 == EOF)
7246 break;
7249 for (i = 1; i >= 0; i--)
7251 if (temp[i])
7252 fclose (temp[i]);
7255 return ret;
7258 driver::driver (bool can_finalize, bool debug) :
7259 explicit_link_files (NULL),
7260 decoded_options (NULL),
7261 m_option_suggestions (NULL)
7263 env.init (can_finalize, debug);
7266 driver::~driver ()
7268 XDELETEVEC (explicit_link_files);
7269 XDELETEVEC (decoded_options);
7270 if (m_option_suggestions)
7272 int i;
7273 char *str;
7274 FOR_EACH_VEC_ELT (*m_option_suggestions, i, str)
7275 free (str);
7276 delete m_option_suggestions;
7280 /* driver::main is implemented as a series of driver:: method calls. */
7283 driver::main (int argc, char **argv)
7285 bool early_exit;
7287 set_progname (argv[0]);
7288 expand_at_files (&argc, &argv);
7289 decode_argv (argc, const_cast <const char **> (argv));
7290 global_initializations ();
7291 build_multilib_strings ();
7292 set_up_specs ();
7293 putenv_COLLECT_GCC (argv[0]);
7294 maybe_putenv_COLLECT_LTO_WRAPPER ();
7295 maybe_putenv_OFFLOAD_TARGETS ();
7296 handle_unrecognized_options ();
7298 if (!maybe_print_and_exit ())
7299 return 0;
7301 early_exit = prepare_infiles ();
7302 if (early_exit)
7303 return get_exit_code ();
7305 do_spec_on_infiles ();
7306 maybe_run_linker (argv[0]);
7307 final_actions ();
7308 return get_exit_code ();
7311 /* Locate the final component of argv[0] after any leading path, and set
7312 the program name accordingly. */
7314 void
7315 driver::set_progname (const char *argv0) const
7317 const char *p = argv0 + strlen (argv0);
7318 while (p != argv0 && !IS_DIR_SEPARATOR (p[-1]))
7319 --p;
7320 progname = p;
7322 xmalloc_set_program_name (progname);
7325 /* Expand any @ files within the command-line args,
7326 setting at_file_supplied if any were expanded. */
7328 void
7329 driver::expand_at_files (int *argc, char ***argv) const
7331 char **old_argv = *argv;
7333 expandargv (argc, argv);
7335 /* Determine if any expansions were made. */
7336 if (*argv != old_argv)
7337 at_file_supplied = true;
7340 /* Decode the command-line arguments from argc/argv into the
7341 decoded_options array. */
7343 void
7344 driver::decode_argv (int argc, const char **argv)
7346 /* Register the language-independent parameters. */
7347 global_init_params ();
7348 finish_params ();
7350 init_opts_obstack ();
7351 init_options_struct (&global_options, &global_options_set);
7353 decode_cmdline_options_to_array (argc, argv,
7354 CL_DRIVER,
7355 &decoded_options, &decoded_options_count);
7358 /* Perform various initializations and setup. */
7360 void
7361 driver::global_initializations ()
7363 /* Unlock the stdio streams. */
7364 unlock_std_streams ();
7366 gcc_init_libintl ();
7368 diagnostic_initialize (global_dc, 0);
7369 diagnostic_color_init (global_dc);
7371 #ifdef GCC_DRIVER_HOST_INITIALIZATION
7372 /* Perform host dependent initialization when needed. */
7373 GCC_DRIVER_HOST_INITIALIZATION;
7374 #endif
7376 if (atexit (delete_temp_files) != 0)
7377 fatal_error (input_location, "atexit failed");
7379 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
7380 signal (SIGINT, fatal_signal);
7381 #ifdef SIGHUP
7382 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
7383 signal (SIGHUP, fatal_signal);
7384 #endif
7385 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
7386 signal (SIGTERM, fatal_signal);
7387 #ifdef SIGPIPE
7388 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
7389 signal (SIGPIPE, fatal_signal);
7390 #endif
7391 #ifdef SIGCHLD
7392 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
7393 receive the signal. A different setting is inheritable */
7394 signal (SIGCHLD, SIG_DFL);
7395 #endif
7397 /* Parsing and gimplification sometimes need quite large stack.
7398 Increase stack size limits if possible. */
7399 stack_limit_increase (64 * 1024 * 1024);
7401 /* Allocate the argument vector. */
7402 alloc_args ();
7404 obstack_init (&obstack);
7407 /* Build multilib_select, et. al from the separate lines that make up each
7408 multilib selection. */
7410 void
7411 driver::build_multilib_strings () const
7414 const char *p;
7415 const char *const *q = multilib_raw;
7416 int need_space;
7418 obstack_init (&multilib_obstack);
7419 while ((p = *q++) != (char *) 0)
7420 obstack_grow (&multilib_obstack, p, strlen (p));
7422 obstack_1grow (&multilib_obstack, 0);
7423 multilib_select = XOBFINISH (&multilib_obstack, const char *);
7425 q = multilib_matches_raw;
7426 while ((p = *q++) != (char *) 0)
7427 obstack_grow (&multilib_obstack, p, strlen (p));
7429 obstack_1grow (&multilib_obstack, 0);
7430 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
7432 q = multilib_exclusions_raw;
7433 while ((p = *q++) != (char *) 0)
7434 obstack_grow (&multilib_obstack, p, strlen (p));
7436 obstack_1grow (&multilib_obstack, 0);
7437 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
7439 q = multilib_reuse_raw;
7440 while ((p = *q++) != (char *) 0)
7441 obstack_grow (&multilib_obstack, p, strlen (p));
7443 obstack_1grow (&multilib_obstack, 0);
7444 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
7446 need_space = FALSE;
7447 for (size_t i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
7449 if (need_space)
7450 obstack_1grow (&multilib_obstack, ' ');
7451 obstack_grow (&multilib_obstack,
7452 multilib_defaults_raw[i],
7453 strlen (multilib_defaults_raw[i]));
7454 need_space = TRUE;
7457 obstack_1grow (&multilib_obstack, 0);
7458 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
7462 /* Set up the spec-handling machinery. */
7464 void
7465 driver::set_up_specs () const
7467 const char *spec_machine_suffix;
7468 char *specs_file;
7469 size_t i;
7471 #ifdef INIT_ENVIRONMENT
7472 /* Set up any other necessary machine specific environment variables. */
7473 xputenv (INIT_ENVIRONMENT);
7474 #endif
7476 /* Make a table of what switches there are (switches, n_switches).
7477 Make a table of specified input files (infiles, n_infiles).
7478 Decode switches that are handled locally. */
7480 process_command (decoded_options_count, decoded_options);
7482 /* Initialize the vector of specs to just the default.
7483 This means one element containing 0s, as a terminator. */
7485 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
7486 memcpy (compilers, default_compilers, sizeof default_compilers);
7487 n_compilers = n_default_compilers;
7489 /* Read specs from a file if there is one. */
7491 machine_suffix = concat (spec_host_machine, dir_separator_str, spec_version,
7492 accel_dir_suffix, dir_separator_str, NULL);
7493 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
7495 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
7496 /* Read the specs file unless it is a default one. */
7497 if (specs_file != 0 && strcmp (specs_file, "specs"))
7498 read_specs (specs_file, true, false);
7499 else
7500 init_spec ();
7502 #ifdef ACCEL_COMPILER
7503 spec_machine_suffix = machine_suffix;
7504 #else
7505 spec_machine_suffix = just_machine_suffix;
7506 #endif
7508 /* We need to check standard_exec_prefix/spec_machine_suffix/specs
7509 for any override of as, ld and libraries. */
7510 specs_file = (char *) alloca (strlen (standard_exec_prefix)
7511 + strlen (spec_machine_suffix) + sizeof ("specs"));
7512 strcpy (specs_file, standard_exec_prefix);
7513 strcat (specs_file, spec_machine_suffix);
7514 strcat (specs_file, "specs");
7515 if (access (specs_file, R_OK) == 0)
7516 read_specs (specs_file, true, false);
7518 /* Process any configure-time defaults specified for the command line
7519 options, via OPTION_DEFAULT_SPECS. */
7520 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
7521 do_option_spec (option_default_specs[i].name,
7522 option_default_specs[i].spec);
7524 /* Process DRIVER_SELF_SPECS, adding any new options to the end
7525 of the command line. */
7527 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
7528 do_self_spec (driver_self_specs[i]);
7530 /* If not cross-compiling, look for executables in the standard
7531 places. */
7532 if (*cross_compile == '0')
7534 if (*md_exec_prefix)
7536 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
7537 PREFIX_PRIORITY_LAST, 0, 0);
7541 /* Process sysroot_suffix_spec. */
7542 if (*sysroot_suffix_spec != 0
7543 && !no_sysroot_suffix
7544 && do_spec_2 (sysroot_suffix_spec) == 0)
7546 if (argbuf.length () > 1)
7547 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
7548 else if (argbuf.length () == 1)
7549 target_sysroot_suffix = xstrdup (argbuf.last ());
7552 #ifdef HAVE_LD_SYSROOT
7553 /* Pass the --sysroot option to the linker, if it supports that. If
7554 there is a sysroot_suffix_spec, it has already been processed by
7555 this point, so target_system_root really is the system root we
7556 should be using. */
7557 if (target_system_root)
7559 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
7560 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
7561 set_spec ("link", XOBFINISH (&obstack, const char *), false);
7563 #endif
7565 /* Process sysroot_hdrs_suffix_spec. */
7566 if (*sysroot_hdrs_suffix_spec != 0
7567 && !no_sysroot_suffix
7568 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
7570 if (argbuf.length () > 1)
7571 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
7572 else if (argbuf.length () == 1)
7573 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
7576 /* Look for startfiles in the standard places. */
7577 if (*startfile_prefix_spec != 0
7578 && do_spec_2 (startfile_prefix_spec) == 0
7579 && do_spec_1 (" ", 0, NULL) == 0)
7581 const char *arg;
7582 int ndx;
7583 FOR_EACH_VEC_ELT (argbuf, ndx, arg)
7584 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
7585 PREFIX_PRIORITY_LAST, 0, 1);
7587 /* We should eventually get rid of all these and stick to
7588 startfile_prefix_spec exclusively. */
7589 else if (*cross_compile == '0' || target_system_root)
7591 if (*md_startfile_prefix)
7592 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
7593 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7595 if (*md_startfile_prefix_1)
7596 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
7597 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
7599 /* If standard_startfile_prefix is relative, base it on
7600 standard_exec_prefix. This lets us move the installed tree
7601 as a unit. If GCC_EXEC_PREFIX is defined, base
7602 standard_startfile_prefix on that as well.
7604 If the prefix is relative, only search it for native compilers;
7605 otherwise we will search a directory containing host libraries. */
7606 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
7607 add_sysrooted_prefix (&startfile_prefixes,
7608 standard_startfile_prefix, "BINUTILS",
7609 PREFIX_PRIORITY_LAST, 0, 1);
7610 else if (*cross_compile == '0')
7612 add_prefix (&startfile_prefixes,
7613 concat (gcc_exec_prefix
7614 ? gcc_exec_prefix : standard_exec_prefix,
7615 machine_suffix,
7616 standard_startfile_prefix, NULL),
7617 NULL, PREFIX_PRIORITY_LAST, 0, 1);
7620 /* Sysrooted prefixes are relocated because target_system_root is
7621 also relocated by gcc_exec_prefix. */
7622 if (*standard_startfile_prefix_1)
7623 add_sysrooted_prefix (&startfile_prefixes,
7624 standard_startfile_prefix_1, "BINUTILS",
7625 PREFIX_PRIORITY_LAST, 0, 1);
7626 if (*standard_startfile_prefix_2)
7627 add_sysrooted_prefix (&startfile_prefixes,
7628 standard_startfile_prefix_2, "BINUTILS",
7629 PREFIX_PRIORITY_LAST, 0, 1);
7632 /* Process any user specified specs in the order given on the command
7633 line. */
7634 for (struct user_specs *uptr = user_specs_head; uptr; uptr = uptr->next)
7636 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
7637 R_OK, true);
7638 read_specs (filename ? filename : uptr->filename, false, true);
7641 /* Process any user self specs. */
7643 struct spec_list *sl;
7644 for (sl = specs; sl; sl = sl->next)
7645 if (sl->name_len == sizeof "self_spec" - 1
7646 && !strcmp (sl->name, "self_spec"))
7647 do_self_spec (*sl->ptr_spec);
7650 if (compare_debug)
7652 enum save_temps save;
7654 if (!compare_debug_second)
7656 n_switches_debug_check[1] = n_switches;
7657 n_switches_alloc_debug_check[1] = n_switches_alloc;
7658 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
7659 n_switches_alloc);
7661 do_self_spec ("%:compare-debug-self-opt()");
7662 n_switches_debug_check[0] = n_switches;
7663 n_switches_alloc_debug_check[0] = n_switches_alloc;
7664 switches_debug_check[0] = switches;
7666 n_switches = n_switches_debug_check[1];
7667 n_switches_alloc = n_switches_alloc_debug_check[1];
7668 switches = switches_debug_check[1];
7671 /* Avoid crash when computing %j in this early. */
7672 save = save_temps_flag;
7673 save_temps_flag = SAVE_TEMPS_NONE;
7675 compare_debug = -compare_debug;
7676 do_self_spec ("%:compare-debug-self-opt()");
7678 save_temps_flag = save;
7680 if (!compare_debug_second)
7682 n_switches_debug_check[1] = n_switches;
7683 n_switches_alloc_debug_check[1] = n_switches_alloc;
7684 switches_debug_check[1] = switches;
7685 compare_debug = -compare_debug;
7686 n_switches = n_switches_debug_check[0];
7687 n_switches_alloc = n_switches_debug_check[0];
7688 switches = switches_debug_check[0];
7693 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
7694 if (gcc_exec_prefix)
7695 gcc_exec_prefix = concat (gcc_exec_prefix, spec_host_machine,
7696 dir_separator_str, spec_version,
7697 accel_dir_suffix, dir_separator_str, NULL);
7699 /* Now we have the specs.
7700 Set the `valid' bits for switches that match anything in any spec. */
7702 validate_all_switches ();
7704 /* Now that we have the switches and the specs, set
7705 the subdirectory based on the options. */
7706 set_multilib_dir ();
7709 /* Set up to remember the pathname of gcc and any options
7710 needed for collect. We use argv[0] instead of progname because
7711 we need the complete pathname. */
7713 void
7714 driver::putenv_COLLECT_GCC (const char *argv0) const
7716 obstack_init (&collect_obstack);
7717 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
7718 obstack_grow (&collect_obstack, argv0, strlen (argv0) + 1);
7719 xputenv (XOBFINISH (&collect_obstack, char *));
7722 /* Set up to remember the pathname of the lto wrapper. */
7724 void
7725 driver::maybe_putenv_COLLECT_LTO_WRAPPER () const
7727 char *lto_wrapper_file;
7729 if (have_c)
7730 lto_wrapper_file = NULL;
7731 else
7732 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
7733 X_OK, false);
7734 if (lto_wrapper_file)
7736 lto_wrapper_file = convert_white_space (lto_wrapper_file);
7737 lto_wrapper_spec = lto_wrapper_file;
7738 obstack_init (&collect_obstack);
7739 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
7740 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
7741 obstack_grow (&collect_obstack, lto_wrapper_spec,
7742 strlen (lto_wrapper_spec) + 1);
7743 xputenv (XOBFINISH (&collect_obstack, char *));
7748 /* Set up to remember the names of offload targets. */
7750 void
7751 driver::maybe_putenv_OFFLOAD_TARGETS () const
7753 if (offload_targets && offload_targets[0] != '\0')
7755 obstack_grow (&collect_obstack, "OFFLOAD_TARGET_NAMES=",
7756 sizeof ("OFFLOAD_TARGET_NAMES=") - 1);
7757 obstack_grow (&collect_obstack, offload_targets,
7758 strlen (offload_targets) + 1);
7759 xputenv (XOBFINISH (&collect_obstack, char *));
7762 free (offload_targets);
7763 offload_targets = NULL;
7766 /* Helper function for driver::suggest_option. Populate
7767 m_option_suggestions with candidate strings for misspelled options.
7768 The strings will be freed by the driver's dtor. */
7770 void
7771 driver::build_option_suggestions (void)
7773 gcc_assert (m_option_suggestions == NULL);
7774 m_option_suggestions = new auto_vec <char *> ();
7776 /* We build a vec of m_option_suggestions, using add_misspelling_candidates
7777 to add copies of strings, without a leading dash. */
7779 for (unsigned int i = 0; i < cl_options_count; i++)
7781 const struct cl_option *option = &cl_options[i];
7782 const char *opt_text = option->opt_text;
7783 switch (i)
7785 default:
7786 if (option->var_type == CLVC_ENUM)
7788 const struct cl_enum *e = &cl_enums[option->var_enum];
7789 for (unsigned j = 0; e->values[j].arg != NULL; j++)
7791 char *with_arg = concat (opt_text, e->values[j].arg, NULL);
7792 add_misspelling_candidates (m_option_suggestions, option,
7793 with_arg);
7794 free (with_arg);
7797 else
7798 add_misspelling_candidates (m_option_suggestions, option,
7799 opt_text);
7800 break;
7802 case OPT_fsanitize_:
7803 case OPT_fsanitize_recover_:
7804 /* -fsanitize= and -fsanitize-recover= can take
7805 a comma-separated list of arguments. Given that combinations
7806 are supported, we can't add all potential candidates to the
7807 vec, but if we at least add them individually without commas,
7808 we should do a better job e.g. correcting
7809 "-sanitize=address"
7811 "-fsanitize=address"
7812 rather than to "-Wframe-address" (PR driver/69265). */
7814 for (int j = 0; sanitizer_opts[j].name != NULL; ++j)
7816 struct cl_option optb;
7817 /* -fsanitize=all is not valid, only -fno-sanitize=all.
7818 So don't register the positive misspelling candidates
7819 for it. */
7820 if (sanitizer_opts[j].flag == ~0U && i == OPT_fsanitize_)
7822 optb = *option;
7823 optb.opt_text = opt_text = "-fno-sanitize=";
7824 optb.cl_reject_negative = true;
7825 option = &optb;
7827 /* Get one arg at a time e.g. "-fsanitize=address". */
7828 char *with_arg = concat (opt_text,
7829 sanitizer_opts[j].name,
7830 NULL);
7831 /* Add with_arg and all of its variant spellings e.g.
7832 "-fno-sanitize=address" to candidates (albeit without
7833 leading dashes). */
7834 add_misspelling_candidates (m_option_suggestions, option,
7835 with_arg);
7836 free (with_arg);
7839 break;
7844 /* Helper function for driver::handle_unrecognized_options.
7846 Given an unrecognized option BAD_OPT (without the leading dash),
7847 locate the closest reasonable matching option (again, without the
7848 leading dash), or NULL.
7850 The returned string is owned by the driver instance. */
7852 const char *
7853 driver::suggest_option (const char *bad_opt)
7855 /* Lazily populate m_option_suggestions. */
7856 if (!m_option_suggestions)
7857 build_option_suggestions ();
7858 gcc_assert (m_option_suggestions);
7860 /* "m_option_suggestions" is now populated. Use it. */
7861 return find_closest_string
7862 (bad_opt,
7863 (auto_vec <const char *> *) m_option_suggestions);
7866 /* Reject switches that no pass was interested in. */
7868 void
7869 driver::handle_unrecognized_options ()
7871 for (size_t i = 0; (int) i < n_switches; i++)
7872 if (! switches[i].validated)
7874 const char *hint = suggest_option (switches[i].part1);
7875 if (hint)
7876 error ("unrecognized command line option %<-%s%>;"
7877 " did you mean %<-%s%>?",
7878 switches[i].part1, hint);
7879 else
7880 error ("unrecognized command line option %<-%s%>",
7881 switches[i].part1);
7885 /* Handle the various -print-* options, returning 0 if the driver
7886 should exit, or nonzero if the driver should continue. */
7889 driver::maybe_print_and_exit () const
7891 if (print_search_dirs)
7893 printf (_("install: %s%s\n"),
7894 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
7895 gcc_exec_prefix ? "" : machine_suffix);
7896 printf (_("programs: %s\n"),
7897 build_search_list (&exec_prefixes, "", false, false));
7898 printf (_("libraries: %s\n"),
7899 build_search_list (&startfile_prefixes, "", false, true));
7900 return (0);
7903 if (print_file_name)
7905 printf ("%s\n", find_file (print_file_name));
7906 return (0);
7909 if (print_prog_name)
7911 if (use_ld != NULL && ! strcmp (print_prog_name, "ld"))
7913 /* Append USE_LD to the default linker. */
7914 #ifdef DEFAULT_LINKER
7915 char *ld;
7916 # ifdef HAVE_HOST_EXECUTABLE_SUFFIX
7917 int len = (sizeof (DEFAULT_LINKER)
7918 - sizeof (HOST_EXECUTABLE_SUFFIX));
7919 ld = NULL;
7920 if (len > 0)
7922 char *default_linker = xstrdup (DEFAULT_LINKER);
7923 /* Strip HOST_EXECUTABLE_SUFFIX if DEFAULT_LINKER contains
7924 HOST_EXECUTABLE_SUFFIX. */
7925 if (! strcmp (&default_linker[len], HOST_EXECUTABLE_SUFFIX))
7927 default_linker[len] = '\0';
7928 ld = concat (default_linker, use_ld,
7929 HOST_EXECUTABLE_SUFFIX, NULL);
7932 if (ld == NULL)
7933 # endif
7934 ld = concat (DEFAULT_LINKER, use_ld, NULL);
7935 if (access (ld, X_OK) == 0)
7937 printf ("%s\n", ld);
7938 return (0);
7940 #endif
7941 print_prog_name = concat (print_prog_name, use_ld, NULL);
7943 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
7944 printf ("%s\n", (newname ? newname : print_prog_name));
7945 return (0);
7948 if (print_multi_lib)
7950 print_multilib_info ();
7951 return (0);
7954 if (print_multi_directory)
7956 if (multilib_dir == NULL)
7957 printf (".\n");
7958 else
7959 printf ("%s\n", multilib_dir);
7960 return (0);
7963 if (print_multiarch)
7965 if (multiarch_dir == NULL)
7966 printf ("\n");
7967 else
7968 printf ("%s\n", multiarch_dir);
7969 return (0);
7972 if (print_sysroot)
7974 if (target_system_root)
7976 if (target_sysroot_suffix)
7977 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
7978 else
7979 printf ("%s\n", target_system_root);
7981 return (0);
7984 if (print_multi_os_directory)
7986 if (multilib_os_dir == NULL)
7987 printf (".\n");
7988 else
7989 printf ("%s\n", multilib_os_dir);
7990 return (0);
7993 if (print_sysroot_headers_suffix)
7995 if (*sysroot_hdrs_suffix_spec)
7997 printf("%s\n", (target_sysroot_hdrs_suffix
7998 ? target_sysroot_hdrs_suffix
7999 : ""));
8000 return (0);
8002 else
8003 /* The error status indicates that only one set of fixed
8004 headers should be built. */
8005 fatal_error (input_location,
8006 "not configured with sysroot headers suffix");
8009 if (print_help_list)
8011 display_help ();
8013 if (! verbose_flag)
8015 printf (_("\nFor bug reporting instructions, please see:\n"));
8016 printf ("%s.\n", bug_report_url);
8018 return (0);
8021 /* We do not exit here. Instead we have created a fake input file
8022 called 'help-dummy' which needs to be compiled, and we pass this
8023 on the various sub-processes, along with the --help switch.
8024 Ensure their output appears after ours. */
8025 fputc ('\n', stdout);
8026 fflush (stdout);
8029 if (print_version)
8031 printf (_("%s %s%s\n"), progname, pkgversion_string,
8032 version_string);
8033 printf ("Copyright %s 2017 Free Software Foundation, Inc.\n",
8034 _("(C)"));
8035 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
8036 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
8037 stdout);
8038 if (! verbose_flag)
8039 return 0;
8041 /* We do not exit here. We use the same mechanism of --help to print
8042 the version of the sub-processes. */
8043 fputc ('\n', stdout);
8044 fflush (stdout);
8047 if (verbose_flag)
8049 print_configuration (stderr);
8050 if (n_infiles == 0)
8051 return (0);
8054 return 1;
8057 /* Figure out what to do with each input file.
8058 Return true if we need to exit early from "main", false otherwise. */
8060 bool
8061 driver::prepare_infiles ()
8063 size_t i;
8064 int lang_n_infiles = 0;
8066 if (n_infiles == added_libraries)
8067 fatal_error (input_location, "no input files");
8069 if (seen_error ())
8070 /* Early exit needed from main. */
8071 return true;
8073 /* Make a place to record the compiler output file names
8074 that correspond to the input files. */
8076 i = n_infiles;
8077 i += lang_specific_extra_outfiles;
8078 outfiles = XCNEWVEC (const char *, i);
8080 /* Record which files were specified explicitly as link input. */
8082 explicit_link_files = XCNEWVEC (char, n_infiles);
8084 combine_inputs = have_o || flag_wpa;
8086 for (i = 0; (int) i < n_infiles; i++)
8088 const char *name = infiles[i].name;
8089 struct compiler *compiler = lookup_compiler (name,
8090 strlen (name),
8091 infiles[i].language);
8093 if (compiler && !(compiler->combinable))
8094 combine_inputs = false;
8096 if (lang_n_infiles > 0 && compiler != input_file_compiler
8097 && infiles[i].language && infiles[i].language[0] != '*')
8098 infiles[i].incompiler = compiler;
8099 else if (compiler)
8101 lang_n_infiles++;
8102 input_file_compiler = compiler;
8103 infiles[i].incompiler = compiler;
8105 else
8107 /* Since there is no compiler for this input file, assume it is a
8108 linker file. */
8109 explicit_link_files[i] = 1;
8110 infiles[i].incompiler = NULL;
8112 infiles[i].compiled = false;
8113 infiles[i].preprocessed = false;
8116 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
8117 fatal_error (input_location,
8118 "cannot specify -o with -c, -S or -E with multiple files");
8120 /* No early exit needed from main; we can continue. */
8121 return false;
8124 /* Run the spec machinery on each input file. */
8126 void
8127 driver::do_spec_on_infiles () const
8129 size_t i;
8131 for (i = 0; (int) i < n_infiles; i++)
8133 int this_file_error = 0;
8135 /* Tell do_spec what to substitute for %i. */
8137 input_file_number = i;
8138 set_input (infiles[i].name);
8140 if (infiles[i].compiled)
8141 continue;
8143 /* Use the same thing in %o, unless cp->spec says otherwise. */
8145 outfiles[i] = gcc_input_filename;
8147 /* Figure out which compiler from the file's suffix. */
8149 input_file_compiler
8150 = lookup_compiler (infiles[i].name, input_filename_length,
8151 infiles[i].language);
8153 if (input_file_compiler)
8155 /* Ok, we found an applicable compiler. Run its spec. */
8157 if (input_file_compiler->spec[0] == '#')
8159 error ("%s: %s compiler not installed on this system",
8160 gcc_input_filename, &input_file_compiler->spec[1]);
8161 this_file_error = 1;
8163 else
8165 int value;
8167 if (compare_debug)
8169 free (debug_check_temp_file[0]);
8170 debug_check_temp_file[0] = NULL;
8172 free (debug_check_temp_file[1]);
8173 debug_check_temp_file[1] = NULL;
8176 value = do_spec (input_file_compiler->spec);
8177 infiles[i].compiled = true;
8178 if (value < 0)
8179 this_file_error = 1;
8180 else if (compare_debug && debug_check_temp_file[0])
8182 if (verbose_flag)
8183 inform (0, "recompiling with -fcompare-debug");
8185 compare_debug = -compare_debug;
8186 n_switches = n_switches_debug_check[1];
8187 n_switches_alloc = n_switches_alloc_debug_check[1];
8188 switches = switches_debug_check[1];
8190 value = do_spec (input_file_compiler->spec);
8192 compare_debug = -compare_debug;
8193 n_switches = n_switches_debug_check[0];
8194 n_switches_alloc = n_switches_alloc_debug_check[0];
8195 switches = switches_debug_check[0];
8197 if (value < 0)
8199 error ("during -fcompare-debug recompilation");
8200 this_file_error = 1;
8203 gcc_assert (debug_check_temp_file[1]
8204 && filename_cmp (debug_check_temp_file[0],
8205 debug_check_temp_file[1]));
8207 if (verbose_flag)
8208 inform (0, "comparing final insns dumps");
8210 if (compare_files (debug_check_temp_file))
8211 this_file_error = 1;
8214 if (compare_debug)
8216 free (debug_check_temp_file[0]);
8217 debug_check_temp_file[0] = NULL;
8219 free (debug_check_temp_file[1]);
8220 debug_check_temp_file[1] = NULL;
8225 /* If this file's name does not contain a recognized suffix,
8226 record it as explicit linker input. */
8228 else
8229 explicit_link_files[i] = 1;
8231 /* Clear the delete-on-failure queue, deleting the files in it
8232 if this compilation failed. */
8234 if (this_file_error)
8236 delete_failure_queue ();
8237 errorcount++;
8239 /* If this compilation succeeded, don't delete those files later. */
8240 clear_failure_queue ();
8243 /* Reset the input file name to the first compile/object file name, for use
8244 with %b in LINK_SPEC. We use the first input file that we can find
8245 a compiler to compile it instead of using infiles.language since for
8246 languages other than C we use aliases that we then lookup later. */
8247 if (n_infiles > 0)
8249 int i;
8251 for (i = 0; i < n_infiles ; i++)
8252 if (infiles[i].incompiler
8253 || (infiles[i].language && infiles[i].language[0] != '*'))
8255 set_input (infiles[i].name);
8256 break;
8260 if (!seen_error ())
8262 /* Make sure INPUT_FILE_NUMBER points to first available open
8263 slot. */
8264 input_file_number = n_infiles;
8265 if (lang_specific_pre_link ())
8266 errorcount++;
8270 /* If we have to run the linker, do it now. */
8272 void
8273 driver::maybe_run_linker (const char *argv0) const
8275 size_t i;
8276 int linker_was_run = 0;
8277 int num_linker_inputs;
8279 /* Determine if there are any linker input files. */
8280 num_linker_inputs = 0;
8281 for (i = 0; (int) i < n_infiles; i++)
8282 if (explicit_link_files[i] || outfiles[i] != NULL)
8283 num_linker_inputs++;
8285 /* Run ld to link all the compiler output files. */
8287 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
8289 int tmp = execution_count;
8291 if (! have_c)
8293 #if HAVE_LTO_PLUGIN > 0
8294 #if HAVE_LTO_PLUGIN == 2
8295 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
8296 #else
8297 const char *fuse_linker_plugin = "fuse-linker-plugin";
8298 #endif
8299 #endif
8301 /* We'll use ld if we can't find collect2. */
8302 if (! strcmp (linker_name_spec, "collect2"))
8304 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
8305 if (s == NULL)
8306 linker_name_spec = "ld";
8309 #if HAVE_LTO_PLUGIN > 0
8310 #if HAVE_LTO_PLUGIN == 2
8311 if (!switch_matches (fno_use_linker_plugin,
8312 fno_use_linker_plugin
8313 + strlen (fno_use_linker_plugin), 0))
8314 #else
8315 if (switch_matches (fuse_linker_plugin,
8316 fuse_linker_plugin
8317 + strlen (fuse_linker_plugin), 0))
8318 #endif
8320 char *temp_spec = find_a_file (&exec_prefixes,
8321 LTOPLUGINSONAME, R_OK,
8322 false);
8323 if (!temp_spec)
8324 fatal_error (input_location,
8325 "-fuse-linker-plugin, but %s not found",
8326 LTOPLUGINSONAME);
8327 linker_plugin_file_spec = convert_white_space (temp_spec);
8329 #endif
8330 lto_gcc_spec = argv0;
8333 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
8334 for collect. */
8335 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
8336 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
8338 if (print_subprocess_help == 1)
8340 printf (_("\nLinker options\n==============\n\n"));
8341 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
8342 " to the linker.\n\n"));
8343 fflush (stdout);
8345 int value = do_spec (link_command_spec);
8346 if (value < 0)
8347 errorcount = 1;
8348 linker_was_run = (tmp != execution_count);
8351 /* If options said don't run linker,
8352 complain about input files to be given to the linker. */
8354 if (! linker_was_run && !seen_error ())
8355 for (i = 0; (int) i < n_infiles; i++)
8356 if (explicit_link_files[i]
8357 && !(infiles[i].language && infiles[i].language[0] == '*'))
8358 warning (0, "%s: linker input file unused because linking not done",
8359 outfiles[i]);
8362 /* The end of "main". */
8364 void
8365 driver::final_actions () const
8367 /* Delete some or all of the temporary files we made. */
8369 if (seen_error ())
8370 delete_failure_queue ();
8371 delete_temp_files ();
8373 if (print_help_list)
8375 printf (("\nFor bug reporting instructions, please see:\n"));
8376 printf ("%s\n", bug_report_url);
8380 /* Determine what the exit code of the driver should be. */
8383 driver::get_exit_code () const
8385 return (signal_count != 0 ? 2
8386 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
8387 : 0);
8390 /* Find the proper compilation spec for the file name NAME,
8391 whose length is LENGTH. LANGUAGE is the specified language,
8392 or 0 if this file is to be passed to the linker. */
8394 static struct compiler *
8395 lookup_compiler (const char *name, size_t length, const char *language)
8397 struct compiler *cp;
8399 /* If this was specified by the user to be a linker input, indicate that. */
8400 if (language != 0 && language[0] == '*')
8401 return 0;
8403 /* Otherwise, look for the language, if one is spec'd. */
8404 if (language != 0)
8406 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8407 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
8409 if (name != NULL && strcmp (name, "-") == 0
8410 && (strcmp (cp->suffix, "@c-header") == 0
8411 || strcmp (cp->suffix, "@c++-header") == 0)
8412 && !have_E)
8413 fatal_error (input_location,
8414 "cannot use %<-%> as input filename for a "
8415 "precompiled header");
8417 return cp;
8420 error ("language %s not recognized", language);
8421 return 0;
8424 /* Look for a suffix. */
8425 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8427 if (/* The suffix `-' matches only the file name `-'. */
8428 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
8429 || (strlen (cp->suffix) < length
8430 /* See if the suffix matches the end of NAME. */
8431 && !strcmp (cp->suffix,
8432 name + length - strlen (cp->suffix))
8434 break;
8437 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
8438 /* Look again, but case-insensitively this time. */
8439 if (cp < compilers)
8440 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
8442 if (/* The suffix `-' matches only the file name `-'. */
8443 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
8444 || (strlen (cp->suffix) < length
8445 /* See if the suffix matches the end of NAME. */
8446 && ((!strcmp (cp->suffix,
8447 name + length - strlen (cp->suffix))
8448 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
8449 && !strcasecmp (cp->suffix,
8450 name + length - strlen (cp->suffix)))
8452 break;
8454 #endif
8456 if (cp >= compilers)
8458 if (cp->spec[0] != '@')
8459 /* A non-alias entry: return it. */
8460 return cp;
8462 /* An alias entry maps a suffix to a language.
8463 Search for the language; pass 0 for NAME and LENGTH
8464 to avoid infinite recursion if language not found. */
8465 return lookup_compiler (NULL, 0, cp->spec + 1);
8467 return 0;
8470 static char *
8471 save_string (const char *s, int len)
8473 char *result = XNEWVEC (char, len + 1);
8475 gcc_checking_assert (strlen (s) >= (unsigned int) len);
8476 memcpy (result, s, len);
8477 result[len] = 0;
8478 return result;
8481 void
8482 pfatal_with_name (const char *name)
8484 perror_with_name (name);
8485 delete_temp_files ();
8486 exit (1);
8489 static void
8490 perror_with_name (const char *name)
8492 error ("%s: %m", name);
8495 static inline void
8496 validate_switches_from_spec (const char *spec, bool user)
8498 const char *p = spec;
8499 char c;
8500 while ((c = *p++))
8501 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
8502 /* We have a switch spec. */
8503 p = validate_switches (p + 1, user);
8506 static void
8507 validate_all_switches (void)
8509 struct compiler *comp;
8510 struct spec_list *spec;
8512 for (comp = compilers; comp->spec; comp++)
8513 validate_switches_from_spec (comp->spec, false);
8515 /* Look through the linked list of specs read from the specs file. */
8516 for (spec = specs; spec; spec = spec->next)
8517 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
8519 validate_switches_from_spec (link_command_spec, false);
8522 /* Look at the switch-name that comes after START
8523 and mark as valid all supplied switches that match it. */
8525 static const char *
8526 validate_switches (const char *start, bool user_spec)
8528 const char *p = start;
8529 const char *atom;
8530 size_t len;
8531 int i;
8532 bool suffix = false;
8533 bool starred = false;
8535 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
8537 next_member:
8538 SKIP_WHITE ();
8540 if (*p == '!')
8541 p++;
8543 SKIP_WHITE ();
8544 if (*p == '.' || *p == ',')
8545 suffix = true, p++;
8547 atom = p;
8548 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
8549 || *p == ',' || *p == '.' || *p == '@')
8550 p++;
8551 len = p - atom;
8553 if (*p == '*')
8554 starred = true, p++;
8556 SKIP_WHITE ();
8558 if (!suffix)
8560 /* Mark all matching switches as valid. */
8561 for (i = 0; i < n_switches; i++)
8562 if (!strncmp (switches[i].part1, atom, len)
8563 && (starred || switches[i].part1[len] == '\0')
8564 && (switches[i].known || user_spec))
8565 switches[i].validated = true;
8568 if (*p) p++;
8569 if (*p && (p[-1] == '|' || p[-1] == '&'))
8570 goto next_member;
8572 if (*p && p[-1] == ':')
8574 while (*p && *p != ';' && *p != '}')
8576 if (*p == '%')
8578 p++;
8579 if (*p == '{' || *p == '<')
8580 p = validate_switches (p+1, user_spec);
8581 else if (p[0] == 'W' && p[1] == '{')
8582 p = validate_switches (p+2, user_spec);
8584 else
8585 p++;
8588 if (*p) p++;
8589 if (*p && p[-1] == ';')
8590 goto next_member;
8593 return p;
8594 #undef SKIP_WHITE
8597 struct mdswitchstr
8599 const char *str;
8600 int len;
8603 static struct mdswitchstr *mdswitches;
8604 static int n_mdswitches;
8606 /* Check whether a particular argument was used. The first time we
8607 canonicalize the switches to keep only the ones we care about. */
8609 class used_arg_t
8611 public:
8612 int operator () (const char *p, int len);
8613 void finalize ();
8615 private:
8616 struct mswitchstr
8618 const char *str;
8619 const char *replace;
8620 int len;
8621 int rep_len;
8624 mswitchstr *mswitches;
8625 int n_mswitches;
8629 used_arg_t used_arg;
8632 used_arg_t::operator () (const char *p, int len)
8634 int i, j;
8636 if (!mswitches)
8638 struct mswitchstr *matches;
8639 const char *q;
8640 int cnt = 0;
8642 /* Break multilib_matches into the component strings of string
8643 and replacement string. */
8644 for (q = multilib_matches; *q != '\0'; q++)
8645 if (*q == ';')
8646 cnt++;
8648 matches
8649 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
8650 i = 0;
8651 q = multilib_matches;
8652 while (*q != '\0')
8654 matches[i].str = q;
8655 while (*q != ' ')
8657 if (*q == '\0')
8659 invalid_matches:
8660 fatal_error (input_location, "multilib spec %qs is invalid",
8661 multilib_matches);
8663 q++;
8665 matches[i].len = q - matches[i].str;
8667 matches[i].replace = ++q;
8668 while (*q != ';' && *q != '\0')
8670 if (*q == ' ')
8671 goto invalid_matches;
8672 q++;
8674 matches[i].rep_len = q - matches[i].replace;
8675 i++;
8676 if (*q == ';')
8677 q++;
8680 /* Now build a list of the replacement string for switches that we care
8681 about. Make sure we allocate at least one entry. This prevents
8682 xmalloc from calling fatal, and prevents us from re-executing this
8683 block of code. */
8684 mswitches
8685 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
8686 for (i = 0; i < n_switches; i++)
8687 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
8689 int xlen = strlen (switches[i].part1);
8690 for (j = 0; j < cnt; j++)
8691 if (xlen == matches[j].len
8692 && ! strncmp (switches[i].part1, matches[j].str, xlen))
8694 mswitches[n_mswitches].str = matches[j].replace;
8695 mswitches[n_mswitches].len = matches[j].rep_len;
8696 mswitches[n_mswitches].replace = (char *) 0;
8697 mswitches[n_mswitches].rep_len = 0;
8698 n_mswitches++;
8699 break;
8703 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
8704 on the command line nor any options mutually incompatible with
8705 them. */
8706 for (i = 0; i < n_mdswitches; i++)
8708 const char *r;
8710 for (q = multilib_options; *q != '\0'; *q && q++)
8712 while (*q == ' ')
8713 q++;
8715 r = q;
8716 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
8717 || strchr (" /", q[mdswitches[i].len]) == NULL)
8719 while (*q != ' ' && *q != '/' && *q != '\0')
8720 q++;
8721 if (*q != '/')
8722 break;
8723 q++;
8726 if (*q != ' ' && *q != '\0')
8728 while (*r != ' ' && *r != '\0')
8730 q = r;
8731 while (*q != ' ' && *q != '/' && *q != '\0')
8732 q++;
8734 if (used_arg (r, q - r))
8735 break;
8737 if (*q != '/')
8739 mswitches[n_mswitches].str = mdswitches[i].str;
8740 mswitches[n_mswitches].len = mdswitches[i].len;
8741 mswitches[n_mswitches].replace = (char *) 0;
8742 mswitches[n_mswitches].rep_len = 0;
8743 n_mswitches++;
8744 break;
8747 r = q + 1;
8749 break;
8755 for (i = 0; i < n_mswitches; i++)
8756 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
8757 return 1;
8759 return 0;
8762 void used_arg_t::finalize ()
8764 XDELETEVEC (mswitches);
8765 mswitches = NULL;
8766 n_mswitches = 0;
8770 static int
8771 default_arg (const char *p, int len)
8773 int i;
8775 for (i = 0; i < n_mdswitches; i++)
8776 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
8777 return 1;
8779 return 0;
8782 /* Work out the subdirectory to use based on the options. The format of
8783 multilib_select is a list of elements. Each element is a subdirectory
8784 name followed by a list of options followed by a semicolon. The format
8785 of multilib_exclusions is the same, but without the preceding
8786 directory. First gcc will check the exclusions, if none of the options
8787 beginning with an exclamation point are present, and all of the other
8788 options are present, then we will ignore this completely. Passing
8789 that, gcc will consider each multilib_select in turn using the same
8790 rules for matching the options. If a match is found, that subdirectory
8791 will be used.
8792 A subdirectory name is optionally followed by a colon and the corresponding
8793 multiarch name. */
8795 static void
8796 set_multilib_dir (void)
8798 const char *p;
8799 unsigned int this_path_len;
8800 const char *this_path, *this_arg;
8801 const char *start, *end;
8802 int not_arg;
8803 int ok, ndfltok, first;
8805 n_mdswitches = 0;
8806 start = multilib_defaults;
8807 while (*start == ' ' || *start == '\t')
8808 start++;
8809 while (*start != '\0')
8811 n_mdswitches++;
8812 while (*start != ' ' && *start != '\t' && *start != '\0')
8813 start++;
8814 while (*start == ' ' || *start == '\t')
8815 start++;
8818 if (n_mdswitches)
8820 int i = 0;
8822 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
8823 for (start = multilib_defaults; *start != '\0'; start = end + 1)
8825 while (*start == ' ' || *start == '\t')
8826 start++;
8828 if (*start == '\0')
8829 break;
8831 for (end = start + 1;
8832 *end != ' ' && *end != '\t' && *end != '\0'; end++)
8835 obstack_grow (&multilib_obstack, start, end - start);
8836 obstack_1grow (&multilib_obstack, 0);
8837 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
8838 mdswitches[i++].len = end - start;
8840 if (*end == '\0')
8841 break;
8845 p = multilib_exclusions;
8846 while (*p != '\0')
8848 /* Ignore newlines. */
8849 if (*p == '\n')
8851 ++p;
8852 continue;
8855 /* Check the arguments. */
8856 ok = 1;
8857 while (*p != ';')
8859 if (*p == '\0')
8861 invalid_exclusions:
8862 fatal_error (input_location, "multilib exclusions %qs is invalid",
8863 multilib_exclusions);
8866 if (! ok)
8868 ++p;
8869 continue;
8872 this_arg = p;
8873 while (*p != ' ' && *p != ';')
8875 if (*p == '\0')
8876 goto invalid_exclusions;
8877 ++p;
8880 if (*this_arg != '!')
8881 not_arg = 0;
8882 else
8884 not_arg = 1;
8885 ++this_arg;
8888 ok = used_arg (this_arg, p - this_arg);
8889 if (not_arg)
8890 ok = ! ok;
8892 if (*p == ' ')
8893 ++p;
8896 if (ok)
8897 return;
8899 ++p;
8902 first = 1;
8903 p = multilib_select;
8905 /* Append multilib reuse rules if any. With those rules, we can reuse
8906 one multilib for certain different options sets. */
8907 if (strlen (multilib_reuse) > 0)
8908 p = concat (p, multilib_reuse, NULL);
8910 while (*p != '\0')
8912 /* Ignore newlines. */
8913 if (*p == '\n')
8915 ++p;
8916 continue;
8919 /* Get the initial path. */
8920 this_path = p;
8921 while (*p != ' ')
8923 if (*p == '\0')
8925 invalid_select:
8926 fatal_error (input_location, "multilib select %qs %qs is invalid",
8927 multilib_select, multilib_reuse);
8929 ++p;
8931 this_path_len = p - this_path;
8933 /* Check the arguments. */
8934 ok = 1;
8935 ndfltok = 1;
8936 ++p;
8937 while (*p != ';')
8939 if (*p == '\0')
8940 goto invalid_select;
8942 if (! ok)
8944 ++p;
8945 continue;
8948 this_arg = p;
8949 while (*p != ' ' && *p != ';')
8951 if (*p == '\0')
8952 goto invalid_select;
8953 ++p;
8956 if (*this_arg != '!')
8957 not_arg = 0;
8958 else
8960 not_arg = 1;
8961 ++this_arg;
8964 /* If this is a default argument, we can just ignore it.
8965 This is true even if this_arg begins with '!'. Beginning
8966 with '!' does not mean that this argument is necessarily
8967 inappropriate for this library: it merely means that
8968 there is a more specific library which uses this
8969 argument. If this argument is a default, we need not
8970 consider that more specific library. */
8971 ok = used_arg (this_arg, p - this_arg);
8972 if (not_arg)
8973 ok = ! ok;
8975 if (! ok)
8976 ndfltok = 0;
8978 if (default_arg (this_arg, p - this_arg))
8979 ok = 1;
8981 if (*p == ' ')
8982 ++p;
8985 if (ok && first)
8987 if (this_path_len != 1
8988 || this_path[0] != '.')
8990 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
8991 char *q;
8993 strncpy (new_multilib_dir, this_path, this_path_len);
8994 new_multilib_dir[this_path_len] = '\0';
8995 q = strchr (new_multilib_dir, ':');
8996 if (q != NULL)
8997 *q = '\0';
8998 multilib_dir = new_multilib_dir;
9000 first = 0;
9003 if (ndfltok)
9005 const char *q = this_path, *end = this_path + this_path_len;
9007 while (q < end && *q != ':')
9008 q++;
9009 if (q < end)
9011 const char *q2 = q + 1, *ml_end = end;
9012 char *new_multilib_os_dir;
9014 while (q2 < end && *q2 != ':')
9015 q2++;
9016 if (*q2 == ':')
9017 ml_end = q2;
9018 if (ml_end - q == 1)
9019 multilib_os_dir = xstrdup (".");
9020 else
9022 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
9023 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
9024 new_multilib_os_dir[ml_end - q - 1] = '\0';
9025 multilib_os_dir = new_multilib_os_dir;
9028 if (q2 < end && *q2 == ':')
9030 char *new_multiarch_dir = XNEWVEC (char, end - q2);
9031 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
9032 new_multiarch_dir[end - q2 - 1] = '\0';
9033 multiarch_dir = new_multiarch_dir;
9035 break;
9039 ++p;
9042 if (multilib_dir == NULL && multilib_os_dir != NULL
9043 && strcmp (multilib_os_dir, ".") == 0)
9045 free (CONST_CAST (char *, multilib_os_dir));
9046 multilib_os_dir = NULL;
9048 else if (multilib_dir != NULL && multilib_os_dir == NULL)
9049 multilib_os_dir = multilib_dir;
9052 /* Print out the multiple library subdirectory selection
9053 information. This prints out a series of lines. Each line looks
9054 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
9055 required. Only the desired options are printed out, the negative
9056 matches. The options are print without a leading dash. There are
9057 no spaces to make it easy to use the information in the shell.
9058 Each subdirectory is printed only once. This assumes the ordering
9059 generated by the genmultilib script. Also, we leave out ones that match
9060 the exclusions. */
9062 static void
9063 print_multilib_info (void)
9065 const char *p = multilib_select;
9066 const char *last_path = 0, *this_path;
9067 int skip;
9068 unsigned int last_path_len = 0;
9070 while (*p != '\0')
9072 skip = 0;
9073 /* Ignore newlines. */
9074 if (*p == '\n')
9076 ++p;
9077 continue;
9080 /* Get the initial path. */
9081 this_path = p;
9082 while (*p != ' ')
9084 if (*p == '\0')
9086 invalid_select:
9087 fatal_error (input_location,
9088 "multilib select %qs is invalid", multilib_select);
9091 ++p;
9094 /* When --disable-multilib was used but target defines
9095 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
9096 with .:: for multiarch configurations) are there just to find
9097 multilib_os_dir, so skip them from output. */
9098 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
9099 skip = 1;
9101 /* Check for matches with the multilib_exclusions. We don't bother
9102 with the '!' in either list. If any of the exclusion rules match
9103 all of its options with the select rule, we skip it. */
9105 const char *e = multilib_exclusions;
9106 const char *this_arg;
9108 while (*e != '\0')
9110 int m = 1;
9111 /* Ignore newlines. */
9112 if (*e == '\n')
9114 ++e;
9115 continue;
9118 /* Check the arguments. */
9119 while (*e != ';')
9121 const char *q;
9122 int mp = 0;
9124 if (*e == '\0')
9126 invalid_exclusion:
9127 fatal_error (input_location,
9128 "multilib exclusion %qs is invalid",
9129 multilib_exclusions);
9132 if (! m)
9134 ++e;
9135 continue;
9138 this_arg = e;
9140 while (*e != ' ' && *e != ';')
9142 if (*e == '\0')
9143 goto invalid_exclusion;
9144 ++e;
9147 q = p + 1;
9148 while (*q != ';')
9150 const char *arg;
9151 int len = e - this_arg;
9153 if (*q == '\0')
9154 goto invalid_select;
9156 arg = q;
9158 while (*q != ' ' && *q != ';')
9160 if (*q == '\0')
9161 goto invalid_select;
9162 ++q;
9165 if (! strncmp (arg, this_arg,
9166 (len < q - arg) ? q - arg : len)
9167 || default_arg (this_arg, e - this_arg))
9169 mp = 1;
9170 break;
9173 if (*q == ' ')
9174 ++q;
9177 if (! mp)
9178 m = 0;
9180 if (*e == ' ')
9181 ++e;
9184 if (m)
9186 skip = 1;
9187 break;
9190 if (*e != '\0')
9191 ++e;
9195 if (! skip)
9197 /* If this is a duplicate, skip it. */
9198 skip = (last_path != 0
9199 && (unsigned int) (p - this_path) == last_path_len
9200 && ! filename_ncmp (last_path, this_path, last_path_len));
9202 last_path = this_path;
9203 last_path_len = p - this_path;
9206 /* If this directory requires any default arguments, we can skip
9207 it. We will already have printed a directory identical to
9208 this one which does not require that default argument. */
9209 if (! skip)
9211 const char *q;
9213 q = p + 1;
9214 while (*q != ';')
9216 const char *arg;
9218 if (*q == '\0')
9219 goto invalid_select;
9221 if (*q == '!')
9222 arg = NULL;
9223 else
9224 arg = q;
9226 while (*q != ' ' && *q != ';')
9228 if (*q == '\0')
9229 goto invalid_select;
9230 ++q;
9233 if (arg != NULL
9234 && default_arg (arg, q - arg))
9236 skip = 1;
9237 break;
9240 if (*q == ' ')
9241 ++q;
9245 if (! skip)
9247 const char *p1;
9249 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
9250 putchar (*p1);
9251 putchar (';');
9254 ++p;
9255 while (*p != ';')
9257 int use_arg;
9259 if (*p == '\0')
9260 goto invalid_select;
9262 if (skip)
9264 ++p;
9265 continue;
9268 use_arg = *p != '!';
9270 if (use_arg)
9271 putchar ('@');
9273 while (*p != ' ' && *p != ';')
9275 if (*p == '\0')
9276 goto invalid_select;
9277 if (use_arg)
9278 putchar (*p);
9279 ++p;
9282 if (*p == ' ')
9283 ++p;
9286 if (! skip)
9288 /* If there are extra options, print them now. */
9289 if (multilib_extra && *multilib_extra)
9291 int print_at = TRUE;
9292 const char *q;
9294 for (q = multilib_extra; *q != '\0'; q++)
9296 if (*q == ' ')
9297 print_at = TRUE;
9298 else
9300 if (print_at)
9301 putchar ('@');
9302 putchar (*q);
9303 print_at = FALSE;
9308 putchar ('\n');
9311 ++p;
9315 /* getenv built-in spec function.
9317 Returns the value of the environment variable given by its first argument,
9318 concatenated with the second argument. If the variable is not defined, a
9319 fatal error is issued unless such undefs are internally allowed, in which
9320 case the variable name is used as the variable value. */
9322 static const char *
9323 getenv_spec_function (int argc, const char **argv)
9325 const char *value;
9326 const char *varname;
9328 char *result;
9329 char *ptr;
9330 size_t len;
9332 if (argc != 2)
9333 return NULL;
9335 varname = argv[0];
9336 value = env.get (varname);
9338 if (!value && spec_undefvar_allowed)
9339 value = varname;
9341 if (!value)
9342 fatal_error (input_location,
9343 "environment variable %qs not defined", varname);
9345 /* We have to escape every character of the environment variable so
9346 they are not interpreted as active spec characters. A
9347 particularly painful case is when we are reading a variable
9348 holding a windows path complete with \ separators. */
9349 len = strlen (value) * 2 + strlen (argv[1]) + 1;
9350 result = XNEWVAR (char, len);
9351 for (ptr = result; *value; ptr += 2)
9353 ptr[0] = '\\';
9354 ptr[1] = *value++;
9357 strcpy (ptr, argv[1]);
9359 return result;
9362 /* if-exists built-in spec function.
9364 Checks to see if the file specified by the absolute pathname in
9365 ARGS exists. Returns that pathname if found.
9367 The usual use for this function is to check for a library file
9368 (whose name has been expanded with %s). */
9370 static const char *
9371 if_exists_spec_function (int argc, const char **argv)
9373 /* Must have only one argument. */
9374 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
9375 return argv[0];
9377 return NULL;
9380 /* if-exists-else built-in spec function.
9382 This is like if-exists, but takes an additional argument which
9383 is returned if the first argument does not exist. */
9385 static const char *
9386 if_exists_else_spec_function (int argc, const char **argv)
9388 /* Must have exactly two arguments. */
9389 if (argc != 2)
9390 return NULL;
9392 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
9393 return argv[0];
9395 return argv[1];
9398 /* sanitize built-in spec function.
9400 This returns non-NULL, if sanitizing address, thread or
9401 any of the undefined behavior sanitizers. */
9403 static const char *
9404 sanitize_spec_function (int argc, const char **argv)
9406 if (argc != 1)
9407 return NULL;
9409 if (strcmp (argv[0], "address") == 0)
9410 return (flag_sanitize & SANITIZE_USER_ADDRESS) ? "" : NULL;
9411 if (strcmp (argv[0], "kernel-address") == 0)
9412 return (flag_sanitize & SANITIZE_KERNEL_ADDRESS) ? "" : NULL;
9413 if (strcmp (argv[0], "thread") == 0)
9414 return (flag_sanitize & SANITIZE_THREAD) ? "" : NULL;
9415 if (strcmp (argv[0], "undefined") == 0)
9416 return ((flag_sanitize
9417 & (SANITIZE_UNDEFINED | SANITIZE_UNDEFINED_NONDEFAULT))
9418 && !flag_sanitize_undefined_trap_on_error) ? "" : NULL;
9419 if (strcmp (argv[0], "leak") == 0)
9420 return ((flag_sanitize
9421 & (SANITIZE_ADDRESS | SANITIZE_LEAK | SANITIZE_THREAD))
9422 == SANITIZE_LEAK) ? "" : NULL;
9423 return NULL;
9426 /* replace-outfile built-in spec function.
9428 This looks for the first argument in the outfiles array's name and
9429 replaces it with the second argument. */
9431 static const char *
9432 replace_outfile_spec_function (int argc, const char **argv)
9434 int i;
9435 /* Must have exactly two arguments. */
9436 if (argc != 2)
9437 abort ();
9439 for (i = 0; i < n_infiles; i++)
9441 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
9442 outfiles[i] = xstrdup (argv[1]);
9444 return NULL;
9447 /* remove-outfile built-in spec function.
9449 * This looks for the first argument in the outfiles array's name and
9450 * removes it. */
9452 static const char *
9453 remove_outfile_spec_function (int argc, const char **argv)
9455 int i;
9456 /* Must have exactly one argument. */
9457 if (argc != 1)
9458 abort ();
9460 for (i = 0; i < n_infiles; i++)
9462 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
9463 outfiles[i] = NULL;
9465 return NULL;
9468 /* Given two version numbers, compares the two numbers.
9469 A version number must match the regular expression
9470 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
9472 static int
9473 compare_version_strings (const char *v1, const char *v2)
9475 int rresult;
9476 regex_t r;
9478 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
9479 REG_EXTENDED | REG_NOSUB) != 0)
9480 abort ();
9481 rresult = regexec (&r, v1, 0, NULL, 0);
9482 if (rresult == REG_NOMATCH)
9483 fatal_error (input_location, "invalid version number %qs", v1);
9484 else if (rresult != 0)
9485 abort ();
9486 rresult = regexec (&r, v2, 0, NULL, 0);
9487 if (rresult == REG_NOMATCH)
9488 fatal_error (input_location, "invalid version number %qs", v2);
9489 else if (rresult != 0)
9490 abort ();
9492 return strverscmp (v1, v2);
9496 /* version_compare built-in spec function.
9498 This takes an argument of the following form:
9500 <comparison-op> <arg1> [<arg2>] <switch> <result>
9502 and produces "result" if the comparison evaluates to true,
9503 and nothing if it doesn't.
9505 The supported <comparison-op> values are:
9507 >= true if switch is a later (or same) version than arg1
9508 !> opposite of >=
9509 < true if switch is an earlier version than arg1
9510 !< opposite of <
9511 >< true if switch is arg1 or later, and earlier than arg2
9512 <> true if switch is earlier than arg1 or is arg2 or later
9514 If the switch is not present, the condition is false unless
9515 the first character of the <comparison-op> is '!'.
9517 For example,
9518 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
9519 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
9521 static const char *
9522 version_compare_spec_function (int argc, const char **argv)
9524 int comp1, comp2;
9525 size_t switch_len;
9526 const char *switch_value = NULL;
9527 int nargs = 1, i;
9528 bool result;
9530 if (argc < 3)
9531 fatal_error (input_location, "too few arguments to %%:version-compare");
9532 if (argv[0][0] == '\0')
9533 abort ();
9534 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
9535 nargs = 2;
9536 if (argc != nargs + 3)
9537 fatal_error (input_location, "too many arguments to %%:version-compare");
9539 switch_len = strlen (argv[nargs + 1]);
9540 for (i = 0; i < n_switches; i++)
9541 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
9542 && check_live_switch (i, switch_len))
9543 switch_value = switches[i].part1 + switch_len;
9545 if (switch_value == NULL)
9546 comp1 = comp2 = -1;
9547 else
9549 comp1 = compare_version_strings (switch_value, argv[1]);
9550 if (nargs == 2)
9551 comp2 = compare_version_strings (switch_value, argv[2]);
9552 else
9553 comp2 = -1; /* This value unused. */
9556 switch (argv[0][0] << 8 | argv[0][1])
9558 case '>' << 8 | '=':
9559 result = comp1 >= 0;
9560 break;
9561 case '!' << 8 | '<':
9562 result = comp1 >= 0 || switch_value == NULL;
9563 break;
9564 case '<' << 8:
9565 result = comp1 < 0;
9566 break;
9567 case '!' << 8 | '>':
9568 result = comp1 < 0 || switch_value == NULL;
9569 break;
9570 case '>' << 8 | '<':
9571 result = comp1 >= 0 && comp2 < 0;
9572 break;
9573 case '<' << 8 | '>':
9574 result = comp1 < 0 || comp2 >= 0;
9575 break;
9577 default:
9578 fatal_error (input_location,
9579 "unknown operator %qs in %%:version-compare", argv[0]);
9581 if (! result)
9582 return NULL;
9584 return argv[nargs + 2];
9587 /* %:include builtin spec function. This differs from %include in that it
9588 can be nested inside a spec, and thus be conditionalized. It takes
9589 one argument, the filename, and looks for it in the startfile path.
9590 The result is always NULL, i.e. an empty expansion. */
9592 static const char *
9593 include_spec_function (int argc, const char **argv)
9595 char *file;
9597 if (argc != 1)
9598 abort ();
9600 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
9601 read_specs (file ? file : argv[0], false, false);
9603 return NULL;
9606 /* %:find-file spec function. This function replaces its argument by
9607 the file found through find_file, that is the -print-file-name gcc
9608 program option. */
9609 static const char *
9610 find_file_spec_function (int argc, const char **argv)
9612 const char *file;
9614 if (argc != 1)
9615 abort ();
9617 file = find_file (argv[0]);
9618 return file;
9622 /* %:find-plugindir spec function. This function replaces its argument
9623 by the -iplugindir=<dir> option. `dir' is found through find_file, that
9624 is the -print-file-name gcc program option. */
9625 static const char *
9626 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
9628 const char *option;
9630 if (argc != 0)
9631 abort ();
9633 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
9634 return option;
9638 /* %:print-asm-header spec function. Print a banner to say that the
9639 following output is from the assembler. */
9641 static const char *
9642 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
9643 const char **argv ATTRIBUTE_UNUSED)
9645 printf (_("Assembler options\n=================\n\n"));
9646 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
9647 fflush (stdout);
9648 return NULL;
9651 /* Get a random number for -frandom-seed */
9653 static unsigned HOST_WIDE_INT
9654 get_random_number (void)
9656 unsigned HOST_WIDE_INT ret = 0;
9657 int fd;
9659 fd = open ("/dev/urandom", O_RDONLY);
9660 if (fd >= 0)
9662 read (fd, &ret, sizeof (HOST_WIDE_INT));
9663 close (fd);
9664 if (ret)
9665 return ret;
9668 /* Get some more or less random data. */
9669 #ifdef HAVE_GETTIMEOFDAY
9671 struct timeval tv;
9673 gettimeofday (&tv, NULL);
9674 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
9676 #else
9678 time_t now = time (NULL);
9680 if (now != (time_t)-1)
9681 ret = (unsigned) now;
9683 #endif
9685 return ret ^ getpid ();
9688 /* %:compare-debug-dump-opt spec function. Save the last argument,
9689 expected to be the last -fdump-final-insns option, or generate a
9690 temporary. */
9692 static const char *
9693 compare_debug_dump_opt_spec_function (int arg,
9694 const char **argv ATTRIBUTE_UNUSED)
9696 char *ret;
9697 char *name;
9698 int which;
9699 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
9701 if (arg != 0)
9702 fatal_error (input_location,
9703 "too many arguments to %%:compare-debug-dump-opt");
9705 do_spec_2 ("%{fdump-final-insns=*:%*}");
9706 do_spec_1 (" ", 0, NULL);
9708 if (argbuf.length () > 0
9709 && strcmp (argv[argbuf.length () - 1], "."))
9711 if (!compare_debug)
9712 return NULL;
9714 name = xstrdup (argv[argbuf.length () - 1]);
9715 ret = NULL;
9717 else
9719 const char *ext = NULL;
9721 if (argbuf.length () > 0)
9723 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
9724 ext = ".gkd";
9726 else if (!compare_debug)
9727 return NULL;
9728 else
9729 do_spec_2 ("%g.gkd");
9731 do_spec_1 (" ", 0, NULL);
9733 gcc_assert (argbuf.length () > 0);
9735 name = concat (argbuf.last (), ext, NULL);
9737 ret = concat ("-fdump-final-insns=", name, NULL);
9740 which = compare_debug < 0;
9741 debug_check_temp_file[which] = name;
9743 if (!which)
9745 unsigned HOST_WIDE_INT value = get_random_number ();
9747 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
9750 if (*random_seed)
9752 char *tmp = ret;
9753 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
9754 ret, NULL);
9755 free (tmp);
9758 if (which)
9759 *random_seed = 0;
9761 return ret;
9764 static const char *debug_auxbase_opt;
9766 /* %:compare-debug-self-opt spec function. Expands to the options
9767 that are to be passed in the second compilation of
9768 compare-debug. */
9770 static const char *
9771 compare_debug_self_opt_spec_function (int arg,
9772 const char **argv ATTRIBUTE_UNUSED)
9774 if (arg != 0)
9775 fatal_error (input_location,
9776 "too many arguments to %%:compare-debug-self-opt");
9778 if (compare_debug >= 0)
9779 return NULL;
9781 do_spec_2 ("%{c|S:%{o*:%*}}");
9782 do_spec_1 (" ", 0, NULL);
9784 if (argbuf.length () > 0)
9785 debug_auxbase_opt = concat ("-auxbase-strip ",
9786 argbuf.last (),
9787 NULL);
9788 else
9789 debug_auxbase_opt = NULL;
9791 return concat ("\
9792 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
9793 %<fdump-final-insns=* -w -S -o %j \
9794 %{!fcompare-debug-second:-fcompare-debug-second} \
9795 ", compare_debug_opt, NULL);
9798 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
9799 options that are to be passed in the second compilation of
9800 compare-debug. It expects, as an argument, the basename of the
9801 current input file name, with the .gk suffix appended to it. */
9803 static const char *
9804 compare_debug_auxbase_opt_spec_function (int arg,
9805 const char **argv)
9807 char *name;
9808 int len;
9810 if (arg == 0)
9811 fatal_error (input_location,
9812 "too few arguments to %%:compare-debug-auxbase-opt");
9814 if (arg != 1)
9815 fatal_error (input_location,
9816 "too many arguments to %%:compare-debug-auxbase-opt");
9818 if (compare_debug >= 0)
9819 return NULL;
9821 len = strlen (argv[0]);
9822 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
9823 fatal_error (input_location, "argument to %%:compare-debug-auxbase-opt "
9824 "does not end in .gk");
9826 if (debug_auxbase_opt)
9827 return debug_auxbase_opt;
9829 #define OPT "-auxbase "
9831 len -= 3;
9832 name = (char*) xmalloc (sizeof (OPT) + len);
9833 memcpy (name, OPT, sizeof (OPT) - 1);
9834 memcpy (name + sizeof (OPT) - 1, argv[0], len);
9835 name[sizeof (OPT) - 1 + len] = '\0';
9837 #undef OPT
9839 return name;
9842 /* %:pass-through-libs spec function. Finds all -l options and input
9843 file names in the lib spec passed to it, and makes a list of them
9844 prepended with the plugin option to cause them to be passed through
9845 to the final link after all the new object files have been added. */
9847 const char *
9848 pass_through_libs_spec_func (int argc, const char **argv)
9850 char *prepended = xstrdup (" ");
9851 int n;
9852 /* Shlemiel the painter's algorithm. Innately horrible, but at least
9853 we know that there will never be more than a handful of strings to
9854 concat, and it's only once per run, so it's not worth optimising. */
9855 for (n = 0; n < argc; n++)
9857 char *old = prepended;
9858 /* Anything that isn't an option is a full path to an output
9859 file; pass it through if it ends in '.a'. Among options,
9860 pass only -l. */
9861 if (argv[n][0] == '-' && argv[n][1] == 'l')
9863 const char *lopt = argv[n] + 2;
9864 /* Handle both joined and non-joined -l options. If for any
9865 reason there's a trailing -l with no joined or following
9866 arg just discard it. */
9867 if (!*lopt && ++n >= argc)
9868 break;
9869 else if (!*lopt)
9870 lopt = argv[n];
9871 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
9872 lopt, " ", NULL);
9874 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
9876 prepended = concat (prepended, "-plugin-opt=-pass-through=",
9877 argv[n], " ", NULL);
9879 if (prepended != old)
9880 free (old);
9882 return prepended;
9885 /* %:replace-extension spec function. Replaces the extension of the
9886 first argument with the second argument. */
9888 const char *
9889 replace_extension_spec_func (int argc, const char **argv)
9891 char *name;
9892 char *p;
9893 char *result;
9894 int i;
9896 if (argc != 2)
9897 fatal_error (input_location, "too few arguments to %%:replace-extension");
9899 name = xstrdup (argv[0]);
9901 for (i = strlen (name) - 1; i >= 0; i--)
9902 if (IS_DIR_SEPARATOR (name[i]))
9903 break;
9905 p = strrchr (name + i + 1, '.');
9906 if (p != NULL)
9907 *p = '\0';
9909 result = concat (name, argv[1], NULL);
9911 free (name);
9912 return result;
9915 /* Returns "" if ARGV[ARGC - 2] is greater than ARGV[ARGC-1].
9916 Otherwise, return NULL. */
9918 static const char *
9919 greater_than_spec_func (int argc, const char **argv)
9921 char *converted;
9923 if (argc == 1)
9924 return NULL;
9926 gcc_assert (argc >= 2);
9928 long arg = strtol (argv[argc - 2], &converted, 10);
9929 gcc_assert (converted != argv[argc - 2]);
9931 long lim = strtol (argv[argc - 1], &converted, 10);
9932 gcc_assert (converted != argv[argc - 1]);
9934 if (arg > lim)
9935 return "";
9937 return NULL;
9940 /* Returns "" if debug_info_level is greater than ARGV[ARGC-1].
9941 Otherwise, return NULL. */
9943 static const char *
9944 debug_level_greater_than_spec_func (int argc, const char **argv)
9946 char *converted;
9948 if (argc != 1)
9949 fatal_error (input_location,
9950 "wrong number of arguments to %%:debug-level-gt");
9952 long arg = strtol (argv[0], &converted, 10);
9953 gcc_assert (converted != argv[0]);
9955 if (debug_info_level > arg)
9956 return "";
9958 return NULL;
9961 /* Insert backslash before spaces in ORIG (usually a file path), to
9962 avoid being broken by spec parser.
9964 This function is needed as do_spec_1 treats white space (' ' and '\t')
9965 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
9966 the file name should be treated as a single argument rather than being
9967 broken into multiple. Solution is to insert '\\' before the space in a
9968 file name.
9970 This function converts and only converts all occurrence of ' '
9971 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
9972 "a b" -> "a\\ b"
9973 "a b" -> "a\\ \\ b"
9974 "a\tb" -> "a\\\tb"
9975 "a\\ b" -> "a\\\\ b"
9977 orig: input null-terminating string that was allocated by xalloc. The
9978 memory it points to might be freed in this function. Behavior undefined
9979 if ORIG wasn't xalloced or was freed already at entry.
9981 Return: ORIG if no conversion needed. Otherwise a newly allocated string
9982 that was converted from ORIG. */
9984 static char *
9985 convert_white_space (char *orig)
9987 int len, number_of_space = 0;
9989 for (len = 0; orig[len]; len++)
9990 if (orig[len] == ' ' || orig[len] == '\t') number_of_space++;
9992 if (number_of_space)
9994 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
9995 int j, k;
9996 for (j = 0, k = 0; j <= len; j++, k++)
9998 if (orig[j] == ' ' || orig[j] == '\t')
9999 new_spec[k++] = '\\';
10000 new_spec[k] = orig[j];
10002 free (orig);
10003 return new_spec;
10005 else
10006 return orig;
10009 static void
10010 path_prefix_reset (path_prefix *prefix)
10012 struct prefix_list *iter, *next;
10013 iter = prefix->plist;
10014 while (iter)
10016 next = iter->next;
10017 free (const_cast <char *> (iter->prefix));
10018 XDELETE (iter);
10019 iter = next;
10021 prefix->plist = 0;
10022 prefix->max_len = 0;
10025 /* Restore all state within gcc.c to the initial state, so that the driver
10026 code can be safely re-run in-process.
10028 Many const char * variables are referenced by static specs (see
10029 INIT_STATIC_SPEC above). These variables are restored to their default
10030 values by a simple loop over the static specs.
10032 For other variables, we directly restore them all to their initial
10033 values (often implicitly 0).
10035 Free the various obstacks in this file, along with "opts_obstack"
10036 from opts.c.
10038 This function also restores any environment variables that were changed. */
10040 void
10041 driver::finalize ()
10043 env.restore ();
10044 params_c_finalize ();
10045 diagnostic_finish (global_dc);
10047 is_cpp_driver = 0;
10048 at_file_supplied = 0;
10049 print_help_list = 0;
10050 print_version = 0;
10051 verbose_only_flag = 0;
10052 print_subprocess_help = 0;
10053 use_ld = NULL;
10054 report_times_to_file = NULL;
10055 target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
10056 target_system_root_changed = 0;
10057 target_sysroot_suffix = 0;
10058 target_sysroot_hdrs_suffix = 0;
10059 save_temps_flag = SAVE_TEMPS_NONE;
10060 save_temps_prefix = 0;
10061 save_temps_length = 0;
10062 spec_machine = DEFAULT_TARGET_MACHINE;
10063 greatest_status = 1;
10065 finalize_options_struct (&global_options);
10066 finalize_options_struct (&global_options_set);
10068 obstack_free (&obstack, NULL);
10069 obstack_free (&opts_obstack, NULL); /* in opts.c */
10070 obstack_free (&collect_obstack, NULL);
10072 link_command_spec = LINK_COMMAND_SPEC;
10074 obstack_free (&multilib_obstack, NULL);
10076 user_specs_head = NULL;
10077 user_specs_tail = NULL;
10079 /* Within the "compilers" vec, the fields "suffix" and "spec" were
10080 statically allocated for the default compilers, but dynamically
10081 allocated for additional compilers. Delete them for the latter. */
10082 for (int i = n_default_compilers; i < n_compilers; i++)
10084 free (const_cast <char *> (compilers[i].suffix));
10085 free (const_cast <char *> (compilers[i].spec));
10087 XDELETEVEC (compilers);
10088 compilers = NULL;
10089 n_compilers = 0;
10091 linker_options.truncate (0);
10092 assembler_options.truncate (0);
10093 preprocessor_options.truncate (0);
10095 path_prefix_reset (&exec_prefixes);
10096 path_prefix_reset (&startfile_prefixes);
10097 path_prefix_reset (&include_prefixes);
10099 machine_suffix = 0;
10100 just_machine_suffix = 0;
10101 gcc_exec_prefix = 0;
10102 gcc_libexec_prefix = 0;
10103 md_exec_prefix = MD_EXEC_PREFIX;
10104 md_startfile_prefix = MD_STARTFILE_PREFIX;
10105 md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
10106 multilib_dir = 0;
10107 multilib_os_dir = 0;
10108 multiarch_dir = 0;
10110 /* Free any specs dynamically-allocated by set_spec.
10111 These will be at the head of the list, before the
10112 statically-allocated ones. */
10113 if (specs)
10115 while (specs != static_specs)
10117 spec_list *next = specs->next;
10118 free (const_cast <char *> (specs->name));
10119 XDELETE (specs);
10120 specs = next;
10122 specs = 0;
10124 for (unsigned i = 0; i < ARRAY_SIZE (static_specs); i++)
10126 spec_list *sl = &static_specs[i];
10127 if (sl->alloc_p)
10129 if (0)
10130 free (const_cast <char *> (*(sl->ptr_spec)));
10131 sl->alloc_p = false;
10133 *(sl->ptr_spec) = sl->default_ptr;
10135 #ifdef EXTRA_SPECS
10136 extra_specs = NULL;
10137 #endif
10139 processing_spec_function = 0;
10141 argbuf.truncate (0);
10143 have_c = 0;
10144 have_o = 0;
10146 temp_names = NULL;
10147 execution_count = 0;
10148 signal_count = 0;
10150 temp_filename = NULL;
10151 temp_filename_length = 0;
10152 always_delete_queue = NULL;
10153 failure_delete_queue = NULL;
10155 XDELETEVEC (switches);
10156 switches = NULL;
10157 n_switches = 0;
10158 n_switches_alloc = 0;
10160 compare_debug = 0;
10161 compare_debug_second = 0;
10162 compare_debug_opt = NULL;
10163 for (int i = 0; i < 2; i++)
10165 switches_debug_check[i] = NULL;
10166 n_switches_debug_check[i] = 0;
10167 n_switches_alloc_debug_check[i] = 0;
10168 debug_check_temp_file[i] = NULL;
10171 XDELETEVEC (infiles);
10172 infiles = NULL;
10173 n_infiles = 0;
10174 n_infiles_alloc = 0;
10176 combine_inputs = false;
10177 added_libraries = 0;
10178 XDELETEVEC (outfiles);
10179 outfiles = NULL;
10180 spec_lang = 0;
10181 last_language_n_infiles = 0;
10182 gcc_input_filename = NULL;
10183 input_file_number = 0;
10184 input_filename_length = 0;
10185 basename_length = 0;
10186 suffixed_basename_length = 0;
10187 input_basename = NULL;
10188 input_suffix = NULL;
10189 /* We don't need to purge "input_stat", just to unset "input_stat_set". */
10190 input_stat_set = 0;
10191 input_file_compiler = NULL;
10192 arg_going = 0;
10193 delete_this_arg = 0;
10194 this_is_output_file = 0;
10195 this_is_library_file = 0;
10196 this_is_linker_script = 0;
10197 input_from_pipe = 0;
10198 suffix_subst = NULL;
10200 mdswitches = NULL;
10201 n_mdswitches = 0;
10203 debug_auxbase_opt = NULL;
10205 used_arg.finalize ();
10208 /* PR jit/64810.
10209 Targets can provide configure-time default options in
10210 OPTION_DEFAULT_SPECS. The jit needs to access these, but
10211 they are expressed in the spec language.
10213 Run just enough of the driver to be able to expand these
10214 specs, and then call the callback CB on each
10215 such option. The options strings are *without* a leading
10216 '-' character e.g. ("march=x86-64"). Finally, clean up. */
10218 void
10219 driver_get_configure_time_options (void (*cb) (const char *option,
10220 void *user_data),
10221 void *user_data)
10223 size_t i;
10225 obstack_init (&obstack);
10226 init_opts_obstack ();
10227 n_switches = 0;
10229 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
10230 do_option_spec (option_default_specs[i].name,
10231 option_default_specs[i].spec);
10233 for (i = 0; (int) i < n_switches; i++)
10235 gcc_assert (switches[i].part1);
10236 (*cb) (switches[i].part1, user_data);
10239 obstack_free (&opts_obstack, NULL);
10240 obstack_free (&obstack, NULL);
10241 n_switches = 0;