]> git.ipfire.org Git - thirdparty/gcc.git/blob - gcc/gcc.c
b75b50b87b2bfcf07fa51a89956919faa862f230
[thirdparty/gcc.git] / gcc / gcc.c
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987-2021 Free Software Foundation, Inc.
3
4 This file is part of GCC.
5
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.
10
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.
15
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/>. */
19
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.
25
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". */
29
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 "opt-suggestions.h"
40 #include "gcc.h"
41 #include "diagnostic.h"
42 #include "flags.h"
43 #include "opts.h"
44 #include "filenames.h"
45 #include "spellcheck.h"
46
47 \f
48
49 /* Manage the manipulation of env vars.
50
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". */
58
59 struct env_manager
60 {
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 ();
66
67 private:
68 bool m_can_restore;
69 bool m_debug;
70 struct kv
71 {
72 char *m_key;
73 char *m_value;
74 };
75 vec<kv> m_keys;
76
77 };
78
79 /* The singleton instance of class env_manager. */
80
81 static env_manager env;
82
83 /* Initializer for class env_manager.
84
85 We can't do this as a constructor since we have a statically
86 allocated instance ("env" above). */
87
88 void
89 env_manager::init (bool can_restore, bool debug)
90 {
91 m_can_restore = can_restore;
92 m_debug = debug;
93 }
94
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. */
98
99 const char *
100 env_manager::get (const char *name)
101 {
102 const char *result = ::getenv (name);
103 if (m_debug)
104 fprintf (stderr, "env_manager::getenv (%s) -> %s\n", name, result);
105 return result;
106 }
107
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. */
112
113 void
114 env_manager::xput (const char *string)
115 {
116 if (m_debug)
117 fprintf (stderr, "env_manager::xput (%s)\n", string);
118 if (verbose_flag)
119 fnotice (stderr, "%s\n", string);
120
121 if (m_can_restore)
122 {
123 char *equals = strchr (const_cast <char *> (string), '=');
124 gcc_assert (equals);
125
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);
133 }
134
135 ::putenv (CONST_CAST (char *, string));
136 }
137
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. */
141
142 void
143 env_manager::restore ()
144 {
145 unsigned int i;
146 struct kv *item;
147
148 gcc_assert (m_can_restore);
149
150 FOR_EACH_VEC_ELT_REVERSE (m_keys, i, item)
151 {
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);
160 }
161
162 m_keys.truncate (0);
163 }
164
165 /* Forbid other uses of getenv and putenv. */
166 #if (GCC_VERSION >= 3000)
167 #pragma GCC poison getenv putenv
168 #endif
169
170 \f
171
172 /* By default there is no special suffix for target executables. */
173 #ifdef TARGET_EXECUTABLE_SUFFIX
174 #define HAVE_TARGET_EXECUTABLE_SUFFIX
175 #else
176 #define TARGET_EXECUTABLE_SUFFIX ""
177 #endif
178
179 /* By default there is no special suffix for host executables. */
180 #ifdef HOST_EXECUTABLE_SUFFIX
181 #define HAVE_HOST_EXECUTABLE_SUFFIX
182 #else
183 #define HOST_EXECUTABLE_SUFFIX ""
184 #endif
185
186 /* By default, the suffix for target object files is ".o". */
187 #ifdef TARGET_OBJECT_SUFFIX
188 #define HAVE_TARGET_OBJECT_SUFFIX
189 #else
190 #define TARGET_OBJECT_SUFFIX ".o"
191 #endif
192
193 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
194
195 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
196 #ifndef LIBRARY_PATH_ENV
197 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
198 #endif
199
200 /* If a stage of compilation returns an exit status >= 1,
201 compilation of that file ceases. */
202
203 #define MIN_FATAL_STATUS 1
204
205 /* Flag set by cppspec.c to 1. */
206 int is_cpp_driver;
207
208 /* Flag set to nonzero if an @file argument has been supplied to gcc. */
209 static bool at_file_supplied;
210
211 /* Definition of string containing the arguments given to configure. */
212 #include "configargs.h"
213
214 /* Flag saying to print the command line options understood by gcc and its
215 sub-processes. */
216
217 static int print_help_list;
218
219 /* Flag saying to print the version of gcc and its sub-processes. */
220
221 static int print_version;
222
223 /* Flag that stores string prefix for which we provide bash completion. */
224
225 static const char *completion = NULL;
226
227 /* Flag indicating whether we should ONLY print the command and
228 arguments (like verbose_flag) without executing the command.
229 Displayed arguments are quoted so that the generated command
230 line is suitable for execution. This is intended for use in
231 shell scripts to capture the driver-generated command line. */
232 static int verbose_only_flag;
233
234 /* Flag indicating how to print command line options of sub-processes. */
235
236 static int print_subprocess_help;
237
238 /* Linker suffix passed to -fuse-ld=... */
239 static const char *use_ld;
240
241 /* Whether we should report subprocess execution times to a file. */
242
243 FILE *report_times_to_file = NULL;
244
245 /* Nonzero means place this string before uses of /, so that include
246 and library files can be found in an alternate location. */
247
248 #ifdef TARGET_SYSTEM_ROOT
249 #define DEFAULT_TARGET_SYSTEM_ROOT (TARGET_SYSTEM_ROOT)
250 #else
251 #define DEFAULT_TARGET_SYSTEM_ROOT (0)
252 #endif
253 static const char *target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
254
255 /* Nonzero means pass the updated target_system_root to the compiler. */
256
257 static int target_system_root_changed;
258
259 /* Nonzero means append this string to target_system_root. */
260
261 static const char *target_sysroot_suffix = 0;
262
263 /* Nonzero means append this string to target_system_root for headers. */
264
265 static const char *target_sysroot_hdrs_suffix = 0;
266
267 /* Nonzero means write "temp" files in source directory
268 and use the source file's name in them, and don't delete them. */
269
270 static enum save_temps {
271 SAVE_TEMPS_NONE, /* no -save-temps */
272 SAVE_TEMPS_CWD, /* -save-temps in current directory */
273 SAVE_TEMPS_DUMP, /* -save-temps in dumpdir */
274 SAVE_TEMPS_OBJ /* -save-temps in object directory */
275 } save_temps_flag;
276
277 /* Set this iff the dumppfx implied by a -save-temps=* option is to
278 override a -dumpdir option, if any. */
279 static bool save_temps_overrides_dumpdir = false;
280
281 /* -dumpdir, -dumpbase and -dumpbase-ext flags passed in, possibly
282 rearranged as they are to be passed down, e.g., dumpbase and
283 dumpbase_ext may be cleared if integrated with dumpdir or
284 dropped. */
285 static char *dumpdir, *dumpbase, *dumpbase_ext;
286
287 /* Usually the length of the string in dumpdir. However, during
288 linking, it may be shortened to omit a driver-added trailing dash,
289 by then replaced with a trailing period, that is still to be passed
290 to sub-processes in -dumpdir, but not to be generally used in spec
291 filename expansions. See maybe_run_linker. */
292 static size_t dumpdir_length = 0;
293
294 /* Set if the last character in dumpdir is (or was) a dash that the
295 driver added to dumpdir after dumpbase or linker output name. */
296 static bool dumpdir_trailing_dash_added = false;
297
298 /* Basename of dump and aux outputs, computed from dumpbase (given or
299 derived from output name), to override input_basename in non-%w %b
300 et al. */
301 static char *outbase;
302 static size_t outbase_length = 0;
303
304 /* The compiler version. */
305
306 static const char *compiler_version;
307
308 /* The target version. */
309
310 static const char *const spec_version = DEFAULT_TARGET_VERSION;
311
312 /* The target machine. */
313
314 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
315 static const char *spec_host_machine = DEFAULT_REAL_TARGET_MACHINE;
316
317 /* List of offload targets. Separated by colon. Empty string for
318 -foffload=disable. */
319
320 static char *offload_targets = NULL;
321
322 #if OFFLOAD_DEFAULTED
323 /* Set to true if -foffload has not been used and offload_targets
324 is set to the configured in default. */
325 static bool offload_targets_default;
326 #endif
327
328 /* Nonzero if cross-compiling.
329 When -b is used, the value comes from the `specs' file. */
330
331 #ifdef CROSS_DIRECTORY_STRUCTURE
332 static const char *cross_compile = "1";
333 #else
334 static const char *cross_compile = "0";
335 #endif
336
337 /* Greatest exit code of sub-processes that has been encountered up to
338 now. */
339 static int greatest_status = 1;
340
341 /* This is the obstack which we use to allocate many strings. */
342
343 static struct obstack obstack;
344
345 /* This is the obstack to build an environment variable to pass to
346 collect2 that describes all of the relevant switches of what to
347 pass the compiler in building the list of pointers to constructors
348 and destructors. */
349
350 static struct obstack collect_obstack;
351
352 /* Forward declaration for prototypes. */
353 struct path_prefix;
354 struct prefix_list;
355
356 static void init_spec (void);
357 static void store_arg (const char *, int, int);
358 static void insert_wrapper (const char *);
359 static char *load_specs (const char *);
360 static void read_specs (const char *, bool, bool);
361 static void set_spec (const char *, const char *, bool);
362 static struct compiler *lookup_compiler (const char *, size_t, const char *);
363 static char *build_search_list (const struct path_prefix *, const char *,
364 bool, bool);
365 static void xputenv (const char *);
366 static void putenv_from_prefixes (const struct path_prefix *, const char *,
367 bool);
368 static int access_check (const char *, int);
369 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
370 static char *find_a_program (const char *);
371 static void add_prefix (struct path_prefix *, const char *, const char *,
372 int, int, int);
373 static void add_sysrooted_prefix (struct path_prefix *, const char *,
374 const char *, int, int, int);
375 static char *skip_whitespace (char *);
376 static void delete_if_ordinary (const char *);
377 static void delete_temp_files (void);
378 static void delete_failure_queue (void);
379 static void clear_failure_queue (void);
380 static int check_live_switch (int, int);
381 static const char *handle_braces (const char *);
382 static inline bool input_suffix_matches (const char *, const char *);
383 static inline bool switch_matches (const char *, const char *, int);
384 static inline void mark_matching_switches (const char *, const char *, int);
385 static inline void process_marked_switches (void);
386 static const char *process_brace_body (const char *, const char *, const char *, int, int);
387 static const struct spec_function *lookup_spec_function (const char *);
388 static const char *eval_spec_function (const char *, const char *, const char *);
389 static const char *handle_spec_function (const char *, bool *, const char *);
390 static char *save_string (const char *, int);
391 static void set_collect_gcc_options (void);
392 static int do_spec_1 (const char *, int, const char *);
393 static int do_spec_2 (const char *, const char *);
394 static void do_option_spec (const char *, const char *);
395 static void do_self_spec (const char *);
396 static const char *find_file (const char *);
397 static int is_directory (const char *, bool);
398 static const char *validate_switches (const char *, bool, bool);
399 static void validate_all_switches (void);
400 static inline void validate_switches_from_spec (const char *, bool);
401 static void give_switch (int, int);
402 static int default_arg (const char *, int);
403 static void set_multilib_dir (void);
404 static void print_multilib_info (void);
405 static void display_help (void);
406 static void add_preprocessor_option (const char *, int);
407 static void add_assembler_option (const char *, int);
408 static void add_linker_option (const char *, int);
409 static void process_command (unsigned int, struct cl_decoded_option *);
410 static int execute (void);
411 static void alloc_args (void);
412 static void clear_args (void);
413 static void fatal_signal (int);
414 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
415 static void init_gcc_specs (struct obstack *, const char *, const char *,
416 const char *);
417 #endif
418 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
419 static const char *convert_filename (const char *, int, int);
420 #endif
421
422 static void try_generate_repro (const char **argv);
423 static const char *getenv_spec_function (int, const char **);
424 static const char *if_exists_spec_function (int, const char **);
425 static const char *if_exists_else_spec_function (int, const char **);
426 static const char *if_exists_then_else_spec_function (int, const char **);
427 static const char *sanitize_spec_function (int, const char **);
428 static const char *replace_outfile_spec_function (int, const char **);
429 static const char *remove_outfile_spec_function (int, const char **);
430 static const char *version_compare_spec_function (int, const char **);
431 static const char *include_spec_function (int, const char **);
432 static const char *find_file_spec_function (int, const char **);
433 static const char *find_plugindir_spec_function (int, const char **);
434 static const char *print_asm_header_spec_function (int, const char **);
435 static const char *compare_debug_dump_opt_spec_function (int, const char **);
436 static const char *compare_debug_self_opt_spec_function (int, const char **);
437 static const char *pass_through_libs_spec_func (int, const char **);
438 static const char *dumps_spec_func (int, const char **);
439 static const char *greater_than_spec_func (int, const char **);
440 static const char *debug_level_greater_than_spec_func (int, const char **);
441 static const char *dwarf_version_greater_than_spec_func (int, const char **);
442 static const char *find_fortran_preinclude_file (int, const char **);
443 static char *convert_white_space (char *);
444 static char *quote_spec (char *);
445 static char *quote_spec_arg (char *);
446 static bool not_actual_file_p (const char *);
447
448 \f
449 /* The Specs Language
450
451 Specs are strings containing lines, each of which (if not blank)
452 is made up of a program name, and arguments separated by spaces.
453 The program name must be exact and start from root, since no path
454 is searched and it is unreliable to depend on the current working directory.
455 Redirection of input or output is not supported; the subprograms must
456 accept filenames saying what files to read and write.
457
458 In addition, the specs can contain %-sequences to substitute variable text
459 or for conditional text. Here is a table of all defined %-sequences.
460 Note that spaces are not generated automatically around the results of
461 expanding these sequences; therefore, you can concatenate them together
462 or with constant text in a single argument.
463
464 %% substitute one % into the program name or argument.
465 %" substitute an empty argument.
466 %i substitute the name of the input file being processed.
467 %b substitute the basename for outputs related with the input file
468 being processed. This is often a substring of the input file name,
469 up to (and not including) the last period but, unless %w is active,
470 it is affected by the directory selected by -save-temps=*, by
471 -dumpdir, and, in case of multiple compilations, even by -dumpbase
472 and -dumpbase-ext and, in case of linking, by the linker output
473 name. When %w is active, it derives the main output name only from
474 the input file base name; when it is not, it names aux/dump output
475 file.
476 %B same as %b, but include the input file suffix (text after the last
477 period).
478 %gSUFFIX
479 substitute a file name that has suffix SUFFIX and is chosen
480 once per compilation, and mark the argument a la %d. To reduce
481 exposure to denial-of-service attacks, the file name is now
482 chosen in a way that is hard to predict even when previously
483 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
484 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
485 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
486 had been pre-processed. Previously, %g was simply substituted
487 with a file name chosen once per compilation, without regard
488 to any appended suffix (which was therefore treated just like
489 ordinary text), making such attacks more likely to succeed.
490 %|SUFFIX
491 like %g, but if -pipe is in effect, expands simply to "-".
492 %mSUFFIX
493 like %g, but if -pipe is in effect, expands to nothing. (We have both
494 %| and %m to accommodate differences between system assemblers; see
495 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
496 %uSUFFIX
497 like %g, but generates a new temporary file name even if %uSUFFIX
498 was already seen.
499 %USUFFIX
500 substitutes the last file name generated with %uSUFFIX, generating a
501 new one if there is no such last file name. In the absence of any
502 %uSUFFIX, this is just like %gSUFFIX, except they don't share
503 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
504 would involve the generation of two distinct file names, one
505 for each `%g.s' and another for each `%U.s'. Previously, %U was
506 simply substituted with a file name chosen for the previous %u,
507 without regard to any appended suffix.
508 %jSUFFIX
509 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
510 writable, and if save-temps is off; otherwise, substitute the name
511 of a temporary file, just like %u. This temporary file is not
512 meant for communication between processes, but rather as a junk
513 disposal mechanism.
514 %.SUFFIX
515 substitutes .SUFFIX for the suffixes of a matched switch's args when
516 it is subsequently output with %*. SUFFIX is terminated by the next
517 space or %.
518 %d marks the argument containing or following the %d as a
519 temporary file name, so that file will be deleted if GCC exits
520 successfully. Unlike %g, this contributes no text to the argument.
521 %w marks the argument containing or following the %w as the
522 "output file" of this compilation. This puts the argument
523 into the sequence of arguments that %o will substitute later.
524 %V indicates that this compilation produces no "output file".
525 %W{...}
526 like %{...} but marks the last argument supplied within as a file
527 to be deleted on failure.
528 %@{...}
529 like %{...} but puts the result into a FILE and substitutes @FILE
530 if an @file argument has been supplied.
531 %o substitutes the names of all the output files, with spaces
532 automatically placed around them. You should write spaces
533 around the %o as well or the results are undefined.
534 %o is for use in the specs for running the linker.
535 Input files whose names have no recognized suffix are not compiled
536 at all, but they are included among the output files, so they will
537 be linked.
538 %O substitutes the suffix for object files. Note that this is
539 handled specially when it immediately follows %g, %u, or %U
540 (with or without a suffix argument) because of the need for
541 those to form complete file names. The handling is such that
542 %O is treated exactly as if it had already been substituted,
543 except that %g, %u, and %U do not currently support additional
544 SUFFIX characters following %O as they would following, for
545 example, `.o'.
546 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
547 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
548 and -B options) and -imultilib as necessary.
549 %s current argument is the name of a library or startup file of some sort.
550 Search for that file in a standard list of directories
551 and substitute the full name found.
552 %T current argument is the name of a linker script.
553 Search for that file in the current list of directories to scan for
554 libraries. If the file is located, insert a --script option into the
555 command line followed by the full path name found. If the file is
556 not found then generate an error message.
557 Note: the current working directory is not searched.
558 %eSTR Print STR as an error message. STR is terminated by a newline.
559 Use this when inconsistent options are detected.
560 %nSTR Print STR as a notice. STR is terminated by a newline.
561 %x{OPTION} Accumulate an option for %X.
562 %X Output the accumulated linker options specified by compilations.
563 %Y Output the accumulated assembler options specified by compilations.
564 %Z Output the accumulated preprocessor options specified by compilations.
565 %a process ASM_SPEC as a spec.
566 This allows config.h to specify part of the spec for running as.
567 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
568 used here. This can be used to run a post-processor after the
569 assembler has done its job.
570 %D Dump out a -L option for each directory in startfile_prefixes.
571 If multilib_dir is set, extra entries are generated with it affixed.
572 %l process LINK_SPEC as a spec.
573 %L process LIB_SPEC as a spec.
574 %M Output multilib_os_dir.
575 %G process LIBGCC_SPEC as a spec.
576 %R Output the concatenation of target_system_root and
577 target_sysroot_suffix.
578 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
579 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
580 %C process CPP_SPEC as a spec.
581 %1 process CC1_SPEC as a spec.
582 %2 process CC1PLUS_SPEC as a spec.
583 %* substitute the variable part of a matched option. (See below.)
584 Note that each comma in the substituted string is replaced by
585 a single space. A space is appended after the last substition
586 unless there is more text in current sequence.
587 %<S remove all occurrences of -S from the command line.
588 Note - this command is position dependent. % commands in the
589 spec string before this one will see -S, % commands in the
590 spec string after this one will not.
591 %>S Similar to "%<S", but keep it in the GCC command line.
592 %<S* remove all occurrences of all switches beginning with -S from the
593 command line.
594 %:function(args)
595 Call the named function FUNCTION, passing it ARGS. ARGS is
596 first processed as a nested spec string, then split into an
597 argument vector in the usual fashion. The function returns
598 a string which is processed as if it had appeared literally
599 as part of the current spec.
600 %{S} substitutes the -S switch, if that switch was given to GCC.
601 If that switch was not specified, this substitutes nothing.
602 Here S is a metasyntactic variable.
603 %{S*} substitutes all the switches specified to GCC whose names start
604 with -S. This is used for -o, -I, etc; switches that take
605 arguments. GCC considers `-o foo' as being one switch whose
606 name starts with `o'. %{o*} would substitute this text,
607 including the space; thus, two arguments would be generated.
608 %{S*&T*} likewise, but preserve order of S and T options (the order
609 of S and T in the spec is not significant). Can be any number
610 of ampersand-separated variables; for each the wild card is
611 optional. Useful for CPP as %{D*&U*&A*}.
612
613 %{S:X} substitutes X, if the -S switch was given to GCC.
614 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
615 %{S*:X} substitutes X if one or more switches whose names start
616 with -S was given to GCC. Normally X is substituted only
617 once, no matter how many such switches appeared. However,
618 if %* appears somewhere in X, then X will be substituted
619 once for each matching switch, with the %* replaced by the
620 part of that switch that matched the '*'. A space will be
621 appended after the last substition unless there is more
622 text in current sequence.
623 %{.S:X} substitutes X, if processing a file with suffix S.
624 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
625 %{,S:X} substitutes X, if processing a file which will use spec S.
626 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
627
628 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
629 combined with '!', '.', ',', and '*' as above binding stronger
630 than the OR.
631 If %* appears in X, all of the alternatives must be starred, and
632 only the first matching alternative is substituted.
633 %{%:function(args):X}
634 Call function named FUNCTION with args ARGS. If the function
635 returns non-NULL, then X is substituted, if it returns
636 NULL, it isn't substituted.
637 %{S:X; if S was given to GCC, substitutes X;
638 T:Y; else if T was given to GCC, substitutes Y;
639 :D} else substitutes D. There can be as many clauses as you need.
640 This may be combined with '.', '!', ',', '|', and '*' as above.
641
642 %(Spec) processes a specification defined in a specs file as *Spec:
643
644 The switch matching text S in a %{S}, %{S:X}, or similar construct can use
645 a backslash to ignore the special meaning of the character following it,
646 thus allowing literal matching of a character that is otherwise specially
647 treated. For example, %{std=iso9899\:1999:X} substitutes X if the
648 -std=iso9899:1999 option is given.
649
650 The conditional text X in a %{S:X} or similar construct may contain
651 other nested % constructs or spaces, or even newlines. They are
652 processed as usual, as described above. Trailing white space in X is
653 ignored. White space may also appear anywhere on the left side of the
654 colon in these constructs, except between . or * and the corresponding
655 word.
656
657 The -O, -f, -g, -m, and -W switches are handled specifically in these
658 constructs. If another value of -O or the negated form of a -f, -m, or
659 -W switch is found later in the command line, the earlier switch
660 value is ignored, except with {S*} where S is just one letter; this
661 passes all matching options.
662
663 The character | at the beginning of the predicate text is used to indicate
664 that a command should be piped to the following command, but only if -pipe
665 is specified.
666
667 Note that it is built into GCC which switches take arguments and which
668 do not. You might think it would be useful to generalize this to
669 allow each compiler's spec to say which switches take arguments. But
670 this cannot be done in a consistent fashion. GCC cannot even decide
671 which input files have been specified without knowing which switches
672 take arguments, and it must know which input files to compile in order
673 to tell which compilers to run.
674
675 GCC also knows implicitly that arguments starting in `-l' are to be
676 treated as compiler output files, and passed to the linker in their
677 proper position among the other output files. */
678 \f
679 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
680
681 /* config.h can define ASM_SPEC to provide extra args to the assembler
682 or extra switch-translations. */
683 #ifndef ASM_SPEC
684 #define ASM_SPEC ""
685 #endif
686
687 /* config.h can define ASM_FINAL_SPEC to run a post processor after
688 the assembler has run. */
689 #ifndef ASM_FINAL_SPEC
690 #define ASM_FINAL_SPEC \
691 "%{gsplit-dwarf: \n\
692 objcopy --extract-dwo \
693 %{c:%{o*:%*}%{!o*:%w%b%O}}%{!c:%U%O} \
694 %b.dwo \n\
695 objcopy --strip-dwo \
696 %{c:%{o*:%*}%{!o*:%w%b%O}}%{!c:%U%O} \
697 }"
698 #endif
699
700 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
701 or extra switch-translations. */
702 #ifndef CPP_SPEC
703 #define CPP_SPEC ""
704 #endif
705
706 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
707 or extra switch-translations. */
708 #ifndef CC1_SPEC
709 #define CC1_SPEC ""
710 #endif
711
712 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
713 or extra switch-translations. */
714 #ifndef CC1PLUS_SPEC
715 #define CC1PLUS_SPEC ""
716 #endif
717
718 /* config.h can define LINK_SPEC to provide extra args to the linker
719 or extra switch-translations. */
720 #ifndef LINK_SPEC
721 #define LINK_SPEC ""
722 #endif
723
724 /* config.h can define LIB_SPEC to override the default libraries. */
725 #ifndef LIB_SPEC
726 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
727 #endif
728
729 /* When using -fsplit-stack we need to wrap pthread_create, in order
730 to initialize the stack guard. We always use wrapping, rather than
731 shared library ordering, and we keep the wrapper function in
732 libgcc. This is not yet a real spec, though it could become one;
733 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
734 only works with GNU ld and gold. */
735 #ifdef HAVE_GOLD_NON_DEFAULT_SPLIT_STACK
736 #define STACK_SPLIT_SPEC " %{fsplit-stack: -fuse-ld=gold --wrap=pthread_create}"
737 #else
738 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
739 #endif
740
741 #ifndef LIBASAN_SPEC
742 #define STATIC_LIBASAN_LIBS \
743 " %{static-libasan|static:%:include(libsanitizer.spec)%(link_libasan)}"
744 #ifdef LIBASAN_EARLY_SPEC
745 #define LIBASAN_SPEC STATIC_LIBASAN_LIBS
746 #elif defined(HAVE_LD_STATIC_DYNAMIC)
747 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
748 "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
749 STATIC_LIBASAN_LIBS
750 #else
751 #define LIBASAN_SPEC "-lasan" STATIC_LIBASAN_LIBS
752 #endif
753 #endif
754
755 #ifndef LIBASAN_EARLY_SPEC
756 #define LIBASAN_EARLY_SPEC ""
757 #endif
758
759 #ifndef LIBHWASAN_SPEC
760 #define STATIC_LIBHWASAN_LIBS \
761 " %{static-libhwasan|static:%:include(libsanitizer.spec)%(link_libhwasan)}"
762 #ifdef LIBHWASAN_EARLY_SPEC
763 #define LIBHWASAN_SPEC STATIC_LIBHWASAN_LIBS
764 #elif defined(HAVE_LD_STATIC_DYNAMIC)
765 #define LIBHWASAN_SPEC "%{static-libhwasan:" LD_STATIC_OPTION \
766 "} -lhwasan %{static-libhwasan:" LD_DYNAMIC_OPTION "}" \
767 STATIC_LIBHWASAN_LIBS
768 #else
769 #define LIBHWASAN_SPEC "-lhwasan" STATIC_LIBHWASAN_LIBS
770 #endif
771 #endif
772
773 #ifndef LIBHWASAN_EARLY_SPEC
774 #define LIBHWASAN_EARLY_SPEC ""
775 #endif
776
777 #ifndef LIBTSAN_SPEC
778 #define STATIC_LIBTSAN_LIBS \
779 " %{static-libtsan|static:%:include(libsanitizer.spec)%(link_libtsan)}"
780 #ifdef LIBTSAN_EARLY_SPEC
781 #define LIBTSAN_SPEC STATIC_LIBTSAN_LIBS
782 #elif defined(HAVE_LD_STATIC_DYNAMIC)
783 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
784 "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}" \
785 STATIC_LIBTSAN_LIBS
786 #else
787 #define LIBTSAN_SPEC "-ltsan" STATIC_LIBTSAN_LIBS
788 #endif
789 #endif
790
791 #ifndef LIBTSAN_EARLY_SPEC
792 #define LIBTSAN_EARLY_SPEC ""
793 #endif
794
795 #ifndef LIBLSAN_SPEC
796 #define STATIC_LIBLSAN_LIBS \
797 " %{static-liblsan|static:%:include(libsanitizer.spec)%(link_liblsan)}"
798 #ifdef LIBLSAN_EARLY_SPEC
799 #define LIBLSAN_SPEC STATIC_LIBLSAN_LIBS
800 #elif defined(HAVE_LD_STATIC_DYNAMIC)
801 #define LIBLSAN_SPEC "%{static-liblsan:" LD_STATIC_OPTION \
802 "} -llsan %{static-liblsan:" LD_DYNAMIC_OPTION "}" \
803 STATIC_LIBLSAN_LIBS
804 #else
805 #define LIBLSAN_SPEC "-llsan" STATIC_LIBLSAN_LIBS
806 #endif
807 #endif
808
809 #ifndef LIBLSAN_EARLY_SPEC
810 #define LIBLSAN_EARLY_SPEC ""
811 #endif
812
813 #ifndef LIBUBSAN_SPEC
814 #define STATIC_LIBUBSAN_LIBS \
815 " %{static-libubsan|static:%:include(libsanitizer.spec)%(link_libubsan)}"
816 #ifdef HAVE_LD_STATIC_DYNAMIC
817 #define LIBUBSAN_SPEC "%{static-libubsan:" LD_STATIC_OPTION \
818 "} -lubsan %{static-libubsan:" LD_DYNAMIC_OPTION "}" \
819 STATIC_LIBUBSAN_LIBS
820 #else
821 #define LIBUBSAN_SPEC "-lubsan" STATIC_LIBUBSAN_LIBS
822 #endif
823 #endif
824
825 /* Linker options for compressed debug sections. */
826 #if HAVE_LD_COMPRESS_DEBUG == 0
827 /* No linker support. */
828 #define LINK_COMPRESS_DEBUG_SPEC \
829 " %{gz*:%e-gz is not supported in this configuration} "
830 #elif HAVE_LD_COMPRESS_DEBUG == 1
831 /* GNU style on input, GNU ld options. Reject, not useful. */
832 #define LINK_COMPRESS_DEBUG_SPEC \
833 " %{gz*:%e-gz is not supported in this configuration} "
834 #elif HAVE_LD_COMPRESS_DEBUG == 2
835 /* GNU style, GNU gold options. */
836 #define LINK_COMPRESS_DEBUG_SPEC \
837 " %{gz|gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
838 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
839 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
840 #elif HAVE_LD_COMPRESS_DEBUG == 3
841 /* ELF gABI style. */
842 #define LINK_COMPRESS_DEBUG_SPEC \
843 " %{gz|gz=zlib:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
844 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
845 " %{gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
846 #else
847 #error Unknown value for HAVE_LD_COMPRESS_DEBUG.
848 #endif
849
850 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
851 included. */
852 #ifndef LIBGCC_SPEC
853 #if defined(REAL_LIBGCC_SPEC)
854 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
855 #elif defined(LINK_LIBGCC_SPECIAL_1)
856 /* Have gcc do the search for libgcc.a. */
857 #define LIBGCC_SPEC "libgcc.a%s"
858 #else
859 #define LIBGCC_SPEC "-lgcc"
860 #endif
861 #endif
862
863 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
864 #ifndef STARTFILE_SPEC
865 #define STARTFILE_SPEC \
866 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
867 #endif
868
869 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
870 #ifndef ENDFILE_SPEC
871 #define ENDFILE_SPEC ""
872 #endif
873
874 #ifndef LINKER_NAME
875 #define LINKER_NAME "collect2"
876 #endif
877
878 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
879 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
880 #else
881 #define ASM_MAP ""
882 #endif
883
884 /* Assembler options for compressed debug sections. */
885 #if HAVE_LD_COMPRESS_DEBUG < 2
886 /* Reject if the linker cannot write compressed debug sections. */
887 #define ASM_COMPRESS_DEBUG_SPEC \
888 " %{gz*:%e-gz is not supported in this configuration} "
889 #else /* HAVE_LD_COMPRESS_DEBUG >= 2 */
890 #if HAVE_AS_COMPRESS_DEBUG == 0
891 /* No assembler support. Ignore silently. */
892 #define ASM_COMPRESS_DEBUG_SPEC \
893 " %{gz*:} "
894 #elif HAVE_AS_COMPRESS_DEBUG == 1
895 /* GNU style, GNU as options. */
896 #define ASM_COMPRESS_DEBUG_SPEC \
897 " %{gz|gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "}" \
898 " %{gz=none:" AS_NO_COMPRESS_DEBUG_OPTION "}" \
899 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
900 #elif HAVE_AS_COMPRESS_DEBUG == 2
901 /* ELF gABI style. */
902 #define ASM_COMPRESS_DEBUG_SPEC \
903 " %{gz|gz=zlib:" AS_COMPRESS_DEBUG_OPTION "=zlib}" \
904 " %{gz=none:" AS_COMPRESS_DEBUG_OPTION "=none}" \
905 " %{gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
906 #else
907 #error Unknown value for HAVE_AS_COMPRESS_DEBUG.
908 #endif
909 #endif /* HAVE_LD_COMPRESS_DEBUG >= 2 */
910
911 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
912 to the assembler, when compiling assembly sources only. */
913 #ifndef ASM_DEBUG_SPEC
914 # if defined(HAVE_AS_GDWARF_5_DEBUG_FLAG) && defined(HAVE_AS_WORKING_DWARF_N_FLAG)
915 /* If --gdwarf-N is supported and as can handle even compiler generated
916 .debug_line with it, supply --gdwarf-N in ASM_DEBUG_OPTION_SPEC rather
917 than in ASM_DEBUG_SPEC, so that it applies to both .s and .c etc.
918 compilations. */
919 # define ASM_DEBUG_DWARF_OPTION ""
920 # elif defined(HAVE_AS_GDWARF_5_DEBUG_FLAG) && !defined(HAVE_LD_BROKEN_PE_DWARF5)
921 # define ASM_DEBUG_DWARF_OPTION "%{%:dwarf-version-gt(4):--gdwarf-5;" \
922 "%:dwarf-version-gt(3):--gdwarf-4;" \
923 "%:dwarf-version-gt(2):--gdwarf-3;" \
924 ":--gdwarf2}"
925 # else
926 # define ASM_DEBUG_DWARF_OPTION "--gdwarf2"
927 # endif
928 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
929 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
930 # define ASM_DEBUG_SPEC \
931 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
932 ? "%{%:debug-level-gt(0):" \
933 "%{gdwarf*:" ASM_DEBUG_DWARF_OPTION "};" \
934 ":%{g*:--gstabs}}" ASM_MAP \
935 : "%{%:debug-level-gt(0):" \
936 "%{gstabs*:--gstabs;" \
937 ":%{g*:" ASM_DEBUG_DWARF_OPTION "}}}" ASM_MAP)
938 # else
939 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
940 # define ASM_DEBUG_SPEC "%{g*:%{%:debug-level-gt(0):--gstabs}}" ASM_MAP
941 # endif
942 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
943 # define ASM_DEBUG_SPEC "%{g*:%{%:debug-level-gt(0):" \
944 ASM_DEBUG_DWARF_OPTION "}}" ASM_MAP
945 # endif
946 # endif
947 #endif
948 #ifndef ASM_DEBUG_SPEC
949 # define ASM_DEBUG_SPEC ""
950 #endif
951
952 /* Define ASM_DEBUG_OPTION_SPEC to be a spec suitable for translating '-g'
953 to the assembler when compiling all sources. */
954 #ifndef ASM_DEBUG_OPTION_SPEC
955 # if defined(HAVE_AS_GDWARF_5_DEBUG_FLAG) && defined(HAVE_AS_WORKING_DWARF_N_FLAG)
956 # define ASM_DEBUG_OPTION_DWARF_OPT \
957 "%{%:dwarf-version-gt(4):--gdwarf-5 ;" \
958 "%:dwarf-version-gt(3):--gdwarf-4 ;" \
959 "%:dwarf-version-gt(2):--gdwarf-3 ;" \
960 ":--gdwarf2 }"
961 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO)
962 # define ASM_DEBUG_OPTION_SPEC \
963 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
964 ? "%{%:debug-level-gt(0):" \
965 "%{gdwarf*:" ASM_DEBUG_OPTION_DWARF_OPT "}}" \
966 : "%{%:debug-level-gt(0):" \
967 "%{!gstabs*:%{g*:" ASM_DEBUG_OPTION_DWARF_OPT "}}}")
968 # elif defined(DWARF2_DEBUGGING_INFO)
969 # define ASM_DEBUG_OPTION_SPEC "%{g*:%{%:debug-level-gt(0):" \
970 ASM_DEBUG_OPTION_DWARF_OPT "}}"
971 # endif
972 # endif
973 #endif
974 #ifndef ASM_DEBUG_OPTION_SPEC
975 # define ASM_DEBUG_OPTION_SPEC ""
976 #endif
977
978 /* Here is the spec for running the linker, after compiling all files. */
979
980 /* This is overridable by the target in case they need to specify the
981 -lgcc and -lc order specially, yet not require them to override all
982 of LINK_COMMAND_SPEC. */
983 #ifndef LINK_GCC_C_SEQUENCE_SPEC
984 #define LINK_GCC_C_SEQUENCE_SPEC "%G %{!nolibc:%L %G}"
985 #endif
986
987 #ifndef LINK_SSP_SPEC
988 #ifdef TARGET_LIBC_PROVIDES_SSP
989 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
990 "|fstack-protector-strong|fstack-protector-explicit:}"
991 #else
992 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all" \
993 "|fstack-protector-strong|fstack-protector-explicit" \
994 ":-lssp_nonshared -lssp}"
995 #endif
996 #endif
997
998 #ifdef ENABLE_DEFAULT_PIE
999 #define PIE_SPEC "!no-pie"
1000 #define NO_FPIE1_SPEC "fno-pie"
1001 #define FPIE1_SPEC NO_FPIE1_SPEC ":;"
1002 #define NO_FPIE2_SPEC "fno-PIE"
1003 #define FPIE2_SPEC NO_FPIE2_SPEC ":;"
1004 #define NO_FPIE_SPEC NO_FPIE1_SPEC "|" NO_FPIE2_SPEC
1005 #define FPIE_SPEC NO_FPIE_SPEC ":;"
1006 #define NO_FPIC1_SPEC "fno-pic"
1007 #define FPIC1_SPEC NO_FPIC1_SPEC ":;"
1008 #define NO_FPIC2_SPEC "fno-PIC"
1009 #define FPIC2_SPEC NO_FPIC2_SPEC ":;"
1010 #define NO_FPIC_SPEC NO_FPIC1_SPEC "|" NO_FPIC2_SPEC
1011 #define FPIC_SPEC NO_FPIC_SPEC ":;"
1012 #define NO_FPIE1_AND_FPIC1_SPEC NO_FPIE1_SPEC "|" NO_FPIC1_SPEC
1013 #define FPIE1_OR_FPIC1_SPEC NO_FPIE1_AND_FPIC1_SPEC ":;"
1014 #define NO_FPIE2_AND_FPIC2_SPEC NO_FPIE2_SPEC "|" NO_FPIC2_SPEC
1015 #define FPIE2_OR_FPIC2_SPEC NO_FPIE2_AND_FPIC2_SPEC ":;"
1016 #define NO_FPIE_AND_FPIC_SPEC NO_FPIE_SPEC "|" NO_FPIC_SPEC
1017 #define FPIE_OR_FPIC_SPEC NO_FPIE_AND_FPIC_SPEC ":;"
1018 #else
1019 #define PIE_SPEC "pie"
1020 #define FPIE1_SPEC "fpie"
1021 #define NO_FPIE1_SPEC FPIE1_SPEC ":;"
1022 #define FPIE2_SPEC "fPIE"
1023 #define NO_FPIE2_SPEC FPIE2_SPEC ":;"
1024 #define FPIE_SPEC FPIE1_SPEC "|" FPIE2_SPEC
1025 #define NO_FPIE_SPEC FPIE_SPEC ":;"
1026 #define FPIC1_SPEC "fpic"
1027 #define NO_FPIC1_SPEC FPIC1_SPEC ":;"
1028 #define FPIC2_SPEC "fPIC"
1029 #define NO_FPIC2_SPEC FPIC2_SPEC ":;"
1030 #define FPIC_SPEC FPIC1_SPEC "|" FPIC2_SPEC
1031 #define NO_FPIC_SPEC FPIC_SPEC ":;"
1032 #define FPIE1_OR_FPIC1_SPEC FPIE1_SPEC "|" FPIC1_SPEC
1033 #define NO_FPIE1_AND_FPIC1_SPEC FPIE1_OR_FPIC1_SPEC ":;"
1034 #define FPIE2_OR_FPIC2_SPEC FPIE2_SPEC "|" FPIC2_SPEC
1035 #define NO_FPIE2_AND_FPIC2_SPEC FPIE1_OR_FPIC2_SPEC ":;"
1036 #define FPIE_OR_FPIC_SPEC FPIE_SPEC "|" FPIC_SPEC
1037 #define NO_FPIE_AND_FPIC_SPEC FPIE_OR_FPIC_SPEC ":;"
1038 #endif
1039
1040 #ifndef LINK_PIE_SPEC
1041 #ifdef HAVE_LD_PIE
1042 #ifndef LD_PIE_SPEC
1043 #define LD_PIE_SPEC "-pie"
1044 #endif
1045 #else
1046 #define LD_PIE_SPEC ""
1047 #endif
1048 #define LINK_PIE_SPEC "%{static|shared|r:;" PIE_SPEC ":" LD_PIE_SPEC "} "
1049 #endif
1050
1051 #ifndef LINK_BUILDID_SPEC
1052 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
1053 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
1054 # endif
1055 #endif
1056
1057 #ifndef LTO_PLUGIN_SPEC
1058 #define LTO_PLUGIN_SPEC ""
1059 #endif
1060
1061 /* Conditional to test whether the LTO plugin is used or not.
1062 FIXME: For slim LTO we will need to enable plugin unconditionally. This
1063 still cause problems with PLUGIN_LD != LD and when plugin is built but
1064 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
1065 plugin only when LTO is enabled. We still honor explicit
1066 -fuse-linker-plugin if the linker used understands -plugin. */
1067
1068 /* The linker has some plugin support. */
1069 #if HAVE_LTO_PLUGIN > 0
1070 /* The linker used has full plugin support, use LTO plugin by default. */
1071 #if HAVE_LTO_PLUGIN == 2
1072 #define PLUGIN_COND "!fno-use-linker-plugin:%{!fno-lto"
1073 #define PLUGIN_COND_CLOSE "}"
1074 #else
1075 /* The linker used has limited plugin support, use LTO plugin with explicit
1076 -fuse-linker-plugin. */
1077 #define PLUGIN_COND "fuse-linker-plugin"
1078 #define PLUGIN_COND_CLOSE ""
1079 #endif
1080 #define LINK_PLUGIN_SPEC \
1081 "%{" PLUGIN_COND": \
1082 -plugin %(linker_plugin_file) \
1083 -plugin-opt=%(lto_wrapper) \
1084 -plugin-opt=-fresolution=%u.res \
1085 " LTO_PLUGIN_SPEC "\
1086 %{flinker-output=*:-plugin-opt=-linker-output-known} \
1087 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
1088 }" PLUGIN_COND_CLOSE
1089 #else
1090 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
1091 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
1092 %e-fuse-linker-plugin is not supported in this configuration}"
1093 #endif
1094
1095 /* Linker command line options for -fsanitize= early on the command line. */
1096 #ifndef SANITIZER_EARLY_SPEC
1097 #define SANITIZER_EARLY_SPEC "\
1098 %{!nostdlib:%{!r:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_EARLY_SPEC "} \
1099 %{%:sanitize(hwaddress):" LIBHWASAN_EARLY_SPEC "} \
1100 %{%:sanitize(thread):" LIBTSAN_EARLY_SPEC "} \
1101 %{%:sanitize(leak):" LIBLSAN_EARLY_SPEC "}}}}"
1102 #endif
1103
1104 /* Linker command line options for -fsanitize= late on the command line. */
1105 #ifndef SANITIZER_SPEC
1106 #define SANITIZER_SPEC "\
1107 %{!nostdlib:%{!r:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_SPEC "\
1108 %{static:%ecannot specify -static with -fsanitize=address}}\
1109 %{%:sanitize(hwaddress):" LIBHWASAN_SPEC "\
1110 %{static:%ecannot specify -static with -fsanitize=hwaddress}}\
1111 %{%:sanitize(thread):" LIBTSAN_SPEC "\
1112 %{static:%ecannot specify -static with -fsanitize=thread}}\
1113 %{%:sanitize(undefined):" LIBUBSAN_SPEC "}\
1114 %{%:sanitize(leak):" LIBLSAN_SPEC "}}}}"
1115 #endif
1116
1117 #ifndef POST_LINK_SPEC
1118 #define POST_LINK_SPEC ""
1119 #endif
1120
1121 /* This is the spec to use, once the code for creating the vtable
1122 verification runtime library, libvtv.so, has been created. Currently
1123 the vtable verification runtime functions are in libstdc++, so we use
1124 the spec just below this one. */
1125 #ifndef VTABLE_VERIFICATION_SPEC
1126 #if ENABLE_VTABLE_VERIFY
1127 #define VTABLE_VERIFICATION_SPEC "\
1128 %{!nostdlib:%{!r:%{fvtable-verify=std: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}\
1129 %{fvtable-verify=preinit: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}}}"
1130 #else
1131 #define VTABLE_VERIFICATION_SPEC "\
1132 %{fvtable-verify=none:} \
1133 %{fvtable-verify=std: \
1134 %e-fvtable-verify=std is not supported in this configuration} \
1135 %{fvtable-verify=preinit: \
1136 %e-fvtable-verify=preinit is not supported in this configuration}"
1137 #endif
1138 #endif
1139
1140 /* -u* was put back because both BSD and SysV seem to support it. */
1141 /* %{static|no-pie|static-pie:} simply prevents an error message:
1142 1. If the target machine doesn't handle -static.
1143 2. If PIE isn't enabled by default.
1144 3. If the target machine doesn't handle -static-pie.
1145 */
1146 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
1147 scripts which exist in user specified directories, or in standard
1148 directories. */
1149 /* We pass any -flto flags on to the linker, which is expected
1150 to understand them. In practice, this means it had better be collect2. */
1151 /* %{e*} includes -export-dynamic; see comment in common.opt. */
1152 #ifndef LINK_COMMAND_SPEC
1153 #define LINK_COMMAND_SPEC "\
1154 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
1155 %(linker) " \
1156 LINK_PLUGIN_SPEC \
1157 "%{flto|flto=*:%<fcompare-debug*} \
1158 %{flto} %{fno-lto} %{flto=*} %l " LINK_PIE_SPEC \
1159 "%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
1160 "%X %{o*} %{e*} %{N} %{n} %{r}\
1161 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!r:%{!nostartfiles:%S}}} \
1162 %{static|no-pie|static-pie:} %@{L*} %(mfwrap) %(link_libgcc) " \
1163 VTABLE_VERIFICATION_SPEC " " SANITIZER_EARLY_SPEC " %o "" \
1164 %{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1):\
1165 %:include(libgomp.spec)%(link_gomp)}\
1166 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
1167 %(mflib) " STACK_SPLIT_SPEC "\
1168 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
1169 %{!nostdlib:%{!r:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}}\
1170 %{!nostdlib:%{!r:%{!nostartfiles:%E}}} %{T*} \n%(post_link) }}}}}}"
1171 #endif
1172
1173 #ifndef LINK_LIBGCC_SPEC
1174 /* Generate -L options for startfile prefix list. */
1175 # define LINK_LIBGCC_SPEC "%D"
1176 #endif
1177
1178 #ifndef STARTFILE_PREFIX_SPEC
1179 # define STARTFILE_PREFIX_SPEC ""
1180 #endif
1181
1182 #ifndef SYSROOT_SPEC
1183 # define SYSROOT_SPEC "--sysroot=%R"
1184 #endif
1185
1186 #ifndef SYSROOT_SUFFIX_SPEC
1187 # define SYSROOT_SUFFIX_SPEC ""
1188 #endif
1189
1190 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
1191 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
1192 #endif
1193
1194 static const char *asm_debug = ASM_DEBUG_SPEC;
1195 static const char *asm_debug_option = ASM_DEBUG_OPTION_SPEC;
1196 static const char *cpp_spec = CPP_SPEC;
1197 static const char *cc1_spec = CC1_SPEC;
1198 static const char *cc1plus_spec = CC1PLUS_SPEC;
1199 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
1200 static const char *link_ssp_spec = LINK_SSP_SPEC;
1201 static const char *asm_spec = ASM_SPEC;
1202 static const char *asm_final_spec = ASM_FINAL_SPEC;
1203 static const char *link_spec = LINK_SPEC;
1204 static const char *lib_spec = LIB_SPEC;
1205 static const char *link_gomp_spec = "";
1206 static const char *libgcc_spec = LIBGCC_SPEC;
1207 static const char *endfile_spec = ENDFILE_SPEC;
1208 static const char *startfile_spec = STARTFILE_SPEC;
1209 static const char *linker_name_spec = LINKER_NAME;
1210 static const char *linker_plugin_file_spec = "";
1211 static const char *lto_wrapper_spec = "";
1212 static const char *lto_gcc_spec = "";
1213 static const char *post_link_spec = POST_LINK_SPEC;
1214 static const char *link_command_spec = LINK_COMMAND_SPEC;
1215 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
1216 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
1217 static const char *sysroot_spec = SYSROOT_SPEC;
1218 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
1219 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
1220 static const char *self_spec = "";
1221
1222 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
1223 There should be no need to override these in target dependent files,
1224 but we need to copy them to the specs file so that newer versions
1225 of the GCC driver can correctly drive older tool chains with the
1226 appropriate -B options. */
1227
1228 /* When cpplib handles traditional preprocessing, get rid of this, and
1229 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
1230 that we default the front end language better. */
1231 static const char *trad_capable_cpp =
1232 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
1233
1234 /* We don't wrap .d files in %W{} since a missing .d file, and
1235 therefore no dependency entry, confuses make into thinking a .o
1236 file that happens to exist is up-to-date. */
1237 static const char *cpp_unique_options =
1238 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %@{I*&F*} %{P} %I\
1239 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
1240 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
1241 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
1242 %{Mmodules} %{Mno-modules}\
1243 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
1244 %{remap} %{%:debug-level-gt(2):-dD}\
1245 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1246 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
1247 %{E|M|MM:%W{o*}}";
1248
1249 /* This contains cpp options which are common with cc1_options and are passed
1250 only when preprocessing only to avoid duplication. We pass the cc1 spec
1251 options to the preprocessor so that it the cc1 spec may manipulate
1252 options used to set target flags. Those special target flags settings may
1253 in turn cause preprocessor symbols to be defined specially. */
1254 static const char *cpp_options =
1255 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
1256 %{f*} %{g*:%{%:debug-level-gt(0):%{g*}\
1257 %{!fno-working-directory:-fworking-directory}}} %{O*}\
1258 %{undef} %{save-temps*:-fpch-preprocess}";
1259
1260 /* Pass -d* flags, possibly modifying -dumpdir, -dumpbase et al.
1261
1262 Make it easy for a language to override the argument for the
1263 %:dumps specs function call. */
1264 #define DUMPS_OPTIONS(EXTS) \
1265 "%<dumpdir %<dumpbase %<dumpbase-ext %{d*} %:dumps(" EXTS ")"
1266
1267 /* This contains cpp options which are not passed when the preprocessor
1268 output will be used by another program. */
1269 static const char *cpp_debug_options = DUMPS_OPTIONS ("");
1270
1271 /* NB: This is shared amongst all front-ends, except for Ada. */
1272 static const char *cc1_options =
1273 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
1274 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
1275 %1 %{!Q:-quiet} %(cpp_debug_options) %{m*} %{aux-info*}\
1276 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
1277 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
1278 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
1279 %{-target-help:--target-help}\
1280 %{-version:--version}\
1281 %{-help=*:--help=%*}\
1282 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %w%b.s}}}\
1283 %{fsyntax-only:-o %j} %{-param*}\
1284 %{coverage:-fprofile-arcs -ftest-coverage}\
1285 %{fprofile-arcs|fprofile-generate*|coverage:\
1286 %{!fprofile-update=single:\
1287 %{pthread:-fprofile-update=prefer-atomic}}}";
1288
1289 static const char *asm_options =
1290 "%{-target-help:%:print-asm-header()} "
1291 #if HAVE_GNU_AS
1292 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
1293 to the assembler equivalents. */
1294 "%{v} %{w:-W} %{I*} "
1295 #endif
1296 "%(asm_debug_option)"
1297 ASM_COMPRESS_DEBUG_SPEC
1298 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
1299
1300 static const char *invoke_as =
1301 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1302 "%{!fwpa*:\
1303 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1304 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
1305 }";
1306 #else
1307 "%{!fwpa*:\
1308 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
1309 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
1310 }";
1311 #endif
1312
1313 /* Some compilers have limits on line lengths, and the multilib_select
1314 and/or multilib_matches strings can be very long, so we build them at
1315 run time. */
1316 static struct obstack multilib_obstack;
1317 static const char *multilib_select;
1318 static const char *multilib_matches;
1319 static const char *multilib_defaults;
1320 static const char *multilib_exclusions;
1321 static const char *multilib_reuse;
1322
1323 /* Check whether a particular argument is a default argument. */
1324
1325 #ifndef MULTILIB_DEFAULTS
1326 #define MULTILIB_DEFAULTS { "" }
1327 #endif
1328
1329 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
1330
1331 #ifndef DRIVER_SELF_SPECS
1332 #define DRIVER_SELF_SPECS ""
1333 #endif
1334
1335 /* Linking to libgomp implies pthreads. This is particularly important
1336 for targets that use different start files and suchlike. */
1337 #ifndef GOMP_SELF_SPECS
1338 #define GOMP_SELF_SPECS \
1339 "%{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1): " \
1340 "-pthread}"
1341 #endif
1342
1343 /* Likewise for -fgnu-tm. */
1344 #ifndef GTM_SELF_SPECS
1345 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
1346 #endif
1347
1348 static const char *const driver_self_specs[] = {
1349 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
1350 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS
1351 };
1352
1353 #ifndef OPTION_DEFAULT_SPECS
1354 #define OPTION_DEFAULT_SPECS { "", "" }
1355 #endif
1356
1357 struct default_spec
1358 {
1359 const char *name;
1360 const char *spec;
1361 };
1362
1363 static const struct default_spec
1364 option_default_specs[] = { OPTION_DEFAULT_SPECS };
1365
1366 struct user_specs
1367 {
1368 struct user_specs *next;
1369 const char *filename;
1370 };
1371
1372 static struct user_specs *user_specs_head, *user_specs_tail;
1373
1374 \f
1375 /* Record the mapping from file suffixes for compilation specs. */
1376
1377 struct compiler
1378 {
1379 const char *suffix; /* Use this compiler for input files
1380 whose names end in this suffix. */
1381
1382 const char *spec; /* To use this compiler, run this spec. */
1383
1384 const char *cpp_spec; /* If non-NULL, substitute this spec
1385 for `%C', rather than the usual
1386 cpp_spec. */
1387 int combinable; /* If nonzero, compiler can deal with
1388 multiple source files at once (IMA). */
1389 int needs_preprocessing; /* If nonzero, source files need to
1390 be run through a preprocessor. */
1391 };
1392
1393 /* Pointer to a vector of `struct compiler' that gives the spec for
1394 compiling a file, based on its suffix.
1395 A file that does not end in any of these suffixes will be passed
1396 unchanged to the loader and nothing else will be done to it.
1397
1398 An entry containing two 0s is used to terminate the vector.
1399
1400 If multiple entries match a file, the last matching one is used. */
1401
1402 static struct compiler *compilers;
1403
1404 /* Number of entries in `compilers', not counting the null terminator. */
1405
1406 static int n_compilers;
1407
1408 /* The default list of file name suffixes and their compilation specs. */
1409
1410 static const struct compiler default_compilers[] =
1411 {
1412 /* Add lists of suffixes of known languages here. If those languages
1413 were not present when we built the driver, we will hit these copies
1414 and be given a more meaningful error than "file not used since
1415 linking is not done". */
1416 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
1417 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
1418 {".mii", "#Objective-C++", 0, 0, 0},
1419 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
1420 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
1421 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
1422 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
1423 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
1424 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
1425 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
1426 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
1427 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
1428 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
1429 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
1430 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1431 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1432 {".r", "#Ratfor", 0, 0, 0},
1433 {".go", "#Go", 0, 1, 0},
1434 {".d", "#D", 0, 1, 0}, {".dd", "#D", 0, 1, 0}, {".di", "#D", 0, 1, 0},
1435 /* Next come the entries for C. */
1436 {".c", "@c", 0, 0, 1},
1437 {"@c",
1438 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1439 external preprocessor if -save-temps is given. */
1440 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1441 %{!E:%{!M:%{!MM:\
1442 %{traditional:\
1443 %eGNU C no longer supports -traditional without -E}\
1444 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1445 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1446 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1447 %(cc1_options)}\
1448 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1449 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1450 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1451 {"-",
1452 "%{!E:%e-E or -x required when input is from standard input}\
1453 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1454 {".h", "@c-header", 0, 0, 0},
1455 {"@c-header",
1456 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1457 external preprocessor if -save-temps is given. */
1458 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1459 %{!E:%{!M:%{!MM:\
1460 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1461 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1462 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1463 %(cc1_options)\
1464 %{!fsyntax-only:%{!S:-o %g.s} \
1465 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1466 %W{o*:--output-pch=%*}}%V}}\
1467 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1468 cc1 %(cpp_unique_options) %(cc1_options)\
1469 %{!fsyntax-only:%{!S:-o %g.s} \
1470 %{!fdump-ada-spec*:%{!o*:--output-pch=%i.gch}\
1471 %W{o*:--output-pch=%*}}%V}}}}}}}", 0, 0, 0},
1472 {".i", "@cpp-output", 0, 0, 0},
1473 {"@cpp-output",
1474 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1475 {".s", "@assembler", 0, 0, 0},
1476 {"@assembler",
1477 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1478 {".sx", "@assembler-with-cpp", 0, 0, 0},
1479 {".S", "@assembler-with-cpp", 0, 0, 0},
1480 {"@assembler-with-cpp",
1481 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1482 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1483 %{E|M|MM:%(cpp_debug_options)}\
1484 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1485 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1486 #else
1487 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1488 %{E|M|MM:%(cpp_debug_options)}\
1489 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1490 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1491 #endif
1492 , 0, 0, 0},
1493
1494 #include "specs.h"
1495 /* Mark end of table. */
1496 {0, 0, 0, 0, 0}
1497 };
1498
1499 /* Number of elements in default_compilers, not counting the terminator. */
1500
1501 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1502
1503 typedef char *char_p; /* For DEF_VEC_P. */
1504
1505 /* A vector of options to give to the linker.
1506 These options are accumulated by %x,
1507 and substituted into the linker command with %X. */
1508 static vec<char_p> linker_options;
1509
1510 /* A vector of options to give to the assembler.
1511 These options are accumulated by -Wa,
1512 and substituted into the assembler command with %Y. */
1513 static vec<char_p> assembler_options;
1514
1515 /* A vector of options to give to the preprocessor.
1516 These options are accumulated by -Wp,
1517 and substituted into the preprocessor command with %Z. */
1518 static vec<char_p> preprocessor_options;
1519 \f
1520 static char *
1521 skip_whitespace (char *p)
1522 {
1523 while (1)
1524 {
1525 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1526 be considered whitespace. */
1527 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1528 return p + 1;
1529 else if (*p == '\n' || *p == ' ' || *p == '\t')
1530 p++;
1531 else if (*p == '#')
1532 {
1533 while (*p != '\n')
1534 p++;
1535 p++;
1536 }
1537 else
1538 break;
1539 }
1540
1541 return p;
1542 }
1543 /* Structures to keep track of prefixes to try when looking for files. */
1544
1545 struct prefix_list
1546 {
1547 const char *prefix; /* String to prepend to the path. */
1548 struct prefix_list *next; /* Next in linked list. */
1549 int require_machine_suffix; /* Don't use without machine_suffix. */
1550 /* 2 means try both machine_suffix and just_machine_suffix. */
1551 int priority; /* Sort key - priority within list. */
1552 int os_multilib; /* 1 if OS multilib scheme should be used,
1553 0 for GCC multilib scheme. */
1554 };
1555
1556 struct path_prefix
1557 {
1558 struct prefix_list *plist; /* List of prefixes to try */
1559 int max_len; /* Max length of a prefix in PLIST */
1560 const char *name; /* Name of this list (used in config stuff) */
1561 };
1562
1563 /* List of prefixes to try when looking for executables. */
1564
1565 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1566
1567 /* List of prefixes to try when looking for startup (crt0) files. */
1568
1569 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1570
1571 /* List of prefixes to try when looking for include files. */
1572
1573 static struct path_prefix include_prefixes = { 0, 0, "include" };
1574
1575 /* Suffix to attach to directories searched for commands.
1576 This looks like `MACHINE/VERSION/'. */
1577
1578 static const char *machine_suffix = 0;
1579
1580 /* Suffix to attach to directories searched for commands.
1581 This is just `MACHINE/'. */
1582
1583 static const char *just_machine_suffix = 0;
1584
1585 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1586
1587 static const char *gcc_exec_prefix;
1588
1589 /* Adjusted value of standard_libexec_prefix. */
1590
1591 static const char *gcc_libexec_prefix;
1592
1593 /* Default prefixes to attach to command names. */
1594
1595 #ifndef STANDARD_STARTFILE_PREFIX_1
1596 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1597 #endif
1598 #ifndef STANDARD_STARTFILE_PREFIX_2
1599 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1600 #endif
1601
1602 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1603 #undef MD_EXEC_PREFIX
1604 #undef MD_STARTFILE_PREFIX
1605 #undef MD_STARTFILE_PREFIX_1
1606 #endif
1607
1608 /* If no prefixes defined, use the null string, which will disable them. */
1609 #ifndef MD_EXEC_PREFIX
1610 #define MD_EXEC_PREFIX ""
1611 #endif
1612 #ifndef MD_STARTFILE_PREFIX
1613 #define MD_STARTFILE_PREFIX ""
1614 #endif
1615 #ifndef MD_STARTFILE_PREFIX_1
1616 #define MD_STARTFILE_PREFIX_1 ""
1617 #endif
1618
1619 /* These directories are locations set at configure-time based on the
1620 --prefix option provided to configure. Their initializers are
1621 defined in Makefile.in. These paths are not *directly* used when
1622 gcc_exec_prefix is set because, in that case, we know where the
1623 compiler has been installed, and use paths relative to that
1624 location instead. */
1625 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1626 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1627 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1628 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1629
1630 /* For native compilers, these are well-known paths containing
1631 components that may be provided by the system. For cross
1632 compilers, these paths are not used. */
1633 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1634 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1635 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1636 static const char *const standard_startfile_prefix_1
1637 = STANDARD_STARTFILE_PREFIX_1;
1638 static const char *const standard_startfile_prefix_2
1639 = STANDARD_STARTFILE_PREFIX_2;
1640
1641 /* A relative path to be used in finding the location of tools
1642 relative to the driver. */
1643 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1644
1645 /* A prefix to be used when this is an accelerator compiler. */
1646 static const char *const accel_dir_suffix = ACCEL_DIR_SUFFIX;
1647
1648 /* Subdirectory to use for locating libraries. Set by
1649 set_multilib_dir based on the compilation options. */
1650
1651 static const char *multilib_dir;
1652
1653 /* Subdirectory to use for locating libraries in OS conventions. Set by
1654 set_multilib_dir based on the compilation options. */
1655
1656 static const char *multilib_os_dir;
1657
1658 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1659 set_multilib_dir based on the compilation options. */
1660
1661 static const char *multiarch_dir;
1662 \f
1663 /* Structure to keep track of the specs that have been defined so far.
1664 These are accessed using %(specname) in a compiler or link
1665 spec. */
1666
1667 struct spec_list
1668 {
1669 /* The following 2 fields must be first */
1670 /* to allow EXTRA_SPECS to be initialized */
1671 const char *name; /* name of the spec. */
1672 const char *ptr; /* available ptr if no static pointer */
1673
1674 /* The following fields are not initialized */
1675 /* by EXTRA_SPECS */
1676 const char **ptr_spec; /* pointer to the spec itself. */
1677 struct spec_list *next; /* Next spec in linked list. */
1678 int name_len; /* length of the name */
1679 bool user_p; /* whether string come from file spec. */
1680 bool alloc_p; /* whether string was allocated */
1681 const char *default_ptr; /* The default value of *ptr_spec. */
1682 };
1683
1684 #define INIT_STATIC_SPEC(NAME,PTR) \
1685 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false, \
1686 *PTR }
1687
1688 /* List of statically defined specs. */
1689 static struct spec_list static_specs[] =
1690 {
1691 INIT_STATIC_SPEC ("asm", &asm_spec),
1692 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1693 INIT_STATIC_SPEC ("asm_debug_option", &asm_debug_option),
1694 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1695 INIT_STATIC_SPEC ("asm_options", &asm_options),
1696 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1697 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1698 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1699 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1700 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1701 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1702 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1703 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1704 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1705 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1706 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1707 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1708 INIT_STATIC_SPEC ("link", &link_spec),
1709 INIT_STATIC_SPEC ("lib", &lib_spec),
1710 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1711 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1712 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1713 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1714 INIT_STATIC_SPEC ("version", &compiler_version),
1715 INIT_STATIC_SPEC ("multilib", &multilib_select),
1716 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1717 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1718 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1719 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1720 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1721 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1722 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1723 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1724 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1725 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1726 INIT_STATIC_SPEC ("post_link", &post_link_spec),
1727 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1728 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1729 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1730 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1731 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1732 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1733 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1734 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1735 INIT_STATIC_SPEC ("self_spec", &self_spec),
1736 };
1737
1738 #ifdef EXTRA_SPECS /* additional specs needed */
1739 /* Structure to keep track of just the first two args of a spec_list.
1740 That is all that the EXTRA_SPECS macro gives us. */
1741 struct spec_list_1
1742 {
1743 const char *const name;
1744 const char *const ptr;
1745 };
1746
1747 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1748 static struct spec_list *extra_specs = (struct spec_list *) 0;
1749 #endif
1750
1751 /* List of dynamically allocates specs that have been defined so far. */
1752
1753 static struct spec_list *specs = (struct spec_list *) 0;
1754 \f
1755 /* List of static spec functions. */
1756
1757 static const struct spec_function static_spec_functions[] =
1758 {
1759 { "getenv", getenv_spec_function },
1760 { "if-exists", if_exists_spec_function },
1761 { "if-exists-else", if_exists_else_spec_function },
1762 { "if-exists-then-else", if_exists_then_else_spec_function },
1763 { "sanitize", sanitize_spec_function },
1764 { "replace-outfile", replace_outfile_spec_function },
1765 { "remove-outfile", remove_outfile_spec_function },
1766 { "version-compare", version_compare_spec_function },
1767 { "include", include_spec_function },
1768 { "find-file", find_file_spec_function },
1769 { "find-plugindir", find_plugindir_spec_function },
1770 { "print-asm-header", print_asm_header_spec_function },
1771 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1772 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1773 { "pass-through-libs", pass_through_libs_spec_func },
1774 { "dumps", dumps_spec_func },
1775 { "gt", greater_than_spec_func },
1776 { "debug-level-gt", debug_level_greater_than_spec_func },
1777 { "dwarf-version-gt", dwarf_version_greater_than_spec_func },
1778 { "fortran-preinclude-file", find_fortran_preinclude_file},
1779 #ifdef EXTRA_SPEC_FUNCTIONS
1780 EXTRA_SPEC_FUNCTIONS
1781 #endif
1782 { 0, 0 }
1783 };
1784
1785 static int processing_spec_function;
1786 \f
1787 /* Add appropriate libgcc specs to OBSTACK, taking into account
1788 various permutations of -shared-libgcc, -shared, and such. */
1789
1790 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1791
1792 #ifndef USE_LD_AS_NEEDED
1793 #define USE_LD_AS_NEEDED 0
1794 #endif
1795
1796 static void
1797 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1798 const char *static_name, const char *eh_name)
1799 {
1800 char *buf;
1801
1802 #if USE_LD_AS_NEEDED
1803 buf = concat ("%{static|static-libgcc|static-pie:", static_name, " ", eh_name, "}"
1804 "%{!static:%{!static-libgcc:%{!static-pie:"
1805 "%{!shared-libgcc:",
1806 static_name, " " LD_AS_NEEDED_OPTION " ",
1807 shared_name, " " LD_NO_AS_NEEDED_OPTION
1808 "}"
1809 "%{shared-libgcc:",
1810 shared_name, "%{!shared: ", static_name, "}"
1811 "}}"
1812 #else
1813 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1814 "%{!static:%{!static-libgcc:"
1815 "%{!shared:"
1816 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1817 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1818 "}"
1819 #ifdef LINK_EH_SPEC
1820 "%{shared:"
1821 "%{shared-libgcc:", shared_name, "}"
1822 "%{!shared-libgcc:", static_name, "}"
1823 "}"
1824 #else
1825 "%{shared:", shared_name, "}"
1826 #endif
1827 #endif
1828 "}}", NULL);
1829
1830 obstack_grow (obstack, buf, strlen (buf));
1831 free (buf);
1832 }
1833 #endif /* ENABLE_SHARED_LIBGCC */
1834
1835 /* Initialize the specs lookup routines. */
1836
1837 static void
1838 init_spec (void)
1839 {
1840 struct spec_list *next = (struct spec_list *) 0;
1841 struct spec_list *sl = (struct spec_list *) 0;
1842 int i;
1843
1844 if (specs)
1845 return; /* Already initialized. */
1846
1847 if (verbose_flag)
1848 fnotice (stderr, "Using built-in specs.\n");
1849
1850 #ifdef EXTRA_SPECS
1851 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1852
1853 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1854 {
1855 sl = &extra_specs[i];
1856 sl->name = extra_specs_1[i].name;
1857 sl->ptr = extra_specs_1[i].ptr;
1858 sl->next = next;
1859 sl->name_len = strlen (sl->name);
1860 sl->ptr_spec = &sl->ptr;
1861 gcc_assert (sl->ptr_spec != NULL);
1862 sl->default_ptr = sl->ptr;
1863 next = sl;
1864 }
1865 #endif
1866
1867 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1868 {
1869 sl = &static_specs[i];
1870 sl->next = next;
1871 next = sl;
1872 }
1873
1874 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1875 /* ??? If neither -shared-libgcc nor --static-libgcc was
1876 seen, then we should be making an educated guess. Some proposed
1877 heuristics for ELF include:
1878
1879 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1880 program will be doing dynamic loading, which will likely
1881 need the shared libgcc.
1882
1883 (2) If "-ldl", then it's also a fair bet that we're doing
1884 dynamic loading.
1885
1886 (3) For each ET_DYN we're linking against (either through -lfoo
1887 or /some/path/foo.so), check to see whether it or one of
1888 its dependencies depends on a shared libgcc.
1889
1890 (4) If "-shared"
1891
1892 If the runtime is fixed to look for program headers instead
1893 of calling __register_frame_info at all, for each object,
1894 use the shared libgcc if any EH symbol referenced.
1895
1896 If crtstuff is fixed to not invoke __register_frame_info
1897 automatically, for each object, use the shared libgcc if
1898 any non-empty unwind section found.
1899
1900 Doing any of this probably requires invoking an external program to
1901 do the actual object file scanning. */
1902 {
1903 const char *p = libgcc_spec;
1904 int in_sep = 1;
1905
1906 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1907 when given the proper command line arguments. */
1908 while (*p)
1909 {
1910 if (in_sep && *p == '-' && startswith (p, "-lgcc"))
1911 {
1912 init_gcc_specs (&obstack,
1913 "-lgcc_s"
1914 #ifdef USE_LIBUNWIND_EXCEPTIONS
1915 " -lunwind"
1916 #endif
1917 ,
1918 "-lgcc",
1919 "-lgcc_eh"
1920 #ifdef USE_LIBUNWIND_EXCEPTIONS
1921 # ifdef HAVE_LD_STATIC_DYNAMIC
1922 " %{!static:%{!static-pie:" LD_STATIC_OPTION "}} -lunwind"
1923 " %{!static:%{!static-pie:" LD_DYNAMIC_OPTION "}}"
1924 # else
1925 " -lunwind"
1926 # endif
1927 #endif
1928 );
1929
1930 p += 5;
1931 in_sep = 0;
1932 }
1933 else if (in_sep && *p == 'l' && startswith (p, "libgcc.a%s"))
1934 {
1935 /* Ug. We don't know shared library extensions. Hope that
1936 systems that use this form don't do shared libraries. */
1937 init_gcc_specs (&obstack,
1938 "-lgcc_s",
1939 "libgcc.a%s",
1940 "libgcc_eh.a%s"
1941 #ifdef USE_LIBUNWIND_EXCEPTIONS
1942 " -lunwind"
1943 #endif
1944 );
1945 p += 10;
1946 in_sep = 0;
1947 }
1948 else
1949 {
1950 obstack_1grow (&obstack, *p);
1951 in_sep = (*p == ' ');
1952 p += 1;
1953 }
1954 }
1955
1956 obstack_1grow (&obstack, '\0');
1957 libgcc_spec = XOBFINISH (&obstack, const char *);
1958 }
1959 #endif
1960 #ifdef USE_AS_TRADITIONAL_FORMAT
1961 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1962 {
1963 static const char tf[] = "--traditional-format ";
1964 obstack_grow (&obstack, tf, sizeof (tf) - 1);
1965 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1966 asm_spec = XOBFINISH (&obstack, const char *);
1967 }
1968 #endif
1969
1970 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1971 defined LINKER_HASH_STYLE
1972 # ifdef LINK_BUILDID_SPEC
1973 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1974 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof (LINK_BUILDID_SPEC) - 1);
1975 # endif
1976 # ifdef LINK_EH_SPEC
1977 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1978 obstack_grow (&obstack, LINK_EH_SPEC, sizeof (LINK_EH_SPEC) - 1);
1979 # endif
1980 # ifdef LINKER_HASH_STYLE
1981 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1982 before. */
1983 {
1984 static const char hash_style[] = "--hash-style=";
1985 obstack_grow (&obstack, hash_style, sizeof (hash_style) - 1);
1986 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof (LINKER_HASH_STYLE) - 1);
1987 obstack_1grow (&obstack, ' ');
1988 }
1989 # endif
1990 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1991 link_spec = XOBFINISH (&obstack, const char *);
1992 #endif
1993
1994 specs = sl;
1995 }
1996
1997 /* Update the entry for SPEC in the static_specs table to point to VALUE,
1998 ensuring that we free the previous value if necessary. Set alloc_p for the
1999 entry to ALLOC_P: this determines whether we take ownership of VALUE (i.e.
2000 whether we need to free it later on). */
2001 static void
2002 set_static_spec (const char **spec, const char *value, bool alloc_p)
2003 {
2004 struct spec_list *sl = NULL;
2005
2006 for (unsigned i = 0; i < ARRAY_SIZE (static_specs); i++)
2007 {
2008 if (static_specs[i].ptr_spec == spec)
2009 {
2010 sl = static_specs + i;
2011 break;
2012 }
2013 }
2014
2015 gcc_assert (sl);
2016
2017 if (sl->alloc_p)
2018 {
2019 const char *old = *spec;
2020 free (const_cast <char *> (old));
2021 }
2022
2023 *spec = value;
2024 sl->alloc_p = alloc_p;
2025 }
2026
2027 /* Update a static spec to a new string, taking ownership of that
2028 string's memory. */
2029 static void set_static_spec_owned (const char **spec, const char *val)
2030 {
2031 return set_static_spec (spec, val, true);
2032 }
2033
2034 /* Update a static spec to point to a new value, but don't take
2035 ownership of (i.e. don't free) that string. */
2036 static void set_static_spec_shared (const char **spec, const char *val)
2037 {
2038 return set_static_spec (spec, val, false);
2039 }
2040
2041 \f
2042 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
2043 removed; If the spec starts with a + then SPEC is added to the end of the
2044 current spec. */
2045
2046 static void
2047 set_spec (const char *name, const char *spec, bool user_p)
2048 {
2049 struct spec_list *sl;
2050 const char *old_spec;
2051 int name_len = strlen (name);
2052 int i;
2053
2054 /* If this is the first call, initialize the statically allocated specs. */
2055 if (!specs)
2056 {
2057 struct spec_list *next = (struct spec_list *) 0;
2058 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
2059 {
2060 sl = &static_specs[i];
2061 sl->next = next;
2062 next = sl;
2063 }
2064 specs = sl;
2065 }
2066
2067 /* See if the spec already exists. */
2068 for (sl = specs; sl; sl = sl->next)
2069 if (name_len == sl->name_len && !strcmp (sl->name, name))
2070 break;
2071
2072 if (!sl)
2073 {
2074 /* Not found - make it. */
2075 sl = XNEW (struct spec_list);
2076 sl->name = xstrdup (name);
2077 sl->name_len = name_len;
2078 sl->ptr_spec = &sl->ptr;
2079 sl->alloc_p = 0;
2080 *(sl->ptr_spec) = "";
2081 sl->next = specs;
2082 sl->default_ptr = NULL;
2083 specs = sl;
2084 }
2085
2086 old_spec = *(sl->ptr_spec);
2087 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
2088 ? concat (old_spec, spec + 1, NULL)
2089 : xstrdup (spec));
2090
2091 #ifdef DEBUG_SPECS
2092 if (verbose_flag)
2093 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
2094 #endif
2095
2096 /* Free the old spec. */
2097 if (old_spec && sl->alloc_p)
2098 free (CONST_CAST (char *, old_spec));
2099
2100 sl->user_p = user_p;
2101 sl->alloc_p = true;
2102 }
2103 \f
2104 /* Accumulate a command (program name and args), and run it. */
2105
2106 typedef const char *const_char_p; /* For DEF_VEC_P. */
2107
2108 /* Vector of pointers to arguments in the current line of specifications. */
2109 static vec<const_char_p> argbuf;
2110
2111 /* Likewise, but for the current @file. */
2112 static vec<const_char_p> at_file_argbuf;
2113
2114 /* Whether an @file is currently open. */
2115 static bool in_at_file = false;
2116
2117 /* Were the options -c, -S or -E passed. */
2118 static int have_c = 0;
2119
2120 /* Was the option -o passed. */
2121 static int have_o = 0;
2122
2123 /* Was the option -E passed. */
2124 static int have_E = 0;
2125
2126 /* Pointer to output file name passed in with -o. */
2127 static const char *output_file = 0;
2128
2129 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
2130 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
2131 it here. */
2132
2133 static struct temp_name {
2134 const char *suffix; /* suffix associated with the code. */
2135 int length; /* strlen (suffix). */
2136 int unique; /* Indicates whether %g or %u/%U was used. */
2137 const char *filename; /* associated filename. */
2138 int filename_length; /* strlen (filename). */
2139 struct temp_name *next;
2140 } *temp_names;
2141
2142 /* Number of commands executed so far. */
2143
2144 static int execution_count;
2145
2146 /* Number of commands that exited with a signal. */
2147
2148 static int signal_count;
2149 \f
2150 /* Allocate the argument vector. */
2151
2152 static void
2153 alloc_args (void)
2154 {
2155 argbuf.create (10);
2156 at_file_argbuf.create (10);
2157 }
2158
2159 /* Clear out the vector of arguments (after a command is executed). */
2160
2161 static void
2162 clear_args (void)
2163 {
2164 argbuf.truncate (0);
2165 at_file_argbuf.truncate (0);
2166 }
2167
2168 /* Add one argument to the vector at the end.
2169 This is done when a space is seen or at the end of the line.
2170 If DELETE_ALWAYS is nonzero, the arg is a filename
2171 and the file should be deleted eventually.
2172 If DELETE_FAILURE is nonzero, the arg is a filename
2173 and the file should be deleted if this compilation fails. */
2174
2175 static void
2176 store_arg (const char *arg, int delete_always, int delete_failure)
2177 {
2178 if (in_at_file)
2179 at_file_argbuf.safe_push (arg);
2180 else
2181 argbuf.safe_push (arg);
2182
2183 if (delete_always || delete_failure)
2184 {
2185 const char *p;
2186 /* If the temporary file we should delete is specified as
2187 part of a joined argument extract the filename. */
2188 if (arg[0] == '-'
2189 && (p = strrchr (arg, '=')))
2190 arg = p + 1;
2191 record_temp_file (arg, delete_always, delete_failure);
2192 }
2193 }
2194
2195 /* Open a temporary @file into which subsequent arguments will be stored. */
2196
2197 static void
2198 open_at_file (void)
2199 {
2200 if (in_at_file)
2201 fatal_error (input_location, "cannot open nested response file");
2202 else
2203 in_at_file = true;
2204 }
2205
2206 /* Create a temporary @file name. */
2207
2208 static char *make_at_file (void)
2209 {
2210 static int fileno = 0;
2211 char filename[20];
2212 const char *base, *ext;
2213
2214 if (!save_temps_flag)
2215 return make_temp_file ("");
2216
2217 base = dumpbase;
2218 if (!(base && *base))
2219 base = dumpdir;
2220 if (!(base && *base))
2221 base = "a";
2222
2223 sprintf (filename, ".args.%d", fileno++);
2224 ext = filename;
2225
2226 if (base == dumpdir && dumpdir_trailing_dash_added)
2227 ext++;
2228
2229 return concat (base, ext, NULL);
2230 }
2231
2232 /* Close the temporary @file and add @file to the argument list. */
2233
2234 static void
2235 close_at_file (void)
2236 {
2237 if (!in_at_file)
2238 fatal_error (input_location, "cannot close nonexistent response file");
2239
2240 in_at_file = false;
2241
2242 const unsigned int n_args = at_file_argbuf.length ();
2243 if (n_args == 0)
2244 return;
2245
2246 char **argv = XALLOCAVEC (char *, n_args + 1);
2247 char *temp_file = make_at_file ();
2248 char *at_argument = concat ("@", temp_file, NULL);
2249 FILE *f = fopen (temp_file, "w");
2250 int status;
2251 unsigned int i;
2252
2253 /* Copy the strings over. */
2254 for (i = 0; i < n_args; i++)
2255 argv[i] = CONST_CAST (char *, at_file_argbuf[i]);
2256 argv[i] = NULL;
2257
2258 at_file_argbuf.truncate (0);
2259
2260 if (f == NULL)
2261 fatal_error (input_location, "could not open temporary response file %s",
2262 temp_file);
2263
2264 status = writeargv (argv, f);
2265
2266 if (status)
2267 fatal_error (input_location,
2268 "could not write to temporary response file %s",
2269 temp_file);
2270
2271 status = fclose (f);
2272
2273 if (status == EOF)
2274 fatal_error (input_location, "could not close temporary response file %s",
2275 temp_file);
2276
2277 store_arg (at_argument, 0, 0);
2278
2279 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
2280 }
2281 \f
2282 /* Load specs from a file name named FILENAME, replacing occurrences of
2283 various different types of line-endings, \r\n, \n\r and just \r, with
2284 a single \n. */
2285
2286 static char *
2287 load_specs (const char *filename)
2288 {
2289 int desc;
2290 int readlen;
2291 struct stat statbuf;
2292 char *buffer;
2293 char *buffer_p;
2294 char *specs;
2295 char *specs_p;
2296
2297 if (verbose_flag)
2298 fnotice (stderr, "Reading specs from %s\n", filename);
2299
2300 /* Open and stat the file. */
2301 desc = open (filename, O_RDONLY, 0);
2302 if (desc < 0)
2303 {
2304 failed:
2305 /* This leaves DESC open, but the OS will save us. */
2306 fatal_error (input_location, "cannot read spec file %qs: %m", filename);
2307 }
2308
2309 if (stat (filename, &statbuf) < 0)
2310 goto failed;
2311
2312 /* Read contents of file into BUFFER. */
2313 buffer = XNEWVEC (char, statbuf.st_size + 1);
2314 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
2315 if (readlen < 0)
2316 goto failed;
2317 buffer[readlen] = 0;
2318 close (desc);
2319
2320 specs = XNEWVEC (char, readlen + 1);
2321 specs_p = specs;
2322 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
2323 {
2324 int skip = 0;
2325 char c = *buffer_p;
2326 if (c == '\r')
2327 {
2328 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
2329 skip = 1;
2330 else if (*(buffer_p + 1) == '\n') /* \r\n */
2331 skip = 1;
2332 else /* \r */
2333 c = '\n';
2334 }
2335 if (! skip)
2336 *specs_p++ = c;
2337 }
2338 *specs_p = '\0';
2339
2340 free (buffer);
2341 return (specs);
2342 }
2343
2344 /* Read compilation specs from a file named FILENAME,
2345 replacing the default ones.
2346
2347 A suffix which starts with `*' is a definition for
2348 one of the machine-specific sub-specs. The "suffix" should be
2349 *asm, *cc1, *cpp, *link, *startfile, etc.
2350 The corresponding spec is stored in asm_spec, etc.,
2351 rather than in the `compilers' vector.
2352
2353 Anything invalid in the file is a fatal error. */
2354
2355 static void
2356 read_specs (const char *filename, bool main_p, bool user_p)
2357 {
2358 char *buffer;
2359 char *p;
2360
2361 buffer = load_specs (filename);
2362
2363 /* Scan BUFFER for specs, putting them in the vector. */
2364 p = buffer;
2365 while (1)
2366 {
2367 char *suffix;
2368 char *spec;
2369 char *in, *out, *p1, *p2, *p3;
2370
2371 /* Advance P in BUFFER to the next nonblank nocomment line. */
2372 p = skip_whitespace (p);
2373 if (*p == 0)
2374 break;
2375
2376 /* Is this a special command that starts with '%'? */
2377 /* Don't allow this for the main specs file, since it would
2378 encourage people to overwrite it. */
2379 if (*p == '%' && !main_p)
2380 {
2381 p1 = p;
2382 while (*p && *p != '\n')
2383 p++;
2384
2385 /* Skip '\n'. */
2386 p++;
2387
2388 if (startswith (p1, "%include")
2389 && (p1[sizeof "%include" - 1] == ' '
2390 || p1[sizeof "%include" - 1] == '\t'))
2391 {
2392 char *new_filename;
2393
2394 p1 += sizeof ("%include");
2395 while (*p1 == ' ' || *p1 == '\t')
2396 p1++;
2397
2398 if (*p1++ != '<' || p[-2] != '>')
2399 fatal_error (input_location,
2400 "specs %%include syntax malformed after "
2401 "%ld characters",
2402 (long) (p1 - buffer + 1));
2403
2404 p[-2] = '\0';
2405 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2406 read_specs (new_filename ? new_filename : p1, false, user_p);
2407 continue;
2408 }
2409 else if (startswith (p1, "%include_noerr")
2410 && (p1[sizeof "%include_noerr" - 1] == ' '
2411 || p1[sizeof "%include_noerr" - 1] == '\t'))
2412 {
2413 char *new_filename;
2414
2415 p1 += sizeof "%include_noerr";
2416 while (*p1 == ' ' || *p1 == '\t')
2417 p1++;
2418
2419 if (*p1++ != '<' || p[-2] != '>')
2420 fatal_error (input_location,
2421 "specs %%include syntax malformed after "
2422 "%ld characters",
2423 (long) (p1 - buffer + 1));
2424
2425 p[-2] = '\0';
2426 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2427 if (new_filename)
2428 read_specs (new_filename, false, user_p);
2429 else if (verbose_flag)
2430 fnotice (stderr, "could not find specs file %s\n", p1);
2431 continue;
2432 }
2433 else if (startswith (p1, "%rename")
2434 && (p1[sizeof "%rename" - 1] == ' '
2435 || p1[sizeof "%rename" - 1] == '\t'))
2436 {
2437 int name_len;
2438 struct spec_list *sl;
2439 struct spec_list *newsl;
2440
2441 /* Get original name. */
2442 p1 += sizeof "%rename";
2443 while (*p1 == ' ' || *p1 == '\t')
2444 p1++;
2445
2446 if (! ISALPHA ((unsigned char) *p1))
2447 fatal_error (input_location,
2448 "specs %%rename syntax malformed after "
2449 "%ld characters",
2450 (long) (p1 - buffer));
2451
2452 p2 = p1;
2453 while (*p2 && !ISSPACE ((unsigned char) *p2))
2454 p2++;
2455
2456 if (*p2 != ' ' && *p2 != '\t')
2457 fatal_error (input_location,
2458 "specs %%rename syntax malformed after "
2459 "%ld characters",
2460 (long) (p2 - buffer));
2461
2462 name_len = p2 - p1;
2463 *p2++ = '\0';
2464 while (*p2 == ' ' || *p2 == '\t')
2465 p2++;
2466
2467 if (! ISALPHA ((unsigned char) *p2))
2468 fatal_error (input_location,
2469 "specs %%rename syntax malformed after "
2470 "%ld characters",
2471 (long) (p2 - buffer));
2472
2473 /* Get new spec name. */
2474 p3 = p2;
2475 while (*p3 && !ISSPACE ((unsigned char) *p3))
2476 p3++;
2477
2478 if (p3 != p - 1)
2479 fatal_error (input_location,
2480 "specs %%rename syntax malformed after "
2481 "%ld characters",
2482 (long) (p3 - buffer));
2483 *p3 = '\0';
2484
2485 for (sl = specs; sl; sl = sl->next)
2486 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2487 break;
2488
2489 if (!sl)
2490 fatal_error (input_location,
2491 "specs %s spec was not found to be renamed", p1);
2492
2493 if (strcmp (p1, p2) == 0)
2494 continue;
2495
2496 for (newsl = specs; newsl; newsl = newsl->next)
2497 if (strcmp (newsl->name, p2) == 0)
2498 fatal_error (input_location,
2499 "%s: attempt to rename spec %qs to "
2500 "already defined spec %qs",
2501 filename, p1, p2);
2502
2503 if (verbose_flag)
2504 {
2505 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
2506 #ifdef DEBUG_SPECS
2507 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
2508 #endif
2509 }
2510
2511 set_spec (p2, *(sl->ptr_spec), user_p);
2512 if (sl->alloc_p)
2513 free (CONST_CAST (char *, *(sl->ptr_spec)));
2514
2515 *(sl->ptr_spec) = "";
2516 sl->alloc_p = 0;
2517 continue;
2518 }
2519 else
2520 fatal_error (input_location,
2521 "specs unknown %% command after %ld characters",
2522 (long) (p1 - buffer));
2523 }
2524
2525 /* Find the colon that should end the suffix. */
2526 p1 = p;
2527 while (*p1 && *p1 != ':' && *p1 != '\n')
2528 p1++;
2529
2530 /* The colon shouldn't be missing. */
2531 if (*p1 != ':')
2532 fatal_error (input_location,
2533 "specs file malformed after %ld characters",
2534 (long) (p1 - buffer));
2535
2536 /* Skip back over trailing whitespace. */
2537 p2 = p1;
2538 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2539 p2--;
2540
2541 /* Copy the suffix to a string. */
2542 suffix = save_string (p, p2 - p);
2543 /* Find the next line. */
2544 p = skip_whitespace (p1 + 1);
2545 if (p[1] == 0)
2546 fatal_error (input_location,
2547 "specs file malformed after %ld characters",
2548 (long) (p - buffer));
2549
2550 p1 = p;
2551 /* Find next blank line or end of string. */
2552 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2553 p1++;
2554
2555 /* Specs end at the blank line and do not include the newline. */
2556 spec = save_string (p, p1 - p);
2557 p = p1;
2558
2559 /* Delete backslash-newline sequences from the spec. */
2560 in = spec;
2561 out = spec;
2562 while (*in != 0)
2563 {
2564 if (in[0] == '\\' && in[1] == '\n')
2565 in += 2;
2566 else if (in[0] == '#')
2567 while (*in && *in != '\n')
2568 in++;
2569
2570 else
2571 *out++ = *in++;
2572 }
2573 *out = 0;
2574
2575 if (suffix[0] == '*')
2576 {
2577 if (! strcmp (suffix, "*link_command"))
2578 link_command_spec = spec;
2579 else
2580 {
2581 set_spec (suffix + 1, spec, user_p);
2582 free (spec);
2583 }
2584 }
2585 else
2586 {
2587 /* Add this pair to the vector. */
2588 compilers
2589 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
2590
2591 compilers[n_compilers].suffix = suffix;
2592 compilers[n_compilers].spec = spec;
2593 n_compilers++;
2594 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2595 }
2596
2597 if (*suffix == 0)
2598 link_command_spec = spec;
2599 }
2600
2601 if (link_command_spec == 0)
2602 fatal_error (input_location, "spec file has no spec for linking");
2603
2604 XDELETEVEC (buffer);
2605 }
2606 \f
2607 /* Record the names of temporary files we tell compilers to write,
2608 and delete them at the end of the run. */
2609
2610 /* This is the common prefix we use to make temp file names.
2611 It is chosen once for each run of this program.
2612 It is substituted into a spec by %g or %j.
2613 Thus, all temp file names contain this prefix.
2614 In practice, all temp file names start with this prefix.
2615
2616 This prefix comes from the envvar TMPDIR if it is defined;
2617 otherwise, from the P_tmpdir macro if that is defined;
2618 otherwise, in /usr/tmp or /tmp;
2619 or finally the current directory if all else fails. */
2620
2621 static const char *temp_filename;
2622
2623 /* Length of the prefix. */
2624
2625 static int temp_filename_length;
2626
2627 /* Define the list of temporary files to delete. */
2628
2629 struct temp_file
2630 {
2631 const char *name;
2632 struct temp_file *next;
2633 };
2634
2635 /* Queue of files to delete on success or failure of compilation. */
2636 static struct temp_file *always_delete_queue;
2637 /* Queue of files to delete on failure of compilation. */
2638 static struct temp_file *failure_delete_queue;
2639
2640 /* Record FILENAME as a file to be deleted automatically.
2641 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2642 otherwise delete it in any case.
2643 FAIL_DELETE nonzero means delete it if a compilation step fails;
2644 otherwise delete it in any case. */
2645
2646 void
2647 record_temp_file (const char *filename, int always_delete, int fail_delete)
2648 {
2649 char *const name = xstrdup (filename);
2650
2651 if (always_delete)
2652 {
2653 struct temp_file *temp;
2654 for (temp = always_delete_queue; temp; temp = temp->next)
2655 if (! filename_cmp (name, temp->name))
2656 {
2657 free (name);
2658 goto already1;
2659 }
2660
2661 temp = XNEW (struct temp_file);
2662 temp->next = always_delete_queue;
2663 temp->name = name;
2664 always_delete_queue = temp;
2665
2666 already1:;
2667 }
2668
2669 if (fail_delete)
2670 {
2671 struct temp_file *temp;
2672 for (temp = failure_delete_queue; temp; temp = temp->next)
2673 if (! filename_cmp (name, temp->name))
2674 {
2675 free (name);
2676 goto already2;
2677 }
2678
2679 temp = XNEW (struct temp_file);
2680 temp->next = failure_delete_queue;
2681 temp->name = name;
2682 failure_delete_queue = temp;
2683
2684 already2:;
2685 }
2686 }
2687
2688 /* Delete all the temporary files whose names we previously recorded. */
2689
2690 #ifndef DELETE_IF_ORDINARY
2691 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2692 do \
2693 { \
2694 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2695 if (unlink (NAME) < 0) \
2696 if (VERBOSE_FLAG) \
2697 error ("%s: %m", (NAME)); \
2698 } while (0)
2699 #endif
2700
2701 static void
2702 delete_if_ordinary (const char *name)
2703 {
2704 struct stat st;
2705 #ifdef DEBUG
2706 int i, c;
2707
2708 printf ("Delete %s? (y or n) ", name);
2709 fflush (stdout);
2710 i = getchar ();
2711 if (i != '\n')
2712 while ((c = getchar ()) != '\n' && c != EOF)
2713 ;
2714
2715 if (i == 'y' || i == 'Y')
2716 #endif /* DEBUG */
2717 DELETE_IF_ORDINARY (name, st, verbose_flag);
2718 }
2719
2720 static void
2721 delete_temp_files (void)
2722 {
2723 struct temp_file *temp;
2724
2725 for (temp = always_delete_queue; temp; temp = temp->next)
2726 delete_if_ordinary (temp->name);
2727 always_delete_queue = 0;
2728 }
2729
2730 /* Delete all the files to be deleted on error. */
2731
2732 static void
2733 delete_failure_queue (void)
2734 {
2735 struct temp_file *temp;
2736
2737 for (temp = failure_delete_queue; temp; temp = temp->next)
2738 delete_if_ordinary (temp->name);
2739 }
2740
2741 static void
2742 clear_failure_queue (void)
2743 {
2744 failure_delete_queue = 0;
2745 }
2746 \f
2747 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2748 returns non-NULL.
2749 If DO_MULTI is true iterate over the paths twice, first with multilib
2750 suffix then without, otherwise iterate over the paths once without
2751 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2752 to avoid visiting the same path twice, but we could do better. For
2753 instance, /usr/lib/../lib is considered different from /usr/lib.
2754 At least EXTRA_SPACE chars past the end of the path passed to
2755 CALLBACK are available for use by the callback.
2756 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2757
2758 Returns the value returned by CALLBACK. */
2759
2760 static void *
2761 for_each_path (const struct path_prefix *paths,
2762 bool do_multi,
2763 size_t extra_space,
2764 void *(*callback) (char *, void *),
2765 void *callback_info)
2766 {
2767 struct prefix_list *pl;
2768 const char *multi_dir = NULL;
2769 const char *multi_os_dir = NULL;
2770 const char *multiarch_suffix = NULL;
2771 const char *multi_suffix;
2772 const char *just_multi_suffix;
2773 char *path = NULL;
2774 void *ret = NULL;
2775 bool skip_multi_dir = false;
2776 bool skip_multi_os_dir = false;
2777
2778 multi_suffix = machine_suffix;
2779 just_multi_suffix = just_machine_suffix;
2780 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2781 {
2782 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2783 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2784 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2785 }
2786 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2787 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2788 if (multiarch_dir)
2789 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2790
2791 while (1)
2792 {
2793 size_t multi_dir_len = 0;
2794 size_t multi_os_dir_len = 0;
2795 size_t multiarch_len = 0;
2796 size_t suffix_len;
2797 size_t just_suffix_len;
2798 size_t len;
2799
2800 if (multi_dir)
2801 multi_dir_len = strlen (multi_dir);
2802 if (multi_os_dir)
2803 multi_os_dir_len = strlen (multi_os_dir);
2804 if (multiarch_suffix)
2805 multiarch_len = strlen (multiarch_suffix);
2806 suffix_len = strlen (multi_suffix);
2807 just_suffix_len = strlen (just_multi_suffix);
2808
2809 if (path == NULL)
2810 {
2811 len = paths->max_len + extra_space + 1;
2812 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2813 path = XNEWVEC (char, len);
2814 }
2815
2816 for (pl = paths->plist; pl != 0; pl = pl->next)
2817 {
2818 len = strlen (pl->prefix);
2819 memcpy (path, pl->prefix, len);
2820
2821 /* Look first in MACHINE/VERSION subdirectory. */
2822 if (!skip_multi_dir)
2823 {
2824 memcpy (path + len, multi_suffix, suffix_len + 1);
2825 ret = callback (path, callback_info);
2826 if (ret)
2827 break;
2828 }
2829
2830 /* Some paths are tried with just the machine (ie. target)
2831 subdir. This is used for finding as, ld, etc. */
2832 if (!skip_multi_dir
2833 && pl->require_machine_suffix == 2)
2834 {
2835 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2836 ret = callback (path, callback_info);
2837 if (ret)
2838 break;
2839 }
2840
2841 /* Now try the multiarch path. */
2842 if (!skip_multi_dir
2843 && !pl->require_machine_suffix && multiarch_dir)
2844 {
2845 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2846 ret = callback (path, callback_info);
2847 if (ret)
2848 break;
2849 }
2850
2851 /* Now try the base path. */
2852 if (!pl->require_machine_suffix
2853 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2854 {
2855 const char *this_multi;
2856 size_t this_multi_len;
2857
2858 if (pl->os_multilib)
2859 {
2860 this_multi = multi_os_dir;
2861 this_multi_len = multi_os_dir_len;
2862 }
2863 else
2864 {
2865 this_multi = multi_dir;
2866 this_multi_len = multi_dir_len;
2867 }
2868
2869 if (this_multi_len)
2870 memcpy (path + len, this_multi, this_multi_len + 1);
2871 else
2872 path[len] = '\0';
2873
2874 ret = callback (path, callback_info);
2875 if (ret)
2876 break;
2877 }
2878 }
2879 if (pl)
2880 break;
2881
2882 if (multi_dir == NULL && multi_os_dir == NULL)
2883 break;
2884
2885 /* Run through the paths again, this time without multilibs.
2886 Don't repeat any we have already seen. */
2887 if (multi_dir)
2888 {
2889 free (CONST_CAST (char *, multi_dir));
2890 multi_dir = NULL;
2891 free (CONST_CAST (char *, multi_suffix));
2892 multi_suffix = machine_suffix;
2893 free (CONST_CAST (char *, just_multi_suffix));
2894 just_multi_suffix = just_machine_suffix;
2895 }
2896 else
2897 skip_multi_dir = true;
2898 if (multi_os_dir)
2899 {
2900 free (CONST_CAST (char *, multi_os_dir));
2901 multi_os_dir = NULL;
2902 }
2903 else
2904 skip_multi_os_dir = true;
2905 }
2906
2907 if (multi_dir)
2908 {
2909 free (CONST_CAST (char *, multi_dir));
2910 free (CONST_CAST (char *, multi_suffix));
2911 free (CONST_CAST (char *, just_multi_suffix));
2912 }
2913 if (multi_os_dir)
2914 free (CONST_CAST (char *, multi_os_dir));
2915 if (ret != path)
2916 free (path);
2917 return ret;
2918 }
2919
2920 /* Callback for build_search_list. Adds path to obstack being built. */
2921
2922 struct add_to_obstack_info {
2923 struct obstack *ob;
2924 bool check_dir;
2925 bool first_time;
2926 };
2927
2928 static void *
2929 add_to_obstack (char *path, void *data)
2930 {
2931 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2932
2933 if (info->check_dir && !is_directory (path, false))
2934 return NULL;
2935
2936 if (!info->first_time)
2937 obstack_1grow (info->ob, PATH_SEPARATOR);
2938
2939 obstack_grow (info->ob, path, strlen (path));
2940
2941 info->first_time = false;
2942 return NULL;
2943 }
2944
2945 /* Add or change the value of an environment variable, outputting the
2946 change to standard error if in verbose mode. */
2947 static void
2948 xputenv (const char *string)
2949 {
2950 env.xput (string);
2951 }
2952
2953 /* Build a list of search directories from PATHS.
2954 PREFIX is a string to prepend to the list.
2955 If CHECK_DIR_P is true we ensure the directory exists.
2956 If DO_MULTI is true, multilib paths are output first, then
2957 non-multilib paths.
2958 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2959 It is also used by the --print-search-dirs flag. */
2960
2961 static char *
2962 build_search_list (const struct path_prefix *paths, const char *prefix,
2963 bool check_dir, bool do_multi)
2964 {
2965 struct add_to_obstack_info info;
2966
2967 info.ob = &collect_obstack;
2968 info.check_dir = check_dir;
2969 info.first_time = true;
2970
2971 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2972 obstack_1grow (&collect_obstack, '=');
2973
2974 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2975
2976 obstack_1grow (&collect_obstack, '\0');
2977 return XOBFINISH (&collect_obstack, char *);
2978 }
2979
2980 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2981 for collect. */
2982
2983 static void
2984 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2985 bool do_multi)
2986 {
2987 xputenv (build_search_list (paths, env_var, true, do_multi));
2988 }
2989 \f
2990 /* Check whether NAME can be accessed in MODE. This is like access,
2991 except that it never considers directories to be executable. */
2992
2993 static int
2994 access_check (const char *name, int mode)
2995 {
2996 if (mode == X_OK)
2997 {
2998 struct stat st;
2999
3000 if (stat (name, &st) < 0
3001 || S_ISDIR (st.st_mode))
3002 return -1;
3003 }
3004
3005 return access (name, mode);
3006 }
3007
3008 /* Callback for find_a_file. Appends the file name to the directory
3009 path. If the resulting file exists in the right mode, return the
3010 full pathname to the file. */
3011
3012 struct file_at_path_info {
3013 const char *name;
3014 const char *suffix;
3015 int name_len;
3016 int suffix_len;
3017 int mode;
3018 };
3019
3020 static void *
3021 file_at_path (char *path, void *data)
3022 {
3023 struct file_at_path_info *info = (struct file_at_path_info *) data;
3024 size_t len = strlen (path);
3025
3026 memcpy (path + len, info->name, info->name_len);
3027 len += info->name_len;
3028
3029 /* Some systems have a suffix for executable files.
3030 So try appending that first. */
3031 if (info->suffix_len)
3032 {
3033 memcpy (path + len, info->suffix, info->suffix_len + 1);
3034 if (access_check (path, info->mode) == 0)
3035 return path;
3036 }
3037
3038 path[len] = '\0';
3039 if (access_check (path, info->mode) == 0)
3040 return path;
3041
3042 return NULL;
3043 }
3044
3045 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
3046 access to check permissions. If DO_MULTI is true, search multilib
3047 paths then non-multilib paths, otherwise do not search multilib paths.
3048 Return 0 if not found, otherwise return its name, allocated with malloc. */
3049
3050 static char *
3051 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
3052 bool do_multi)
3053 {
3054 struct file_at_path_info info;
3055
3056 /* Find the filename in question (special case for absolute paths). */
3057
3058 if (IS_ABSOLUTE_PATH (name))
3059 {
3060 if (access (name, mode) == 0)
3061 return xstrdup (name);
3062
3063 return NULL;
3064 }
3065
3066 info.name = name;
3067 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
3068 info.name_len = strlen (info.name);
3069 info.suffix_len = strlen (info.suffix);
3070 info.mode = mode;
3071
3072 return (char*) for_each_path (pprefix, do_multi,
3073 info.name_len + info.suffix_len,
3074 file_at_path, &info);
3075 }
3076
3077 /* Specialization of find_a_file for programs that also takes into account
3078 configure-specified default programs. */
3079
3080 static char*
3081 find_a_program (const char *name)
3082 {
3083 /* Do not search if default matches query. */
3084
3085 #ifdef DEFAULT_ASSEMBLER
3086 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, X_OK) == 0)
3087 return xstrdup (DEFAULT_ASSEMBLER);
3088 #endif
3089
3090 #ifdef DEFAULT_LINKER
3091 if (! strcmp (name, "ld") && access (DEFAULT_LINKER, X_OK) == 0)
3092 return xstrdup (DEFAULT_LINKER);
3093 #endif
3094
3095 #ifdef DEFAULT_DSYMUTIL
3096 if (! strcmp (name, "dsymutil") && access (DEFAULT_DSYMUTIL, X_OK) == 0)
3097 return xstrdup (DEFAULT_DSYMUTIL);
3098 #endif
3099
3100 return find_a_file (&exec_prefixes, name, X_OK, false);
3101 }
3102
3103 /* Ranking of prefixes in the sort list. -B prefixes are put before
3104 all others. */
3105
3106 enum path_prefix_priority
3107 {
3108 PREFIX_PRIORITY_B_OPT,
3109 PREFIX_PRIORITY_LAST
3110 };
3111
3112 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
3113 order according to PRIORITY. Within each PRIORITY, new entries are
3114 appended.
3115
3116 If WARN is nonzero, we will warn if no file is found
3117 through this prefix. WARN should point to an int
3118 which will be set to 1 if this entry is used.
3119
3120 COMPONENT is the value to be passed to update_path.
3121
3122 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
3123 the complete value of machine_suffix.
3124 2 means try both machine_suffix and just_machine_suffix. */
3125
3126 static void
3127 add_prefix (struct path_prefix *pprefix, const char *prefix,
3128 const char *component, /* enum prefix_priority */ int priority,
3129 int require_machine_suffix, int os_multilib)
3130 {
3131 struct prefix_list *pl, **prev;
3132 int len;
3133
3134 for (prev = &pprefix->plist;
3135 (*prev) != NULL && (*prev)->priority <= priority;
3136 prev = &(*prev)->next)
3137 ;
3138
3139 /* Keep track of the longest prefix. */
3140
3141 prefix = update_path (prefix, component);
3142 len = strlen (prefix);
3143 if (len > pprefix->max_len)
3144 pprefix->max_len = len;
3145
3146 pl = XNEW (struct prefix_list);
3147 pl->prefix = prefix;
3148 pl->require_machine_suffix = require_machine_suffix;
3149 pl->priority = priority;
3150 pl->os_multilib = os_multilib;
3151
3152 /* Insert after PREV. */
3153 pl->next = (*prev);
3154 (*prev) = pl;
3155 }
3156
3157 /* Same as add_prefix, but prepending target_system_root to prefix. */
3158 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
3159 static void
3160 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
3161 const char *component,
3162 /* enum prefix_priority */ int priority,
3163 int require_machine_suffix, int os_multilib)
3164 {
3165 if (!IS_ABSOLUTE_PATH (prefix))
3166 fatal_error (input_location, "system path %qs is not absolute", prefix);
3167
3168 if (target_system_root)
3169 {
3170 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
3171 size_t sysroot_len = strlen (target_system_root);
3172
3173 if (sysroot_len > 0
3174 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
3175 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
3176
3177 if (target_sysroot_suffix)
3178 prefix = concat (sysroot_no_trailing_dir_separator,
3179 target_sysroot_suffix, prefix, NULL);
3180 else
3181 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
3182
3183 free (sysroot_no_trailing_dir_separator);
3184
3185 /* We have to override this because GCC's notion of sysroot
3186 moves along with GCC. */
3187 component = "GCC";
3188 }
3189
3190 add_prefix (pprefix, prefix, component, priority,
3191 require_machine_suffix, os_multilib);
3192 }
3193
3194 /* Same as add_prefix, but prepending target_sysroot_hdrs_suffix to prefix. */
3195
3196 static void
3197 add_sysrooted_hdrs_prefix (struct path_prefix *pprefix, const char *prefix,
3198 const char *component,
3199 /* enum prefix_priority */ int priority,
3200 int require_machine_suffix, int os_multilib)
3201 {
3202 if (!IS_ABSOLUTE_PATH (prefix))
3203 fatal_error (input_location, "system path %qs is not absolute", prefix);
3204
3205 if (target_system_root)
3206 {
3207 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
3208 size_t sysroot_len = strlen (target_system_root);
3209
3210 if (sysroot_len > 0
3211 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
3212 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
3213
3214 if (target_sysroot_hdrs_suffix)
3215 prefix = concat (sysroot_no_trailing_dir_separator,
3216 target_sysroot_hdrs_suffix, prefix, NULL);
3217 else
3218 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
3219
3220 free (sysroot_no_trailing_dir_separator);
3221
3222 /* We have to override this because GCC's notion of sysroot
3223 moves along with GCC. */
3224 component = "GCC";
3225 }
3226
3227 add_prefix (pprefix, prefix, component, priority,
3228 require_machine_suffix, os_multilib);
3229 }
3230
3231 \f
3232 /* Execute the command specified by the arguments on the current line of spec.
3233 When using pipes, this includes several piped-together commands
3234 with `|' between them.
3235
3236 Return 0 if successful, -1 if failed. */
3237
3238 static int
3239 execute (void)
3240 {
3241 int i;
3242 int n_commands; /* # of command. */
3243 char *string;
3244 struct pex_obj *pex;
3245 struct command
3246 {
3247 const char *prog; /* program name. */
3248 const char **argv; /* vector of args. */
3249 };
3250 const char *arg;
3251
3252 struct command *commands; /* each command buffer with above info. */
3253
3254 gcc_assert (!processing_spec_function);
3255
3256 if (wrapper_string)
3257 {
3258 string = find_a_program (argbuf[0]);
3259 if (string)
3260 argbuf[0] = string;
3261 insert_wrapper (wrapper_string);
3262 }
3263
3264 /* Count # of piped commands. */
3265 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
3266 if (strcmp (arg, "|") == 0)
3267 n_commands++;
3268
3269 /* Get storage for each command. */
3270 commands = XALLOCAVEC (struct command, n_commands);
3271
3272 /* Split argbuf into its separate piped processes,
3273 and record info about each one.
3274 Also search for the programs that are to be run. */
3275
3276 argbuf.safe_push (0);
3277
3278 commands[0].prog = argbuf[0]; /* first command. */
3279 commands[0].argv = argbuf.address ();
3280
3281 if (!wrapper_string)
3282 {
3283 string = find_a_program(commands[0].prog);
3284 if (string)
3285 commands[0].argv[0] = string;
3286 }
3287
3288 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
3289 if (arg && strcmp (arg, "|") == 0)
3290 { /* each command. */
3291 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
3292 fatal_error (input_location, "%<-pipe%> not supported");
3293 #endif
3294 argbuf[i] = 0; /* Termination of command args. */
3295 commands[n_commands].prog = argbuf[i + 1];
3296 commands[n_commands].argv
3297 = &(argbuf.address ())[i + 1];
3298 string = find_a_program(commands[n_commands].prog);
3299 if (string)
3300 commands[n_commands].argv[0] = string;
3301 n_commands++;
3302 }
3303
3304 /* If -v, print what we are about to do, and maybe query. */
3305
3306 if (verbose_flag)
3307 {
3308 /* For help listings, put a blank line between sub-processes. */
3309 if (print_help_list)
3310 fputc ('\n', stderr);
3311
3312 /* Print each piped command as a separate line. */
3313 for (i = 0; i < n_commands; i++)
3314 {
3315 const char *const *j;
3316
3317 if (verbose_only_flag)
3318 {
3319 for (j = commands[i].argv; *j; j++)
3320 {
3321 const char *p;
3322 for (p = *j; *p; ++p)
3323 if (!ISALNUM ((unsigned char) *p)
3324 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
3325 break;
3326 if (*p || !*j)
3327 {
3328 fprintf (stderr, " \"");
3329 for (p = *j; *p; ++p)
3330 {
3331 if (*p == '"' || *p == '\\' || *p == '$')
3332 fputc ('\\', stderr);
3333 fputc (*p, stderr);
3334 }
3335 fputc ('"', stderr);
3336 }
3337 /* If it's empty, print "". */
3338 else if (!**j)
3339 fprintf (stderr, " \"\"");
3340 else
3341 fprintf (stderr, " %s", *j);
3342 }
3343 }
3344 else
3345 for (j = commands[i].argv; *j; j++)
3346 /* If it's empty, print "". */
3347 if (!**j)
3348 fprintf (stderr, " \"\"");
3349 else
3350 fprintf (stderr, " %s", *j);
3351
3352 /* Print a pipe symbol after all but the last command. */
3353 if (i + 1 != n_commands)
3354 fprintf (stderr, " |");
3355 fprintf (stderr, "\n");
3356 }
3357 fflush (stderr);
3358 if (verbose_only_flag != 0)
3359 {
3360 /* verbose_only_flag should act as if the spec was
3361 executed, so increment execution_count before
3362 returning. This prevents spurious warnings about
3363 unused linker input files, etc. */
3364 execution_count++;
3365 return 0;
3366 }
3367 #ifdef DEBUG
3368 fnotice (stderr, "\nGo ahead? (y or n) ");
3369 fflush (stderr);
3370 i = getchar ();
3371 if (i != '\n')
3372 while (getchar () != '\n')
3373 ;
3374
3375 if (i != 'y' && i != 'Y')
3376 return 0;
3377 #endif /* DEBUG */
3378 }
3379
3380 #ifdef ENABLE_VALGRIND_CHECKING
3381 /* Run the each command through valgrind. To simplify prepending the
3382 path to valgrind and the option "-q" (for quiet operation unless
3383 something triggers), we allocate a separate argv array. */
3384
3385 for (i = 0; i < n_commands; i++)
3386 {
3387 const char **argv;
3388 int argc;
3389 int j;
3390
3391 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
3392 ;
3393
3394 argv = XALLOCAVEC (const char *, argc + 3);
3395
3396 argv[0] = VALGRIND_PATH;
3397 argv[1] = "-q";
3398 for (j = 2; j < argc + 2; j++)
3399 argv[j] = commands[i].argv[j - 2];
3400 argv[j] = NULL;
3401
3402 commands[i].argv = argv;
3403 commands[i].prog = argv[0];
3404 }
3405 #endif
3406
3407 /* Run each piped subprocess. */
3408
3409 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
3410 ? PEX_RECORD_TIMES : 0),
3411 progname, temp_filename);
3412 if (pex == NULL)
3413 fatal_error (input_location, "%<pex_init%> failed: %m");
3414
3415 for (i = 0; i < n_commands; i++)
3416 {
3417 const char *errmsg;
3418 int err;
3419 const char *string = commands[i].argv[0];
3420
3421 errmsg = pex_run (pex,
3422 ((i + 1 == n_commands ? PEX_LAST : 0)
3423 | (string == commands[i].prog ? PEX_SEARCH : 0)),
3424 string, CONST_CAST (char **, commands[i].argv),
3425 NULL, NULL, &err);
3426 if (errmsg != NULL)
3427 {
3428 errno = err;
3429 fatal_error (input_location,
3430 err ? G_("cannot execute %qs: %s: %m")
3431 : G_("cannot execute %qs: %s"),
3432 string, errmsg);
3433 }
3434
3435 if (i && string != commands[i].prog)
3436 free (CONST_CAST (char *, string));
3437 }
3438
3439 execution_count++;
3440
3441 /* Wait for all the subprocesses to finish. */
3442
3443 {
3444 int *statuses;
3445 struct pex_time *times = NULL;
3446 int ret_code = 0;
3447
3448 statuses = XALLOCAVEC (int, n_commands);
3449 if (!pex_get_status (pex, n_commands, statuses))
3450 fatal_error (input_location, "failed to get exit status: %m");
3451
3452 if (report_times || report_times_to_file)
3453 {
3454 times = XALLOCAVEC (struct pex_time, n_commands);
3455 if (!pex_get_times (pex, n_commands, times))
3456 fatal_error (input_location, "failed to get process times: %m");
3457 }
3458
3459 pex_free (pex);
3460
3461 for (i = 0; i < n_commands; ++i)
3462 {
3463 int status = statuses[i];
3464
3465 if (WIFSIGNALED (status))
3466 switch (WTERMSIG (status))
3467 {
3468 case SIGINT:
3469 case SIGTERM:
3470 /* SIGQUIT and SIGKILL are not available on MinGW. */
3471 #ifdef SIGQUIT
3472 case SIGQUIT:
3473 #endif
3474 #ifdef SIGKILL
3475 case SIGKILL:
3476 #endif
3477 /* The user (or environment) did something to the
3478 inferior. Making this an ICE confuses the user into
3479 thinking there's a compiler bug. Much more likely is
3480 the user or OOM killer nuked it. */
3481 fatal_error (input_location,
3482 "%s signal terminated program %s",
3483 strsignal (WTERMSIG (status)),
3484 commands[i].prog);
3485 break;
3486
3487 #ifdef SIGPIPE
3488 case SIGPIPE:
3489 /* SIGPIPE is a special case. It happens in -pipe mode
3490 when the compiler dies before the preprocessor is
3491 done, or the assembler dies before the compiler is
3492 done. There's generally been an error already, and
3493 this is just fallout. So don't generate another
3494 error unless we would otherwise have succeeded. */
3495 if (signal_count || greatest_status >= MIN_FATAL_STATUS)
3496 {
3497 signal_count++;
3498 ret_code = -1;
3499 break;
3500 }
3501 #endif
3502 /* FALLTHROUGH */
3503
3504 default:
3505 /* The inferior failed to catch the signal. */
3506 internal_error_no_backtrace ("%s signal terminated program %s",
3507 strsignal (WTERMSIG (status)),
3508 commands[i].prog);
3509 }
3510 else if (WIFEXITED (status)
3511 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
3512 {
3513 /* For ICEs in cc1, cc1obj, cc1plus see if it is
3514 reproducible or not. */
3515 const char *p;
3516 if (flag_report_bug
3517 && WEXITSTATUS (status) == ICE_EXIT_CODE
3518 && i == 0
3519 && (p = strrchr (commands[0].argv[0], DIR_SEPARATOR))
3520 && startswith (p + 1, "cc1"))
3521 try_generate_repro (commands[0].argv);
3522 if (WEXITSTATUS (status) > greatest_status)
3523 greatest_status = WEXITSTATUS (status);
3524 ret_code = -1;
3525 }
3526
3527 if (report_times || report_times_to_file)
3528 {
3529 struct pex_time *pt = &times[i];
3530 double ut, st;
3531
3532 ut = ((double) pt->user_seconds
3533 + (double) pt->user_microseconds / 1.0e6);
3534 st = ((double) pt->system_seconds
3535 + (double) pt->system_microseconds / 1.0e6);
3536
3537 if (ut + st != 0)
3538 {
3539 if (report_times)
3540 fnotice (stderr, "# %s %.2f %.2f\n",
3541 commands[i].prog, ut, st);
3542
3543 if (report_times_to_file)
3544 {
3545 int c = 0;
3546 const char *const *j;
3547
3548 fprintf (report_times_to_file, "%g %g", ut, st);
3549
3550 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
3551 {
3552 const char *p;
3553 for (p = *j; *p; ++p)
3554 if (*p == '"' || *p == '\\' || *p == '$'
3555 || ISSPACE (*p))
3556 break;
3557
3558 if (*p)
3559 {
3560 fprintf (report_times_to_file, " \"");
3561 for (p = *j; *p; ++p)
3562 {
3563 if (*p == '"' || *p == '\\' || *p == '$')
3564 fputc ('\\', report_times_to_file);
3565 fputc (*p, report_times_to_file);
3566 }
3567 fputc ('"', report_times_to_file);
3568 }
3569 else
3570 fprintf (report_times_to_file, " %s", *j);
3571 }
3572
3573 fputc ('\n', report_times_to_file);
3574 }
3575 }
3576 }
3577 }
3578
3579 if (commands[0].argv[0] != commands[0].prog)
3580 free (CONST_CAST (char *, commands[0].argv[0]));
3581
3582 return ret_code;
3583 }
3584 }
3585 \f
3586 /* Find all the switches given to us
3587 and make a vector describing them.
3588 The elements of the vector are strings, one per switch given.
3589 If a switch uses following arguments, then the `part1' field
3590 is the switch itself and the `args' field
3591 is a null-terminated vector containing the following arguments.
3592 Bits in the `live_cond' field are:
3593 SWITCH_LIVE to indicate this switch is true in a conditional spec.
3594 SWITCH_FALSE to indicate this switch is overridden by a later switch.
3595 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
3596 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored.
3597 SWITCH_KEEP_FOR_GCC to indicate that this switch, otherwise ignored,
3598 should be included in COLLECT_GCC_OPTIONS.
3599 in all do_spec calls afterwards. Used for %<S from self specs.
3600 The `known' field describes whether this is an internal switch.
3601 The `validated' field describes whether any spec has looked at this switch;
3602 if it remains false at the end of the run, the switch must be meaningless.
3603 The `ordering' field is used to temporarily mark switches that have to be
3604 kept in a specific order. */
3605
3606 #define SWITCH_LIVE (1 << 0)
3607 #define SWITCH_FALSE (1 << 1)
3608 #define SWITCH_IGNORE (1 << 2)
3609 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
3610 #define SWITCH_KEEP_FOR_GCC (1 << 4)
3611
3612 struct switchstr
3613 {
3614 const char *part1;
3615 const char **args;
3616 unsigned int live_cond;
3617 bool known;
3618 bool validated;
3619 bool ordering;
3620 };
3621
3622 static struct switchstr *switches;
3623
3624 static int n_switches;
3625
3626 static int n_switches_alloc;
3627
3628 /* Set to zero if -fcompare-debug is disabled, positive if it's
3629 enabled and we're running the first compilation, negative if it's
3630 enabled and we're running the second compilation. For most of the
3631 time, it's in the range -1..1, but it can be temporarily set to 2
3632 or 3 to indicate that the -fcompare-debug flags didn't come from
3633 the command-line, but rather from the GCC_COMPARE_DEBUG environment
3634 variable, until a synthesized -fcompare-debug flag is added to the
3635 command line. */
3636 int compare_debug;
3637
3638 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
3639 int compare_debug_second;
3640
3641 /* Set to the flags that should be passed to the second compilation in
3642 a -fcompare-debug compilation. */
3643 const char *compare_debug_opt;
3644
3645 static struct switchstr *switches_debug_check[2];
3646
3647 static int n_switches_debug_check[2];
3648
3649 static int n_switches_alloc_debug_check[2];
3650
3651 static char *debug_check_temp_file[2];
3652
3653 /* Language is one of three things:
3654
3655 1) The name of a real programming language.
3656 2) NULL, indicating that no one has figured out
3657 what it is yet.
3658 3) '*', indicating that the file should be passed
3659 to the linker. */
3660 struct infile
3661 {
3662 const char *name;
3663 const char *language;
3664 struct compiler *incompiler;
3665 bool compiled;
3666 bool preprocessed;
3667 };
3668
3669 /* Also a vector of input files specified. */
3670
3671 static struct infile *infiles;
3672
3673 int n_infiles;
3674
3675 static int n_infiles_alloc;
3676
3677 /* True if undefined environment variables encountered during spec processing
3678 are ok to ignore, typically when we're running for --help or --version. */
3679
3680 static bool spec_undefvar_allowed;
3681
3682 /* True if multiple input files are being compiled to a single
3683 assembly file. */
3684
3685 static bool combine_inputs;
3686
3687 /* This counts the number of libraries added by lang_specific_driver, so that
3688 we can tell if there were any user supplied any files or libraries. */
3689
3690 static int added_libraries;
3691
3692 /* And a vector of corresponding output files is made up later. */
3693
3694 const char **outfiles;
3695 \f
3696 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3697
3698 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3699 is true if we should look for an executable suffix. DO_OBJ
3700 is true if we should look for an object suffix. */
3701
3702 static const char *
3703 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3704 int do_obj ATTRIBUTE_UNUSED)
3705 {
3706 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3707 int i;
3708 #endif
3709 int len;
3710
3711 if (name == NULL)
3712 return NULL;
3713
3714 len = strlen (name);
3715
3716 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3717 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3718 if (do_obj && len > 2
3719 && name[len - 2] == '.'
3720 && name[len - 1] == 'o')
3721 {
3722 obstack_grow (&obstack, name, len - 2);
3723 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3724 name = XOBFINISH (&obstack, const char *);
3725 }
3726 #endif
3727
3728 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3729 /* If there is no filetype, make it the executable suffix (which includes
3730 the "."). But don't get confused if we have just "-o". */
3731 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || not_actual_file_p (name))
3732 return name;
3733
3734 for (i = len - 1; i >= 0; i--)
3735 if (IS_DIR_SEPARATOR (name[i]))
3736 break;
3737
3738 for (i++; i < len; i++)
3739 if (name[i] == '.')
3740 return name;
3741
3742 obstack_grow (&obstack, name, len);
3743 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3744 strlen (TARGET_EXECUTABLE_SUFFIX));
3745 name = XOBFINISH (&obstack, const char *);
3746 #endif
3747
3748 return name;
3749 }
3750 #endif
3751 \f
3752 /* Display the command line switches accepted by gcc. */
3753 static void
3754 display_help (void)
3755 {
3756 printf (_("Usage: %s [options] file...\n"), progname);
3757 fputs (_("Options:\n"), stdout);
3758
3759 fputs (_(" -pass-exit-codes Exit with highest error code from a phase.\n"), stdout);
3760 fputs (_(" --help Display this information.\n"), stdout);
3761 fputs (_(" --target-help Display target specific command line options.\n"), stdout);
3762 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...].\n"), stdout);
3763 fputs (_(" Display specific types of command line options.\n"), stdout);
3764 if (! verbose_flag)
3765 fputs (_(" (Use '-v --help' to display command line options of sub-processes).\n"), stdout);
3766 fputs (_(" --version Display compiler version information.\n"), stdout);
3767 fputs (_(" -dumpspecs Display all of the built in spec strings.\n"), stdout);
3768 fputs (_(" -dumpversion Display the version of the compiler.\n"), stdout);
3769 fputs (_(" -dumpmachine Display the compiler's target processor.\n"), stdout);
3770 fputs (_(" -foffload=<targets> Specify offloading targets.\n"), stdout);
3771 fputs (_(" -print-search-dirs Display the directories in the compiler's search path.\n"), stdout);
3772 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library.\n"), stdout);
3773 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>.\n"), stdout);
3774 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>.\n"), stdout);
3775 fputs (_("\
3776 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3777 a component in the library path.\n"), stdout);
3778 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc.\n"), stdout);
3779 fputs (_("\
3780 -print-multi-lib Display the mapping between command line options and\n\
3781 multiple library search directories.\n"), stdout);
3782 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries.\n"), stdout);
3783 fputs (_(" -print-sysroot Display the target libraries directory.\n"), stdout);
3784 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers.\n"), stdout);
3785 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler.\n"), stdout);
3786 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor.\n"), stdout);
3787 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker.\n"), stdout);
3788 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler.\n"), stdout);
3789 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor.\n"), stdout);
3790 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker.\n"), stdout);
3791 fputs (_(" -save-temps Do not delete intermediate files.\n"), stdout);
3792 fputs (_(" -save-temps=<arg> Do not delete intermediate files.\n"), stdout);
3793 fputs (_("\
3794 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3795 prefixes to other gcc components.\n"), stdout);
3796 fputs (_(" -pipe Use pipes rather than intermediate files.\n"), stdout);
3797 fputs (_(" -time Time the execution of each subprocess.\n"), stdout);
3798 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>.\n"), stdout);
3799 fputs (_(" -std=<standard> Assume that the input sources are for <standard>.\n"), stdout);
3800 fputs (_("\
3801 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3802 and libraries.\n"), stdout);
3803 fputs (_(" -B <directory> Add <directory> to the compiler's search paths.\n"), stdout);
3804 fputs (_(" -v Display the programs invoked by the compiler.\n"), stdout);
3805 fputs (_(" -### Like -v but options quoted and commands not executed.\n"), stdout);
3806 fputs (_(" -E Preprocess only; do not compile, assemble or link.\n"), stdout);
3807 fputs (_(" -S Compile only; do not assemble or link.\n"), stdout);
3808 fputs (_(" -c Compile and assemble, but do not link.\n"), stdout);
3809 fputs (_(" -o <file> Place the output into <file>.\n"), stdout);
3810 fputs (_(" -pie Create a dynamically linked position independent\n\
3811 executable.\n"), stdout);
3812 fputs (_(" -shared Create a shared library.\n"), stdout);
3813 fputs (_("\
3814 -x <language> Specify the language of the following input files.\n\
3815 Permissible languages include: c c++ assembler none\n\
3816 'none' means revert to the default behavior of\n\
3817 guessing the language based on the file's extension.\n\
3818 "), stdout);
3819
3820 printf (_("\
3821 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3822 passed on to the various sub-processes invoked by %s. In order to pass\n\
3823 other options on to these processes the -W<letter> options must be used.\n\
3824 "), progname);
3825
3826 /* The rest of the options are displayed by invocations of the various
3827 sub-processes. */
3828 }
3829
3830 static void
3831 add_preprocessor_option (const char *option, int len)
3832 {
3833 preprocessor_options.safe_push (save_string (option, len));
3834 }
3835
3836 static void
3837 add_assembler_option (const char *option, int len)
3838 {
3839 assembler_options.safe_push (save_string (option, len));
3840 }
3841
3842 static void
3843 add_linker_option (const char *option, int len)
3844 {
3845 linker_options.safe_push (save_string (option, len));
3846 }
3847 \f
3848 /* Allocate space for an input file in infiles. */
3849
3850 static void
3851 alloc_infile (void)
3852 {
3853 if (n_infiles_alloc == 0)
3854 {
3855 n_infiles_alloc = 16;
3856 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3857 }
3858 else if (n_infiles_alloc == n_infiles)
3859 {
3860 n_infiles_alloc *= 2;
3861 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3862 }
3863 }
3864
3865 /* Store an input file with the given NAME and LANGUAGE in
3866 infiles. */
3867
3868 static void
3869 add_infile (const char *name, const char *language)
3870 {
3871 alloc_infile ();
3872 infiles[n_infiles].name = name;
3873 infiles[n_infiles++].language = language;
3874 }
3875
3876 /* Allocate space for a switch in switches. */
3877
3878 static void
3879 alloc_switch (void)
3880 {
3881 if (n_switches_alloc == 0)
3882 {
3883 n_switches_alloc = 16;
3884 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3885 }
3886 else if (n_switches_alloc == n_switches)
3887 {
3888 n_switches_alloc *= 2;
3889 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3890 }
3891 }
3892
3893 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3894 as validated if VALIDATED and KNOWN if it is an internal switch. */
3895
3896 static void
3897 save_switch (const char *opt, size_t n_args, const char *const *args,
3898 bool validated, bool known)
3899 {
3900 alloc_switch ();
3901 switches[n_switches].part1 = opt + 1;
3902 if (n_args == 0)
3903 switches[n_switches].args = 0;
3904 else
3905 {
3906 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3907 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3908 switches[n_switches].args[n_args] = NULL;
3909 }
3910
3911 switches[n_switches].live_cond = 0;
3912 switches[n_switches].validated = validated;
3913 switches[n_switches].known = known;
3914 switches[n_switches].ordering = 0;
3915 n_switches++;
3916 }
3917
3918 /* Set the SOURCE_DATE_EPOCH environment variable to the current time if it is
3919 not set already. */
3920
3921 static void
3922 set_source_date_epoch_envvar ()
3923 {
3924 /* Array size is 21 = ceil(log_10(2^64)) + 1 to hold string representations
3925 of 64 bit integers. */
3926 char source_date_epoch[21];
3927 time_t tt;
3928
3929 errno = 0;
3930 tt = time (NULL);
3931 if (tt < (time_t) 0 || errno != 0)
3932 tt = (time_t) 0;
3933
3934 snprintf (source_date_epoch, 21, "%llu", (unsigned long long) tt);
3935 /* Using setenv instead of xputenv because we want the variable to remain
3936 after finalizing so that it's still set in the second run when using
3937 -fcompare-debug. */
3938 setenv ("SOURCE_DATE_EPOCH", source_date_epoch, 0);
3939 }
3940
3941 /* Handle an option DECODED that is unknown to the option-processing
3942 machinery. */
3943
3944 static bool
3945 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3946 {
3947 const char *opt = decoded->arg;
3948 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3949 && !(decoded->errors & CL_ERR_NEGATIVE))
3950 {
3951 /* Leave unknown -Wno-* options for the compiler proper, to be
3952 diagnosed only if there are warnings. */
3953 save_switch (decoded->canonical_option[0],
3954 decoded->canonical_option_num_elements - 1,
3955 &decoded->canonical_option[1], false, true);
3956 return false;
3957 }
3958 if (decoded->opt_index == OPT_SPECIAL_unknown)
3959 {
3960 /* Give it a chance to define it a spec file. */
3961 save_switch (decoded->canonical_option[0],
3962 decoded->canonical_option_num_elements - 1,
3963 &decoded->canonical_option[1], false, false);
3964 return false;
3965 }
3966 else
3967 return true;
3968 }
3969
3970 /* Handle an option DECODED that is not marked as CL_DRIVER.
3971 LANG_MASK will always be CL_DRIVER. */
3972
3973 static void
3974 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3975 unsigned int lang_mask ATTRIBUTE_UNUSED)
3976 {
3977 /* At this point, non-driver options are accepted (and expected to
3978 be passed down by specs) unless marked to be rejected by the
3979 driver. Options to be rejected by the driver but accepted by the
3980 compilers proper are treated just like completely unknown
3981 options. */
3982 const struct cl_option *option = &cl_options[decoded->opt_index];
3983
3984 if (option->cl_reject_driver)
3985 error ("unrecognized command-line option %qs",
3986 decoded->orig_option_with_args_text);
3987 else
3988 save_switch (decoded->canonical_option[0],
3989 decoded->canonical_option_num_elements - 1,
3990 &decoded->canonical_option[1], false, true);
3991 }
3992
3993 static const char *spec_lang = 0;
3994 static int last_language_n_infiles;
3995
3996
3997 /* Check that GCC is configured to support the offload target. */
3998
3999 static bool
4000 check_offload_target_name (const char *target, ptrdiff_t len)
4001 {
4002 const char *n, *c = OFFLOAD_TARGETS;
4003 while (c)
4004 {
4005 n = strchr (c, ',');
4006 if (n == NULL)
4007 n = strchr (c, '\0');
4008 if (len == n - c && strncmp (target, c, n - c) == 0)
4009 break;
4010 c = *n ? n + 1 : NULL;
4011 }
4012 if (!c)
4013 {
4014 auto_vec<const char*> candidates;
4015 size_t olen = strlen (OFFLOAD_TARGETS) + 1;
4016 char *cand = XALLOCAVEC (char, olen);
4017 memcpy (cand, OFFLOAD_TARGETS, olen);
4018 for (c = strtok (cand, ","); c; c = strtok (NULL, ","))
4019 candidates.safe_push (c);
4020 candidates.safe_push ("default");
4021 candidates.safe_push ("disable");
4022
4023 char *target2 = XALLOCAVEC (char, len + 1);
4024 memcpy (target2, target, len);
4025 target2[len] = '\0';
4026
4027 error ("GCC is not configured to support %qs as %<-foffload=%> argument",
4028 target2);
4029
4030 char *s;
4031 const char *hint = candidates_list_and_hint (target2, s, candidates);
4032 if (hint)
4033 inform (UNKNOWN_LOCATION,
4034 "valid %<-foffload=%> arguments are: %s; "
4035 "did you mean %qs?", s, hint);
4036 else
4037 inform (UNKNOWN_LOCATION, "valid %<-foffload=%> arguments are: %s", s);
4038 XDELETEVEC (s);
4039 return false;
4040 }
4041 return true;
4042 }
4043
4044 /* Sanity check for -foffload-options. */
4045
4046 static void
4047 check_foffload_target_names (const char *arg)
4048 {
4049 const char *cur, *next, *end;
4050 /* If option argument starts with '-' then no target is specified and we
4051 do not need to parse it. */
4052 if (arg[0] == '-')
4053 return;
4054 end = strchr (arg, '=');
4055 if (end == NULL)
4056 {
4057 error ("%<=%>options missing after %<-foffload-options=%>target");
4058 return;
4059 }
4060
4061 cur = arg;
4062 while (cur < end)
4063 {
4064 next = strchr (cur, ',');
4065 if (next == NULL)
4066 next = end;
4067 next = (next > end) ? end : next;
4068
4069 /* Retain non-supported targets after printing an error as those will not
4070 be processed; each enabled target only processes its triplet. */
4071 check_offload_target_name (cur, next - cur);
4072 cur = next + 1;
4073 }
4074 }
4075
4076 /* Parse -foffload option argument. */
4077
4078 static void
4079 handle_foffload_option (const char *arg)
4080 {
4081 const char *c, *cur, *n, *next, *end;
4082 char *target;
4083
4084 /* If option argument starts with '-' then no target is specified and we
4085 do not need to parse it. */
4086 if (arg[0] == '-')
4087 return;
4088
4089 end = strchr (arg, '=');
4090 if (end == NULL)
4091 end = strchr (arg, '\0');
4092 cur = arg;
4093
4094 while (cur < end)
4095 {
4096 next = strchr (cur, ',');
4097 if (next == NULL)
4098 next = end;
4099 next = (next > end) ? end : next;
4100
4101 target = XNEWVEC (char, next - cur + 1);
4102 memcpy (target, cur, next - cur);
4103 target[next - cur] = '\0';
4104
4105 /* Reset offloading list and continue. */
4106 if (strcmp (target, "default") == 0)
4107 {
4108 free (offload_targets);
4109 offload_targets = NULL;
4110 goto next_item;
4111 }
4112
4113 /* If 'disable' is passed to the option, clean the list of
4114 offload targets and return, even if more targets follow.
4115 Likewise if GCC is not configured to support that offload target. */
4116 if (strcmp (target, "disable") == 0
4117 || !check_offload_target_name (target, next - cur))
4118 {
4119 free (offload_targets);
4120 offload_targets = xstrdup ("");
4121 return;
4122 }
4123
4124 if (!offload_targets)
4125 {
4126 offload_targets = target;
4127 target = NULL;
4128 }
4129 else
4130 {
4131 /* Check that the target hasn't already presented in the list. */
4132 c = offload_targets;
4133 do
4134 {
4135 n = strchr (c, ':');
4136 if (n == NULL)
4137 n = strchr (c, '\0');
4138
4139 if (next - cur == n - c && strncmp (c, target, n - c) == 0)
4140 break;
4141
4142 c = n + 1;
4143 }
4144 while (*n);
4145
4146 /* If duplicate is not found, append the target to the list. */
4147 if (c > n)
4148 {
4149 size_t offload_targets_len = strlen (offload_targets);
4150 offload_targets
4151 = XRESIZEVEC (char, offload_targets,
4152 offload_targets_len + 1 + next - cur + 1);
4153 offload_targets[offload_targets_len++] = ':';
4154 memcpy (offload_targets + offload_targets_len, target, next - cur + 1);
4155 }
4156 }
4157 next_item:
4158 cur = next + 1;
4159 XDELETEVEC (target);
4160 }
4161 }
4162
4163 /* Handle a driver option; arguments and return value as for
4164 handle_option. */
4165
4166 static bool
4167 driver_handle_option (struct gcc_options *opts,
4168 struct gcc_options *opts_set,
4169 const struct cl_decoded_option *decoded,
4170 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
4171 location_t loc,
4172 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
4173 diagnostic_context *dc,
4174 void (*) (void))
4175 {
4176 size_t opt_index = decoded->opt_index;
4177 const char *arg = decoded->arg;
4178 const char *compare_debug_replacement_opt;
4179 int value = decoded->value;
4180 bool validated = false;
4181 bool do_save = true;
4182
4183 gcc_assert (opts == &global_options);
4184 gcc_assert (opts_set == &global_options_set);
4185 gcc_assert (kind == DK_UNSPECIFIED);
4186 gcc_assert (loc == UNKNOWN_LOCATION);
4187 gcc_assert (dc == global_dc);
4188
4189 switch (opt_index)
4190 {
4191 case OPT_dumpspecs:
4192 {
4193 struct spec_list *sl;
4194 init_spec ();
4195 for (sl = specs; sl; sl = sl->next)
4196 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
4197 if (link_command_spec)
4198 printf ("*link_command:\n%s\n\n", link_command_spec);
4199 exit (0);
4200 }
4201
4202 case OPT_dumpversion:
4203 printf ("%s\n", spec_version);
4204 exit (0);
4205
4206 case OPT_dumpmachine:
4207 printf ("%s\n", spec_machine);
4208 exit (0);
4209
4210 case OPT_dumpfullversion:
4211 printf ("%s\n", BASEVER);
4212 exit (0);
4213
4214 case OPT__version:
4215 print_version = 1;
4216
4217 /* CPP driver cannot obtain switch from cc1_options. */
4218 if (is_cpp_driver)
4219 add_preprocessor_option ("--version", strlen ("--version"));
4220 add_assembler_option ("--version", strlen ("--version"));
4221 add_linker_option ("--version", strlen ("--version"));
4222 break;
4223
4224 case OPT__completion_:
4225 validated = true;
4226 completion = decoded->arg;
4227 break;
4228
4229 case OPT__help:
4230 print_help_list = 1;
4231
4232 /* CPP driver cannot obtain switch from cc1_options. */
4233 if (is_cpp_driver)
4234 add_preprocessor_option ("--help", 6);
4235 add_assembler_option ("--help", 6);
4236 add_linker_option ("--help", 6);
4237 break;
4238
4239 case OPT__help_:
4240 print_subprocess_help = 2;
4241 break;
4242
4243 case OPT__target_help:
4244 print_subprocess_help = 1;
4245
4246 /* CPP driver cannot obtain switch from cc1_options. */
4247 if (is_cpp_driver)
4248 add_preprocessor_option ("--target-help", 13);
4249 add_assembler_option ("--target-help", 13);
4250 add_linker_option ("--target-help", 13);
4251 break;
4252
4253 case OPT__no_sysroot_suffix:
4254 case OPT_pass_exit_codes:
4255 case OPT_print_search_dirs:
4256 case OPT_print_file_name_:
4257 case OPT_print_prog_name_:
4258 case OPT_print_multi_lib:
4259 case OPT_print_multi_directory:
4260 case OPT_print_sysroot:
4261 case OPT_print_multi_os_directory:
4262 case OPT_print_multiarch:
4263 case OPT_print_sysroot_headers_suffix:
4264 case OPT_time:
4265 case OPT_wrapper:
4266 /* These options set the variables specified in common.opt
4267 automatically, and do not need to be saved for spec
4268 processing. */
4269 do_save = false;
4270 break;
4271
4272 case OPT_print_libgcc_file_name:
4273 print_file_name = "libgcc.a";
4274 do_save = false;
4275 break;
4276
4277 case OPT_fuse_ld_bfd:
4278 use_ld = ".bfd";
4279 break;
4280
4281 case OPT_fuse_ld_gold:
4282 use_ld = ".gold";
4283 break;
4284
4285 case OPT_fcompare_debug_second:
4286 compare_debug_second = 1;
4287 break;
4288
4289 case OPT_fcompare_debug:
4290 switch (value)
4291 {
4292 case 0:
4293 compare_debug_replacement_opt = "-fcompare-debug=";
4294 arg = "";
4295 goto compare_debug_with_arg;
4296
4297 case 1:
4298 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
4299 arg = "-gtoggle";
4300 goto compare_debug_with_arg;
4301
4302 default:
4303 gcc_unreachable ();
4304 }
4305 break;
4306
4307 case OPT_fcompare_debug_:
4308 compare_debug_replacement_opt = decoded->canonical_option[0];
4309 compare_debug_with_arg:
4310 gcc_assert (decoded->canonical_option_num_elements == 1);
4311 gcc_assert (arg != NULL);
4312 if (*arg)
4313 compare_debug = 1;
4314 else
4315 compare_debug = -1;
4316 if (compare_debug < 0)
4317 compare_debug_opt = NULL;
4318 else
4319 compare_debug_opt = arg;
4320 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
4321 set_source_date_epoch_envvar ();
4322 return true;
4323
4324 case OPT_fdiagnostics_color_:
4325 diagnostic_color_init (dc, value);
4326 break;
4327
4328 case OPT_fdiagnostics_urls_:
4329 diagnostic_urls_init (dc, value);
4330 break;
4331
4332 case OPT_fdiagnostics_format_:
4333 diagnostic_output_format_init (dc,
4334 (enum diagnostics_output_format)value);
4335 break;
4336
4337 case OPT_Wa_:
4338 {
4339 int prev, j;
4340 /* Pass the rest of this option to the assembler. */
4341
4342 /* Split the argument at commas. */
4343 prev = 0;
4344 for (j = 0; arg[j]; j++)
4345 if (arg[j] == ',')
4346 {
4347 add_assembler_option (arg + prev, j - prev);
4348 prev = j + 1;
4349 }
4350
4351 /* Record the part after the last comma. */
4352 add_assembler_option (arg + prev, j - prev);
4353 }
4354 do_save = false;
4355 break;
4356
4357 case OPT_Wp_:
4358 {
4359 int prev, j;
4360 /* Pass the rest of this option to the preprocessor. */
4361
4362 /* Split the argument at commas. */
4363 prev = 0;
4364 for (j = 0; arg[j]; j++)
4365 if (arg[j] == ',')
4366 {
4367 add_preprocessor_option (arg + prev, j - prev);
4368 prev = j + 1;
4369 }
4370
4371 /* Record the part after the last comma. */
4372 add_preprocessor_option (arg + prev, j - prev);
4373 }
4374 do_save = false;
4375 break;
4376
4377 case OPT_Wl_:
4378 {
4379 int prev, j;
4380 /* Split the argument at commas. */
4381 prev = 0;
4382 for (j = 0; arg[j]; j++)
4383 if (arg[j] == ',')
4384 {
4385 add_infile (save_string (arg + prev, j - prev), "*");
4386 prev = j + 1;
4387 }
4388 /* Record the part after the last comma. */
4389 add_infile (arg + prev, "*");
4390 }
4391 do_save = false;
4392 break;
4393
4394 case OPT_Xlinker:
4395 add_infile (arg, "*");
4396 do_save = false;
4397 break;
4398
4399 case OPT_Xpreprocessor:
4400 add_preprocessor_option (arg, strlen (arg));
4401 do_save = false;
4402 break;
4403
4404 case OPT_Xassembler:
4405 add_assembler_option (arg, strlen (arg));
4406 do_save = false;
4407 break;
4408
4409 case OPT_l:
4410 /* POSIX allows separation of -l and the lib arg; canonicalize
4411 by concatenating -l with its arg */
4412 add_infile (concat ("-l", arg, NULL), "*");
4413 do_save = false;
4414 break;
4415
4416 case OPT_L:
4417 /* Similarly, canonicalize -L for linkers that may not accept
4418 separate arguments. */
4419 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
4420 return true;
4421
4422 case OPT_F:
4423 /* Likewise -F. */
4424 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
4425 return true;
4426
4427 case OPT_save_temps:
4428 if (!save_temps_flag)
4429 save_temps_flag = SAVE_TEMPS_DUMP;
4430 validated = true;
4431 break;
4432
4433 case OPT_save_temps_:
4434 if (strcmp (arg, "cwd") == 0)
4435 save_temps_flag = SAVE_TEMPS_CWD;
4436 else if (strcmp (arg, "obj") == 0
4437 || strcmp (arg, "object") == 0)
4438 save_temps_flag = SAVE_TEMPS_OBJ;
4439 else
4440 fatal_error (input_location, "%qs is an unknown %<-save-temps%> option",
4441 decoded->orig_option_with_args_text);
4442 save_temps_overrides_dumpdir = true;
4443 break;
4444
4445 case OPT_dumpdir:
4446 free (dumpdir);
4447 dumpdir = xstrdup (arg);
4448 save_temps_overrides_dumpdir = false;
4449 break;
4450
4451 case OPT_dumpbase:
4452 free (dumpbase);
4453 dumpbase = xstrdup (arg);
4454 break;
4455
4456 case OPT_dumpbase_ext:
4457 free (dumpbase_ext);
4458 dumpbase_ext = xstrdup (arg);
4459 break;
4460
4461 case OPT_no_canonical_prefixes:
4462 /* Already handled as a special case, so ignored here. */
4463 do_save = false;
4464 break;
4465
4466 case OPT_pipe:
4467 validated = true;
4468 /* These options set the variables specified in common.opt
4469 automatically, but do need to be saved for spec
4470 processing. */
4471 break;
4472
4473 case OPT_specs_:
4474 {
4475 struct user_specs *user = XNEW (struct user_specs);
4476
4477 user->next = (struct user_specs *) 0;
4478 user->filename = arg;
4479 if (user_specs_tail)
4480 user_specs_tail->next = user;
4481 else
4482 user_specs_head = user;
4483 user_specs_tail = user;
4484 }
4485 validated = true;
4486 break;
4487
4488 case OPT__sysroot_:
4489 target_system_root = arg;
4490 target_system_root_changed = 1;
4491 do_save = false;
4492 break;
4493
4494 case OPT_time_:
4495 if (report_times_to_file)
4496 fclose (report_times_to_file);
4497 report_times_to_file = fopen (arg, "a");
4498 do_save = false;
4499 break;
4500
4501 case OPT____:
4502 /* "-###"
4503 This is similar to -v except that there is no execution
4504 of the commands and the echoed arguments are quoted. It
4505 is intended for use in shell scripts to capture the
4506 driver-generated command line. */
4507 verbose_only_flag++;
4508 verbose_flag = 1;
4509 do_save = false;
4510 break;
4511
4512 case OPT_B:
4513 {
4514 size_t len = strlen (arg);
4515
4516 /* Catch the case where the user has forgotten to append a
4517 directory separator to the path. Note, they may be using
4518 -B to add an executable name prefix, eg "i386-elf-", in
4519 order to distinguish between multiple installations of
4520 GCC in the same directory. Hence we must check to see
4521 if appending a directory separator actually makes a
4522 valid directory name. */
4523 if (!IS_DIR_SEPARATOR (arg[len - 1])
4524 && is_directory (arg, false))
4525 {
4526 char *tmp = XNEWVEC (char, len + 2);
4527 strcpy (tmp, arg);
4528 tmp[len] = DIR_SEPARATOR;
4529 tmp[++len] = 0;
4530 arg = tmp;
4531 }
4532
4533 add_prefix (&exec_prefixes, arg, NULL,
4534 PREFIX_PRIORITY_B_OPT, 0, 0);
4535 add_prefix (&startfile_prefixes, arg, NULL,
4536 PREFIX_PRIORITY_B_OPT, 0, 0);
4537 add_prefix (&include_prefixes, arg, NULL,
4538 PREFIX_PRIORITY_B_OPT, 0, 0);
4539 }
4540 validated = true;
4541 break;
4542
4543 case OPT_E:
4544 have_E = true;
4545 break;
4546
4547 case OPT_x:
4548 spec_lang = arg;
4549 if (!strcmp (spec_lang, "none"))
4550 /* Suppress the warning if -xnone comes after the last input
4551 file, because alternate command interfaces like g++ might
4552 find it useful to place -xnone after each input file. */
4553 spec_lang = 0;
4554 else
4555 last_language_n_infiles = n_infiles;
4556 do_save = false;
4557 break;
4558
4559 case OPT_o:
4560 have_o = 1;
4561 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
4562 arg = convert_filename (arg, ! have_c, 0);
4563 #endif
4564 output_file = arg;
4565 /* On some systems, ld cannot handle "-o" without a space. So
4566 split the option from its argument. */
4567 save_switch ("-o", 1, &arg, validated, true);
4568 return true;
4569
4570 #ifdef ENABLE_DEFAULT_PIE
4571 case OPT_pie:
4572 /* -pie is turned on by default. */
4573 #endif
4574
4575 case OPT_static_libgcc:
4576 case OPT_shared_libgcc:
4577 case OPT_static_libgfortran:
4578 case OPT_static_libphobos:
4579 case OPT_static_libstdc__:
4580 /* These are always valid, since gcc.c itself understands the
4581 first two, gfortranspec.c understands -static-libgfortran,
4582 d-spec.cc understands -static-libphobos, and g++spec.c
4583 understands -static-libstdc++ */
4584 validated = true;
4585 break;
4586
4587 case OPT_fwpa:
4588 flag_wpa = "";
4589 break;
4590
4591 case OPT_foffload_options_:
4592 check_foffload_target_names (arg);
4593 break;
4594
4595 case OPT_foffload_:
4596 handle_foffload_option (arg);
4597 if (arg[0] == '-' || NULL != strchr (arg, '='))
4598 save_switch (concat ("-foffload-options=", arg, NULL),
4599 0, NULL, validated, true);
4600 do_save = false;
4601 break;
4602
4603 default:
4604 /* Various driver options need no special processing at this
4605 point, having been handled in a prescan above or being
4606 handled by specs. */
4607 break;
4608 }
4609
4610 if (do_save)
4611 save_switch (decoded->canonical_option[0],
4612 decoded->canonical_option_num_elements - 1,
4613 &decoded->canonical_option[1], validated, true);
4614 return true;
4615 }
4616
4617 /* Return true if F2 is F1 followed by a single suffix, i.e., by a
4618 period and additional characters other than a period. */
4619
4620 static inline bool
4621 adds_single_suffix_p (const char *f2, const char *f1)
4622 {
4623 size_t len = strlen (f1);
4624
4625 return (strncmp (f1, f2, len) == 0
4626 && f2[len] == '.'
4627 && strchr (f2 + len + 1, '.') == NULL);
4628 }
4629
4630 /* Put the driver's standard set of option handlers in *HANDLERS. */
4631
4632 static void
4633 set_option_handlers (struct cl_option_handlers *handlers)
4634 {
4635 handlers->unknown_option_callback = driver_unknown_option_callback;
4636 handlers->wrong_lang_callback = driver_wrong_lang_callback;
4637 handlers->num_handlers = 3;
4638 handlers->handlers[0].handler = driver_handle_option;
4639 handlers->handlers[0].mask = CL_DRIVER;
4640 handlers->handlers[1].handler = common_handle_option;
4641 handlers->handlers[1].mask = CL_COMMON;
4642 handlers->handlers[2].handler = target_handle_option;
4643 handlers->handlers[2].mask = CL_TARGET;
4644 }
4645
4646
4647 /* Return the index into infiles for the single non-library
4648 non-lto-wpa input file, -1 if there isn't any, or -2 if there is
4649 more than one. */
4650 static inline int
4651 single_input_file_index ()
4652 {
4653 int ret = -1;
4654
4655 for (int i = 0; i < n_infiles; i++)
4656 {
4657 if (infiles[i].language
4658 && (infiles[i].language[0] == '*'
4659 || (flag_wpa
4660 && strcmp (infiles[i].language, "lto") == 0)))
4661 continue;
4662
4663 if (ret != -1)
4664 return -2;
4665
4666 ret = i;
4667 }
4668
4669 return ret;
4670 }
4671
4672 /* Create the vector `switches' and its contents.
4673 Store its length in `n_switches'. */
4674
4675 static void
4676 process_command (unsigned int decoded_options_count,
4677 struct cl_decoded_option *decoded_options)
4678 {
4679 const char *temp;
4680 char *temp1;
4681 char *tooldir_prefix, *tooldir_prefix2;
4682 char *(*get_relative_prefix) (const char *, const char *,
4683 const char *) = NULL;
4684 struct cl_option_handlers handlers;
4685 unsigned int j;
4686
4687 gcc_exec_prefix = env.get ("GCC_EXEC_PREFIX");
4688
4689 n_switches = 0;
4690 n_infiles = 0;
4691 added_libraries = 0;
4692
4693 /* Figure compiler version from version string. */
4694
4695 compiler_version = temp1 = xstrdup (version_string);
4696
4697 for (; *temp1; ++temp1)
4698 {
4699 if (*temp1 == ' ')
4700 {
4701 *temp1 = '\0';
4702 break;
4703 }
4704 }
4705
4706 /* Handle any -no-canonical-prefixes flag early, to assign the function
4707 that builds relative prefixes. This function creates default search
4708 paths that are needed later in normal option handling. */
4709
4710 for (j = 1; j < decoded_options_count; j++)
4711 {
4712 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
4713 {
4714 get_relative_prefix = make_relative_prefix_ignore_links;
4715 break;
4716 }
4717 }
4718 if (! get_relative_prefix)
4719 get_relative_prefix = make_relative_prefix;
4720
4721 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
4722 see if we can create it from the pathname specified in
4723 decoded_options[0].arg. */
4724
4725 gcc_libexec_prefix = standard_libexec_prefix;
4726 #ifndef VMS
4727 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
4728 if (!gcc_exec_prefix)
4729 {
4730 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
4731 standard_bindir_prefix,
4732 standard_exec_prefix);
4733 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
4734 standard_bindir_prefix,
4735 standard_libexec_prefix);
4736 if (gcc_exec_prefix)
4737 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
4738 }
4739 else
4740 {
4741 /* make_relative_prefix requires a program name, but
4742 GCC_EXEC_PREFIX is typically a directory name with a trailing
4743 / (which is ignored by make_relative_prefix), so append a
4744 program name. */
4745 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
4746 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
4747 standard_exec_prefix,
4748 standard_libexec_prefix);
4749
4750 /* The path is unrelocated, so fallback to the original setting. */
4751 if (!gcc_libexec_prefix)
4752 gcc_libexec_prefix = standard_libexec_prefix;
4753
4754 free (tmp_prefix);
4755 }
4756 #else
4757 #endif
4758 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
4759 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
4760 or an automatically created GCC_EXEC_PREFIX from
4761 decoded_options[0].arg. */
4762
4763 /* Do language-specific adjustment/addition of flags. */
4764 lang_specific_driver (&decoded_options, &decoded_options_count,
4765 &added_libraries);
4766
4767 if (gcc_exec_prefix)
4768 {
4769 int len = strlen (gcc_exec_prefix);
4770
4771 if (len > (int) sizeof ("/lib/gcc/") - 1
4772 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
4773 {
4774 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
4775 if (IS_DIR_SEPARATOR (*temp)
4776 && filename_ncmp (temp + 1, "lib", 3) == 0
4777 && IS_DIR_SEPARATOR (temp[4])
4778 && filename_ncmp (temp + 5, "gcc", 3) == 0)
4779 len -= sizeof ("/lib/gcc/") - 1;
4780 }
4781
4782 set_std_prefix (gcc_exec_prefix, len);
4783 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
4784 PREFIX_PRIORITY_LAST, 0, 0);
4785 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
4786 PREFIX_PRIORITY_LAST, 0, 0);
4787 }
4788
4789 /* COMPILER_PATH and LIBRARY_PATH have values
4790 that are lists of directory names with colons. */
4791
4792 temp = env.get ("COMPILER_PATH");
4793 if (temp)
4794 {
4795 const char *startp, *endp;
4796 char *nstore = (char *) alloca (strlen (temp) + 3);
4797
4798 startp = endp = temp;
4799 while (1)
4800 {
4801 if (*endp == PATH_SEPARATOR || *endp == 0)
4802 {
4803 strncpy (nstore, startp, endp - startp);
4804 if (endp == startp)
4805 strcpy (nstore, concat (".", dir_separator_str, NULL));
4806 else if (!IS_DIR_SEPARATOR (endp[-1]))
4807 {
4808 nstore[endp - startp] = DIR_SEPARATOR;
4809 nstore[endp - startp + 1] = 0;
4810 }
4811 else
4812 nstore[endp - startp] = 0;
4813 add_prefix (&exec_prefixes, nstore, 0,
4814 PREFIX_PRIORITY_LAST, 0, 0);
4815 add_prefix (&include_prefixes, nstore, 0,
4816 PREFIX_PRIORITY_LAST, 0, 0);
4817 if (*endp == 0)
4818 break;
4819 endp = startp = endp + 1;
4820 }
4821 else
4822 endp++;
4823 }
4824 }
4825
4826 temp = env.get (LIBRARY_PATH_ENV);
4827 if (temp && *cross_compile == '0')
4828 {
4829 const char *startp, *endp;
4830 char *nstore = (char *) alloca (strlen (temp) + 3);
4831
4832 startp = endp = temp;
4833 while (1)
4834 {
4835 if (*endp == PATH_SEPARATOR || *endp == 0)
4836 {
4837 strncpy (nstore, startp, endp - startp);
4838 if (endp == startp)
4839 strcpy (nstore, concat (".", dir_separator_str, NULL));
4840 else if (!IS_DIR_SEPARATOR (endp[-1]))
4841 {
4842 nstore[endp - startp] = DIR_SEPARATOR;
4843 nstore[endp - startp + 1] = 0;
4844 }
4845 else
4846 nstore[endp - startp] = 0;
4847 add_prefix (&startfile_prefixes, nstore, NULL,
4848 PREFIX_PRIORITY_LAST, 0, 1);
4849 if (*endp == 0)
4850 break;
4851 endp = startp = endp + 1;
4852 }
4853 else
4854 endp++;
4855 }
4856 }
4857
4858 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
4859 temp = env.get ("LPATH");
4860 if (temp && *cross_compile == '0')
4861 {
4862 const char *startp, *endp;
4863 char *nstore = (char *) alloca (strlen (temp) + 3);
4864
4865 startp = endp = temp;
4866 while (1)
4867 {
4868 if (*endp == PATH_SEPARATOR || *endp == 0)
4869 {
4870 strncpy (nstore, startp, endp - startp);
4871 if (endp == startp)
4872 strcpy (nstore, concat (".", dir_separator_str, NULL));
4873 else if (!IS_DIR_SEPARATOR (endp[-1]))
4874 {
4875 nstore[endp - startp] = DIR_SEPARATOR;
4876 nstore[endp - startp + 1] = 0;
4877 }
4878 else
4879 nstore[endp - startp] = 0;
4880 add_prefix (&startfile_prefixes, nstore, NULL,
4881 PREFIX_PRIORITY_LAST, 0, 1);
4882 if (*endp == 0)
4883 break;
4884 endp = startp = endp + 1;
4885 }
4886 else
4887 endp++;
4888 }
4889 }
4890
4891 /* Process the options and store input files and switches in their
4892 vectors. */
4893
4894 last_language_n_infiles = -1;
4895
4896 set_option_handlers (&handlers);
4897
4898 for (j = 1; j < decoded_options_count; j++)
4899 {
4900 switch (decoded_options[j].opt_index)
4901 {
4902 case OPT_S:
4903 case OPT_c:
4904 case OPT_E:
4905 have_c = 1;
4906 break;
4907 }
4908 if (have_c)
4909 break;
4910 }
4911
4912 for (j = 1; j < decoded_options_count; j++)
4913 {
4914 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
4915 {
4916 const char *arg = decoded_options[j].arg;
4917
4918 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4919 arg = convert_filename (arg, 0, access (arg, F_OK));
4920 #endif
4921 add_infile (arg, spec_lang);
4922
4923 continue;
4924 }
4925
4926 read_cmdline_option (&global_options, &global_options_set,
4927 decoded_options + j, UNKNOWN_LOCATION,
4928 CL_DRIVER, &handlers, global_dc);
4929 }
4930
4931 /* If the user didn't specify any, default to all configured offload
4932 targets. */
4933 if (ENABLE_OFFLOADING && offload_targets == NULL)
4934 {
4935 handle_foffload_option (OFFLOAD_TARGETS);
4936 #if OFFLOAD_DEFAULTED
4937 offload_targets_default = true;
4938 #endif
4939 }
4940
4941 /* Handle -gtoggle as it would later in toplev.c:process_options to
4942 make the debug-level-gt spec function work as expected. */
4943 if (flag_gtoggle)
4944 {
4945 if (debug_info_level == DINFO_LEVEL_NONE)
4946 debug_info_level = DINFO_LEVEL_NORMAL;
4947 else
4948 debug_info_level = DINFO_LEVEL_NONE;
4949 }
4950
4951 if (output_file
4952 && strcmp (output_file, "-") != 0
4953 && strcmp (output_file, HOST_BIT_BUCKET) != 0)
4954 {
4955 int i;
4956 for (i = 0; i < n_infiles; i++)
4957 if ((!infiles[i].language || infiles[i].language[0] != '*')
4958 && canonical_filename_eq (infiles[i].name, output_file))
4959 fatal_error (input_location,
4960 "input file %qs is the same as output file",
4961 output_file);
4962 }
4963
4964 if (output_file != NULL && output_file[0] == '\0')
4965 fatal_error (input_location, "output filename may not be empty");
4966
4967 /* -dumpdir and -save-temps=* both specify the location of aux/dump
4968 outputs; the one that appears last prevails. When compiling
4969 multiple sources, an explicit dumpbase (minus -ext) may be
4970 combined with an explicit or implicit dumpdir, whereas when
4971 linking, a specified or implied link output name (minus
4972 extension) may be combined with a prevailing -save-temps=* or an
4973 otherwise implied dumpdir, but not override a prevailing
4974 -dumpdir. Primary outputs (e.g., linker output when linking
4975 without -o, or .i, .s or .o outputs when processing multiple
4976 inputs with -E, -S or -c, respectively) are NOT affected by these
4977 -save-temps=/-dump* options, always landing in the current
4978 directory and with the same basename as the input when an output
4979 name is not given, but when they're intermediate outputs, they
4980 are named like other aux outputs, so the options affect their
4981 location and name.
4982
4983 Here are some examples. There are several more in the
4984 documentation of -o and -dump*, and some quite exhaustive tests
4985 in gcc.misc-tests/outputs.exp.
4986
4987 When compiling any number of sources, no -dump* nor
4988 -save-temps=*, all outputs in cwd without prefix:
4989
4990 # gcc -c b.c -gsplit-dwarf
4991 -> cc1 [-dumpdir ./] -dumpbase b.c -dumpbase-ext .c # b.o b.dwo
4992
4993 # gcc -c b.c d.c -gsplit-dwarf
4994 -> cc1 [-dumpdir ./] -dumpbase b.c -dumpbase-ext .c # b.o b.dwo
4995 && cc1 [-dumpdir ./] -dumpbase d.c -dumpbase-ext .c # d.o d.dwo
4996
4997 When compiling and linking, no -dump* nor -save-temps=*, .o
4998 outputs are temporary, aux outputs land in the dir of the output,
4999 prefixed with the basename of the linker output:
5000
5001 # gcc b.c d.c -o ab -gsplit-dwarf
5002 -> cc1 -dumpdir ab- -dumpbase b.c -dumpbase-ext .c # ab-b.dwo
5003 && cc1 -dumpdir ab- -dumpbase d.c -dumpbase-ext .c # ab-d.dwo
5004 && link ... -o ab
5005
5006 # gcc b.c d.c [-o a.out] -gsplit-dwarf
5007 -> cc1 -dumpdir a- -dumpbase b.c -dumpbase-ext .c # a-b.dwo
5008 && cc1 -dumpdir a- -dumpbase d.c -dumpbase-ext .c # a-d.dwo
5009 && link ... [-o a.out]
5010
5011 When compiling and linking, a prevailing -dumpdir fully overrides
5012 the prefix of aux outputs given by the output name:
5013
5014 # gcc -dumpdir f b.c d.c -gsplit-dwarf [-o [dir/]whatever]
5015 -> cc1 -dumpdir f -dumpbase b.c -dumpbase-ext .c # fb.dwo
5016 && cc1 -dumpdir f -dumpbase d.c -dumpbase-ext .c # fd.dwo
5017 && link ... [-o whatever]
5018
5019 When compiling multiple inputs, an explicit -dumpbase is combined
5020 with -dumpdir, affecting aux outputs, but not the .o outputs:
5021
5022 # gcc -dumpdir f -dumpbase g- b.c d.c -gsplit-dwarf -c
5023 -> cc1 -dumpdir fg- -dumpbase b.c -dumpbase-ext .c # b.o fg-b.dwo
5024 && cc1 -dumpdir fg- -dumpbase d.c -dumpbase-ext .c # d.o fg-d.dwo
5025
5026 When compiling and linking with -save-temps, the .o outputs that
5027 would have been temporary become aux outputs, so they get
5028 affected by -dump* flags:
5029
5030 # gcc -dumpdir f -dumpbase g- -save-temps b.c d.c
5031 -> cc1 -dumpdir fg- -dumpbase b.c -dumpbase-ext .c # fg-b.o
5032 && cc1 -dumpdir fg- -dumpbase d.c -dumpbase-ext .c # fg-d.o
5033 && link
5034
5035 If -save-temps=* prevails over -dumpdir, however, the explicit
5036 -dumpdir is discarded, as if it wasn't there. The basename of
5037 the implicit linker output, a.out or a.exe, becomes a- as the aux
5038 output prefix for all compilations:
5039
5040 # gcc [-dumpdir f] -save-temps=cwd b.c d.c
5041 -> cc1 -dumpdir a- -dumpbase b.c -dumpbase-ext .c # a-b.o
5042 && cc1 -dumpdir a- -dumpbase d.c -dumpbase-ext .c # a-d.o
5043 && link
5044
5045 A single -dumpbase, applying to multiple inputs, overrides the
5046 linker output name, implied or explicit, as the aux output prefix:
5047
5048 # gcc [-dumpdir f] -dumpbase g- -save-temps=cwd b.c d.c
5049 -> cc1 -dumpdir g- -dumpbase b.c -dumpbase-ext .c # g-b.o
5050 && cc1 -dumpdir g- -dumpbase d.c -dumpbase-ext .c # g-d.o
5051 && link
5052
5053 # gcc [-dumpdir f] -dumpbase g- -save-temps=cwd b.c d.c -o dir/h.out
5054 -> cc1 -dumpdir g- -dumpbase b.c -dumpbase-ext .c # g-b.o
5055 && cc1 -dumpdir g- -dumpbase d.c -dumpbase-ext .c # g-d.o
5056 && link -o dir/h.out
5057
5058 Now, if the linker output is NOT overridden as a prefix, but
5059 -save-temps=* overrides implicit or explicit -dumpdir, the
5060 effective dump dir combines the dir selected by the -save-temps=*
5061 option with the basename of the specified or implied link output:
5062
5063 # gcc [-dumpdir f] -save-temps=cwd b.c d.c -o dir/h.out
5064 -> cc1 -dumpdir h- -dumpbase b.c -dumpbase-ext .c # h-b.o
5065 && cc1 -dumpdir h- -dumpbase d.c -dumpbase-ext .c # h-d.o
5066 && link -o dir/h.out
5067
5068 # gcc [-dumpdir f] -save-temps=obj b.c d.c -o dir/h.out
5069 -> cc1 -dumpdir dir/h- -dumpbase b.c -dumpbase-ext .c # dir/h-b.o
5070 && cc1 -dumpdir dir/h- -dumpbase d.c -dumpbase-ext .c # dir/h-d.o
5071 && link -o dir/h.out
5072
5073 But then again, a single -dumpbase applying to multiple inputs
5074 gets used instead of the linker output basename in the combined
5075 dumpdir:
5076
5077 # gcc [-dumpdir f] -dumpbase g- -save-temps=obj b.c d.c -o dir/h.out
5078 -> cc1 -dumpdir dir/g- -dumpbase b.c -dumpbase-ext .c # dir/g-b.o
5079 && cc1 -dumpdir dir/g- -dumpbase d.c -dumpbase-ext .c # dir/g-d.o
5080 && link -o dir/h.out
5081
5082 With a single input being compiled, the output basename does NOT
5083 affect the dumpdir prefix.
5084
5085 # gcc -save-temps=obj b.c -gsplit-dwarf -c -o dir/b.o
5086 -> cc1 -dumpdir dir/ -dumpbase b.c -dumpbase-ext .c # dir/b.o dir/b.dwo
5087
5088 but when compiling and linking even a single file, it does:
5089
5090 # gcc -save-temps=obj b.c -o dir/h.out
5091 -> cc1 -dumpdir dir/h- -dumpbase b.c -dumpbase-ext .c # dir/h-b.o
5092
5093 unless an explicit -dumpdir prevails:
5094
5095 # gcc -save-temps[=obj] -dumpdir g- b.c -o dir/h.out
5096 -> cc1 -dumpdir g- -dumpbase b.c -dumpbase-ext .c # g-b.o
5097
5098 */
5099
5100 bool explicit_dumpdir = dumpdir;
5101
5102 if ((!save_temps_overrides_dumpdir && explicit_dumpdir)
5103 || (output_file && not_actual_file_p (output_file)))
5104 {
5105 /* Do nothing. */
5106 }
5107
5108 /* If -save-temps=obj and -o name, create the prefix to use for %b.
5109 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
5110 else if (save_temps_flag != SAVE_TEMPS_CWD && output_file != NULL)
5111 {
5112 free (dumpdir);
5113 dumpdir = NULL;
5114 temp = lbasename (output_file);
5115 if (temp != output_file)
5116 dumpdir = xstrndup (output_file,
5117 strlen (output_file) - strlen (temp));
5118 }
5119 else if (dumpdir)
5120 {
5121 free (dumpdir);
5122 dumpdir = NULL;
5123 }
5124
5125 if (save_temps_flag)
5126 save_temps_flag = SAVE_TEMPS_DUMP;
5127
5128 /* If there is any pathname component in an explicit -dumpbase, it
5129 overrides dumpdir entirely, so discard it right away. Although
5130 the presence of an explicit -dumpdir matters for the driver, it
5131 shouldn't matter for other processes, that get all that's needed
5132 from the -dumpdir and -dumpbase always passed to them. */
5133 if (dumpdir && dumpbase && lbasename (dumpbase) != dumpbase)
5134 {
5135 free (dumpdir);
5136 dumpdir = NULL;
5137 }
5138
5139 /* Check that dumpbase_ext matches the end of dumpbase, drop it
5140 otherwise. */
5141 if (dumpbase_ext && dumpbase && *dumpbase)
5142 {
5143 int lendb = strlen (dumpbase);
5144 int lendbx = strlen (dumpbase_ext);
5145
5146 /* -dumpbase-ext must be a suffix proper; discard it if it
5147 matches all of -dumpbase, as that would make for an empty
5148 basename. */
5149 if (lendbx >= lendb
5150 || strcmp (dumpbase + lendb - lendbx, dumpbase_ext) != 0)
5151 {
5152 free (dumpbase_ext);
5153 dumpbase_ext = NULL;
5154 }
5155 }
5156
5157 /* -dumpbase with multiple sources goes into dumpdir. With a single
5158 source, it does only if linking and if dumpdir was not explicitly
5159 specified. */
5160 if (dumpbase && *dumpbase
5161 && (single_input_file_index () == -2
5162 || (!have_c && !explicit_dumpdir)))
5163 {
5164 char *prefix;
5165
5166 if (dumpbase_ext)
5167 /* We checked that they match above. */
5168 dumpbase[strlen (dumpbase) - strlen (dumpbase_ext)] = '\0';
5169
5170 if (dumpdir)
5171 prefix = concat (dumpdir, dumpbase, "-", NULL);
5172 else
5173 prefix = concat (dumpbase, "-", NULL);
5174
5175 free (dumpdir);
5176 free (dumpbase);
5177 free (dumpbase_ext);
5178 dumpbase = dumpbase_ext = NULL;
5179 dumpdir = prefix;
5180 dumpdir_trailing_dash_added = true;
5181 }
5182
5183 /* If dumpbase was not brought into dumpdir but we're linking, bring
5184 output_file into dumpdir unless dumpdir was explicitly specified.
5185 The test for !explicit_dumpdir is further below, because we want
5186 to use the obase computation for a ghost outbase, passed to
5187 GCC_COLLECT_OPTIONS. */
5188 else if (!have_c && (!explicit_dumpdir || (dumpbase && !*dumpbase)))
5189 {
5190 /* If we get here, we know dumpbase was not specified, or it was
5191 specified as an empty string. If it was anything else, it
5192 would have combined with dumpdir above, because the condition
5193 for dumpbase to be used when present is broader than the
5194 condition that gets us here. */
5195 gcc_assert (!dumpbase || !*dumpbase);
5196
5197 const char *obase;
5198 char *tofree = NULL;
5199 if (!output_file || not_actual_file_p (output_file))
5200 obase = "a";
5201 else
5202 {
5203 obase = lbasename (output_file);
5204 size_t blen = strlen (obase), xlen;
5205 /* Drop the suffix if it's dumpbase_ext, if given,
5206 otherwise .exe or the target executable suffix, or if the
5207 output was explicitly named a.out, but not otherwise. */
5208 if (dumpbase_ext
5209 ? (blen > (xlen = strlen (dumpbase_ext))
5210 && strcmp ((temp = (obase + blen - xlen)),
5211 dumpbase_ext) == 0)
5212 : ((temp = strrchr (obase + 1, '.'))
5213 && (xlen = strlen (temp))
5214 && (strcmp (temp, ".exe") == 0
5215 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
5216 || strcmp (temp, TARGET_EXECUTABLE_SUFFIX) == 0
5217 #endif
5218 || strcmp (obase, "a.out") == 0)))
5219 {
5220 tofree = xstrndup (obase, blen - xlen);
5221 obase = tofree;
5222 }
5223 }
5224
5225 /* We wish to save this basename to the -dumpdir passed through
5226 GCC_COLLECT_OPTIONS within maybe_run_linker, for e.g. LTO,
5227 but we do NOT wish to add it to e.g. %b, so we keep
5228 outbase_length as zero. */
5229 gcc_assert (!outbase);
5230 outbase_length = 0;
5231
5232 /* If we're building [dir1/]foo[.exe] out of a single input
5233 [dir2/]foo.c that shares the same basename, dump to
5234 [dir2/]foo.c.* rather than duplicating the basename into
5235 [dir2/]foo-foo.c.*. */
5236 int idxin;
5237 if (dumpbase
5238 || ((idxin = single_input_file_index ()) >= 0
5239 && adds_single_suffix_p (lbasename (infiles[idxin].name),
5240 obase)))
5241 {
5242 if (obase == tofree)
5243 outbase = tofree;
5244 else
5245 {
5246 outbase = xstrdup (obase);
5247 free (tofree);
5248 }
5249 obase = tofree = NULL;
5250 }
5251 else
5252 {
5253 if (dumpdir)
5254 {
5255 char *p = concat (dumpdir, obase, "-", NULL);
5256 free (dumpdir);
5257 dumpdir = p;
5258 }
5259 else
5260 dumpdir = concat (obase, "-", NULL);
5261
5262 dumpdir_trailing_dash_added = true;
5263
5264 free (tofree);
5265 obase = tofree = NULL;
5266 }
5267
5268 if (!explicit_dumpdir || dumpbase)
5269 {
5270 /* Absent -dumpbase and present -dumpbase-ext have been applied
5271 to the linker output name, so compute fresh defaults for each
5272 compilation. */
5273 free (dumpbase_ext);
5274 dumpbase_ext = NULL;
5275 }
5276 }
5277
5278 /* Now, if we're compiling, or if we haven't used the dumpbase
5279 above, then outbase (%B) is derived from dumpbase, if given, or
5280 from the output name, given or implied. We can't precompute
5281 implied output names, but that's ok, since they're derived from
5282 input names. Just make sure we skip this if dumpbase is the
5283 empty string: we want to use input names then, so don't set
5284 outbase. */
5285 if ((dumpbase || have_c)
5286 && !(dumpbase && !*dumpbase))
5287 {
5288 gcc_assert (!outbase);
5289
5290 if (dumpbase)
5291 {
5292 gcc_assert (single_input_file_index () != -2);
5293 /* We do not want lbasename here; dumpbase with dirnames
5294 overrides dumpdir entirely, even if dumpdir is
5295 specified. */
5296 if (dumpbase_ext)
5297 /* We've already checked above that the suffix matches. */
5298 outbase = xstrndup (dumpbase,
5299 strlen (dumpbase) - strlen (dumpbase_ext));
5300 else
5301 outbase = xstrdup (dumpbase);
5302 }
5303 else if (output_file && !not_actual_file_p (output_file))
5304 {
5305 outbase = xstrdup (lbasename (output_file));
5306 char *p = strrchr (outbase + 1, '.');
5307 if (p)
5308 *p = '\0';
5309 }
5310
5311 if (outbase)
5312 outbase_length = strlen (outbase);
5313 }
5314
5315 /* If there is any pathname component in an explicit -dumpbase, do
5316 not use dumpdir, but retain it to pass it on to the compiler. */
5317 if (dumpdir)
5318 dumpdir_length = strlen (dumpdir);
5319 else
5320 dumpdir_length = 0;
5321
5322 /* Check that dumpbase_ext, if still present, still matches the end
5323 of dumpbase, if present, and drop it otherwise. We only retained
5324 it above when dumpbase was absent to maybe use it to drop the
5325 extension from output_name before combining it with dumpdir. We
5326 won't deal with -dumpbase-ext when -dumpbase is not explicitly
5327 given, even if just to activate backward-compatible dumpbase:
5328 dropping it on the floor is correct, expected and documented
5329 behavior. Attempting to deal with a -dumpbase-ext that might
5330 match the end of some input filename, or of the combination of
5331 the output basename with the suffix of the input filename,
5332 possible with an intermediate .gk extension for -fcompare-debug,
5333 is just calling for trouble. */
5334 if (dumpbase_ext)
5335 {
5336 if (!dumpbase || !*dumpbase)
5337 {
5338 free (dumpbase_ext);
5339 dumpbase_ext = NULL;
5340 }
5341 else
5342 gcc_assert (strcmp (dumpbase + strlen (dumpbase)
5343 - strlen (dumpbase_ext), dumpbase_ext) == 0);
5344 }
5345
5346 if (save_temps_flag && use_pipes)
5347 {
5348 /* -save-temps overrides -pipe, so that temp files are produced */
5349 if (save_temps_flag)
5350 warning (0, "%<-pipe%> ignored because %<-save-temps%> specified");
5351 use_pipes = 0;
5352 }
5353
5354 if (!compare_debug)
5355 {
5356 const char *gcd = env.get ("GCC_COMPARE_DEBUG");
5357
5358 if (gcd && gcd[0] == '-')
5359 {
5360 compare_debug = 2;
5361 compare_debug_opt = gcd;
5362 }
5363 else if (gcd && *gcd && strcmp (gcd, "0"))
5364 {
5365 compare_debug = 3;
5366 compare_debug_opt = "-gtoggle";
5367 }
5368 }
5369 else if (compare_debug < 0)
5370 {
5371 compare_debug = 0;
5372 gcc_assert (!compare_debug_opt);
5373 }
5374
5375 /* Set up the search paths. We add directories that we expect to
5376 contain GNU Toolchain components before directories specified by
5377 the machine description so that we will find GNU components (like
5378 the GNU assembler) before those of the host system. */
5379
5380 /* If we don't know where the toolchain has been installed, use the
5381 configured-in locations. */
5382 if (!gcc_exec_prefix)
5383 {
5384 #ifndef OS2
5385 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
5386 PREFIX_PRIORITY_LAST, 1, 0);
5387 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
5388 PREFIX_PRIORITY_LAST, 2, 0);
5389 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
5390 PREFIX_PRIORITY_LAST, 2, 0);
5391 #endif
5392 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
5393 PREFIX_PRIORITY_LAST, 1, 0);
5394 }
5395
5396 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
5397 tooldir_prefix2 = concat (tooldir_base_prefix, spec_machine,
5398 dir_separator_str, NULL);
5399
5400 /* Look for tools relative to the location from which the driver is
5401 running, or, if that is not available, the configured prefix. */
5402 tooldir_prefix
5403 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
5404 spec_host_machine, dir_separator_str, spec_version,
5405 accel_dir_suffix, dir_separator_str, tooldir_prefix2, NULL);
5406 free (tooldir_prefix2);
5407
5408 add_prefix (&exec_prefixes,
5409 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
5410 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
5411 add_prefix (&startfile_prefixes,
5412 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
5413 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
5414 free (tooldir_prefix);
5415
5416 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
5417 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
5418 then consider it to relocate with the rest of the GCC installation
5419 if GCC_EXEC_PREFIX is set.
5420 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
5421 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
5422 {
5423 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
5424 standard_bindir_prefix,
5425 target_system_root);
5426 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
5427 {
5428 target_system_root = tmp_prefix;
5429 target_system_root_changed = 1;
5430 }
5431 }
5432 #endif
5433
5434 /* More prefixes are enabled in main, after we read the specs file
5435 and determine whether this is cross-compilation or not. */
5436
5437 if (n_infiles != 0 && n_infiles == last_language_n_infiles && spec_lang != 0)
5438 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
5439
5440 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
5441 environment variable. */
5442 if (compare_debug == 2 || compare_debug == 3)
5443 {
5444 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
5445 save_switch (opt, 0, NULL, false, true);
5446 compare_debug = 1;
5447 }
5448
5449 /* Ensure we only invoke each subprocess once. */
5450 if (n_infiles == 0
5451 && (print_subprocess_help || print_help_list || print_version))
5452 {
5453 /* Create a dummy input file, so that we can pass
5454 the help option on to the various sub-processes. */
5455 add_infile ("help-dummy", "c");
5456 }
5457
5458 /* Decide if undefined variable references are allowed in specs. */
5459
5460 /* -v alone is safe. --version and --help alone or together are safe. Note
5461 that -v would make them unsafe, as they'd then be run for subprocesses as
5462 well, the location of which might depend on variables possibly coming
5463 from self-specs. Note also that the command name is counted in
5464 decoded_options_count. */
5465
5466 unsigned help_version_count = 0;
5467
5468 if (print_version)
5469 help_version_count++;
5470
5471 if (print_help_list)
5472 help_version_count++;
5473
5474 spec_undefvar_allowed =
5475 ((verbose_flag && decoded_options_count == 2)
5476 || help_version_count == decoded_options_count - 1);
5477
5478 alloc_switch ();
5479 switches[n_switches].part1 = 0;
5480 alloc_infile ();
5481 infiles[n_infiles].name = 0;
5482 }
5483
5484 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
5485 and place that in the environment. */
5486
5487 static void
5488 set_collect_gcc_options (void)
5489 {
5490 int i;
5491 int first_time;
5492
5493 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
5494 the compiler. */
5495 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
5496 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
5497
5498 first_time = TRUE;
5499 for (i = 0; (int) i < n_switches; i++)
5500 {
5501 const char *const *args;
5502 const char *p, *q;
5503 if (!first_time)
5504 obstack_grow (&collect_obstack, " ", 1);
5505
5506 first_time = FALSE;
5507
5508 /* Ignore elided switches. */
5509 if ((switches[i].live_cond
5510 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
5511 == SWITCH_IGNORE)
5512 continue;
5513
5514 obstack_grow (&collect_obstack, "'-", 2);
5515 q = switches[i].part1;
5516 while ((p = strchr (q, '\'')))
5517 {
5518 obstack_grow (&collect_obstack, q, p - q);
5519 obstack_grow (&collect_obstack, "'\\''", 4);
5520 q = ++p;
5521 }
5522 obstack_grow (&collect_obstack, q, strlen (q));
5523 obstack_grow (&collect_obstack, "'", 1);
5524
5525 for (args = switches[i].args; args && *args; args++)
5526 {
5527 obstack_grow (&collect_obstack, " '", 2);
5528 q = *args;
5529 while ((p = strchr (q, '\'')))
5530 {
5531 obstack_grow (&collect_obstack, q, p - q);
5532 obstack_grow (&collect_obstack, "'\\''", 4);
5533 q = ++p;
5534 }
5535 obstack_grow (&collect_obstack, q, strlen (q));
5536 obstack_grow (&collect_obstack, "'", 1);
5537 }
5538 }
5539
5540 if (dumpdir)
5541 {
5542 if (!first_time)
5543 obstack_grow (&collect_obstack, " ", 1);
5544 first_time = FALSE;
5545
5546 obstack_grow (&collect_obstack, "'-dumpdir' '", 12);
5547 const char *p, *q;
5548
5549 q = dumpdir;
5550 while ((p = strchr (q, '\'')))
5551 {
5552 obstack_grow (&collect_obstack, q, p - q);
5553 obstack_grow (&collect_obstack, "'\\''", 4);
5554 q = ++p;
5555 }
5556 obstack_grow (&collect_obstack, q, strlen (q));
5557
5558 obstack_grow (&collect_obstack, "'", 1);
5559 }
5560
5561 obstack_grow (&collect_obstack, "\0", 1);
5562 xputenv (XOBFINISH (&collect_obstack, char *));
5563 }
5564 \f
5565 /* Process a spec string, accumulating and running commands. */
5566
5567 /* These variables describe the input file name.
5568 input_file_number is the index on outfiles of this file,
5569 so that the output file name can be stored for later use by %o.
5570 input_basename is the start of the part of the input file
5571 sans all directory names, and basename_length is the number
5572 of characters starting there excluding the suffix .c or whatever. */
5573
5574 static const char *gcc_input_filename;
5575 static int input_file_number;
5576 size_t input_filename_length;
5577 static int basename_length;
5578 static int suffixed_basename_length;
5579 static const char *input_basename;
5580 static const char *input_suffix;
5581 #ifndef HOST_LACKS_INODE_NUMBERS
5582 static struct stat input_stat;
5583 #endif
5584 static int input_stat_set;
5585
5586 /* The compiler used to process the current input file. */
5587 static struct compiler *input_file_compiler;
5588
5589 /* These are variables used within do_spec and do_spec_1. */
5590
5591 /* Nonzero if an arg has been started and not yet terminated
5592 (with space, tab or newline). */
5593 static int arg_going;
5594
5595 /* Nonzero means %d or %g has been seen; the next arg to be terminated
5596 is a temporary file name. */
5597 static int delete_this_arg;
5598
5599 /* Nonzero means %w has been seen; the next arg to be terminated
5600 is the output file name of this compilation. */
5601 static int this_is_output_file;
5602
5603 /* Nonzero means %s has been seen; the next arg to be terminated
5604 is the name of a library file and we should try the standard
5605 search dirs for it. */
5606 static int this_is_library_file;
5607
5608 /* Nonzero means %T has been seen; the next arg to be terminated
5609 is the name of a linker script and we should try all of the
5610 standard search dirs for it. If it is found insert a --script
5611 command line switch and then substitute the full path in place,
5612 otherwise generate an error message. */
5613 static int this_is_linker_script;
5614
5615 /* Nonzero means that the input of this command is coming from a pipe. */
5616 static int input_from_pipe;
5617
5618 /* Nonnull means substitute this for any suffix when outputting a switches
5619 arguments. */
5620 static const char *suffix_subst;
5621
5622 /* If there is an argument being accumulated, terminate it and store it. */
5623
5624 static void
5625 end_going_arg (void)
5626 {
5627 if (arg_going)
5628 {
5629 const char *string;
5630
5631 obstack_1grow (&obstack, 0);
5632 string = XOBFINISH (&obstack, const char *);
5633 if (this_is_library_file)
5634 string = find_file (string);
5635 if (this_is_linker_script)
5636 {
5637 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
5638
5639 if (full_script_path == NULL)
5640 {
5641 error ("unable to locate default linker script %qs in the library search paths", string);
5642 /* Script was not found on search path. */
5643 return;
5644 }
5645 store_arg ("--script", false, false);
5646 string = full_script_path;
5647 }
5648 store_arg (string, delete_this_arg, this_is_output_file);
5649 if (this_is_output_file)
5650 outfiles[input_file_number] = string;
5651 arg_going = 0;
5652 }
5653 }
5654
5655
5656 /* Parse the WRAPPER string which is a comma separated list of the command line
5657 and insert them into the beginning of argbuf. */
5658
5659 static void
5660 insert_wrapper (const char *wrapper)
5661 {
5662 int n = 0;
5663 int i;
5664 char *buf = xstrdup (wrapper);
5665 char *p = buf;
5666 unsigned int old_length = argbuf.length ();
5667
5668 do
5669 {
5670 n++;
5671 while (*p == ',')
5672 p++;
5673 }
5674 while ((p = strchr (p, ',')) != NULL);
5675
5676 argbuf.safe_grow (old_length + n, true);
5677 memmove (argbuf.address () + n,
5678 argbuf.address (),
5679 old_length * sizeof (const_char_p));
5680
5681 i = 0;
5682 p = buf;
5683 do
5684 {
5685 while (*p == ',')
5686 {
5687 *p = 0;
5688 p++;
5689 }
5690 argbuf[i] = p;
5691 i++;
5692 }
5693 while ((p = strchr (p, ',')) != NULL);
5694 gcc_assert (i == n);
5695 }
5696
5697 /* Process the spec SPEC and run the commands specified therein.
5698 Returns 0 if the spec is successfully processed; -1 if failed. */
5699
5700 int
5701 do_spec (const char *spec)
5702 {
5703 int value;
5704
5705 value = do_spec_2 (spec, NULL);
5706
5707 /* Force out any unfinished command.
5708 If -pipe, this forces out the last command if it ended in `|'. */
5709 if (value == 0)
5710 {
5711 if (argbuf.length () > 0
5712 && !strcmp (argbuf.last (), "|"))
5713 argbuf.pop ();
5714
5715 set_collect_gcc_options ();
5716
5717 if (argbuf.length () > 0)
5718 value = execute ();
5719 }
5720
5721 return value;
5722 }
5723
5724 /* Process the spec SPEC, with SOFT_MATCHED_PART designating the current value
5725 of a matched * pattern which may be re-injected by way of %*. */
5726
5727 static int
5728 do_spec_2 (const char *spec, const char *soft_matched_part)
5729 {
5730 int result;
5731
5732 clear_args ();
5733 arg_going = 0;
5734 delete_this_arg = 0;
5735 this_is_output_file = 0;
5736 this_is_library_file = 0;
5737 this_is_linker_script = 0;
5738 input_from_pipe = 0;
5739 suffix_subst = NULL;
5740
5741 result = do_spec_1 (spec, 0, soft_matched_part);
5742
5743 end_going_arg ();
5744
5745 return result;
5746 }
5747
5748 /* Process the given spec string and add any new options to the end
5749 of the switches/n_switches array. */
5750
5751 static void
5752 do_option_spec (const char *name, const char *spec)
5753 {
5754 unsigned int i, value_count, value_len;
5755 const char *p, *q, *value;
5756 char *tmp_spec, *tmp_spec_p;
5757
5758 if (configure_default_options[0].name == NULL)
5759 return;
5760
5761 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
5762 if (strcmp (configure_default_options[i].name, name) == 0)
5763 break;
5764 if (i == ARRAY_SIZE (configure_default_options))
5765 return;
5766
5767 value = configure_default_options[i].value;
5768 value_len = strlen (value);
5769
5770 /* Compute the size of the final spec. */
5771 value_count = 0;
5772 p = spec;
5773 while ((p = strstr (p, "%(VALUE)")) != NULL)
5774 {
5775 p ++;
5776 value_count ++;
5777 }
5778
5779 /* Replace each %(VALUE) by the specified value. */
5780 tmp_spec = (char *) alloca (strlen (spec) + 1
5781 + value_count * (value_len - strlen ("%(VALUE)")));
5782 tmp_spec_p = tmp_spec;
5783 q = spec;
5784 while ((p = strstr (q, "%(VALUE)")) != NULL)
5785 {
5786 memcpy (tmp_spec_p, q, p - q);
5787 tmp_spec_p = tmp_spec_p + (p - q);
5788 memcpy (tmp_spec_p, value, value_len);
5789 tmp_spec_p += value_len;
5790 q = p + strlen ("%(VALUE)");
5791 }
5792 strcpy (tmp_spec_p, q);
5793
5794 do_self_spec (tmp_spec);
5795 }
5796
5797 /* Process the given spec string and add any new options to the end
5798 of the switches/n_switches array. */
5799
5800 static void
5801 do_self_spec (const char *spec)
5802 {
5803 int i;
5804
5805 do_spec_2 (spec, NULL);
5806 do_spec_1 (" ", 0, NULL);
5807
5808 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
5809 do_self_specs adds the replacements to switches array, so it shouldn't
5810 be processed afterwards. */
5811 for (i = 0; i < n_switches; i++)
5812 if ((switches[i].live_cond & SWITCH_IGNORE))
5813 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
5814
5815 if (argbuf.length () > 0)
5816 {
5817 const char **argbuf_copy;
5818 struct cl_decoded_option *decoded_options;
5819 struct cl_option_handlers handlers;
5820 unsigned int decoded_options_count;
5821 unsigned int j;
5822
5823 /* Create a copy of argbuf with a dummy argv[0] entry for
5824 decode_cmdline_options_to_array. */
5825 argbuf_copy = XNEWVEC (const char *,
5826 argbuf.length () + 1);
5827 argbuf_copy[0] = "";
5828 memcpy (argbuf_copy + 1, argbuf.address (),
5829 argbuf.length () * sizeof (const char *));
5830
5831 decode_cmdline_options_to_array (argbuf.length () + 1,
5832 argbuf_copy,
5833 CL_DRIVER, &decoded_options,
5834 &decoded_options_count);
5835 free (argbuf_copy);
5836
5837 set_option_handlers (&handlers);
5838
5839 for (j = 1; j < decoded_options_count; j++)
5840 {
5841 switch (decoded_options[j].opt_index)
5842 {
5843 case OPT_SPECIAL_input_file:
5844 /* Specs should only generate options, not input
5845 files. */
5846 if (strcmp (decoded_options[j].arg, "-") != 0)
5847 fatal_error (input_location,
5848 "switch %qs does not start with %<-%>",
5849 decoded_options[j].arg);
5850 else
5851 fatal_error (input_location,
5852 "spec-generated switch is just %<-%>");
5853 break;
5854
5855 case OPT_fcompare_debug_second:
5856 case OPT_fcompare_debug:
5857 case OPT_fcompare_debug_:
5858 case OPT_o:
5859 /* Avoid duplicate processing of some options from
5860 compare-debug specs; just save them here. */
5861 save_switch (decoded_options[j].canonical_option[0],
5862 (decoded_options[j].canonical_option_num_elements
5863 - 1),
5864 &decoded_options[j].canonical_option[1], false, true);
5865 break;
5866
5867 default:
5868 read_cmdline_option (&global_options, &global_options_set,
5869 decoded_options + j, UNKNOWN_LOCATION,
5870 CL_DRIVER, &handlers, global_dc);
5871 break;
5872 }
5873 }
5874
5875 free (decoded_options);
5876
5877 alloc_switch ();
5878 switches[n_switches].part1 = 0;
5879 }
5880 }
5881
5882 /* Callback for processing %D and %I specs. */
5883
5884 struct spec_path_info {
5885 const char *option;
5886 const char *append;
5887 size_t append_len;
5888 bool omit_relative;
5889 bool separate_options;
5890 };
5891
5892 static void *
5893 spec_path (char *path, void *data)
5894 {
5895 struct spec_path_info *info = (struct spec_path_info *) data;
5896 size_t len = 0;
5897 char save = 0;
5898
5899 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
5900 return NULL;
5901
5902 if (info->append_len != 0)
5903 {
5904 len = strlen (path);
5905 memcpy (path + len, info->append, info->append_len + 1);
5906 }
5907
5908 if (!is_directory (path, true))
5909 return NULL;
5910
5911 do_spec_1 (info->option, 1, NULL);
5912 if (info->separate_options)
5913 do_spec_1 (" ", 0, NULL);
5914
5915 if (info->append_len == 0)
5916 {
5917 len = strlen (path);
5918 save = path[len - 1];
5919 if (IS_DIR_SEPARATOR (path[len - 1]))
5920 path[len - 1] = '\0';
5921 }
5922
5923 do_spec_1 (path, 1, NULL);
5924 do_spec_1 (" ", 0, NULL);
5925
5926 /* Must not damage the original path. */
5927 if (info->append_len == 0)
5928 path[len - 1] = save;
5929
5930 return NULL;
5931 }
5932
5933 /* True if we should compile INFILE. */
5934
5935 static bool
5936 compile_input_file_p (struct infile *infile)
5937 {
5938 if ((!infile->language) || (infile->language[0] != '*'))
5939 if (infile->incompiler == input_file_compiler)
5940 return true;
5941 return false;
5942 }
5943
5944 /* Process each member of VEC as a spec. */
5945
5946 static void
5947 do_specs_vec (vec<char_p> vec)
5948 {
5949 for (char *opt : vec)
5950 {
5951 do_spec_1 (opt, 1, NULL);
5952 /* Make each accumulated option a separate argument. */
5953 do_spec_1 (" ", 0, NULL);
5954 }
5955 }
5956
5957 /* Add options passed via -Xassembler or -Wa to COLLECT_AS_OPTIONS. */
5958
5959 static void
5960 putenv_COLLECT_AS_OPTIONS (vec<char_p> vec)
5961 {
5962 if (vec.is_empty ())
5963 return;
5964
5965 obstack_init (&collect_obstack);
5966 obstack_grow (&collect_obstack, "COLLECT_AS_OPTIONS=",
5967 strlen ("COLLECT_AS_OPTIONS="));
5968
5969 char *opt;
5970 unsigned ix;
5971
5972 FOR_EACH_VEC_ELT (vec, ix, opt)
5973 {
5974 obstack_1grow (&collect_obstack, '\'');
5975 obstack_grow (&collect_obstack, opt, strlen (opt));
5976 obstack_1grow (&collect_obstack, '\'');
5977 if (ix < vec.length () - 1)
5978 obstack_1grow(&collect_obstack, ' ');
5979 }
5980
5981 obstack_1grow (&collect_obstack, '\0');
5982 xputenv (XOBFINISH (&collect_obstack, char *));
5983 }
5984
5985 /* Process the sub-spec SPEC as a portion of a larger spec.
5986 This is like processing a whole spec except that we do
5987 not initialize at the beginning and we do not supply a
5988 newline by default at the end.
5989 INSWITCH nonzero means don't process %-sequences in SPEC;
5990 in this case, % is treated as an ordinary character.
5991 This is used while substituting switches.
5992 INSWITCH nonzero also causes SPC not to terminate an argument.
5993
5994 Value is zero unless a line was finished
5995 and the command on that line reported an error. */
5996
5997 static int
5998 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
5999 {
6000 const char *p = spec;
6001 int c;
6002 int i;
6003 int value;
6004
6005 /* If it's an empty string argument to a switch, keep it as is. */
6006 if (inswitch && !*p)
6007 arg_going = 1;
6008
6009 while ((c = *p++))
6010 /* If substituting a switch, treat all chars like letters.
6011 Otherwise, NL, SPC, TAB and % are special. */
6012 switch (inswitch ? 'a' : c)
6013 {
6014 case '\n':
6015 end_going_arg ();
6016
6017 if (argbuf.length () > 0
6018 && !strcmp (argbuf.last (), "|"))
6019 {
6020 /* A `|' before the newline means use a pipe here,
6021 but only if -pipe was specified.
6022 Otherwise, execute now and don't pass the `|' as an arg. */
6023 if (use_pipes)
6024 {
6025 input_from_pipe = 1;
6026 break;
6027 }
6028 else
6029 argbuf.pop ();
6030 }
6031
6032 set_collect_gcc_options ();
6033
6034 if (argbuf.length () > 0)
6035 {
6036 value = execute ();
6037 if (value)
6038 return value;
6039 }
6040 /* Reinitialize for a new command, and for a new argument. */
6041 clear_args ();
6042 arg_going = 0;
6043 delete_this_arg = 0;
6044 this_is_output_file = 0;
6045 this_is_library_file = 0;
6046 this_is_linker_script = 0;
6047 input_from_pipe = 0;
6048 break;
6049
6050 case '|':
6051 end_going_arg ();
6052
6053 /* Use pipe */
6054 obstack_1grow (&obstack, c);
6055 arg_going = 1;
6056 break;
6057
6058 case '\t':
6059 case ' ':
6060 end_going_arg ();
6061
6062 /* Reinitialize for a new argument. */
6063 delete_this_arg = 0;
6064 this_is_output_file = 0;
6065 this_is_library_file = 0;
6066 this_is_linker_script = 0;
6067 break;
6068
6069 case '%':
6070 switch (c = *p++)
6071 {
6072 case 0:
6073 fatal_error (input_location, "spec %qs invalid", spec);
6074
6075 case 'b':
6076 /* Don't use %b in the linker command. */
6077 gcc_assert (suffixed_basename_length);
6078 if (!this_is_output_file && dumpdir_length)
6079 obstack_grow (&obstack, dumpdir, dumpdir_length);
6080 if (this_is_output_file || !outbase_length)
6081 obstack_grow (&obstack, input_basename, basename_length);
6082 else
6083 obstack_grow (&obstack, outbase, outbase_length);
6084 if (compare_debug < 0)
6085 obstack_grow (&obstack, ".gk", 3);
6086 arg_going = 1;
6087 break;
6088
6089 case 'B':
6090 /* Don't use %B in the linker command. */
6091 gcc_assert (suffixed_basename_length);
6092 if (!this_is_output_file && dumpdir_length)
6093 obstack_grow (&obstack, dumpdir, dumpdir_length);
6094 if (this_is_output_file || !outbase_length)
6095 obstack_grow (&obstack, input_basename, basename_length);
6096 else
6097 obstack_grow (&obstack, outbase, outbase_length);
6098 if (compare_debug < 0)
6099 obstack_grow (&obstack, ".gk", 3);
6100 obstack_grow (&obstack, input_basename + basename_length,
6101 suffixed_basename_length - basename_length);
6102
6103 arg_going = 1;
6104 break;
6105
6106 case 'd':
6107 delete_this_arg = 2;
6108 break;
6109
6110 /* Dump out the directories specified with LIBRARY_PATH,
6111 followed by the absolute directories
6112 that we search for startfiles. */
6113 case 'D':
6114 {
6115 struct spec_path_info info;
6116
6117 info.option = "-L";
6118 info.append_len = 0;
6119 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
6120 /* Used on systems which record the specified -L dirs
6121 and use them to search for dynamic linking.
6122 Relative directories always come from -B,
6123 and it is better not to use them for searching
6124 at run time. In particular, stage1 loses. */
6125 info.omit_relative = true;
6126 #else
6127 info.omit_relative = false;
6128 #endif
6129 info.separate_options = false;
6130
6131 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
6132 }
6133 break;
6134
6135 case 'e':
6136 /* %efoo means report an error with `foo' as error message
6137 and don't execute any more commands for this file. */
6138 {
6139 const char *q = p;
6140 char *buf;
6141 while (*p != 0 && *p != '\n')
6142 p++;
6143 buf = (char *) alloca (p - q + 1);
6144 strncpy (buf, q, p - q);
6145 buf[p - q] = 0;
6146 error ("%s", _(buf));
6147 return -1;
6148 }
6149 break;
6150 case 'n':
6151 /* %nfoo means report a notice with `foo' on stderr. */
6152 {
6153 const char *q = p;
6154 char *buf;
6155 while (*p != 0 && *p != '\n')
6156 p++;
6157 buf = (char *) alloca (p - q + 1);
6158 strncpy (buf, q, p - q);
6159 buf[p - q] = 0;
6160 inform (UNKNOWN_LOCATION, "%s", _(buf));
6161 if (*p)
6162 p++;
6163 }
6164 break;
6165
6166 case 'j':
6167 {
6168 struct stat st;
6169
6170 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
6171 defined, and it is not a directory, and it is
6172 writable, use it. Otherwise, treat this like any
6173 other temporary file. */
6174
6175 if ((!save_temps_flag)
6176 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
6177 && (access (HOST_BIT_BUCKET, W_OK) == 0))
6178 {
6179 obstack_grow (&obstack, HOST_BIT_BUCKET,
6180 strlen (HOST_BIT_BUCKET));
6181 delete_this_arg = 0;
6182 arg_going = 1;
6183 break;
6184 }
6185 }
6186 goto create_temp_file;
6187 case '|':
6188 if (use_pipes)
6189 {
6190 obstack_1grow (&obstack, '-');
6191 delete_this_arg = 0;
6192 arg_going = 1;
6193
6194 /* consume suffix */
6195 while (*p == '.' || ISALNUM ((unsigned char) *p))
6196 p++;
6197 if (p[0] == '%' && p[1] == 'O')
6198 p += 2;
6199
6200 break;
6201 }
6202 goto create_temp_file;
6203 case 'm':
6204 if (use_pipes)
6205 {
6206 /* consume suffix */
6207 while (*p == '.' || ISALNUM ((unsigned char) *p))
6208 p++;
6209 if (p[0] == '%' && p[1] == 'O')
6210 p += 2;
6211
6212 break;
6213 }
6214 goto create_temp_file;
6215 case 'g':
6216 case 'u':
6217 case 'U':
6218 create_temp_file:
6219 {
6220 struct temp_name *t;
6221 int suffix_length;
6222 const char *suffix = p;
6223 char *saved_suffix = NULL;
6224
6225 while (*p == '.' || ISALNUM ((unsigned char) *p))
6226 p++;
6227 suffix_length = p - suffix;
6228 if (p[0] == '%' && p[1] == 'O')
6229 {
6230 p += 2;
6231 /* We don't support extra suffix characters after %O. */
6232 if (*p == '.' || ISALNUM ((unsigned char) *p))
6233 fatal_error (input_location,
6234 "spec %qs has invalid %<%%0%c%>", spec, *p);
6235 if (suffix_length == 0)
6236 suffix = TARGET_OBJECT_SUFFIX;
6237 else
6238 {
6239 saved_suffix
6240 = XNEWVEC (char, suffix_length
6241 + strlen (TARGET_OBJECT_SUFFIX) + 1);
6242 strncpy (saved_suffix, suffix, suffix_length);
6243 strcpy (saved_suffix + suffix_length,
6244 TARGET_OBJECT_SUFFIX);
6245 }
6246 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
6247 }
6248
6249 if (compare_debug < 0)
6250 {
6251 suffix = concat (".gk", suffix, NULL);
6252 suffix_length += 3;
6253 }
6254
6255 /* If -save-temps was specified, use that for the
6256 temp file. */
6257 if (save_temps_flag)
6258 {
6259 char *tmp;
6260 bool adjusted_suffix = false;
6261 if (suffix_length
6262 && !outbase_length && !basename_length
6263 && !dumpdir_trailing_dash_added)
6264 {
6265 adjusted_suffix = true;
6266 suffix++;
6267 suffix_length--;
6268 }
6269 temp_filename_length
6270 = dumpdir_length + suffix_length + 1;
6271 if (outbase_length)
6272 temp_filename_length += outbase_length;
6273 else
6274 temp_filename_length += basename_length;
6275 tmp = (char *) alloca (temp_filename_length);
6276 if (dumpdir_length)
6277 memcpy (tmp, dumpdir, dumpdir_length);
6278 if (outbase_length)
6279 memcpy (tmp + dumpdir_length, outbase,
6280 outbase_length);
6281 else if (basename_length)
6282 memcpy (tmp + dumpdir_length, input_basename,
6283 basename_length);
6284 memcpy (tmp + temp_filename_length - suffix_length - 1,
6285 suffix, suffix_length);
6286 if (adjusted_suffix)
6287 {
6288 adjusted_suffix = false;
6289 suffix--;
6290 suffix_length++;
6291 }
6292 tmp[temp_filename_length - 1] = '\0';
6293 temp_filename = tmp;
6294
6295 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
6296 {
6297 #ifndef HOST_LACKS_INODE_NUMBERS
6298 struct stat st_temp;
6299
6300 /* Note, set_input() resets input_stat_set to 0. */
6301 if (input_stat_set == 0)
6302 {
6303 input_stat_set = stat (gcc_input_filename,
6304 &input_stat);
6305 if (input_stat_set >= 0)
6306 input_stat_set = 1;
6307 }
6308
6309 /* If we have the stat for the gcc_input_filename
6310 and we can do the stat for the temp_filename
6311 then the they could still refer to the same
6312 file if st_dev/st_ino's are the same. */
6313 if (input_stat_set != 1
6314 || stat (temp_filename, &st_temp) < 0
6315 || input_stat.st_dev != st_temp.st_dev
6316 || input_stat.st_ino != st_temp.st_ino)
6317 #else
6318 /* Just compare canonical pathnames. */
6319 char* input_realname = lrealpath (gcc_input_filename);
6320 char* temp_realname = lrealpath (temp_filename);
6321 bool files_differ = filename_cmp (input_realname, temp_realname);
6322 free (input_realname);
6323 free (temp_realname);
6324 if (files_differ)
6325 #endif
6326 {
6327 temp_filename
6328 = save_string (temp_filename,
6329 temp_filename_length - 1);
6330 obstack_grow (&obstack, temp_filename,
6331 temp_filename_length);
6332 arg_going = 1;
6333 delete_this_arg = 0;
6334 break;
6335 }
6336 }
6337 }
6338
6339 /* See if we already have an association of %g/%u/%U and
6340 suffix. */
6341 for (t = temp_names; t; t = t->next)
6342 if (t->length == suffix_length
6343 && strncmp (t->suffix, suffix, suffix_length) == 0
6344 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
6345 break;
6346
6347 /* Make a new association if needed. %u and %j
6348 require one. */
6349 if (t == 0 || c == 'u' || c == 'j')
6350 {
6351 if (t == 0)
6352 {
6353 t = XNEW (struct temp_name);
6354 t->next = temp_names;
6355 temp_names = t;
6356 }
6357 t->length = suffix_length;
6358 if (saved_suffix)
6359 {
6360 t->suffix = saved_suffix;
6361 saved_suffix = NULL;
6362 }
6363 else
6364 t->suffix = save_string (suffix, suffix_length);
6365 t->unique = (c == 'u' || c == 'U' || c == 'j');
6366 temp_filename = make_temp_file (t->suffix);
6367 temp_filename_length = strlen (temp_filename);
6368 t->filename = temp_filename;
6369 t->filename_length = temp_filename_length;
6370 }
6371
6372 free (saved_suffix);
6373
6374 obstack_grow (&obstack, t->filename, t->filename_length);
6375 delete_this_arg = 1;
6376 }
6377 arg_going = 1;
6378 break;
6379
6380 case 'i':
6381 if (combine_inputs)
6382 {
6383 /* We are going to expand `%i' into `@FILE', where FILE
6384 is a newly-created temporary filename. The filenames
6385 that would usually be expanded in place of %o will be
6386 written to the temporary file. */
6387 if (at_file_supplied)
6388 open_at_file ();
6389
6390 for (i = 0; (int) i < n_infiles; i++)
6391 if (compile_input_file_p (&infiles[i]))
6392 {
6393 store_arg (infiles[i].name, 0, 0);
6394 infiles[i].compiled = true;
6395 }
6396
6397 if (at_file_supplied)
6398 close_at_file ();
6399 }
6400 else
6401 {
6402 obstack_grow (&obstack, gcc_input_filename,
6403 input_filename_length);
6404 arg_going = 1;
6405 }
6406 break;
6407
6408 case 'I':
6409 {
6410 struct spec_path_info info;
6411
6412 if (multilib_dir)
6413 {
6414 do_spec_1 ("-imultilib", 1, NULL);
6415 /* Make this a separate argument. */
6416 do_spec_1 (" ", 0, NULL);
6417 do_spec_1 (multilib_dir, 1, NULL);
6418 do_spec_1 (" ", 0, NULL);
6419 }
6420
6421 if (multiarch_dir)
6422 {
6423 do_spec_1 ("-imultiarch", 1, NULL);
6424 /* Make this a separate argument. */
6425 do_spec_1 (" ", 0, NULL);
6426 do_spec_1 (multiarch_dir, 1, NULL);
6427 do_spec_1 (" ", 0, NULL);
6428 }
6429
6430 if (gcc_exec_prefix)
6431 {
6432 do_spec_1 ("-iprefix", 1, NULL);
6433 /* Make this a separate argument. */
6434 do_spec_1 (" ", 0, NULL);
6435 do_spec_1 (gcc_exec_prefix, 1, NULL);
6436 do_spec_1 (" ", 0, NULL);
6437 }
6438
6439 if (target_system_root_changed ||
6440 (target_system_root && target_sysroot_hdrs_suffix))
6441 {
6442 do_spec_1 ("-isysroot", 1, NULL);
6443 /* Make this a separate argument. */
6444 do_spec_1 (" ", 0, NULL);
6445 do_spec_1 (target_system_root, 1, NULL);
6446 if (target_sysroot_hdrs_suffix)
6447 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
6448 do_spec_1 (" ", 0, NULL);
6449 }
6450
6451 info.option = "-isystem";
6452 info.append = "include";
6453 info.append_len = strlen (info.append);
6454 info.omit_relative = false;
6455 info.separate_options = true;
6456
6457 for_each_path (&include_prefixes, false, info.append_len,
6458 spec_path, &info);
6459
6460 info.append = "include-fixed";
6461 if (*sysroot_hdrs_suffix_spec)
6462 info.append = concat (info.append, dir_separator_str,
6463 multilib_dir, NULL);
6464 info.append_len = strlen (info.append);
6465 for_each_path (&include_prefixes, false, info.append_len,
6466 spec_path, &info);
6467 }
6468 break;
6469
6470 case 'o':
6471 /* We are going to expand `%o' into `@FILE', where FILE
6472 is a newly-created temporary filename. The filenames
6473 that would usually be expanded in place of %o will be
6474 written to the temporary file. */
6475 if (at_file_supplied)
6476 open_at_file ();
6477
6478 for (i = 0; i < n_infiles + lang_specific_extra_outfiles; i++)
6479 if (outfiles[i])
6480 store_arg (outfiles[i], 0, 0);
6481
6482 if (at_file_supplied)
6483 close_at_file ();
6484 break;
6485
6486 case 'O':
6487 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
6488 arg_going = 1;
6489 break;
6490
6491 case 's':
6492 this_is_library_file = 1;
6493 break;
6494
6495 case 'T':
6496 this_is_linker_script = 1;
6497 break;
6498
6499 case 'V':
6500 outfiles[input_file_number] = NULL;
6501 break;
6502
6503 case 'w':
6504 this_is_output_file = 1;
6505 break;
6506
6507 case 'W':
6508 {
6509 unsigned int cur_index = argbuf.length ();
6510 /* Handle the {...} following the %W. */
6511 if (*p != '{')
6512 fatal_error (input_location,
6513 "spec %qs has invalid %<%%W%c%>", spec, *p);
6514 p = handle_braces (p + 1);
6515 if (p == 0)
6516 return -1;
6517 end_going_arg ();
6518 /* If any args were output, mark the last one for deletion
6519 on failure. */
6520 if (argbuf.length () != cur_index)
6521 record_temp_file (argbuf.last (), 0, 1);
6522 break;
6523 }
6524
6525 case '@':
6526 /* Handle the {...} following the %@. */
6527 if (*p != '{')
6528 fatal_error (input_location,
6529 "spec %qs has invalid %<%%@%c%>", spec, *p);
6530 if (at_file_supplied)
6531 open_at_file ();
6532 p = handle_braces (p + 1);
6533 if (at_file_supplied)
6534 close_at_file ();
6535 if (p == 0)
6536 return -1;
6537 break;
6538
6539 /* %x{OPTION} records OPTION for %X to output. */
6540 case 'x':
6541 {
6542 const char *p1 = p;
6543 char *string;
6544
6545 /* Skip past the option value and make a copy. */
6546 if (*p != '{')
6547 fatal_error (input_location,
6548 "spec %qs has invalid %<%%x%c%>", spec, *p);
6549 while (*p++ != '}')
6550 ;
6551 string = save_string (p1 + 1, p - p1 - 2);
6552
6553 /* See if we already recorded this option. */
6554 for (const char *opt : linker_options)
6555 if (! strcmp (string, opt))
6556 {
6557 free (string);
6558 return 0;
6559 }
6560
6561 /* This option is new; add it. */
6562 add_linker_option (string, strlen (string));
6563 free (string);
6564 }
6565 break;
6566
6567 /* Dump out the options accumulated previously using %x. */
6568 case 'X':
6569 do_specs_vec (linker_options);
6570 break;
6571
6572 /* Dump out the options accumulated previously using -Wa,. */
6573 case 'Y':
6574 do_specs_vec (assembler_options);
6575 break;
6576
6577 /* Dump out the options accumulated previously using -Wp,. */
6578 case 'Z':
6579 do_specs_vec (preprocessor_options);
6580 break;
6581
6582 /* Here are digits and numbers that just process
6583 a certain constant string as a spec. */
6584
6585 case '1':
6586 value = do_spec_1 (cc1_spec, 0, NULL);
6587 if (value != 0)
6588 return value;
6589 break;
6590
6591 case '2':
6592 value = do_spec_1 (cc1plus_spec, 0, NULL);
6593 if (value != 0)
6594 return value;
6595 break;
6596
6597 case 'a':
6598 value = do_spec_1 (asm_spec, 0, NULL);
6599 if (value != 0)
6600 return value;
6601 break;
6602
6603 case 'A':
6604 value = do_spec_1 (asm_final_spec, 0, NULL);
6605 if (value != 0)
6606 return value;
6607 break;
6608
6609 case 'C':
6610 {
6611 const char *const spec
6612 = (input_file_compiler->cpp_spec
6613 ? input_file_compiler->cpp_spec
6614 : cpp_spec);
6615 value = do_spec_1 (spec, 0, NULL);
6616 if (value != 0)
6617 return value;
6618 }
6619 break;
6620
6621 case 'E':
6622 value = do_spec_1 (endfile_spec, 0, NULL);
6623 if (value != 0)
6624 return value;
6625 break;
6626
6627 case 'l':
6628 value = do_spec_1 (link_spec, 0, NULL);
6629 if (value != 0)
6630 return value;
6631 break;
6632
6633 case 'L':
6634 value = do_spec_1 (lib_spec, 0, NULL);
6635 if (value != 0)
6636 return value;
6637 break;
6638
6639 case 'M':
6640 if (multilib_os_dir == NULL)
6641 obstack_1grow (&obstack, '.');
6642 else
6643 obstack_grow (&obstack, multilib_os_dir,
6644 strlen (multilib_os_dir));
6645 break;
6646
6647 case 'G':
6648 value = do_spec_1 (libgcc_spec, 0, NULL);
6649 if (value != 0)
6650 return value;
6651 break;
6652
6653 case 'R':
6654 /* We assume there is a directory
6655 separator at the end of this string. */
6656 if (target_system_root)
6657 {
6658 obstack_grow (&obstack, target_system_root,
6659 strlen (target_system_root));
6660 if (target_sysroot_suffix)
6661 obstack_grow (&obstack, target_sysroot_suffix,
6662 strlen (target_sysroot_suffix));
6663 }
6664 break;
6665
6666 case 'S':
6667 value = do_spec_1 (startfile_spec, 0, NULL);
6668 if (value != 0)
6669 return value;
6670 break;
6671
6672 /* Here we define characters other than letters and digits. */
6673
6674 case '{':
6675 p = handle_braces (p);
6676 if (p == 0)
6677 return -1;
6678 break;
6679
6680 case ':':
6681 p = handle_spec_function (p, NULL, soft_matched_part);
6682 if (p == 0)
6683 return -1;
6684 break;
6685
6686 case '%':
6687 obstack_1grow (&obstack, '%');
6688 break;
6689
6690 case '.':
6691 {
6692 unsigned len = 0;
6693
6694 while (p[len] && p[len] != ' ' && p[len] != '%')
6695 len++;
6696 suffix_subst = save_string (p - 1, len + 1);
6697 p += len;
6698 }
6699 break;
6700
6701 /* Henceforth ignore the option(s) matching the pattern
6702 after the %<. */
6703 case '<':
6704 case '>':
6705 {
6706 unsigned len = 0;
6707 int have_wildcard = 0;
6708 int i;
6709 int switch_option;
6710
6711 if (c == '>')
6712 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
6713 else
6714 switch_option = SWITCH_IGNORE;
6715
6716 while (p[len] && p[len] != ' ' && p[len] != '\t')
6717 len++;
6718
6719 if (p[len-1] == '*')
6720 have_wildcard = 1;
6721
6722 for (i = 0; i < n_switches; i++)
6723 if (!strncmp (switches[i].part1, p, len - have_wildcard)
6724 && (have_wildcard || switches[i].part1[len] == '\0'))
6725 {
6726 switches[i].live_cond |= switch_option;
6727 /* User switch be validated from validate_all_switches.
6728 when the definition is seen from the spec file.
6729 If not defined anywhere, will be rejected. */
6730 if (switches[i].known)
6731 switches[i].validated = true;
6732 }
6733
6734 p += len;
6735 }
6736 break;
6737
6738 case '*':
6739 if (soft_matched_part)
6740 {
6741 if (soft_matched_part[0])
6742 do_spec_1 (soft_matched_part, 1, NULL);
6743 /* Only insert a space after the substitution if it is at the
6744 end of the current sequence. So if:
6745
6746 "%{foo=*:bar%*}%{foo=*:one%*two}"
6747
6748 matches -foo=hello then it will produce:
6749
6750 barhello onehellotwo
6751 */
6752 if (*p == 0 || *p == '}')
6753 do_spec_1 (" ", 0, NULL);
6754 }
6755 else
6756 /* Catch the case where a spec string contains something like
6757 '%{foo:%*}'. i.e. there is no * in the pattern on the left
6758 hand side of the :. */
6759 error ("spec failure: %<%%*%> has not been initialized by pattern match");
6760 break;
6761
6762 /* Process a string found as the value of a spec given by name.
6763 This feature allows individual machine descriptions
6764 to add and use their own specs. */
6765 case '(':
6766 {
6767 const char *name = p;
6768 struct spec_list *sl;
6769 int len;
6770
6771 /* The string after the S/P is the name of a spec that is to be
6772 processed. */
6773 while (*p && *p != ')')
6774 p++;
6775
6776 /* See if it's in the list. */
6777 for (len = p - name, sl = specs; sl; sl = sl->next)
6778 if (sl->name_len == len && !strncmp (sl->name, name, len))
6779 {
6780 name = *(sl->ptr_spec);
6781 #ifdef DEBUG_SPECS
6782 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
6783 sl->name, name);
6784 #endif
6785 break;
6786 }
6787
6788 if (sl)
6789 {
6790 value = do_spec_1 (name, 0, NULL);
6791 if (value != 0)
6792 return value;
6793 }
6794
6795 /* Discard the closing paren. */
6796 if (*p)
6797 p++;
6798 }
6799 break;
6800
6801 case '"':
6802 /* End a previous argument, if there is one, then issue an
6803 empty argument. */
6804 end_going_arg ();
6805 arg_going = 1;
6806 end_going_arg ();
6807 break;
6808
6809 default:
6810 error ("spec failure: unrecognized spec option %qc", c);
6811 break;
6812 }
6813 break;
6814
6815 case '\\':
6816 /* Backslash: treat next character as ordinary. */
6817 c = *p++;
6818
6819 /* When adding more cases that previously matched default, make
6820 sure to adjust quote_spec_char_p as well. */
6821
6822 /* Fall through. */
6823 default:
6824 /* Ordinary character: put it into the current argument. */
6825 obstack_1grow (&obstack, c);
6826 arg_going = 1;
6827 }
6828
6829 /* End of string. If we are processing a spec function, we need to
6830 end any pending argument. */
6831 if (processing_spec_function)
6832 end_going_arg ();
6833
6834 return 0;
6835 }
6836
6837 /* Look up a spec function. */
6838
6839 static const struct spec_function *
6840 lookup_spec_function (const char *name)
6841 {
6842 const struct spec_function *sf;
6843
6844 for (sf = static_spec_functions; sf->name != NULL; sf++)
6845 if (strcmp (sf->name, name) == 0)
6846 return sf;
6847
6848 return NULL;
6849 }
6850
6851 /* Evaluate a spec function. */
6852
6853 static const char *
6854 eval_spec_function (const char *func, const char *args,
6855 const char *soft_matched_part)
6856 {
6857 const struct spec_function *sf;
6858 const char *funcval;
6859
6860 /* Saved spec processing context. */
6861 vec<const_char_p> save_argbuf;
6862
6863 int save_arg_going;
6864 int save_delete_this_arg;
6865 int save_this_is_output_file;
6866 int save_this_is_library_file;
6867 int save_input_from_pipe;
6868 int save_this_is_linker_script;
6869 const char *save_suffix_subst;
6870
6871 int save_growing_size;
6872 void *save_growing_value = NULL;
6873
6874 sf = lookup_spec_function (func);
6875 if (sf == NULL)
6876 fatal_error (input_location, "unknown spec function %qs", func);
6877
6878 /* Push the spec processing context. */
6879 save_argbuf = argbuf;
6880
6881 save_arg_going = arg_going;
6882 save_delete_this_arg = delete_this_arg;
6883 save_this_is_output_file = this_is_output_file;
6884 save_this_is_library_file = this_is_library_file;
6885 save_this_is_linker_script = this_is_linker_script;
6886 save_input_from_pipe = input_from_pipe;
6887 save_suffix_subst = suffix_subst;
6888
6889 /* If we have some object growing now, finalize it so the args and function
6890 eval proceed from a cleared context. This is needed to prevent the first
6891 constructed arg from mistakenly including the growing value. We'll push
6892 this value back on the obstack once the function evaluation is done, to
6893 restore a consistent processing context for our caller. This is fine as
6894 the address of growing objects isn't guaranteed to remain stable until
6895 they are finalized, and we expect this situation to be rare enough for
6896 the extra copy not to be an issue. */
6897 save_growing_size = obstack_object_size (&obstack);
6898 if (save_growing_size > 0)
6899 save_growing_value = obstack_finish (&obstack);
6900
6901 /* Create a new spec processing context, and build the function
6902 arguments. */
6903
6904 alloc_args ();
6905 if (do_spec_2 (args, soft_matched_part) < 0)
6906 fatal_error (input_location, "error in arguments to spec function %qs",
6907 func);
6908
6909 /* argbuf_index is an index for the next argument to be inserted, and
6910 so contains the count of the args already inserted. */
6911
6912 funcval = (*sf->func) (argbuf.length (),
6913 argbuf.address ());
6914
6915 /* Pop the spec processing context. */
6916 argbuf.release ();
6917 argbuf = save_argbuf;
6918
6919 arg_going = save_arg_going;
6920 delete_this_arg = save_delete_this_arg;
6921 this_is_output_file = save_this_is_output_file;
6922 this_is_library_file = save_this_is_library_file;
6923 this_is_linker_script = save_this_is_linker_script;
6924 input_from_pipe = save_input_from_pipe;
6925 suffix_subst = save_suffix_subst;
6926
6927 if (save_growing_size > 0)
6928 obstack_grow (&obstack, save_growing_value, save_growing_size);
6929
6930 return funcval;
6931 }
6932
6933 /* Handle a spec function call of the form:
6934
6935 %:function(args)
6936
6937 ARGS is processed as a spec in a separate context and split into an
6938 argument vector in the normal fashion. The function returns a string
6939 containing a spec which we then process in the caller's context, or
6940 NULL if no processing is required.
6941
6942 If RETVAL_NONNULL is not NULL, then store a bool whether function
6943 returned non-NULL.
6944
6945 SOFT_MATCHED_PART holds the current value of a matched * pattern, which
6946 may be re-expanded with a %* as part of the function arguments. */
6947
6948 static const char *
6949 handle_spec_function (const char *p, bool *retval_nonnull,
6950 const char *soft_matched_part)
6951 {
6952 char *func, *args;
6953 const char *endp, *funcval;
6954 int count;
6955
6956 processing_spec_function++;
6957
6958 /* Get the function name. */
6959 for (endp = p; *endp != '\0'; endp++)
6960 {
6961 if (*endp == '(') /* ) */
6962 break;
6963 /* Only allow [A-Za-z0-9], -, and _ in function names. */
6964 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
6965 fatal_error (input_location, "malformed spec function name");
6966 }
6967 if (*endp != '(') /* ) */
6968 fatal_error (input_location, "no arguments for spec function");
6969 func = save_string (p, endp - p);
6970 p = ++endp;
6971
6972 /* Get the arguments. */
6973 for (count = 0; *endp != '\0'; endp++)
6974 {
6975 /* ( */
6976 if (*endp == ')')
6977 {
6978 if (count == 0)
6979 break;
6980 count--;
6981 }
6982 else if (*endp == '(') /* ) */
6983 count++;
6984 }
6985 /* ( */
6986 if (*endp != ')')
6987 fatal_error (input_location, "malformed spec function arguments");
6988 args = save_string (p, endp - p);
6989 p = ++endp;
6990
6991 /* p now points to just past the end of the spec function expression. */
6992
6993 funcval = eval_spec_function (func, args, soft_matched_part);
6994 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
6995 p = NULL;
6996 if (retval_nonnull)
6997 *retval_nonnull = funcval != NULL;
6998
6999 free (func);
7000 free (args);
7001
7002 processing_spec_function--;
7003
7004 return p;
7005 }
7006
7007 /* Inline subroutine of handle_braces. Returns true if the current
7008 input suffix matches the atom bracketed by ATOM and END_ATOM. */
7009 static inline bool
7010 input_suffix_matches (const char *atom, const char *end_atom)
7011 {
7012 return (input_suffix
7013 && !strncmp (input_suffix, atom, end_atom - atom)
7014 && input_suffix[end_atom - atom] == '\0');
7015 }
7016
7017 /* Subroutine of handle_braces. Returns true if the current
7018 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
7019 static bool
7020 input_spec_matches (const char *atom, const char *end_atom)
7021 {
7022 return (input_file_compiler
7023 && input_file_compiler->suffix
7024 && input_file_compiler->suffix[0] != '\0'
7025 && !strncmp (input_file_compiler->suffix + 1, atom,
7026 end_atom - atom)
7027 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
7028 }
7029
7030 /* Subroutine of handle_braces. Returns true if a switch
7031 matching the atom bracketed by ATOM and END_ATOM appeared on the
7032 command line. */
7033 static bool
7034 switch_matches (const char *atom, const char *end_atom, int starred)
7035 {
7036 int i;
7037 int len = end_atom - atom;
7038 int plen = starred ? len : -1;
7039
7040 for (i = 0; i < n_switches; i++)
7041 if (!strncmp (switches[i].part1, atom, len)
7042 && (starred || switches[i].part1[len] == '\0')
7043 && check_live_switch (i, plen))
7044 return true;
7045
7046 /* Check if a switch with separated form matching the atom.
7047 We check -D and -U switches. */
7048 else if (switches[i].args != 0)
7049 {
7050 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
7051 && *switches[i].part1 == atom[0])
7052 {
7053 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
7054 && (starred || (switches[i].part1[1] == '\0'
7055 && switches[i].args[0][len - 1] == '\0'))
7056 && check_live_switch (i, (starred ? 1 : -1)))
7057 return true;
7058 }
7059 }
7060
7061 return false;
7062 }
7063
7064 /* Inline subroutine of handle_braces. Mark all of the switches which
7065 match ATOM (extends to END_ATOM; STARRED indicates whether there
7066 was a star after the atom) for later processing. */
7067 static inline void
7068 mark_matching_switches (const char *atom, const char *end_atom, int starred)
7069 {
7070 int i;
7071 int len = end_atom - atom;
7072 int plen = starred ? len : -1;
7073
7074 for (i = 0; i < n_switches; i++)
7075 if (!strncmp (switches[i].part1, atom, len)
7076 && (starred || switches[i].part1[len] == '\0')
7077 && check_live_switch (i, plen))
7078 switches[i].ordering = 1;
7079 }
7080
7081 /* Inline subroutine of handle_braces. Process all the currently
7082 marked switches through give_switch, and clear the marks. */
7083 static inline void
7084 process_marked_switches (void)
7085 {
7086 int i;
7087
7088 for (i = 0; i < n_switches; i++)
7089 if (switches[i].ordering == 1)
7090 {
7091 switches[i].ordering = 0;
7092 give_switch (i, 0);
7093 }
7094 }
7095
7096 /* Handle a %{ ... } construct. P points just inside the leading {.
7097 Returns a pointer one past the end of the brace block, or 0
7098 if we call do_spec_1 and that returns -1. */
7099
7100 static const char *
7101 handle_braces (const char *p)
7102 {
7103 const char *atom, *end_atom;
7104 const char *d_atom = NULL, *d_end_atom = NULL;
7105 char *esc_buf = NULL, *d_esc_buf = NULL;
7106 int esc;
7107 const char *orig = p;
7108
7109 bool a_is_suffix;
7110 bool a_is_spectype;
7111 bool a_is_starred;
7112 bool a_is_negated;
7113 bool a_matched;
7114
7115 bool a_must_be_last = false;
7116 bool ordered_set = false;
7117 bool disjunct_set = false;
7118 bool disj_matched = false;
7119 bool disj_starred = true;
7120 bool n_way_choice = false;
7121 bool n_way_matched = false;
7122
7123 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
7124
7125 do
7126 {
7127 if (a_must_be_last)
7128 goto invalid;
7129
7130 /* Scan one "atom" (S in the description above of %{}, possibly
7131 with '!', '.', '@', ',', or '*' modifiers). */
7132 a_matched = false;
7133 a_is_suffix = false;
7134 a_is_starred = false;
7135 a_is_negated = false;
7136 a_is_spectype = false;
7137
7138 SKIP_WHITE ();
7139 if (*p == '!')
7140 p++, a_is_negated = true;
7141
7142 SKIP_WHITE ();
7143 if (*p == '%' && p[1] == ':')
7144 {
7145 atom = NULL;
7146 end_atom = NULL;
7147 p = handle_spec_function (p + 2, &a_matched, NULL);
7148 }
7149 else
7150 {
7151 if (*p == '.')
7152 p++, a_is_suffix = true;
7153 else if (*p == ',')
7154 p++, a_is_spectype = true;
7155
7156 atom = p;
7157 esc = 0;
7158 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
7159 || *p == ',' || *p == '.' || *p == '@' || *p == '\\')
7160 {
7161 if (*p == '\\')
7162 {
7163 p++;
7164 if (!*p)
7165 fatal_error (input_location,
7166 "braced spec %qs ends in escape", orig);
7167 esc++;
7168 }
7169 p++;
7170 }
7171 end_atom = p;
7172
7173 if (esc)
7174 {
7175 const char *ap;
7176 char *ep;
7177
7178 if (esc_buf && esc_buf != d_esc_buf)
7179 free (esc_buf);
7180 esc_buf = NULL;
7181 ep = esc_buf = (char *) xmalloc (end_atom - atom - esc + 1);
7182 for (ap = atom; ap != end_atom; ap++, ep++)
7183 {
7184 if (*ap == '\\')
7185 ap++;
7186 *ep = *ap;
7187 }
7188 *ep = '\0';
7189 atom = esc_buf;
7190 end_atom = ep;
7191 }
7192
7193 if (*p == '*')
7194 p++, a_is_starred = 1;
7195 }
7196
7197 SKIP_WHITE ();
7198 switch (*p)
7199 {
7200 case '&': case '}':
7201 /* Substitute the switch(es) indicated by the current atom. */
7202 ordered_set = true;
7203 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
7204 || a_is_spectype || atom == end_atom)
7205 goto invalid;
7206
7207 mark_matching_switches (atom, end_atom, a_is_starred);
7208
7209 if (*p == '}')
7210 process_marked_switches ();
7211 break;
7212
7213 case '|': case ':':
7214 /* Substitute some text if the current atom appears as a switch
7215 or suffix. */
7216 disjunct_set = true;
7217 if (ordered_set)
7218 goto invalid;
7219
7220 if (atom && atom == end_atom)
7221 {
7222 if (!n_way_choice || disj_matched || *p == '|'
7223 || a_is_negated || a_is_suffix || a_is_spectype
7224 || a_is_starred)
7225 goto invalid;
7226
7227 /* An empty term may appear as the last choice of an
7228 N-way choice set; it means "otherwise". */
7229 a_must_be_last = true;
7230 disj_matched = !n_way_matched;
7231 disj_starred = false;
7232 }
7233 else
7234 {
7235 if ((a_is_suffix || a_is_spectype) && a_is_starred)
7236 goto invalid;
7237
7238 if (!a_is_starred)
7239 disj_starred = false;
7240
7241 /* Don't bother testing this atom if we already have a
7242 match. */
7243 if (!disj_matched && !n_way_matched)
7244 {
7245 if (atom == NULL)
7246 /* a_matched is already set by handle_spec_function. */;
7247 else if (a_is_suffix)
7248 a_matched = input_suffix_matches (atom, end_atom);
7249 else if (a_is_spectype)
7250 a_matched = input_spec_matches (atom, end_atom);
7251 else
7252 a_matched = switch_matches (atom, end_atom, a_is_starred);
7253
7254 if (a_matched != a_is_negated)
7255 {
7256 disj_matched = true;
7257 d_atom = atom;
7258 d_end_atom = end_atom;
7259 d_esc_buf = esc_buf;
7260 }
7261 }
7262 }
7263
7264 if (*p == ':')
7265 {
7266 /* Found the body, that is, the text to substitute if the
7267 current disjunction matches. */
7268 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
7269 disj_matched && !n_way_matched);
7270 if (p == 0)
7271 goto done;
7272
7273 /* If we have an N-way choice, reset state for the next
7274 disjunction. */
7275 if (*p == ';')
7276 {
7277 n_way_choice = true;
7278 n_way_matched |= disj_matched;
7279 disj_matched = false;
7280 disj_starred = true;
7281 d_atom = d_end_atom = NULL;
7282 }
7283 }
7284 break;
7285
7286 default:
7287 goto invalid;
7288 }
7289 }
7290 while (*p++ != '}');
7291
7292 done:
7293 if (d_esc_buf && d_esc_buf != esc_buf)
7294 free (d_esc_buf);
7295 if (esc_buf)
7296 free (esc_buf);
7297
7298 return p;
7299
7300 invalid:
7301 fatal_error (input_location, "braced spec %qs is invalid at %qc", orig, *p);
7302
7303 #undef SKIP_WHITE
7304 }
7305
7306 /* Subroutine of handle_braces. Scan and process a brace substitution body
7307 (X in the description of %{} syntax). P points one past the colon;
7308 ATOM and END_ATOM bracket the first atom which was found to be true
7309 (present) in the current disjunction; STARRED indicates whether all
7310 the atoms in the current disjunction were starred (for syntax validation);
7311 MATCHED indicates whether the disjunction matched or not, and therefore
7312 whether or not the body is to be processed through do_spec_1 or just
7313 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
7314 returns -1. */
7315
7316 static const char *
7317 process_brace_body (const char *p, const char *atom, const char *end_atom,
7318 int starred, int matched)
7319 {
7320 const char *body, *end_body;
7321 unsigned int nesting_level;
7322 bool have_subst = false;
7323
7324 /* Locate the closing } or ;, honoring nested braces.
7325 Trim trailing whitespace. */
7326 body = p;
7327 nesting_level = 1;
7328 for (;;)
7329 {
7330 if (*p == '{')
7331 nesting_level++;
7332 else if (*p == '}')
7333 {
7334 if (!--nesting_level)
7335 break;
7336 }
7337 else if (*p == ';' && nesting_level == 1)
7338 break;
7339 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
7340 have_subst = true;
7341 else if (*p == '\0')
7342 goto invalid;
7343 p++;
7344 }
7345
7346 end_body = p;
7347 while (end_body[-1] == ' ' || end_body[-1] == '\t')
7348 end_body--;
7349
7350 if (have_subst && !starred)
7351 goto invalid;
7352
7353 if (matched)
7354 {
7355 /* Copy the substitution body to permanent storage and execute it.
7356 If have_subst is false, this is a simple matter of running the
7357 body through do_spec_1... */
7358 char *string = save_string (body, end_body - body);
7359 if (!have_subst)
7360 {
7361 if (do_spec_1 (string, 0, NULL) < 0)
7362 {
7363 free (string);
7364 return 0;
7365 }
7366 }
7367 else
7368 {
7369 /* ... but if have_subst is true, we have to process the
7370 body once for each matching switch, with %* set to the
7371 variant part of the switch. */
7372 unsigned int hard_match_len = end_atom - atom;
7373 int i;
7374
7375 for (i = 0; i < n_switches; i++)
7376 if (!strncmp (switches[i].part1, atom, hard_match_len)
7377 && check_live_switch (i, hard_match_len))
7378 {
7379 if (do_spec_1 (string, 0,
7380 &switches[i].part1[hard_match_len]) < 0)
7381 {
7382 free (string);
7383 return 0;
7384 }
7385 /* Pass any arguments this switch has. */
7386 give_switch (i, 1);
7387 suffix_subst = NULL;
7388 }
7389 }
7390 free (string);
7391 }
7392
7393 return p;
7394
7395 invalid:
7396 fatal_error (input_location, "braced spec body %qs is invalid", body);
7397 }
7398 \f
7399 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
7400 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
7401 spec, or -1 if either exact match or %* is used.
7402
7403 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
7404 whose value does not begin with "no-" is obsoleted by the same value
7405 with the "no-", similarly for a switch with the "no-" prefix. */
7406
7407 static int
7408 check_live_switch (int switchnum, int prefix_length)
7409 {
7410 const char *name = switches[switchnum].part1;
7411 int i;
7412
7413 /* If we already processed this switch and determined if it was
7414 live or not, return our past determination. */
7415 if (switches[switchnum].live_cond != 0)
7416 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
7417 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
7418 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
7419 == 0);
7420
7421 /* In the common case of {<at-most-one-letter>*}, a negating
7422 switch would always match, so ignore that case. We will just
7423 send the conflicting switches to the compiler phase. */
7424 if (prefix_length >= 0 && prefix_length <= 1)
7425 return 1;
7426
7427 /* Now search for duplicate in a manner that depends on the name. */
7428 switch (*name)
7429 {
7430 case 'O':
7431 for (i = switchnum + 1; i < n_switches; i++)
7432 if (switches[i].part1[0] == 'O')
7433 {
7434 switches[switchnum].validated = true;
7435 switches[switchnum].live_cond = SWITCH_FALSE;
7436 return 0;
7437 }
7438 break;
7439
7440 case 'W': case 'f': case 'm': case 'g':
7441 if (startswith (name + 1, "no-"))
7442 {
7443 /* We have Xno-YYY, search for XYYY. */
7444 for (i = switchnum + 1; i < n_switches; i++)
7445 if (switches[i].part1[0] == name[0]
7446 && ! strcmp (&switches[i].part1[1], &name[4]))
7447 {
7448 /* --specs are validated with the validate_switches mechanism. */
7449 if (switches[switchnum].known)
7450 switches[switchnum].validated = true;
7451 switches[switchnum].live_cond = SWITCH_FALSE;
7452 return 0;
7453 }
7454 }
7455 else
7456 {
7457 /* We have XYYY, search for Xno-YYY. */
7458 for (i = switchnum + 1; i < n_switches; i++)
7459 if (switches[i].part1[0] == name[0]
7460 && switches[i].part1[1] == 'n'
7461 && switches[i].part1[2] == 'o'
7462 && switches[i].part1[3] == '-'
7463 && !strcmp (&switches[i].part1[4], &name[1]))
7464 {
7465 /* --specs are validated with the validate_switches mechanism. */
7466 if (switches[switchnum].known)
7467 switches[switchnum].validated = true;
7468 switches[switchnum].live_cond = SWITCH_FALSE;
7469 return 0;
7470 }
7471 }
7472 break;
7473 }
7474
7475 /* Otherwise the switch is live. */
7476 switches[switchnum].live_cond |= SWITCH_LIVE;
7477 return 1;
7478 }
7479 \f
7480 /* Pass a switch to the current accumulating command
7481 in the same form that we received it.
7482 SWITCHNUM identifies the switch; it is an index into
7483 the vector of switches gcc received, which is `switches'.
7484 This cannot fail since it never finishes a command line.
7485
7486 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
7487
7488 static void
7489 give_switch (int switchnum, int omit_first_word)
7490 {
7491 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
7492 return;
7493
7494 if (!omit_first_word)
7495 {
7496 do_spec_1 ("-", 0, NULL);
7497 do_spec_1 (switches[switchnum].part1, 1, NULL);
7498 }
7499
7500 if (switches[switchnum].args != 0)
7501 {
7502 const char **p;
7503 for (p = switches[switchnum].args; *p; p++)
7504 {
7505 const char *arg = *p;
7506
7507 do_spec_1 (" ", 0, NULL);
7508 if (suffix_subst)
7509 {
7510 unsigned length = strlen (arg);
7511 int dot = 0;
7512
7513 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
7514 if (arg[length] == '.')
7515 {
7516 (CONST_CAST (char *, arg))[length] = 0;
7517 dot = 1;
7518 break;
7519 }
7520 do_spec_1 (arg, 1, NULL);
7521 if (dot)
7522 (CONST_CAST (char *, arg))[length] = '.';
7523 do_spec_1 (suffix_subst, 1, NULL);
7524 }
7525 else
7526 do_spec_1 (arg, 1, NULL);
7527 }
7528 }
7529
7530 do_spec_1 (" ", 0, NULL);
7531 switches[switchnum].validated = true;
7532 }
7533 \f
7534 /* Print GCC configuration (e.g. version, thread model, target,
7535 configuration_arguments) to a given FILE. */
7536
7537 static void
7538 print_configuration (FILE *file)
7539 {
7540 int n;
7541 const char *thrmod;
7542
7543 fnotice (file, "Target: %s\n", spec_machine);
7544 fnotice (file, "Configured with: %s\n", configuration_arguments);
7545
7546 #ifdef THREAD_MODEL_SPEC
7547 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
7548 but there's no point in doing all this processing just to get
7549 thread_model back. */
7550 obstack_init (&obstack);
7551 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
7552 obstack_1grow (&obstack, '\0');
7553 thrmod = XOBFINISH (&obstack, const char *);
7554 #else
7555 thrmod = thread_model;
7556 #endif
7557
7558 fnotice (file, "Thread model: %s\n", thrmod);
7559 fnotice (file, "Supported LTO compression algorithms: zlib");
7560 #ifdef HAVE_ZSTD_H
7561 fnotice (file, " zstd");
7562 #endif
7563 fnotice (file, "\n");
7564
7565 /* compiler_version is truncated at the first space when initialized
7566 from version string, so truncate version_string at the first space
7567 before comparing. */
7568 for (n = 0; version_string[n]; n++)
7569 if (version_string[n] == ' ')
7570 break;
7571
7572 if (! strncmp (version_string, compiler_version, n)
7573 && compiler_version[n] == 0)
7574 fnotice (file, "gcc version %s %s\n", version_string,
7575 pkgversion_string);
7576 else
7577 fnotice (file, "gcc driver version %s %sexecuting gcc version %s\n",
7578 version_string, pkgversion_string, compiler_version);
7579
7580 }
7581
7582 #define RETRY_ICE_ATTEMPTS 3
7583
7584 /* Returns true if FILE1 and FILE2 contain equivalent data, 0 otherwise. */
7585
7586 static bool
7587 files_equal_p (char *file1, char *file2)
7588 {
7589 struct stat st1, st2;
7590 off_t n, len;
7591 int fd1, fd2;
7592 const int bufsize = 8192;
7593 char *buf = XNEWVEC (char, bufsize);
7594
7595 fd1 = open (file1, O_RDONLY);
7596 fd2 = open (file2, O_RDONLY);
7597
7598 if (fd1 < 0 || fd2 < 0)
7599 goto error;
7600
7601 if (fstat (fd1, &st1) < 0 || fstat (fd2, &st2) < 0)
7602 goto error;
7603
7604 if (st1.st_size != st2.st_size)
7605 goto error;
7606
7607 for (n = st1.st_size; n; n -= len)
7608 {
7609 len = n;
7610 if ((int) len > bufsize / 2)
7611 len = bufsize / 2;
7612
7613 if (read (fd1, buf, len) != (int) len
7614 || read (fd2, buf + bufsize / 2, len) != (int) len)
7615 {
7616 goto error;
7617 }
7618
7619 if (memcmp (buf, buf + bufsize / 2, len) != 0)
7620 goto error;
7621 }
7622
7623 free (buf);
7624 close (fd1);
7625 close (fd2);
7626
7627 return 1;
7628
7629 error:
7630 free (buf);
7631 close (fd1);
7632 close (fd2);
7633 return 0;
7634 }
7635
7636 /* Check that compiler's output doesn't differ across runs.
7637 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are arrays of files, containing
7638 stdout and stderr for each compiler run. Return true if all of
7639 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are equivalent. */
7640
7641 static bool
7642 check_repro (char **temp_stdout_files, char **temp_stderr_files)
7643 {
7644 int i;
7645 for (i = 0; i < RETRY_ICE_ATTEMPTS - 2; ++i)
7646 {
7647 if (!files_equal_p (temp_stdout_files[i], temp_stdout_files[i + 1])
7648 || !files_equal_p (temp_stderr_files[i], temp_stderr_files[i + 1]))
7649 {
7650 fnotice (stderr, "The bug is not reproducible, so it is"
7651 " likely a hardware or OS problem.\n");
7652 break;
7653 }
7654 }
7655 return i == RETRY_ICE_ATTEMPTS - 2;
7656 }
7657
7658 enum attempt_status {
7659 ATTEMPT_STATUS_FAIL_TO_RUN,
7660 ATTEMPT_STATUS_SUCCESS,
7661 ATTEMPT_STATUS_ICE
7662 };
7663
7664
7665 /* Run compiler with arguments NEW_ARGV to reproduce the ICE, storing stdout
7666 to OUT_TEMP and stderr to ERR_TEMP. If APPEND is TRUE, append to OUT_TEMP
7667 and ERR_TEMP instead of truncating. If EMIT_SYSTEM_INFO is TRUE, also write
7668 GCC configuration into to ERR_TEMP. Return ATTEMPT_STATUS_FAIL_TO_RUN if
7669 compiler failed to run, ATTEMPT_STATUS_ICE if compiled ICE-ed and
7670 ATTEMPT_STATUS_SUCCESS otherwise. */
7671
7672 static enum attempt_status
7673 run_attempt (const char **new_argv, const char *out_temp,
7674 const char *err_temp, int emit_system_info, int append)
7675 {
7676
7677 if (emit_system_info)
7678 {
7679 FILE *file_out = fopen (err_temp, "a");
7680 print_configuration (file_out);
7681 fputs ("\n", file_out);
7682 fclose (file_out);
7683 }
7684
7685 int exit_status;
7686 const char *errmsg;
7687 struct pex_obj *pex;
7688 int err;
7689 int pex_flags = PEX_USE_PIPES | PEX_LAST;
7690 enum attempt_status status = ATTEMPT_STATUS_FAIL_TO_RUN;
7691
7692 if (append)
7693 pex_flags |= PEX_STDOUT_APPEND | PEX_STDERR_APPEND;
7694
7695 pex = pex_init (PEX_USE_PIPES, new_argv[0], NULL);
7696 if (!pex)
7697 fatal_error (input_location, "%<pex_init%> failed: %m");
7698
7699 errmsg = pex_run (pex, pex_flags, new_argv[0],
7700 CONST_CAST2 (char *const *, const char **, &new_argv[1]),
7701 out_temp, err_temp, &err);
7702 if (errmsg != NULL)
7703 {
7704 errno = err;
7705 fatal_error (input_location,
7706 err ? G_ ("cannot execute %qs: %s: %m")
7707 : G_ ("cannot execute %qs: %s"),
7708 new_argv[0], errmsg);
7709 }
7710
7711 if (!pex_get_status (pex, 1, &exit_status))
7712 goto out;
7713
7714 switch (WEXITSTATUS (exit_status))
7715 {
7716 case ICE_EXIT_CODE:
7717 status = ATTEMPT_STATUS_ICE;
7718 break;
7719
7720 case SUCCESS_EXIT_CODE:
7721 status = ATTEMPT_STATUS_SUCCESS;
7722 break;
7723
7724 default:
7725 ;
7726 }
7727
7728 out:
7729 pex_free (pex);
7730 return status;
7731 }
7732
7733 /* This routine reads lines from IN file, adds C++ style comments
7734 at the begining of each line and writes result into OUT. */
7735
7736 static void
7737 insert_comments (const char *file_in, const char *file_out)
7738 {
7739 FILE *in = fopen (file_in, "rb");
7740 FILE *out = fopen (file_out, "wb");
7741 char line[256];
7742
7743 bool add_comment = true;
7744 while (fgets (line, sizeof (line), in))
7745 {
7746 if (add_comment)
7747 fputs ("// ", out);
7748 fputs (line, out);
7749 add_comment = strchr (line, '\n') != NULL;
7750 }
7751
7752 fclose (in);
7753 fclose (out);
7754 }
7755
7756 /* This routine adds preprocessed source code into the given ERR_FILE.
7757 To do this, it adds "-E" to NEW_ARGV and execute RUN_ATTEMPT routine to
7758 add information in report file. RUN_ATTEMPT should return
7759 ATTEMPT_STATUS_SUCCESS, in other case we cannot generate the report. */
7760
7761 static void
7762 do_report_bug (const char **new_argv, const int nargs,
7763 char **out_file, char **err_file)
7764 {
7765 int i, status;
7766 int fd = open (*out_file, O_RDWR | O_APPEND);
7767 if (fd < 0)
7768 return;
7769 write (fd, "\n//", 3);
7770 for (i = 0; i < nargs; i++)
7771 {
7772 write (fd, " ", 1);
7773 write (fd, new_argv[i], strlen (new_argv[i]));
7774 }
7775 write (fd, "\n\n", 2);
7776 close (fd);
7777 new_argv[nargs] = "-E";
7778 new_argv[nargs + 1] = NULL;
7779
7780 status = run_attempt (new_argv, *out_file, *err_file, 0, 1);
7781
7782 if (status == ATTEMPT_STATUS_SUCCESS)
7783 {
7784 fnotice (stderr, "Preprocessed source stored into %s file,"
7785 " please attach this to your bugreport.\n", *out_file);
7786 /* Make sure it is not deleted. */
7787 free (*out_file);
7788 *out_file = NULL;
7789 }
7790 }
7791
7792 /* Try to reproduce ICE. If bug is reproducible, generate report .err file
7793 containing GCC configuration, backtrace, compiler's command line options
7794 and preprocessed source code. */
7795
7796 static void
7797 try_generate_repro (const char **argv)
7798 {
7799 int i, nargs, out_arg = -1, quiet = 0, attempt;
7800 const char **new_argv;
7801 char *temp_files[RETRY_ICE_ATTEMPTS * 2];
7802 char **temp_stdout_files = &temp_files[0];
7803 char **temp_stderr_files = &temp_files[RETRY_ICE_ATTEMPTS];
7804
7805 if (gcc_input_filename == NULL || ! strcmp (gcc_input_filename, "-"))
7806 return;
7807
7808 for (nargs = 0; argv[nargs] != NULL; ++nargs)
7809 /* Only retry compiler ICEs, not preprocessor ones. */
7810 if (! strcmp (argv[nargs], "-E"))
7811 return;
7812 else if (argv[nargs][0] == '-' && argv[nargs][1] == 'o')
7813 {
7814 if (out_arg == -1)
7815 out_arg = nargs;
7816 else
7817 return;
7818 }
7819 /* If the compiler is going to output any time information,
7820 it might varry between invocations. */
7821 else if (! strcmp (argv[nargs], "-quiet"))
7822 quiet = 1;
7823 else if (! strcmp (argv[nargs], "-ftime-report"))
7824 return;
7825
7826 if (out_arg == -1 || !quiet)
7827 return;
7828
7829 memset (temp_files, '\0', sizeof (temp_files));
7830 new_argv = XALLOCAVEC (const char *, nargs + 4);
7831 memcpy (new_argv, argv, (nargs + 1) * sizeof (const char *));
7832 new_argv[nargs++] = "-frandom-seed=0";
7833 new_argv[nargs++] = "-fdump-noaddr";
7834 new_argv[nargs] = NULL;
7835 if (new_argv[out_arg][2] == '\0')
7836 new_argv[out_arg + 1] = "-";
7837 else
7838 new_argv[out_arg] = "-o-";
7839
7840 int status;
7841 for (attempt = 0; attempt < RETRY_ICE_ATTEMPTS; ++attempt)
7842 {
7843 int emit_system_info = 0;
7844 int append = 0;
7845 temp_stdout_files[attempt] = make_temp_file (".out");
7846 temp_stderr_files[attempt] = make_temp_file (".err");
7847
7848 if (attempt == RETRY_ICE_ATTEMPTS - 1)
7849 {
7850 append = 1;
7851 emit_system_info = 1;
7852 }
7853
7854 status = run_attempt (new_argv, temp_stdout_files[attempt],
7855 temp_stderr_files[attempt], emit_system_info,
7856 append);
7857
7858 if (status != ATTEMPT_STATUS_ICE)
7859 {
7860 fnotice (stderr, "The bug is not reproducible, so it is"
7861 " likely a hardware or OS problem.\n");
7862 goto out;
7863 }
7864 }
7865
7866 if (!check_repro (temp_stdout_files, temp_stderr_files))
7867 goto out;
7868
7869 {
7870 /* Insert commented out backtrace into report file. */
7871 char **stderr_commented = &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1];
7872 insert_comments (temp_stderr_files[RETRY_ICE_ATTEMPTS - 1],
7873 *stderr_commented);
7874
7875 /* In final attempt we append compiler options and preprocesssed code to last
7876 generated .out file with configuration and backtrace. */
7877 char **err = &temp_stderr_files[RETRY_ICE_ATTEMPTS - 1];
7878 do_report_bug (new_argv, nargs, stderr_commented, err);
7879 }
7880
7881 out:
7882 for (i = 0; i < RETRY_ICE_ATTEMPTS * 2; i++)
7883 if (temp_files[i])
7884 {
7885 unlink (temp_stdout_files[i]);
7886 free (temp_stdout_files[i]);
7887 }
7888 }
7889
7890 /* Search for a file named NAME trying various prefixes including the
7891 user's -B prefix and some standard ones.
7892 Return the absolute file name found. If nothing is found, return NAME. */
7893
7894 static const char *
7895 find_file (const char *name)
7896 {
7897 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
7898 return newname ? newname : name;
7899 }
7900
7901 /* Determine whether a directory exists. If LINKER, return 0 for
7902 certain fixed names not needed by the linker. */
7903
7904 static int
7905 is_directory (const char *path1, bool linker)
7906 {
7907 int len1;
7908 char *path;
7909 char *cp;
7910 struct stat st;
7911
7912 /* Ensure the string ends with "/.". The resulting path will be a
7913 directory even if the given path is a symbolic link. */
7914 len1 = strlen (path1);
7915 path = (char *) alloca (3 + len1);
7916 memcpy (path, path1, len1);
7917 cp = path + len1;
7918 if (!IS_DIR_SEPARATOR (cp[-1]))
7919 *cp++ = DIR_SEPARATOR;
7920 *cp++ = '.';
7921 *cp = '\0';
7922
7923 /* Exclude directories that the linker is known to search. */
7924 if (linker
7925 && IS_DIR_SEPARATOR (path[0])
7926 && ((cp - path == 6
7927 && filename_ncmp (path + 1, "lib", 3) == 0)
7928 || (cp - path == 10
7929 && filename_ncmp (path + 1, "usr", 3) == 0
7930 && IS_DIR_SEPARATOR (path[4])
7931 && filename_ncmp (path + 5, "lib", 3) == 0)))
7932 return 0;
7933
7934 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
7935 }
7936
7937 /* Set up the various global variables to indicate that we're processing
7938 the input file named FILENAME. */
7939
7940 void
7941 set_input (const char *filename)
7942 {
7943 const char *p;
7944
7945 gcc_input_filename = filename;
7946 input_filename_length = strlen (gcc_input_filename);
7947 input_basename = lbasename (gcc_input_filename);
7948
7949 /* Find a suffix starting with the last period,
7950 and set basename_length to exclude that suffix. */
7951 basename_length = strlen (input_basename);
7952 suffixed_basename_length = basename_length;
7953 p = input_basename + basename_length;
7954 while (p != input_basename && *p != '.')
7955 --p;
7956 if (*p == '.' && p != input_basename)
7957 {
7958 basename_length = p - input_basename;
7959 input_suffix = p + 1;
7960 }
7961 else
7962 input_suffix = "";
7963
7964 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
7965 we will need to do a stat on the gcc_input_filename. The
7966 INPUT_STAT_SET signals that the stat is needed. */
7967 input_stat_set = 0;
7968 }
7969 \f
7970 /* On fatal signals, delete all the temporary files. */
7971
7972 static void
7973 fatal_signal (int signum)
7974 {
7975 signal (signum, SIG_DFL);
7976 delete_failure_queue ();
7977 delete_temp_files ();
7978 /* Get the same signal again, this time not handled,
7979 so its normal effect occurs. */
7980 kill (getpid (), signum);
7981 }
7982
7983 /* Compare the contents of the two files named CMPFILE[0] and
7984 CMPFILE[1]. Return zero if they're identical, nonzero
7985 otherwise. */
7986
7987 static int
7988 compare_files (char *cmpfile[])
7989 {
7990 int ret = 0;
7991 FILE *temp[2] = { NULL, NULL };
7992 int i;
7993
7994 #if HAVE_MMAP_FILE
7995 {
7996 size_t length[2];
7997 void *map[2] = { NULL, NULL };
7998
7999 for (i = 0; i < 2; i++)
8000 {
8001 struct stat st;
8002
8003 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
8004 {
8005 error ("%s: could not determine length of compare-debug file %s",
8006 gcc_input_filename, cmpfile[i]);
8007 ret = 1;
8008 break;
8009 }
8010
8011 length[i] = st.st_size;
8012 }
8013
8014 if (!ret && length[0] != length[1])
8015 {
8016 error ("%s: %<-fcompare-debug%> failure (length)", gcc_input_filename);
8017 ret = 1;
8018 }
8019
8020 if (!ret)
8021 for (i = 0; i < 2; i++)
8022 {
8023 int fd = open (cmpfile[i], O_RDONLY);
8024 if (fd < 0)
8025 {
8026 error ("%s: could not open compare-debug file %s",
8027 gcc_input_filename, cmpfile[i]);
8028 ret = 1;
8029 break;
8030 }
8031
8032 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
8033 close (fd);
8034
8035 if (map[i] == (void *) MAP_FAILED)
8036 {
8037 ret = -1;
8038 break;
8039 }
8040 }
8041
8042 if (!ret)
8043 {
8044 if (memcmp (map[0], map[1], length[0]) != 0)
8045 {
8046 error ("%s: %<-fcompare-debug%> failure", gcc_input_filename);
8047 ret = 1;
8048 }
8049 }
8050
8051 for (i = 0; i < 2; i++)
8052 if (map[i])
8053 munmap ((caddr_t) map[i], length[i]);
8054
8055 if (ret >= 0)
8056 return ret;
8057
8058 ret = 0;
8059 }
8060 #endif
8061
8062 for (i = 0; i < 2; i++)
8063 {
8064 temp[i] = fopen (cmpfile[i], "r");
8065 if (!temp[i])
8066 {
8067 error ("%s: could not open compare-debug file %s",
8068 gcc_input_filename, cmpfile[i]);
8069 ret = 1;
8070 break;
8071 }
8072 }
8073
8074 if (!ret && temp[0] && temp[1])
8075 for (;;)
8076 {
8077 int c0, c1;
8078 c0 = fgetc (temp[0]);
8079 c1 = fgetc (temp[1]);
8080
8081 if (c0 != c1)
8082 {
8083 error ("%s: %<-fcompare-debug%> failure",
8084 gcc_input_filename);
8085 ret = 1;
8086 break;
8087 }
8088
8089 if (c0 == EOF)
8090 break;
8091 }
8092
8093 for (i = 1; i >= 0; i--)
8094 {
8095 if (temp[i])
8096 fclose (temp[i]);
8097 }
8098
8099 return ret;
8100 }
8101
8102 driver::driver (bool can_finalize, bool debug) :
8103 explicit_link_files (NULL),
8104 decoded_options (NULL)
8105 {
8106 env.init (can_finalize, debug);
8107 }
8108
8109 driver::~driver ()
8110 {
8111 XDELETEVEC (explicit_link_files);
8112 XDELETEVEC (decoded_options);
8113 }
8114
8115 /* driver::main is implemented as a series of driver:: method calls. */
8116
8117 int
8118 driver::main (int argc, char **argv)
8119 {
8120 bool early_exit;
8121
8122 set_progname (argv[0]);
8123 expand_at_files (&argc, &argv);
8124 decode_argv (argc, const_cast <const char **> (argv));
8125 global_initializations ();
8126 build_multilib_strings ();
8127 set_up_specs ();
8128 putenv_COLLECT_AS_OPTIONS (assembler_options);
8129 putenv_COLLECT_GCC (argv[0]);
8130 maybe_putenv_COLLECT_LTO_WRAPPER ();
8131 maybe_putenv_OFFLOAD_TARGETS ();
8132 handle_unrecognized_options ();
8133
8134 if (completion)
8135 {
8136 m_option_proposer.suggest_completion (completion);
8137 return 0;
8138 }
8139
8140 if (!maybe_print_and_exit ())
8141 return 0;
8142
8143 early_exit = prepare_infiles ();
8144 if (early_exit)
8145 return get_exit_code ();
8146
8147 do_spec_on_infiles ();
8148 maybe_run_linker (argv[0]);
8149 final_actions ();
8150 return get_exit_code ();
8151 }
8152
8153 /* Locate the final component of argv[0] after any leading path, and set
8154 the program name accordingly. */
8155
8156 void
8157 driver::set_progname (const char *argv0) const
8158 {
8159 const char *p = argv0 + strlen (argv0);
8160 while (p != argv0 && !IS_DIR_SEPARATOR (p[-1]))
8161 --p;
8162 progname = p;
8163
8164 xmalloc_set_program_name (progname);
8165 }
8166
8167 /* Expand any @ files within the command-line args,
8168 setting at_file_supplied if any were expanded. */
8169
8170 void
8171 driver::expand_at_files (int *argc, char ***argv) const
8172 {
8173 char **old_argv = *argv;
8174
8175 expandargv (argc, argv);
8176
8177 /* Determine if any expansions were made. */
8178 if (*argv != old_argv)
8179 at_file_supplied = true;
8180 }
8181
8182 /* Decode the command-line arguments from argc/argv into the
8183 decoded_options array. */
8184
8185 void
8186 driver::decode_argv (int argc, const char **argv)
8187 {
8188 init_opts_obstack ();
8189 init_options_struct (&global_options, &global_options_set);
8190
8191 decode_cmdline_options_to_array (argc, argv,
8192 CL_DRIVER,
8193 &decoded_options, &decoded_options_count);
8194 }
8195
8196 /* Perform various initializations and setup. */
8197
8198 void
8199 driver::global_initializations ()
8200 {
8201 /* Unlock the stdio streams. */
8202 unlock_std_streams ();
8203
8204 gcc_init_libintl ();
8205
8206 diagnostic_initialize (global_dc, 0);
8207 diagnostic_color_init (global_dc);
8208 diagnostic_urls_init (global_dc);
8209
8210 #ifdef GCC_DRIVER_HOST_INITIALIZATION
8211 /* Perform host dependent initialization when needed. */
8212 GCC_DRIVER_HOST_INITIALIZATION;
8213 #endif
8214
8215 if (atexit (delete_temp_files) != 0)
8216 fatal_error (input_location, "atexit failed");
8217
8218 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
8219 signal (SIGINT, fatal_signal);
8220 #ifdef SIGHUP
8221 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
8222 signal (SIGHUP, fatal_signal);
8223 #endif
8224 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
8225 signal (SIGTERM, fatal_signal);
8226 #ifdef SIGPIPE
8227 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
8228 signal (SIGPIPE, fatal_signal);
8229 #endif
8230 #ifdef SIGCHLD
8231 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
8232 receive the signal. A different setting is inheritable */
8233 signal (SIGCHLD, SIG_DFL);
8234 #endif
8235
8236 /* Parsing and gimplification sometimes need quite large stack.
8237 Increase stack size limits if possible. */
8238 stack_limit_increase (64 * 1024 * 1024);
8239
8240 /* Allocate the argument vector. */
8241 alloc_args ();
8242
8243 obstack_init (&obstack);
8244 }
8245
8246 /* Build multilib_select, et. al from the separate lines that make up each
8247 multilib selection. */
8248
8249 void
8250 driver::build_multilib_strings () const
8251 {
8252 {
8253 const char *p;
8254 const char *const *q = multilib_raw;
8255 int need_space;
8256
8257 obstack_init (&multilib_obstack);
8258 while ((p = *q++) != (char *) 0)
8259 obstack_grow (&multilib_obstack, p, strlen (p));
8260
8261 obstack_1grow (&multilib_obstack, 0);
8262 multilib_select = XOBFINISH (&multilib_obstack, const char *);
8263
8264 q = multilib_matches_raw;
8265 while ((p = *q++) != (char *) 0)
8266 obstack_grow (&multilib_obstack, p, strlen (p));
8267
8268 obstack_1grow (&multilib_obstack, 0);
8269 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
8270
8271 q = multilib_exclusions_raw;
8272 while ((p = *q++) != (char *) 0)
8273 obstack_grow (&multilib_obstack, p, strlen (p));
8274
8275 obstack_1grow (&multilib_obstack, 0);
8276 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
8277
8278 q = multilib_reuse_raw;
8279 while ((p = *q++) != (char *) 0)
8280 obstack_grow (&multilib_obstack, p, strlen (p));
8281
8282 obstack_1grow (&multilib_obstack, 0);
8283 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
8284
8285 need_space = FALSE;
8286 for (size_t i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
8287 {
8288 if (need_space)
8289 obstack_1grow (&multilib_obstack, ' ');
8290 obstack_grow (&multilib_obstack,
8291 multilib_defaults_raw[i],
8292 strlen (multilib_defaults_raw[i]));
8293 need_space = TRUE;
8294 }
8295
8296 obstack_1grow (&multilib_obstack, 0);
8297 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
8298 }
8299 }
8300
8301 /* Set up the spec-handling machinery. */
8302
8303 void
8304 driver::set_up_specs () const
8305 {
8306 const char *spec_machine_suffix;
8307 char *specs_file;
8308 size_t i;
8309
8310 #ifdef INIT_ENVIRONMENT
8311 /* Set up any other necessary machine specific environment variables. */
8312 xputenv (INIT_ENVIRONMENT);
8313 #endif
8314
8315 /* Make a table of what switches there are (switches, n_switches).
8316 Make a table of specified input files (infiles, n_infiles).
8317 Decode switches that are handled locally. */
8318
8319 process_command (decoded_options_count, decoded_options);
8320
8321 /* Initialize the vector of specs to just the default.
8322 This means one element containing 0s, as a terminator. */
8323
8324 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
8325 memcpy (compilers, default_compilers, sizeof default_compilers);
8326 n_compilers = n_default_compilers;
8327
8328 /* Read specs from a file if there is one. */
8329
8330 machine_suffix = concat (spec_host_machine, dir_separator_str, spec_version,
8331 accel_dir_suffix, dir_separator_str, NULL);
8332 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
8333
8334 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
8335 /* Read the specs file unless it is a default one. */
8336 if (specs_file != 0 && strcmp (specs_file, "specs"))
8337 read_specs (specs_file, true, false);
8338 else
8339 init_spec ();
8340
8341 #ifdef ACCEL_COMPILER
8342 spec_machine_suffix = machine_suffix;
8343 #else
8344 spec_machine_suffix = just_machine_suffix;
8345 #endif
8346
8347 /* We need to check standard_exec_prefix/spec_machine_suffix/specs
8348 for any override of as, ld and libraries. */
8349 specs_file = (char *) alloca (strlen (standard_exec_prefix)
8350 + strlen (spec_machine_suffix) + sizeof ("specs"));
8351 strcpy (specs_file, standard_exec_prefix);
8352 strcat (specs_file, spec_machine_suffix);
8353 strcat (specs_file, "specs");
8354 if (access (specs_file, R_OK) == 0)
8355 read_specs (specs_file, true, false);
8356
8357 /* Process any configure-time defaults specified for the command line
8358 options, via OPTION_DEFAULT_SPECS. */
8359 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
8360 do_option_spec (option_default_specs[i].name,
8361 option_default_specs[i].spec);
8362
8363 /* Process DRIVER_SELF_SPECS, adding any new options to the end
8364 of the command line. */
8365
8366 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
8367 do_self_spec (driver_self_specs[i]);
8368
8369 /* If not cross-compiling, look for executables in the standard
8370 places. */
8371 if (*cross_compile == '0')
8372 {
8373 if (*md_exec_prefix)
8374 {
8375 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
8376 PREFIX_PRIORITY_LAST, 0, 0);
8377 }
8378 }
8379
8380 /* Process sysroot_suffix_spec. */
8381 if (*sysroot_suffix_spec != 0
8382 && !no_sysroot_suffix
8383 && do_spec_2 (sysroot_suffix_spec, NULL) == 0)
8384 {
8385 if (argbuf.length () > 1)
8386 error ("spec failure: more than one argument to "
8387 "%<SYSROOT_SUFFIX_SPEC%>");
8388 else if (argbuf.length () == 1)
8389 target_sysroot_suffix = xstrdup (argbuf.last ());
8390 }
8391
8392 #ifdef HAVE_LD_SYSROOT
8393 /* Pass the --sysroot option to the linker, if it supports that. If
8394 there is a sysroot_suffix_spec, it has already been processed by
8395 this point, so target_system_root really is the system root we
8396 should be using. */
8397 if (target_system_root)
8398 {
8399 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
8400 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
8401 set_spec ("link", XOBFINISH (&obstack, const char *), false);
8402 }
8403 #endif
8404
8405 /* Process sysroot_hdrs_suffix_spec. */
8406 if (*sysroot_hdrs_suffix_spec != 0
8407 && !no_sysroot_suffix
8408 && do_spec_2 (sysroot_hdrs_suffix_spec, NULL) == 0)
8409 {
8410 if (argbuf.length () > 1)
8411 error ("spec failure: more than one argument "
8412 "to %<SYSROOT_HEADERS_SUFFIX_SPEC%>");
8413 else if (argbuf.length () == 1)
8414 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
8415 }
8416
8417 /* Look for startfiles in the standard places. */
8418 if (*startfile_prefix_spec != 0
8419 && do_spec_2 (startfile_prefix_spec, NULL) == 0
8420 && do_spec_1 (" ", 0, NULL) == 0)
8421 {
8422 for (const char *arg : argbuf)
8423 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
8424 PREFIX_PRIORITY_LAST, 0, 1);
8425 }
8426 /* We should eventually get rid of all these and stick to
8427 startfile_prefix_spec exclusively. */
8428 else if (*cross_compile == '0' || target_system_root)
8429 {
8430 if (*md_startfile_prefix)
8431 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
8432 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
8433
8434 if (*md_startfile_prefix_1)
8435 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
8436 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
8437
8438 /* If standard_startfile_prefix is relative, base it on
8439 standard_exec_prefix. This lets us move the installed tree
8440 as a unit. If GCC_EXEC_PREFIX is defined, base
8441 standard_startfile_prefix on that as well.
8442
8443 If the prefix is relative, only search it for native compilers;
8444 otherwise we will search a directory containing host libraries. */
8445 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
8446 add_sysrooted_prefix (&startfile_prefixes,
8447 standard_startfile_prefix, "BINUTILS",
8448 PREFIX_PRIORITY_LAST, 0, 1);
8449 else if (*cross_compile == '0')
8450 {
8451 add_prefix (&startfile_prefixes,
8452 concat (gcc_exec_prefix
8453 ? gcc_exec_prefix : standard_exec_prefix,
8454 machine_suffix,
8455 standard_startfile_prefix, NULL),
8456 NULL, PREFIX_PRIORITY_LAST, 0, 1);
8457 }
8458
8459 /* Sysrooted prefixes are relocated because target_system_root is
8460 also relocated by gcc_exec_prefix. */
8461 if (*standard_startfile_prefix_1)
8462 add_sysrooted_prefix (&startfile_prefixes,
8463 standard_startfile_prefix_1, "BINUTILS",
8464 PREFIX_PRIORITY_LAST, 0, 1);
8465 if (*standard_startfile_prefix_2)
8466 add_sysrooted_prefix (&startfile_prefixes,
8467 standard_startfile_prefix_2, "BINUTILS",
8468 PREFIX_PRIORITY_LAST, 0, 1);
8469 }
8470
8471 /* Process any user specified specs in the order given on the command
8472 line. */
8473 for (struct user_specs *uptr = user_specs_head; uptr; uptr = uptr->next)
8474 {
8475 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
8476 R_OK, true);
8477 read_specs (filename ? filename : uptr->filename, false, true);
8478 }
8479
8480 /* Process any user self specs. */
8481 {
8482 struct spec_list *sl;
8483 for (sl = specs; sl; sl = sl->next)
8484 if (sl->name_len == sizeof "self_spec" - 1
8485 && !strcmp (sl->name, "self_spec"))
8486 do_self_spec (*sl->ptr_spec);
8487 }
8488
8489 if (compare_debug)
8490 {
8491 enum save_temps save;
8492
8493 if (!compare_debug_second)
8494 {
8495 n_switches_debug_check[1] = n_switches;
8496 n_switches_alloc_debug_check[1] = n_switches_alloc;
8497 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
8498 n_switches_alloc);
8499
8500 do_self_spec ("%:compare-debug-self-opt()");
8501 n_switches_debug_check[0] = n_switches;
8502 n_switches_alloc_debug_check[0] = n_switches_alloc;
8503 switches_debug_check[0] = switches;
8504
8505 n_switches = n_switches_debug_check[1];
8506 n_switches_alloc = n_switches_alloc_debug_check[1];
8507 switches = switches_debug_check[1];
8508 }
8509
8510 /* Avoid crash when computing %j in this early. */
8511 save = save_temps_flag;
8512 save_temps_flag = SAVE_TEMPS_NONE;
8513
8514 compare_debug = -compare_debug;
8515 do_self_spec ("%:compare-debug-self-opt()");
8516
8517 save_temps_flag = save;
8518
8519 if (!compare_debug_second)
8520 {
8521 n_switches_debug_check[1] = n_switches;
8522 n_switches_alloc_debug_check[1] = n_switches_alloc;
8523 switches_debug_check[1] = switches;
8524 compare_debug = -compare_debug;
8525 n_switches = n_switches_debug_check[0];
8526 n_switches_alloc = n_switches_debug_check[0];
8527 switches = switches_debug_check[0];
8528 }
8529 }
8530
8531
8532 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
8533 if (gcc_exec_prefix)
8534 gcc_exec_prefix = concat (gcc_exec_prefix, spec_host_machine,
8535 dir_separator_str, spec_version,
8536 accel_dir_suffix, dir_separator_str, NULL);
8537
8538 /* Now we have the specs.
8539 Set the `valid' bits for switches that match anything in any spec. */
8540
8541 validate_all_switches ();
8542
8543 /* Now that we have the switches and the specs, set
8544 the subdirectory based on the options. */
8545 set_multilib_dir ();
8546 }
8547
8548 /* Set up to remember the pathname of gcc and any options
8549 needed for collect. We use argv[0] instead of progname because
8550 we need the complete pathname. */
8551
8552 void
8553 driver::putenv_COLLECT_GCC (const char *argv0) const
8554 {
8555 obstack_init (&collect_obstack);
8556 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
8557 obstack_grow (&collect_obstack, argv0, strlen (argv0) + 1);
8558 xputenv (XOBFINISH (&collect_obstack, char *));
8559 }
8560
8561 /* Set up to remember the pathname of the lto wrapper. */
8562
8563 void
8564 driver::maybe_putenv_COLLECT_LTO_WRAPPER () const
8565 {
8566 char *lto_wrapper_file;
8567
8568 if (have_c)
8569 lto_wrapper_file = NULL;
8570 else
8571 lto_wrapper_file = find_a_program ("lto-wrapper");
8572 if (lto_wrapper_file)
8573 {
8574 lto_wrapper_file = convert_white_space (lto_wrapper_file);
8575 set_static_spec_owned (&lto_wrapper_spec, lto_wrapper_file);
8576 obstack_init (&collect_obstack);
8577 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
8578 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
8579 obstack_grow (&collect_obstack, lto_wrapper_spec,
8580 strlen (lto_wrapper_spec) + 1);
8581 xputenv (XOBFINISH (&collect_obstack, char *));
8582 }
8583
8584 }
8585
8586 /* Set up to remember the names of offload targets. */
8587
8588 void
8589 driver::maybe_putenv_OFFLOAD_TARGETS () const
8590 {
8591 if (offload_targets && offload_targets[0] != '\0')
8592 {
8593 obstack_grow (&collect_obstack, "OFFLOAD_TARGET_NAMES=",
8594 sizeof ("OFFLOAD_TARGET_NAMES=") - 1);
8595 obstack_grow (&collect_obstack, offload_targets,
8596 strlen (offload_targets) + 1);
8597 xputenv (XOBFINISH (&collect_obstack, char *));
8598 #if OFFLOAD_DEFAULTED
8599 if (offload_targets_default)
8600 xputenv ("OFFLOAD_TARGET_DEFAULT=1");
8601 #endif
8602 }
8603
8604 free (offload_targets);
8605 offload_targets = NULL;
8606 }
8607
8608 /* Reject switches that no pass was interested in. */
8609
8610 void
8611 driver::handle_unrecognized_options ()
8612 {
8613 for (size_t i = 0; (int) i < n_switches; i++)
8614 if (! switches[i].validated)
8615 {
8616 const char *hint = m_option_proposer.suggest_option (switches[i].part1);
8617 if (hint)
8618 error ("unrecognized command-line option %<-%s%>;"
8619 " did you mean %<-%s%>?",
8620 switches[i].part1, hint);
8621 else
8622 error ("unrecognized command-line option %<-%s%>",
8623 switches[i].part1);
8624 }
8625 }
8626
8627 /* Handle the various -print-* options, returning 0 if the driver
8628 should exit, or nonzero if the driver should continue. */
8629
8630 int
8631 driver::maybe_print_and_exit () const
8632 {
8633 if (print_search_dirs)
8634 {
8635 printf (_("install: %s%s\n"),
8636 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
8637 gcc_exec_prefix ? "" : machine_suffix);
8638 printf (_("programs: %s\n"),
8639 build_search_list (&exec_prefixes, "", false, false));
8640 printf (_("libraries: %s\n"),
8641 build_search_list (&startfile_prefixes, "", false, true));
8642 return (0);
8643 }
8644
8645 if (print_file_name)
8646 {
8647 printf ("%s\n", find_file (print_file_name));
8648 return (0);
8649 }
8650
8651 if (print_prog_name)
8652 {
8653 if (use_ld != NULL && ! strcmp (print_prog_name, "ld"))
8654 {
8655 /* Append USE_LD to the default linker. */
8656 #ifdef DEFAULT_LINKER
8657 char *ld;
8658 # ifdef HAVE_HOST_EXECUTABLE_SUFFIX
8659 int len = (sizeof (DEFAULT_LINKER)
8660 - sizeof (HOST_EXECUTABLE_SUFFIX));
8661 ld = NULL;
8662 if (len > 0)
8663 {
8664 char *default_linker = xstrdup (DEFAULT_LINKER);
8665 /* Strip HOST_EXECUTABLE_SUFFIX if DEFAULT_LINKER contains
8666 HOST_EXECUTABLE_SUFFIX. */
8667 if (! strcmp (&default_linker[len], HOST_EXECUTABLE_SUFFIX))
8668 {
8669 default_linker[len] = '\0';
8670 ld = concat (default_linker, use_ld,
8671 HOST_EXECUTABLE_SUFFIX, NULL);
8672 }
8673 }
8674 if (ld == NULL)
8675 # endif
8676 ld = concat (DEFAULT_LINKER, use_ld, NULL);
8677 if (access (ld, X_OK) == 0)
8678 {
8679 printf ("%s\n", ld);
8680 return (0);
8681 }
8682 #endif
8683 print_prog_name = concat (print_prog_name, use_ld, NULL);
8684 }
8685 char *newname = find_a_program (print_prog_name);
8686 printf ("%s\n", (newname ? newname : print_prog_name));
8687 return (0);
8688 }
8689
8690 if (print_multi_lib)
8691 {
8692 print_multilib_info ();
8693 return (0);
8694 }
8695
8696 if (print_multi_directory)
8697 {
8698 if (multilib_dir == NULL)
8699 printf (".\n");
8700 else
8701 printf ("%s\n", multilib_dir);
8702 return (0);
8703 }
8704
8705 if (print_multiarch)
8706 {
8707 if (multiarch_dir == NULL)
8708 printf ("\n");
8709 else
8710 printf ("%s\n", multiarch_dir);
8711 return (0);
8712 }
8713
8714 if (print_sysroot)
8715 {
8716 if (target_system_root)
8717 {
8718 if (target_sysroot_suffix)
8719 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
8720 else
8721 printf ("%s\n", target_system_root);
8722 }
8723 return (0);
8724 }
8725
8726 if (print_multi_os_directory)
8727 {
8728 if (multilib_os_dir == NULL)
8729 printf (".\n");
8730 else
8731 printf ("%s\n", multilib_os_dir);
8732 return (0);
8733 }
8734
8735 if (print_sysroot_headers_suffix)
8736 {
8737 if (*sysroot_hdrs_suffix_spec)
8738 {
8739 printf("%s\n", (target_sysroot_hdrs_suffix
8740 ? target_sysroot_hdrs_suffix
8741 : ""));
8742 return (0);
8743 }
8744 else
8745 /* The error status indicates that only one set of fixed
8746 headers should be built. */
8747 fatal_error (input_location,
8748 "not configured with sysroot headers suffix");
8749 }
8750
8751 if (print_help_list)
8752 {
8753 display_help ();
8754
8755 if (! verbose_flag)
8756 {
8757 printf (_("\nFor bug reporting instructions, please see:\n"));
8758 printf ("%s.\n", bug_report_url);
8759
8760 return (0);
8761 }
8762
8763 /* We do not exit here. Instead we have created a fake input file
8764 called 'help-dummy' which needs to be compiled, and we pass this
8765 on the various sub-processes, along with the --help switch.
8766 Ensure their output appears after ours. */
8767 fputc ('\n', stdout);
8768 fflush (stdout);
8769 }
8770
8771 if (print_version)
8772 {
8773 printf (_("%s %s%s\n"), progname, pkgversion_string,
8774 version_string);
8775 printf ("Copyright %s 2021 Free Software Foundation, Inc.\n",
8776 _("(C)"));
8777 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
8778 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
8779 stdout);
8780 if (! verbose_flag)
8781 return 0;
8782
8783 /* We do not exit here. We use the same mechanism of --help to print
8784 the version of the sub-processes. */
8785 fputc ('\n', stdout);
8786 fflush (stdout);
8787 }
8788
8789 if (verbose_flag)
8790 {
8791 print_configuration (stderr);
8792 if (n_infiles == 0)
8793 return (0);
8794 }
8795
8796 return 1;
8797 }
8798
8799 /* Figure out what to do with each input file.
8800 Return true if we need to exit early from "main", false otherwise. */
8801
8802 bool
8803 driver::prepare_infiles ()
8804 {
8805 size_t i;
8806 int lang_n_infiles = 0;
8807
8808 if (n_infiles == added_libraries)
8809 fatal_error (input_location, "no input files");
8810
8811 if (seen_error ())
8812 /* Early exit needed from main. */
8813 return true;
8814
8815 /* Make a place to record the compiler output file names
8816 that correspond to the input files. */
8817
8818 i = n_infiles;
8819 i += lang_specific_extra_outfiles;
8820 outfiles = XCNEWVEC (const char *, i);
8821
8822 /* Record which files were specified explicitly as link input. */
8823
8824 explicit_link_files = XCNEWVEC (char, n_infiles);
8825
8826 combine_inputs = have_o || flag_wpa;
8827
8828 for (i = 0; (int) i < n_infiles; i++)
8829 {
8830 const char *name = infiles[i].name;
8831 struct compiler *compiler = lookup_compiler (name,
8832 strlen (name),
8833 infiles[i].language);
8834
8835 if (compiler && !(compiler->combinable))
8836 combine_inputs = false;
8837
8838 if (lang_n_infiles > 0 && compiler != input_file_compiler
8839 && infiles[i].language && infiles[i].language[0] != '*')
8840 infiles[i].incompiler = compiler;
8841 else if (compiler)
8842 {
8843 lang_n_infiles++;
8844 input_file_compiler = compiler;
8845 infiles[i].incompiler = compiler;
8846 }
8847 else
8848 {
8849 /* Since there is no compiler for this input file, assume it is a
8850 linker file. */
8851 explicit_link_files[i] = 1;
8852 infiles[i].incompiler = NULL;
8853 }
8854 infiles[i].compiled = false;
8855 infiles[i].preprocessed = false;
8856 }
8857
8858 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
8859 fatal_error (input_location,
8860 "cannot specify %<-o%> with %<-c%>, %<-S%> or %<-E%> "
8861 "with multiple files");
8862
8863 /* No early exit needed from main; we can continue. */
8864 return false;
8865 }
8866
8867 /* Run the spec machinery on each input file. */
8868
8869 void
8870 driver::do_spec_on_infiles () const
8871 {
8872 size_t i;
8873
8874 for (i = 0; (int) i < n_infiles; i++)
8875 {
8876 int this_file_error = 0;
8877
8878 /* Tell do_spec what to substitute for %i. */
8879
8880 input_file_number = i;
8881 set_input (infiles[i].name);
8882
8883 if (infiles[i].compiled)
8884 continue;
8885
8886 /* Use the same thing in %o, unless cp->spec says otherwise. */
8887
8888 outfiles[i] = gcc_input_filename;
8889
8890 /* Figure out which compiler from the file's suffix. */
8891
8892 input_file_compiler
8893 = lookup_compiler (infiles[i].name, input_filename_length,
8894 infiles[i].language);
8895
8896 if (input_file_compiler)
8897 {
8898 /* Ok, we found an applicable compiler. Run its spec. */
8899
8900 if (input_file_compiler->spec[0] == '#')
8901 {
8902 error ("%s: %s compiler not installed on this system",
8903 gcc_input_filename, &input_file_compiler->spec[1]);
8904 this_file_error = 1;
8905 }
8906 else
8907 {
8908 int value;
8909
8910 if (compare_debug)
8911 {
8912 free (debug_check_temp_file[0]);
8913 debug_check_temp_file[0] = NULL;
8914
8915 free (debug_check_temp_file[1]);
8916 debug_check_temp_file[1] = NULL;
8917 }
8918
8919 value = do_spec (input_file_compiler->spec);
8920 infiles[i].compiled = true;
8921 if (value < 0)
8922 this_file_error = 1;
8923 else if (compare_debug && debug_check_temp_file[0])
8924 {
8925 if (verbose_flag)
8926 inform (UNKNOWN_LOCATION,
8927 "recompiling with %<-fcompare-debug%>");
8928
8929 compare_debug = -compare_debug;
8930 n_switches = n_switches_debug_check[1];
8931 n_switches_alloc = n_switches_alloc_debug_check[1];
8932 switches = switches_debug_check[1];
8933
8934 value = do_spec (input_file_compiler->spec);
8935
8936 compare_debug = -compare_debug;
8937 n_switches = n_switches_debug_check[0];
8938 n_switches_alloc = n_switches_alloc_debug_check[0];
8939 switches = switches_debug_check[0];
8940
8941 if (value < 0)
8942 {
8943 error ("during %<-fcompare-debug%> recompilation");
8944 this_file_error = 1;
8945 }
8946
8947 gcc_assert (debug_check_temp_file[1]
8948 && filename_cmp (debug_check_temp_file[0],
8949 debug_check_temp_file[1]));
8950
8951 if (verbose_flag)
8952 inform (UNKNOWN_LOCATION, "comparing final insns dumps");
8953
8954 if (compare_files (debug_check_temp_file))
8955 this_file_error = 1;
8956 }
8957
8958 if (compare_debug)
8959 {
8960 free (debug_check_temp_file[0]);
8961 debug_check_temp_file[0] = NULL;
8962
8963 free (debug_check_temp_file[1]);
8964 debug_check_temp_file[1] = NULL;
8965 }
8966 }
8967 }
8968
8969 /* If this file's name does not contain a recognized suffix,
8970 record it as explicit linker input. */
8971
8972 else
8973 explicit_link_files[i] = 1;
8974
8975 /* Clear the delete-on-failure queue, deleting the files in it
8976 if this compilation failed. */
8977
8978 if (this_file_error)
8979 {
8980 delete_failure_queue ();
8981 errorcount++;
8982 }
8983 /* If this compilation succeeded, don't delete those files later. */
8984 clear_failure_queue ();
8985 }
8986
8987 /* Reset the input file name to the first compile/object file name, for use
8988 with %b in LINK_SPEC. We use the first input file that we can find
8989 a compiler to compile it instead of using infiles.language since for
8990 languages other than C we use aliases that we then lookup later. */
8991 if (n_infiles > 0)
8992 {
8993 int i;
8994
8995 for (i = 0; i < n_infiles ; i++)
8996 if (infiles[i].incompiler
8997 || (infiles[i].language && infiles[i].language[0] != '*'))
8998 {
8999 set_input (infiles[i].name);
9000 break;
9001 }
9002 }
9003
9004 if (!seen_error ())
9005 {
9006 /* Make sure INPUT_FILE_NUMBER points to first available open
9007 slot. */
9008 input_file_number = n_infiles;
9009 if (lang_specific_pre_link ())
9010 errorcount++;
9011 }
9012 }
9013
9014 /* If we have to run the linker, do it now. */
9015
9016 void
9017 driver::maybe_run_linker (const char *argv0) const
9018 {
9019 size_t i;
9020 int linker_was_run = 0;
9021 int num_linker_inputs;
9022
9023 /* Determine if there are any linker input files. */
9024 num_linker_inputs = 0;
9025 for (i = 0; (int) i < n_infiles; i++)
9026 if (explicit_link_files[i] || outfiles[i] != NULL)
9027 num_linker_inputs++;
9028
9029 /* Arrange for temporary file names created during linking to take
9030 on names related with the linker output rather than with the
9031 inputs when appropriate. */
9032 if (outbase && *outbase)
9033 {
9034 if (dumpdir)
9035 {
9036 char *tofree = dumpdir;
9037 gcc_checking_assert (strlen (dumpdir) == dumpdir_length);
9038 dumpdir = concat (dumpdir, outbase, ".", NULL);
9039 free (tofree);
9040 }
9041 else
9042 dumpdir = concat (outbase, ".", NULL);
9043 dumpdir_length += strlen (outbase) + 1;
9044 dumpdir_trailing_dash_added = true;
9045 }
9046 else if (dumpdir_trailing_dash_added)
9047 {
9048 gcc_assert (dumpdir[dumpdir_length - 1] == '-');
9049 dumpdir[dumpdir_length - 1] = '.';
9050 }
9051
9052 if (dumpdir_trailing_dash_added)
9053 {
9054 gcc_assert (dumpdir_length > 0);
9055 gcc_assert (dumpdir[dumpdir_length - 1] == '.');
9056 dumpdir_length--;
9057 }
9058
9059 free (outbase);
9060 input_basename = outbase = NULL;
9061 outbase_length = suffixed_basename_length = basename_length = 0;
9062
9063 /* Run ld to link all the compiler output files. */
9064
9065 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
9066 {
9067 int tmp = execution_count;
9068
9069 detect_jobserver ();
9070
9071 if (! have_c)
9072 {
9073 #if HAVE_LTO_PLUGIN > 0
9074 #if HAVE_LTO_PLUGIN == 2
9075 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
9076 #else
9077 const char *fuse_linker_plugin = "fuse-linker-plugin";
9078 #endif
9079 #endif
9080
9081 /* We'll use ld if we can't find collect2. */
9082 if (! strcmp (linker_name_spec, "collect2"))
9083 {
9084 char *s = find_a_program ("collect2");
9085 if (s == NULL)
9086 set_static_spec_shared (&linker_name_spec, "ld");
9087 }
9088
9089 #if HAVE_LTO_PLUGIN > 0
9090 #if HAVE_LTO_PLUGIN == 2
9091 if (!switch_matches (fno_use_linker_plugin,
9092 fno_use_linker_plugin
9093 + strlen (fno_use_linker_plugin), 0))
9094 #else
9095 if (switch_matches (fuse_linker_plugin,
9096 fuse_linker_plugin
9097 + strlen (fuse_linker_plugin), 0))
9098 #endif
9099 {
9100 char *temp_spec = find_a_file (&exec_prefixes,
9101 LTOPLUGINSONAME, R_OK,
9102 false);
9103 if (!temp_spec)
9104 fatal_error (input_location,
9105 "%<-fuse-linker-plugin%>, but %s not found",
9106 LTOPLUGINSONAME);
9107 linker_plugin_file_spec = convert_white_space (temp_spec);
9108 }
9109 #endif
9110 set_static_spec_shared (&lto_gcc_spec, argv0);
9111 }
9112
9113 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
9114 for collect. */
9115 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
9116 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
9117
9118 if (print_subprocess_help == 1)
9119 {
9120 printf (_("\nLinker options\n==============\n\n"));
9121 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
9122 " to the linker.\n\n"));
9123 fflush (stdout);
9124 }
9125 int value = do_spec (link_command_spec);
9126 if (value < 0)
9127 errorcount = 1;
9128 linker_was_run = (tmp != execution_count);
9129 }
9130
9131 /* If options said don't run linker,
9132 complain about input files to be given to the linker. */
9133
9134 if (! linker_was_run && !seen_error ())
9135 for (i = 0; (int) i < n_infiles; i++)
9136 if (explicit_link_files[i]
9137 && !(infiles[i].language && infiles[i].language[0] == '*'))
9138 {
9139 warning (0, "%s: linker input file unused because linking not done",
9140 outfiles[i]);
9141 if (access (outfiles[i], F_OK) < 0)
9142 /* This is can be an indication the user specifed an errorneous
9143 separated option value, (or used the wrong prefix for an
9144 option). */
9145 error ("%s: linker input file not found: %m", outfiles[i]);
9146 }
9147 }
9148
9149 /* The end of "main". */
9150
9151 void
9152 driver::final_actions () const
9153 {
9154 /* Delete some or all of the temporary files we made. */
9155
9156 if (seen_error ())
9157 delete_failure_queue ();
9158 delete_temp_files ();
9159
9160 if (print_help_list)
9161 {
9162 printf (("\nFor bug reporting instructions, please see:\n"));
9163 printf ("%s\n", bug_report_url);
9164 }
9165 }
9166
9167 /* Detect whether jobserver is active and working. If not drop
9168 --jobserver-auth from MAKEFLAGS. */
9169
9170 void
9171 driver::detect_jobserver () const
9172 {
9173 /* Detect jobserver and drop it if it's not working. */
9174 const char *makeflags = env.get ("MAKEFLAGS");
9175 if (makeflags != NULL)
9176 {
9177 const char *needle = "--jobserver-auth=";
9178 const char *n = strstr (makeflags, needle);
9179 if (n != NULL)
9180 {
9181 int rfd = -1;
9182 int wfd = -1;
9183
9184 bool jobserver
9185 = (sscanf (n + strlen (needle), "%d,%d", &rfd, &wfd) == 2
9186 && rfd > 0
9187 && wfd > 0
9188 && is_valid_fd (rfd)
9189 && is_valid_fd (wfd));
9190
9191 /* Drop the jobserver if it's not working now. */
9192 if (!jobserver)
9193 {
9194 unsigned offset = n - makeflags;
9195 char *dup = xstrdup (makeflags);
9196 dup[offset] = '\0';
9197
9198 const char *space = strchr (makeflags + offset, ' ');
9199 if (space != NULL)
9200 strcpy (dup + offset, space);
9201 xputenv (concat ("MAKEFLAGS=", dup, NULL));
9202 }
9203 }
9204 }
9205 }
9206
9207 /* Determine what the exit code of the driver should be. */
9208
9209 int
9210 driver::get_exit_code () const
9211 {
9212 return (signal_count != 0 ? 2
9213 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
9214 : 0);
9215 }
9216
9217 /* Find the proper compilation spec for the file name NAME,
9218 whose length is LENGTH. LANGUAGE is the specified language,
9219 or 0 if this file is to be passed to the linker. */
9220
9221 static struct compiler *
9222 lookup_compiler (const char *name, size_t length, const char *language)
9223 {
9224 struct compiler *cp;
9225
9226 /* If this was specified by the user to be a linker input, indicate that. */
9227 if (language != 0 && language[0] == '*')
9228 return 0;
9229
9230 /* Otherwise, look for the language, if one is spec'd. */
9231 if (language != 0)
9232 {
9233 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
9234 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
9235 {
9236 if (name != NULL && strcmp (name, "-") == 0
9237 && (strcmp (cp->suffix, "@c-header") == 0
9238 || strcmp (cp->suffix, "@c++-header") == 0)
9239 && !have_E)
9240 fatal_error (input_location,
9241 "cannot use %<-%> as input filename for a "
9242 "precompiled header");
9243
9244 return cp;
9245 }
9246
9247 error ("language %s not recognized", language);
9248 return 0;
9249 }
9250
9251 /* Look for a suffix. */
9252 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
9253 {
9254 if (/* The suffix `-' matches only the file name `-'. */
9255 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
9256 || (strlen (cp->suffix) < length
9257 /* See if the suffix matches the end of NAME. */
9258 && !strcmp (cp->suffix,
9259 name + length - strlen (cp->suffix))
9260 ))
9261 break;
9262 }
9263
9264 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
9265 /* Look again, but case-insensitively this time. */
9266 if (cp < compilers)
9267 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
9268 {
9269 if (/* The suffix `-' matches only the file name `-'. */
9270 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
9271 || (strlen (cp->suffix) < length
9272 /* See if the suffix matches the end of NAME. */
9273 && ((!strcmp (cp->suffix,
9274 name + length - strlen (cp->suffix))
9275 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
9276 && !strcasecmp (cp->suffix,
9277 name + length - strlen (cp->suffix)))
9278 ))
9279 break;
9280 }
9281 #endif
9282
9283 if (cp >= compilers)
9284 {
9285 if (cp->spec[0] != '@')
9286 /* A non-alias entry: return it. */
9287 return cp;
9288
9289 /* An alias entry maps a suffix to a language.
9290 Search for the language; pass 0 for NAME and LENGTH
9291 to avoid infinite recursion if language not found. */
9292 return lookup_compiler (NULL, 0, cp->spec + 1);
9293 }
9294 return 0;
9295 }
9296 \f
9297 static char *
9298 save_string (const char *s, int len)
9299 {
9300 char *result = XNEWVEC (char, len + 1);
9301
9302 gcc_checking_assert (strlen (s) >= (unsigned int) len);
9303 memcpy (result, s, len);
9304 result[len] = 0;
9305 return result;
9306 }
9307
9308 \f
9309 static inline void
9310 validate_switches_from_spec (const char *spec, bool user)
9311 {
9312 const char *p = spec;
9313 char c;
9314 while ((c = *p++))
9315 if (c == '%'
9316 && (*p == '{'
9317 || *p == '<'
9318 || (*p == 'W' && *++p == '{')
9319 || (*p == '@' && *++p == '{')))
9320 /* We have a switch spec. */
9321 p = validate_switches (p + 1, user, *p == '{');
9322 }
9323
9324 static void
9325 validate_all_switches (void)
9326 {
9327 struct compiler *comp;
9328 struct spec_list *spec;
9329
9330 for (comp = compilers; comp->spec; comp++)
9331 validate_switches_from_spec (comp->spec, false);
9332
9333 /* Look through the linked list of specs read from the specs file. */
9334 for (spec = specs; spec; spec = spec->next)
9335 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
9336
9337 validate_switches_from_spec (link_command_spec, false);
9338 }
9339
9340 /* Look at the switch-name that comes after START and mark as valid
9341 all supplied switches that match it. If BRACED, handle other
9342 switches after '|' and '&', and specs after ':' until ';' or '}',
9343 going back for more switches after ';'. Without BRACED, handle
9344 only one atom. Return a pointer to whatever follows the handled
9345 items, after the closing brace if BRACED. */
9346
9347 static const char *
9348 validate_switches (const char *start, bool user_spec, bool braced)
9349 {
9350 const char *p = start;
9351 const char *atom;
9352 size_t len;
9353 int i;
9354 bool suffix = false;
9355 bool starred = false;
9356
9357 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
9358
9359 next_member:
9360 SKIP_WHITE ();
9361
9362 if (*p == '!')
9363 p++;
9364
9365 SKIP_WHITE ();
9366 if (*p == '.' || *p == ',')
9367 suffix = true, p++;
9368
9369 atom = p;
9370 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
9371 || *p == ',' || *p == '.' || *p == '@')
9372 p++;
9373 len = p - atom;
9374
9375 if (*p == '*')
9376 starred = true, p++;
9377
9378 SKIP_WHITE ();
9379
9380 if (!suffix)
9381 {
9382 /* Mark all matching switches as valid. */
9383 for (i = 0; i < n_switches; i++)
9384 if (!strncmp (switches[i].part1, atom, len)
9385 && (starred || switches[i].part1[len] == '\0')
9386 && (switches[i].known || user_spec))
9387 switches[i].validated = true;
9388 }
9389
9390 if (!braced)
9391 return p;
9392
9393 if (*p) p++;
9394 if (*p && (p[-1] == '|' || p[-1] == '&'))
9395 goto next_member;
9396
9397 if (*p && p[-1] == ':')
9398 {
9399 while (*p && *p != ';' && *p != '}')
9400 {
9401 if (*p == '%')
9402 {
9403 p++;
9404 if (*p == '{' || *p == '<')
9405 p = validate_switches (p+1, user_spec, *p == '{');
9406 else if (p[0] == 'W' && p[1] == '{')
9407 p = validate_switches (p+2, user_spec, true);
9408 else if (p[0] == '@' && p[1] == '{')
9409 p = validate_switches (p+2, user_spec, true);
9410 }
9411 else
9412 p++;
9413 }
9414
9415 if (*p) p++;
9416 if (*p && p[-1] == ';')
9417 goto next_member;
9418 }
9419
9420 return p;
9421 #undef SKIP_WHITE
9422 }
9423 \f
9424 struct mdswitchstr
9425 {
9426 const char *str;
9427 int len;
9428 };
9429
9430 static struct mdswitchstr *mdswitches;
9431 static int n_mdswitches;
9432
9433 /* Check whether a particular argument was used. The first time we
9434 canonicalize the switches to keep only the ones we care about. */
9435
9436 struct used_arg_t
9437 {
9438 public:
9439 int operator () (const char *p, int len);
9440 void finalize ();
9441
9442 private:
9443 struct mswitchstr
9444 {
9445 const char *str;
9446 const char *replace;
9447 int len;
9448 int rep_len;
9449 };
9450
9451 mswitchstr *mswitches;
9452 int n_mswitches;
9453
9454 };
9455
9456 used_arg_t used_arg;
9457
9458 int
9459 used_arg_t::operator () (const char *p, int len)
9460 {
9461 int i, j;
9462
9463 if (!mswitches)
9464 {
9465 struct mswitchstr *matches;
9466 const char *q;
9467 int cnt = 0;
9468
9469 /* Break multilib_matches into the component strings of string
9470 and replacement string. */
9471 for (q = multilib_matches; *q != '\0'; q++)
9472 if (*q == ';')
9473 cnt++;
9474
9475 matches
9476 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
9477 i = 0;
9478 q = multilib_matches;
9479 while (*q != '\0')
9480 {
9481 matches[i].str = q;
9482 while (*q != ' ')
9483 {
9484 if (*q == '\0')
9485 {
9486 invalid_matches:
9487 fatal_error (input_location, "multilib spec %qs is invalid",
9488 multilib_matches);
9489 }
9490 q++;
9491 }
9492 matches[i].len = q - matches[i].str;
9493
9494 matches[i].replace = ++q;
9495 while (*q != ';' && *q != '\0')
9496 {
9497 if (*q == ' ')
9498 goto invalid_matches;
9499 q++;
9500 }
9501 matches[i].rep_len = q - matches[i].replace;
9502 i++;
9503 if (*q == ';')
9504 q++;
9505 }
9506
9507 /* Now build a list of the replacement string for switches that we care
9508 about. Make sure we allocate at least one entry. This prevents
9509 xmalloc from calling fatal, and prevents us from re-executing this
9510 block of code. */
9511 mswitches
9512 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
9513 for (i = 0; i < n_switches; i++)
9514 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
9515 {
9516 int xlen = strlen (switches[i].part1);
9517 for (j = 0; j < cnt; j++)
9518 if (xlen == matches[j].len
9519 && ! strncmp (switches[i].part1, matches[j].str, xlen))
9520 {
9521 mswitches[n_mswitches].str = matches[j].replace;
9522 mswitches[n_mswitches].len = matches[j].rep_len;
9523 mswitches[n_mswitches].replace = (char *) 0;
9524 mswitches[n_mswitches].rep_len = 0;
9525 n_mswitches++;
9526 break;
9527 }
9528 }
9529
9530 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
9531 on the command line nor any options mutually incompatible with
9532 them. */
9533 for (i = 0; i < n_mdswitches; i++)
9534 {
9535 const char *r;
9536
9537 for (q = multilib_options; *q != '\0'; *q && q++)
9538 {
9539 while (*q == ' ')
9540 q++;
9541
9542 r = q;
9543 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
9544 || strchr (" /", q[mdswitches[i].len]) == NULL)
9545 {
9546 while (*q != ' ' && *q != '/' && *q != '\0')
9547 q++;
9548 if (*q != '/')
9549 break;
9550 q++;
9551 }
9552
9553 if (*q != ' ' && *q != '\0')
9554 {
9555 while (*r != ' ' && *r != '\0')
9556 {
9557 q = r;
9558 while (*q != ' ' && *q != '/' && *q != '\0')
9559 q++;
9560
9561 if (used_arg (r, q - r))
9562 break;
9563
9564 if (*q != '/')
9565 {
9566 mswitches[n_mswitches].str = mdswitches[i].str;
9567 mswitches[n_mswitches].len = mdswitches[i].len;
9568 mswitches[n_mswitches].replace = (char *) 0;
9569 mswitches[n_mswitches].rep_len = 0;
9570 n_mswitches++;
9571 break;
9572 }
9573
9574 r = q + 1;
9575 }
9576 break;
9577 }
9578 }
9579 }
9580 }
9581
9582 for (i = 0; i < n_mswitches; i++)
9583 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
9584 return 1;
9585
9586 return 0;
9587 }
9588
9589 void used_arg_t::finalize ()
9590 {
9591 XDELETEVEC (mswitches);
9592 mswitches = NULL;
9593 n_mswitches = 0;
9594 }
9595
9596
9597 static int
9598 default_arg (const char *p, int len)
9599 {
9600 int i;
9601
9602 for (i = 0; i < n_mdswitches; i++)
9603 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
9604 return 1;
9605
9606 return 0;
9607 }
9608
9609 /* Work out the subdirectory to use based on the options. The format of
9610 multilib_select is a list of elements. Each element is a subdirectory
9611 name followed by a list of options followed by a semicolon. The format
9612 of multilib_exclusions is the same, but without the preceding
9613 directory. First gcc will check the exclusions, if none of the options
9614 beginning with an exclamation point are present, and all of the other
9615 options are present, then we will ignore this completely. Passing
9616 that, gcc will consider each multilib_select in turn using the same
9617 rules for matching the options. If a match is found, that subdirectory
9618 will be used.
9619 A subdirectory name is optionally followed by a colon and the corresponding
9620 multiarch name. */
9621
9622 static void
9623 set_multilib_dir (void)
9624 {
9625 const char *p;
9626 unsigned int this_path_len;
9627 const char *this_path, *this_arg;
9628 const char *start, *end;
9629 int not_arg;
9630 int ok, ndfltok, first;
9631
9632 n_mdswitches = 0;
9633 start = multilib_defaults;
9634 while (*start == ' ' || *start == '\t')
9635 start++;
9636 while (*start != '\0')
9637 {
9638 n_mdswitches++;
9639 while (*start != ' ' && *start != '\t' && *start != '\0')
9640 start++;
9641 while (*start == ' ' || *start == '\t')
9642 start++;
9643 }
9644
9645 if (n_mdswitches)
9646 {
9647 int i = 0;
9648
9649 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
9650 for (start = multilib_defaults; *start != '\0'; start = end + 1)
9651 {
9652 while (*start == ' ' || *start == '\t')
9653 start++;
9654
9655 if (*start == '\0')
9656 break;
9657
9658 for (end = start + 1;
9659 *end != ' ' && *end != '\t' && *end != '\0'; end++)
9660 ;
9661
9662 obstack_grow (&multilib_obstack, start, end - start);
9663 obstack_1grow (&multilib_obstack, 0);
9664 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
9665 mdswitches[i++].len = end - start;
9666
9667 if (*end == '\0')
9668 break;
9669 }
9670 }
9671
9672 p = multilib_exclusions;
9673 while (*p != '\0')
9674 {
9675 /* Ignore newlines. */
9676 if (*p == '\n')
9677 {
9678 ++p;
9679 continue;
9680 }
9681
9682 /* Check the arguments. */
9683 ok = 1;
9684 while (*p != ';')
9685 {
9686 if (*p == '\0')
9687 {
9688 invalid_exclusions:
9689 fatal_error (input_location, "multilib exclusions %qs is invalid",
9690 multilib_exclusions);
9691 }
9692
9693 if (! ok)
9694 {
9695 ++p;
9696 continue;
9697 }
9698
9699 this_arg = p;
9700 while (*p != ' ' && *p != ';')
9701 {
9702 if (*p == '\0')
9703 goto invalid_exclusions;
9704 ++p;
9705 }
9706
9707 if (*this_arg != '!')
9708 not_arg = 0;
9709 else
9710 {
9711 not_arg = 1;
9712 ++this_arg;
9713 }
9714
9715 ok = used_arg (this_arg, p - this_arg);
9716 if (not_arg)
9717 ok = ! ok;
9718
9719 if (*p == ' ')
9720 ++p;
9721 }
9722
9723 if (ok)
9724 return;
9725
9726 ++p;
9727 }
9728
9729 first = 1;
9730 p = multilib_select;
9731
9732 /* Append multilib reuse rules if any. With those rules, we can reuse
9733 one multilib for certain different options sets. */
9734 if (strlen (multilib_reuse) > 0)
9735 p = concat (p, multilib_reuse, NULL);
9736
9737 while (*p != '\0')
9738 {
9739 /* Ignore newlines. */
9740 if (*p == '\n')
9741 {
9742 ++p;
9743 continue;
9744 }
9745
9746 /* Get the initial path. */
9747 this_path = p;
9748 while (*p != ' ')
9749 {
9750 if (*p == '\0')
9751 {
9752 invalid_select:
9753 fatal_error (input_location, "multilib select %qs %qs is invalid",
9754 multilib_select, multilib_reuse);
9755 }
9756 ++p;
9757 }
9758 this_path_len = p - this_path;
9759
9760 /* Check the arguments. */
9761 ok = 1;
9762 ndfltok = 1;
9763 ++p;
9764 while (*p != ';')
9765 {
9766 if (*p == '\0')
9767 goto invalid_select;
9768
9769 if (! ok)
9770 {
9771 ++p;
9772 continue;
9773 }
9774
9775 this_arg = p;
9776 while (*p != ' ' && *p != ';')
9777 {
9778 if (*p == '\0')
9779 goto invalid_select;
9780 ++p;
9781 }
9782
9783 if (*this_arg != '!')
9784 not_arg = 0;
9785 else
9786 {
9787 not_arg = 1;
9788 ++this_arg;
9789 }
9790
9791 /* If this is a default argument, we can just ignore it.
9792 This is true even if this_arg begins with '!'. Beginning
9793 with '!' does not mean that this argument is necessarily
9794 inappropriate for this library: it merely means that
9795 there is a more specific library which uses this
9796 argument. If this argument is a default, we need not
9797 consider that more specific library. */
9798 ok = used_arg (this_arg, p - this_arg);
9799 if (not_arg)
9800 ok = ! ok;
9801
9802 if (! ok)
9803 ndfltok = 0;
9804
9805 if (default_arg (this_arg, p - this_arg))
9806 ok = 1;
9807
9808 if (*p == ' ')
9809 ++p;
9810 }
9811
9812 if (ok && first)
9813 {
9814 if (this_path_len != 1
9815 || this_path[0] != '.')
9816 {
9817 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
9818 char *q;
9819
9820 strncpy (new_multilib_dir, this_path, this_path_len);
9821 new_multilib_dir[this_path_len] = '\0';
9822 q = strchr (new_multilib_dir, ':');
9823 if (q != NULL)
9824 *q = '\0';
9825 multilib_dir = new_multilib_dir;
9826 }
9827 first = 0;
9828 }
9829
9830 if (ndfltok)
9831 {
9832 const char *q = this_path, *end = this_path + this_path_len;
9833
9834 while (q < end && *q != ':')
9835 q++;
9836 if (q < end)
9837 {
9838 const char *q2 = q + 1, *ml_end = end;
9839 char *new_multilib_os_dir;
9840
9841 while (q2 < end && *q2 != ':')
9842 q2++;
9843 if (*q2 == ':')
9844 ml_end = q2;
9845 if (ml_end - q == 1)
9846 multilib_os_dir = xstrdup (".");
9847 else
9848 {
9849 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
9850 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
9851 new_multilib_os_dir[ml_end - q - 1] = '\0';
9852 multilib_os_dir = new_multilib_os_dir;
9853 }
9854
9855 if (q2 < end && *q2 == ':')
9856 {
9857 char *new_multiarch_dir = XNEWVEC (char, end - q2);
9858 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
9859 new_multiarch_dir[end - q2 - 1] = '\0';
9860 multiarch_dir = new_multiarch_dir;
9861 }
9862 break;
9863 }
9864 }
9865
9866 ++p;
9867 }
9868
9869 if (multilib_dir == NULL && multilib_os_dir != NULL
9870 && strcmp (multilib_os_dir, ".") == 0)
9871 {
9872 free (CONST_CAST (char *, multilib_os_dir));
9873 multilib_os_dir = NULL;
9874 }
9875 else if (multilib_dir != NULL && multilib_os_dir == NULL)
9876 multilib_os_dir = multilib_dir;
9877 }
9878
9879 /* Print out the multiple library subdirectory selection
9880 information. This prints out a series of lines. Each line looks
9881 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
9882 required. Only the desired options are printed out, the negative
9883 matches. The options are print without a leading dash. There are
9884 no spaces to make it easy to use the information in the shell.
9885 Each subdirectory is printed only once. This assumes the ordering
9886 generated by the genmultilib script. Also, we leave out ones that match
9887 the exclusions. */
9888
9889 static void
9890 print_multilib_info (void)
9891 {
9892 const char *p = multilib_select;
9893 const char *last_path = 0, *this_path;
9894 int skip;
9895 int not_arg;
9896 unsigned int last_path_len = 0;
9897
9898 while (*p != '\0')
9899 {
9900 skip = 0;
9901 /* Ignore newlines. */
9902 if (*p == '\n')
9903 {
9904 ++p;
9905 continue;
9906 }
9907
9908 /* Get the initial path. */
9909 this_path = p;
9910 while (*p != ' ')
9911 {
9912 if (*p == '\0')
9913 {
9914 invalid_select:
9915 fatal_error (input_location,
9916 "multilib select %qs is invalid", multilib_select);
9917 }
9918
9919 ++p;
9920 }
9921
9922 /* When --disable-multilib was used but target defines
9923 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
9924 with .:: for multiarch configurations) are there just to find
9925 multilib_os_dir, so skip them from output. */
9926 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
9927 skip = 1;
9928
9929 /* Check for matches with the multilib_exclusions. We don't bother
9930 with the '!' in either list. If any of the exclusion rules match
9931 all of its options with the select rule, we skip it. */
9932 {
9933 const char *e = multilib_exclusions;
9934 const char *this_arg;
9935
9936 while (*e != '\0')
9937 {
9938 int m = 1;
9939 /* Ignore newlines. */
9940 if (*e == '\n')
9941 {
9942 ++e;
9943 continue;
9944 }
9945
9946 /* Check the arguments. */
9947 while (*e != ';')
9948 {
9949 const char *q;
9950 int mp = 0;
9951
9952 if (*e == '\0')
9953 {
9954 invalid_exclusion:
9955 fatal_error (input_location,
9956 "multilib exclusion %qs is invalid",
9957 multilib_exclusions);
9958 }
9959
9960 if (! m)
9961 {
9962 ++e;
9963 continue;
9964 }
9965
9966 this_arg = e;
9967
9968 while (*e != ' ' && *e != ';')
9969 {
9970 if (*e == '\0')
9971 goto invalid_exclusion;
9972 ++e;
9973 }
9974
9975 q = p + 1;
9976 while (*q != ';')
9977 {
9978 const char *arg;
9979 int len = e - this_arg;
9980
9981 if (*q == '\0')
9982 goto invalid_select;
9983
9984 arg = q;
9985
9986 while (*q != ' ' && *q != ';')
9987 {
9988 if (*q == '\0')
9989 goto invalid_select;
9990 ++q;
9991 }
9992
9993 if (! strncmp (arg, this_arg,
9994 (len < q - arg) ? q - arg : len)
9995 || default_arg (this_arg, e - this_arg))
9996 {
9997 mp = 1;
9998 break;
9999 }
10000
10001 if (*q == ' ')
10002 ++q;
10003 }
10004
10005 if (! mp)
10006 m = 0;
10007
10008 if (*e == ' ')
10009 ++e;
10010 }
10011
10012 if (m)
10013 {
10014 skip = 1;
10015 break;
10016 }
10017
10018 if (*e != '\0')
10019 ++e;
10020 }
10021 }
10022
10023 if (! skip)
10024 {
10025 /* If this is a duplicate, skip it. */
10026 skip = (last_path != 0
10027 && (unsigned int) (p - this_path) == last_path_len
10028 && ! filename_ncmp (last_path, this_path, last_path_len));
10029
10030 last_path = this_path;
10031 last_path_len = p - this_path;
10032 }
10033
10034 /* If all required arguments are default arguments, and no default
10035 arguments appear in the ! argument list, then we can skip it.
10036 We will already have printed a directory identical to this one
10037 which does not require that default argument. */
10038 if (! skip)
10039 {
10040 const char *q;
10041 bool default_arg_ok = false;
10042
10043 q = p + 1;
10044 while (*q != ';')
10045 {
10046 const char *arg;
10047
10048 if (*q == '\0')
10049 goto invalid_select;
10050
10051 if (*q == '!')
10052 {
10053 not_arg = 1;
10054 q++;
10055 }
10056 else
10057 not_arg = 0;
10058 arg = q;
10059
10060 while (*q != ' ' && *q != ';')
10061 {
10062 if (*q == '\0')
10063 goto invalid_select;
10064 ++q;
10065 }
10066
10067 if (default_arg (arg, q - arg))
10068 {
10069 /* Stop checking if any default arguments appeared in not
10070 list. */
10071 if (not_arg)
10072 {
10073 default_arg_ok = false;
10074 break;
10075 }
10076
10077 default_arg_ok = true;
10078 }
10079 else if (!not_arg)
10080 {
10081 /* Stop checking if any required argument is not provided by
10082 default arguments. */
10083 default_arg_ok = false;
10084 break;
10085 }
10086
10087 if (*q == ' ')
10088 ++q;
10089 }
10090
10091 /* Make sure all default argument is OK for this multi-lib set. */
10092 if (default_arg_ok)
10093 skip = 1;
10094 else
10095 skip = 0;
10096 }
10097
10098 if (! skip)
10099 {
10100 const char *p1;
10101
10102 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
10103 putchar (*p1);
10104 putchar (';');
10105 }
10106
10107 ++p;
10108 while (*p != ';')
10109 {
10110 int use_arg;
10111
10112 if (*p == '\0')
10113 goto invalid_select;
10114
10115 if (skip)
10116 {
10117 ++p;
10118 continue;
10119 }
10120
10121 use_arg = *p != '!';
10122
10123 if (use_arg)
10124 putchar ('@');
10125
10126 while (*p != ' ' && *p != ';')
10127 {
10128 if (*p == '\0')
10129 goto invalid_select;
10130 if (use_arg)
10131 putchar (*p);
10132 ++p;
10133 }
10134
10135 if (*p == ' ')
10136 ++p;
10137 }
10138
10139 if (! skip)
10140 {
10141 /* If there are extra options, print them now. */
10142 if (multilib_extra && *multilib_extra)
10143 {
10144 int print_at = TRUE;
10145 const char *q;
10146
10147 for (q = multilib_extra; *q != '\0'; q++)
10148 {
10149 if (*q == ' ')
10150 print_at = TRUE;
10151 else
10152 {
10153 if (print_at)
10154 putchar ('@');
10155 putchar (*q);
10156 print_at = FALSE;
10157 }
10158 }
10159 }
10160
10161 putchar ('\n');
10162 }
10163
10164 ++p;
10165 }
10166 }
10167 \f
10168 /* getenv built-in spec function.
10169
10170 Returns the value of the environment variable given by its first argument,
10171 concatenated with the second argument. If the variable is not defined, a
10172 fatal error is issued unless such undefs are internally allowed, in which
10173 case the variable name prefixed by a '/' is used as the variable value.
10174
10175 The leading '/' allows using the result at a spot where a full path would
10176 normally be expected and when the actual value doesn't really matter since
10177 undef vars are allowed. */
10178
10179 static const char *
10180 getenv_spec_function (int argc, const char **argv)
10181 {
10182 const char *value;
10183 const char *varname;
10184
10185 char *result;
10186 char *ptr;
10187 size_t len;
10188
10189 if (argc != 2)
10190 return NULL;
10191
10192 varname = argv[0];
10193 value = env.get (varname);
10194
10195 /* If the variable isn't defined and this is allowed, craft our expected
10196 return value. Assume variable names used in specs strings don't contain
10197 any active spec character so don't need escaping. */
10198 if (!value && spec_undefvar_allowed)
10199 {
10200 result = XNEWVAR (char, strlen(varname) + 2);
10201 sprintf (result, "/%s", varname);
10202 return result;
10203 }
10204
10205 if (!value)
10206 fatal_error (input_location,
10207 "environment variable %qs not defined", varname);
10208
10209 /* We have to escape every character of the environment variable so
10210 they are not interpreted as active spec characters. A
10211 particularly painful case is when we are reading a variable
10212 holding a windows path complete with \ separators. */
10213 len = strlen (value) * 2 + strlen (argv[1]) + 1;
10214 result = XNEWVAR (char, len);
10215 for (ptr = result; *value; ptr += 2)
10216 {
10217 ptr[0] = '\\';
10218 ptr[1] = *value++;
10219 }
10220
10221 strcpy (ptr, argv[1]);
10222
10223 return result;
10224 }
10225
10226 /* if-exists built-in spec function.
10227
10228 Checks to see if the file specified by the absolute pathname in
10229 ARGS exists. Returns that pathname if found.
10230
10231 The usual use for this function is to check for a library file
10232 (whose name has been expanded with %s). */
10233
10234 static const char *
10235 if_exists_spec_function (int argc, const char **argv)
10236 {
10237 /* Must have only one argument. */
10238 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
10239 return argv[0];
10240
10241 return NULL;
10242 }
10243
10244 /* if-exists-else built-in spec function.
10245
10246 This is like if-exists, but takes an additional argument which
10247 is returned if the first argument does not exist. */
10248
10249 static const char *
10250 if_exists_else_spec_function (int argc, const char **argv)
10251 {
10252 /* Must have exactly two arguments. */
10253 if (argc != 2)
10254 return NULL;
10255
10256 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
10257 return argv[0];
10258
10259 return argv[1];
10260 }
10261
10262 /* if-exists-then-else built-in spec function.
10263
10264 Checks to see if the file specified by the absolute pathname in
10265 the first arg exists. Returns the second arg if so, otherwise returns
10266 the third arg if it is present. */
10267
10268 static const char *
10269 if_exists_then_else_spec_function (int argc, const char **argv)
10270 {
10271
10272 /* Must have two or three arguments. */
10273 if (argc != 2 && argc != 3)
10274 return NULL;
10275
10276 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
10277 return argv[1];
10278
10279 if (argc == 3)
10280 return argv[2];
10281
10282 return NULL;
10283 }
10284
10285 /* sanitize built-in spec function.
10286
10287 This returns non-NULL, if sanitizing address, thread or
10288 any of the undefined behavior sanitizers. */
10289
10290 static const char *
10291 sanitize_spec_function (int argc, const char **argv)
10292 {
10293 if (argc != 1)
10294 return NULL;
10295
10296 if (strcmp (argv[0], "address") == 0)
10297 return (flag_sanitize & SANITIZE_USER_ADDRESS) ? "" : NULL;
10298 if (strcmp (argv[0], "hwaddress") == 0)
10299 return (flag_sanitize & SANITIZE_USER_HWADDRESS) ? "" : NULL;
10300 if (strcmp (argv[0], "kernel-address") == 0)
10301 return (flag_sanitize & SANITIZE_KERNEL_ADDRESS) ? "" : NULL;
10302 if (strcmp (argv[0], "kernel-hwaddress") == 0)
10303 return (flag_sanitize & SANITIZE_KERNEL_HWADDRESS) ? "" : NULL;
10304 if (strcmp (argv[0], "thread") == 0)
10305 return (flag_sanitize & SANITIZE_THREAD) ? "" : NULL;
10306 if (strcmp (argv[0], "undefined") == 0)
10307 return ((flag_sanitize
10308 & (SANITIZE_UNDEFINED | SANITIZE_UNDEFINED_NONDEFAULT))
10309 && !flag_sanitize_undefined_trap_on_error) ? "" : NULL;
10310 if (strcmp (argv[0], "leak") == 0)
10311 return ((flag_sanitize
10312 & (SANITIZE_ADDRESS | SANITIZE_LEAK | SANITIZE_THREAD))
10313 == SANITIZE_LEAK) ? "" : NULL;
10314 return NULL;
10315 }
10316
10317 /* replace-outfile built-in spec function.
10318
10319 This looks for the first argument in the outfiles array's name and
10320 replaces it with the second argument. */
10321
10322 static const char *
10323 replace_outfile_spec_function (int argc, const char **argv)
10324 {
10325 int i;
10326 /* Must have exactly two arguments. */
10327 if (argc != 2)
10328 abort ();
10329
10330 for (i = 0; i < n_infiles; i++)
10331 {
10332 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
10333 outfiles[i] = xstrdup (argv[1]);
10334 }
10335 return NULL;
10336 }
10337
10338 /* remove-outfile built-in spec function.
10339 *
10340 * This looks for the first argument in the outfiles array's name and
10341 * removes it. */
10342
10343 static const char *
10344 remove_outfile_spec_function (int argc, const char **argv)
10345 {
10346 int i;
10347 /* Must have exactly one argument. */
10348 if (argc != 1)
10349 abort ();
10350
10351 for (i = 0; i < n_infiles; i++)
10352 {
10353 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
10354 outfiles[i] = NULL;
10355 }
10356 return NULL;
10357 }
10358
10359 /* Given two version numbers, compares the two numbers.
10360 A version number must match the regular expression
10361 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
10362 */
10363 static int
10364 compare_version_strings (const char *v1, const char *v2)
10365 {
10366 int rresult;
10367 regex_t r;
10368
10369 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
10370 REG_EXTENDED | REG_NOSUB) != 0)
10371 abort ();
10372 rresult = regexec (&r, v1, 0, NULL, 0);
10373 if (rresult == REG_NOMATCH)
10374 fatal_error (input_location, "invalid version number %qs", v1);
10375 else if (rresult != 0)
10376 abort ();
10377 rresult = regexec (&r, v2, 0, NULL, 0);
10378 if (rresult == REG_NOMATCH)
10379 fatal_error (input_location, "invalid version number %qs", v2);
10380 else if (rresult != 0)
10381 abort ();
10382
10383 return strverscmp (v1, v2);
10384 }
10385
10386
10387 /* version_compare built-in spec function.
10388
10389 This takes an argument of the following form:
10390
10391 <comparison-op> <arg1> [<arg2>] <switch> <result>
10392
10393 and produces "result" if the comparison evaluates to true,
10394 and nothing if it doesn't.
10395
10396 The supported <comparison-op> values are:
10397
10398 >= true if switch is a later (or same) version than arg1
10399 !> opposite of >=
10400 < true if switch is an earlier version than arg1
10401 !< opposite of <
10402 >< true if switch is arg1 or later, and earlier than arg2
10403 <> true if switch is earlier than arg1 or is arg2 or later
10404
10405 If the switch is not present, the condition is false unless
10406 the first character of the <comparison-op> is '!'.
10407
10408 For example,
10409 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
10410 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
10411
10412 static const char *
10413 version_compare_spec_function (int argc, const char **argv)
10414 {
10415 int comp1, comp2;
10416 size_t switch_len;
10417 const char *switch_value = NULL;
10418 int nargs = 1, i;
10419 bool result;
10420
10421 if (argc < 3)
10422 fatal_error (input_location, "too few arguments to %%:version-compare");
10423 if (argv[0][0] == '\0')
10424 abort ();
10425 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
10426 nargs = 2;
10427 if (argc != nargs + 3)
10428 fatal_error (input_location, "too many arguments to %%:version-compare");
10429
10430 switch_len = strlen (argv[nargs + 1]);
10431 for (i = 0; i < n_switches; i++)
10432 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
10433 && check_live_switch (i, switch_len))
10434 switch_value = switches[i].part1 + switch_len;
10435
10436 if (switch_value == NULL)
10437 comp1 = comp2 = -1;
10438 else
10439 {
10440 comp1 = compare_version_strings (switch_value, argv[1]);
10441 if (nargs == 2)
10442 comp2 = compare_version_strings (switch_value, argv[2]);
10443 else
10444 comp2 = -1; /* This value unused. */
10445 }
10446
10447 switch (argv[0][0] << 8 | argv[0][1])
10448 {
10449 case '>' << 8 | '=':
10450 result = comp1 >= 0;
10451 break;
10452 case '!' << 8 | '<':
10453 result = comp1 >= 0 || switch_value == NULL;
10454 break;
10455 case '<' << 8:
10456 result = comp1 < 0;
10457 break;
10458 case '!' << 8 | '>':
10459 result = comp1 < 0 || switch_value == NULL;
10460 break;
10461 case '>' << 8 | '<':
10462 result = comp1 >= 0 && comp2 < 0;
10463 break;
10464 case '<' << 8 | '>':
10465 result = comp1 < 0 || comp2 >= 0;
10466 break;
10467
10468 default:
10469 fatal_error (input_location,
10470 "unknown operator %qs in %%:version-compare", argv[0]);
10471 }
10472 if (! result)
10473 return NULL;
10474
10475 return argv[nargs + 2];
10476 }
10477
10478 /* %:include builtin spec function. This differs from %include in that it
10479 can be nested inside a spec, and thus be conditionalized. It takes
10480 one argument, the filename, and looks for it in the startfile path.
10481 The result is always NULL, i.e. an empty expansion. */
10482
10483 static const char *
10484 include_spec_function (int argc, const char **argv)
10485 {
10486 char *file;
10487
10488 if (argc != 1)
10489 abort ();
10490
10491 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
10492 read_specs (file ? file : argv[0], false, false);
10493
10494 return NULL;
10495 }
10496
10497 /* %:find-file spec function. This function replaces its argument by
10498 the file found through find_file, that is the -print-file-name gcc
10499 program option. */
10500 static const char *
10501 find_file_spec_function (int argc, const char **argv)
10502 {
10503 const char *file;
10504
10505 if (argc != 1)
10506 abort ();
10507
10508 file = find_file (argv[0]);
10509 return file;
10510 }
10511
10512
10513 /* %:find-plugindir spec function. This function replaces its argument
10514 by the -iplugindir=<dir> option. `dir' is found through find_file, that
10515 is the -print-file-name gcc program option. */
10516 static const char *
10517 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
10518 {
10519 const char *option;
10520
10521 if (argc != 0)
10522 abort ();
10523
10524 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
10525 return option;
10526 }
10527
10528
10529 /* %:print-asm-header spec function. Print a banner to say that the
10530 following output is from the assembler. */
10531
10532 static const char *
10533 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
10534 const char **argv ATTRIBUTE_UNUSED)
10535 {
10536 printf (_("Assembler options\n=================\n\n"));
10537 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
10538 fflush (stdout);
10539 return NULL;
10540 }
10541
10542 /* Get a random number for -frandom-seed */
10543
10544 static unsigned HOST_WIDE_INT
10545 get_random_number (void)
10546 {
10547 unsigned HOST_WIDE_INT ret = 0;
10548 int fd;
10549
10550 fd = open ("/dev/urandom", O_RDONLY);
10551 if (fd >= 0)
10552 {
10553 read (fd, &ret, sizeof (HOST_WIDE_INT));
10554 close (fd);
10555 if (ret)
10556 return ret;
10557 }
10558
10559 /* Get some more or less random data. */
10560 #ifdef HAVE_GETTIMEOFDAY
10561 {
10562 struct timeval tv;
10563
10564 gettimeofday (&tv, NULL);
10565 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
10566 }
10567 #else
10568 {
10569 time_t now = time (NULL);
10570
10571 if (now != (time_t)-1)
10572 ret = (unsigned) now;
10573 }
10574 #endif
10575
10576 return ret ^ getpid ();
10577 }
10578
10579 /* %:compare-debug-dump-opt spec function. Save the last argument,
10580 expected to be the last -fdump-final-insns option, or generate a
10581 temporary. */
10582
10583 static const char *
10584 compare_debug_dump_opt_spec_function (int arg,
10585 const char **argv ATTRIBUTE_UNUSED)
10586 {
10587 char *ret;
10588 char *name;
10589 int which;
10590 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
10591
10592 if (arg != 0)
10593 fatal_error (input_location,
10594 "too many arguments to %%:compare-debug-dump-opt");
10595
10596 do_spec_2 ("%{fdump-final-insns=*:%*}", NULL);
10597 do_spec_1 (" ", 0, NULL);
10598
10599 if (argbuf.length () > 0
10600 && strcmp (argv[argbuf.length () - 1], ".") != 0)
10601 {
10602 if (!compare_debug)
10603 return NULL;
10604
10605 name = xstrdup (argv[argbuf.length () - 1]);
10606 ret = NULL;
10607 }
10608 else
10609 {
10610 if (argbuf.length () > 0)
10611 do_spec_2 ("%B.gkd", NULL);
10612 else if (!compare_debug)
10613 return NULL;
10614 else
10615 do_spec_2 ("%{!save-temps*:%g.gkd}%{save-temps*:%B.gkd}", NULL);
10616
10617 do_spec_1 (" ", 0, NULL);
10618
10619 gcc_assert (argbuf.length () > 0);
10620
10621 name = xstrdup (argbuf.last ());
10622
10623 char *arg = quote_spec (xstrdup (name));
10624 ret = concat ("-fdump-final-insns=", arg, NULL);
10625 free (arg);
10626 }
10627
10628 which = compare_debug < 0;
10629 debug_check_temp_file[which] = name;
10630
10631 if (!which)
10632 {
10633 unsigned HOST_WIDE_INT value = get_random_number ();
10634
10635 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
10636 }
10637
10638 if (*random_seed)
10639 {
10640 char *tmp = ret;
10641 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
10642 ret, NULL);
10643 free (tmp);
10644 }
10645
10646 if (which)
10647 *random_seed = 0;
10648
10649 return ret;
10650 }
10651
10652 /* %:compare-debug-self-opt spec function. Expands to the options
10653 that are to be passed in the second compilation of
10654 compare-debug. */
10655
10656 static const char *
10657 compare_debug_self_opt_spec_function (int arg,
10658 const char **argv ATTRIBUTE_UNUSED)
10659 {
10660 if (arg != 0)
10661 fatal_error (input_location,
10662 "too many arguments to %%:compare-debug-self-opt");
10663
10664 if (compare_debug >= 0)
10665 return NULL;
10666
10667 return concat ("\
10668 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
10669 %<fdump-final-insns=* -w -S -o %j \
10670 %{!fcompare-debug-second:-fcompare-debug-second} \
10671 ", compare_debug_opt, NULL);
10672 }
10673
10674 /* %:pass-through-libs spec function. Finds all -l options and input
10675 file names in the lib spec passed to it, and makes a list of them
10676 prepended with the plugin option to cause them to be passed through
10677 to the final link after all the new object files have been added. */
10678
10679 const char *
10680 pass_through_libs_spec_func (int argc, const char **argv)
10681 {
10682 char *prepended = xstrdup (" ");
10683 int n;
10684 /* Shlemiel the painter's algorithm. Innately horrible, but at least
10685 we know that there will never be more than a handful of strings to
10686 concat, and it's only once per run, so it's not worth optimising. */
10687 for (n = 0; n < argc; n++)
10688 {
10689 char *old = prepended;
10690 /* Anything that isn't an option is a full path to an output
10691 file; pass it through if it ends in '.a'. Among options,
10692 pass only -l. */
10693 if (argv[n][0] == '-' && argv[n][1] == 'l')
10694 {
10695 const char *lopt = argv[n] + 2;
10696 /* Handle both joined and non-joined -l options. If for any
10697 reason there's a trailing -l with no joined or following
10698 arg just discard it. */
10699 if (!*lopt && ++n >= argc)
10700 break;
10701 else if (!*lopt)
10702 lopt = argv[n];
10703 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
10704 lopt, " ", NULL);
10705 }
10706 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
10707 {
10708 prepended = concat (prepended, "-plugin-opt=-pass-through=",
10709 argv[n], " ", NULL);
10710 }
10711 if (prepended != old)
10712 free (old);
10713 }
10714 return prepended;
10715 }
10716
10717 static bool
10718 not_actual_file_p (const char *name)
10719 {
10720 return (strcmp (name, "-") == 0
10721 || strcmp (name, HOST_BIT_BUCKET) == 0);
10722 }
10723
10724 /* %:dumps spec function. Take an optional argument that overrides
10725 the default extension for -dumpbase and -dumpbase-ext.
10726 Return -dumpdir, -dumpbase and -dumpbase-ext, if needed. */
10727 const char *
10728 dumps_spec_func (int argc, const char **argv ATTRIBUTE_UNUSED)
10729 {
10730 const char *ext = dumpbase_ext;
10731 char *p;
10732
10733 char *args[3] = { NULL, NULL, NULL };
10734 int nargs = 0;
10735
10736 /* Do not compute a default for -dumpbase-ext when -dumpbase was
10737 given explicitly. */
10738 if (dumpbase && *dumpbase && !ext)
10739 ext = "";
10740
10741 if (argc == 1)
10742 {
10743 /* Do not override the explicitly-specified -dumpbase-ext with
10744 the specs-provided overrider. */
10745 if (!ext)
10746 ext = argv[0];
10747 }
10748 else if (argc != 0)
10749 fatal_error (input_location, "too many arguments for %%:dumps");
10750
10751 if (dumpdir)
10752 {
10753 p = quote_spec_arg (xstrdup (dumpdir));
10754 args[nargs++] = concat (" -dumpdir ", p, NULL);
10755 free (p);
10756 }
10757
10758 if (!ext)
10759 ext = input_basename + basename_length;
10760
10761 /* Use the precomputed outbase, or compute dumpbase from
10762 input_basename, just like %b would. */
10763 char *base;
10764
10765 if (dumpbase && *dumpbase)
10766 {
10767 base = xstrdup (dumpbase);
10768 p = base + outbase_length;
10769 gcc_checking_assert (strncmp (base, outbase, outbase_length) == 0);
10770 gcc_checking_assert (strcmp (p, ext) == 0);
10771 }
10772 else if (outbase_length)
10773 {
10774 base = xstrndup (outbase, outbase_length);
10775 p = NULL;
10776 }
10777 else
10778 {
10779 base = xstrndup (input_basename, suffixed_basename_length);
10780 p = base + basename_length;
10781 }
10782
10783 if (compare_debug < 0 || !p || strcmp (p, ext) != 0)
10784 {
10785 if (p)
10786 *p = '\0';
10787
10788 const char *gk;
10789 if (compare_debug < 0)
10790 gk = ".gk";
10791 else
10792 gk = "";
10793
10794 p = concat (base, gk, ext, NULL);
10795
10796 free (base);
10797 base = p;
10798 }
10799
10800 base = quote_spec_arg (base);
10801 args[nargs++] = concat (" -dumpbase ", base, NULL);
10802 free (base);
10803
10804 if (*ext)
10805 {
10806 p = quote_spec_arg (xstrdup (ext));
10807 args[nargs++] = concat (" -dumpbase-ext ", p, NULL);
10808 free (p);
10809 }
10810
10811 const char *ret = concat (args[0], args[1], args[2], NULL);
10812 while (nargs > 0)
10813 free (args[--nargs]);
10814
10815 return ret;
10816 }
10817
10818 /* Returns "" if ARGV[ARGC - 2] is greater than ARGV[ARGC-1].
10819 Otherwise, return NULL. */
10820
10821 static const char *
10822 greater_than_spec_func (int argc, const char **argv)
10823 {
10824 char *converted;
10825
10826 if (argc == 1)
10827 return NULL;
10828
10829 gcc_assert (argc >= 2);
10830
10831 long arg = strtol (argv[argc - 2], &converted, 10);
10832 gcc_assert (converted != argv[argc - 2]);
10833
10834 long lim = strtol (argv[argc - 1], &converted, 10);
10835 gcc_assert (converted != argv[argc - 1]);
10836
10837 if (arg > lim)
10838 return "";
10839
10840 return NULL;
10841 }
10842
10843 /* Returns "" if debug_info_level is greater than ARGV[ARGC-1].
10844 Otherwise, return NULL. */
10845
10846 static const char *
10847 debug_level_greater_than_spec_func (int argc, const char **argv)
10848 {
10849 char *converted;
10850
10851 if (argc != 1)
10852 fatal_error (input_location,
10853 "wrong number of arguments to %%:debug-level-gt");
10854
10855 long arg = strtol (argv[0], &converted, 10);
10856 gcc_assert (converted != argv[0]);
10857
10858 if (debug_info_level > arg)
10859 return "";
10860
10861 return NULL;
10862 }
10863
10864 /* Returns "" if dwarf_version is greater than ARGV[ARGC-1].
10865 Otherwise, return NULL. */
10866
10867 static const char *
10868 dwarf_version_greater_than_spec_func (int argc, const char **argv)
10869 {
10870 char *converted;
10871
10872 if (argc != 1)
10873 fatal_error (input_location,
10874 "wrong number of arguments to %%:dwarf-version-gt");
10875
10876 long arg = strtol (argv[0], &converted, 10);
10877 gcc_assert (converted != argv[0]);
10878
10879 if (dwarf_version > arg)
10880 return "";
10881
10882 return NULL;
10883 }
10884
10885 static void
10886 path_prefix_reset (path_prefix *prefix)
10887 {
10888 struct prefix_list *iter, *next;
10889 iter = prefix->plist;
10890 while (iter)
10891 {
10892 next = iter->next;
10893 free (const_cast <char *> (iter->prefix));
10894 XDELETE (iter);
10895 iter = next;
10896 }
10897 prefix->plist = 0;
10898 prefix->max_len = 0;
10899 }
10900
10901 /* The function takes 3 arguments: OPTION name, file name and location
10902 where we search for Fortran modules.
10903 When the FILE is found by find_file, return OPTION=path_to_file. */
10904
10905 static const char *
10906 find_fortran_preinclude_file (int argc, const char **argv)
10907 {
10908 char *result = NULL;
10909 if (argc != 3)
10910 return NULL;
10911
10912 struct path_prefix prefixes = { 0, 0, "preinclude" };
10913
10914 /* Search first for 'finclude' folder location for a header file
10915 installed by the compiler (similar to omp_lib.h). */
10916 add_prefix (&prefixes, argv[2], NULL, 0, 0, 0);
10917 #ifdef TOOL_INCLUDE_DIR
10918 /* Then search: <prefix>/<target>/<include>/finclude */
10919 add_prefix (&prefixes, TOOL_INCLUDE_DIR "/finclude/",
10920 NULL, 0, 0, 0);
10921 #endif
10922 #ifdef NATIVE_SYSTEM_HEADER_DIR
10923 /* Then search: <sysroot>/usr/include/finclude/<multilib> */
10924 add_sysrooted_hdrs_prefix (&prefixes, NATIVE_SYSTEM_HEADER_DIR "/finclude/",
10925 NULL, 0, 0, 0);
10926 #endif
10927
10928 const char *path = find_a_file (&include_prefixes, argv[1], R_OK, false);
10929 if (path != NULL)
10930 result = concat (argv[0], path, NULL);
10931 else
10932 {
10933 path = find_a_file (&prefixes, argv[1], R_OK, false);
10934 if (path != NULL)
10935 result = concat (argv[0], path, NULL);
10936 }
10937
10938 path_prefix_reset (&prefixes);
10939 return result;
10940 }
10941
10942 /* If any character in ORIG fits QUOTE_P (_, P), reallocate the string
10943 so as to precede every one of them with a backslash. Return the
10944 original string or the reallocated one. */
10945
10946 static inline char *
10947 quote_string (char *orig, bool (*quote_p)(char, void *), void *p)
10948 {
10949 int len, number_of_space = 0;
10950
10951 for (len = 0; orig[len]; len++)
10952 if (quote_p (orig[len], p))
10953 number_of_space++;
10954
10955 if (number_of_space)
10956 {
10957 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
10958 int j, k;
10959 for (j = 0, k = 0; j <= len; j++, k++)
10960 {
10961 if (quote_p (orig[j], p))
10962 new_spec[k++] = '\\';
10963 new_spec[k] = orig[j];
10964 }
10965 free (orig);
10966 return new_spec;
10967 }
10968 else
10969 return orig;
10970 }
10971
10972 /* Return true iff C is any of the characters convert_white_space
10973 should quote. */
10974
10975 static inline bool
10976 whitespace_to_convert_p (char c, void *)
10977 {
10978 return (c == ' ' || c == '\t');
10979 }
10980
10981 /* Insert backslash before spaces in ORIG (usually a file path), to
10982 avoid being broken by spec parser.
10983
10984 This function is needed as do_spec_1 treats white space (' ' and '\t')
10985 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
10986 the file name should be treated as a single argument rather than being
10987 broken into multiple. Solution is to insert '\\' before the space in a
10988 file name.
10989
10990 This function converts and only converts all occurrence of ' '
10991 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
10992 "a b" -> "a\\ b"
10993 "a b" -> "a\\ \\ b"
10994 "a\tb" -> "a\\\tb"
10995 "a\\ b" -> "a\\\\ b"
10996
10997 orig: input null-terminating string that was allocated by xalloc. The
10998 memory it points to might be freed in this function. Behavior undefined
10999 if ORIG wasn't xalloced or was freed already at entry.
11000
11001 Return: ORIG if no conversion needed. Otherwise a newly allocated string
11002 that was converted from ORIG. */
11003
11004 static char *
11005 convert_white_space (char *orig)
11006 {
11007 return quote_string (orig, whitespace_to_convert_p, NULL);
11008 }
11009
11010 /* Return true iff C matches any of the spec active characters. */
11011 static inline bool
11012 quote_spec_char_p (char c, void *)
11013 {
11014 switch (c)
11015 {
11016 case ' ':
11017 case '\t':
11018 case '\n':
11019 case '|':
11020 case '%':
11021 case '\\':
11022 return true;
11023
11024 default:
11025 return false;
11026 }
11027 }
11028
11029 /* Like convert_white_space, but deactivate all active spec chars by
11030 quoting them. */
11031
11032 static inline char *
11033 quote_spec (char *orig)
11034 {
11035 return quote_string (orig, quote_spec_char_p, NULL);
11036 }
11037
11038 /* Like quote_spec, but also turn an empty string into the spec for an
11039 empty argument. */
11040
11041 static inline char *
11042 quote_spec_arg (char *orig)
11043 {
11044 if (!*orig)
11045 {
11046 free (orig);
11047 return xstrdup ("%\"");
11048 }
11049
11050 return quote_spec (orig);
11051 }
11052
11053 /* Restore all state within gcc.c to the initial state, so that the driver
11054 code can be safely re-run in-process.
11055
11056 Many const char * variables are referenced by static specs (see
11057 INIT_STATIC_SPEC above). These variables are restored to their default
11058 values by a simple loop over the static specs.
11059
11060 For other variables, we directly restore them all to their initial
11061 values (often implicitly 0).
11062
11063 Free the various obstacks in this file, along with "opts_obstack"
11064 from opts.c.
11065
11066 This function also restores any environment variables that were changed. */
11067
11068 void
11069 driver::finalize ()
11070 {
11071 env.restore ();
11072 diagnostic_finish (global_dc);
11073
11074 is_cpp_driver = 0;
11075 at_file_supplied = 0;
11076 print_help_list = 0;
11077 print_version = 0;
11078 verbose_only_flag = 0;
11079 print_subprocess_help = 0;
11080 use_ld = NULL;
11081 report_times_to_file = NULL;
11082 target_system_root = DEFAULT_TARGET_SYSTEM_ROOT;
11083 target_system_root_changed = 0;
11084 target_sysroot_suffix = 0;
11085 target_sysroot_hdrs_suffix = 0;
11086 save_temps_flag = SAVE_TEMPS_NONE;
11087 save_temps_overrides_dumpdir = false;
11088 dumpdir_trailing_dash_added = false;
11089 free (dumpdir);
11090 free (dumpbase);
11091 free (dumpbase_ext);
11092 free (outbase);
11093 dumpdir = dumpbase = dumpbase_ext = outbase = NULL;
11094 dumpdir_length = outbase_length = 0;
11095 spec_machine = DEFAULT_TARGET_MACHINE;
11096 greatest_status = 1;
11097
11098 obstack_free (&obstack, NULL);
11099 obstack_free (&opts_obstack, NULL); /* in opts.c */
11100 obstack_free (&collect_obstack, NULL);
11101
11102 link_command_spec = LINK_COMMAND_SPEC;
11103
11104 obstack_free (&multilib_obstack, NULL);
11105
11106 user_specs_head = NULL;
11107 user_specs_tail = NULL;
11108
11109 /* Within the "compilers" vec, the fields "suffix" and "spec" were
11110 statically allocated for the default compilers, but dynamically
11111 allocated for additional compilers. Delete them for the latter. */
11112 for (int i = n_default_compilers; i < n_compilers; i++)
11113 {
11114 free (const_cast <char *> (compilers[i].suffix));
11115 free (const_cast <char *> (compilers[i].spec));
11116 }
11117 XDELETEVEC (compilers);
11118 compilers = NULL;
11119 n_compilers = 0;
11120
11121 linker_options.truncate (0);
11122 assembler_options.truncate (0);
11123 preprocessor_options.truncate (0);
11124
11125 path_prefix_reset (&exec_prefixes);
11126 path_prefix_reset (&startfile_prefixes);
11127 path_prefix_reset (&include_prefixes);
11128
11129 machine_suffix = 0;
11130 just_machine_suffix = 0;
11131 gcc_exec_prefix = 0;
11132 gcc_libexec_prefix = 0;
11133 set_static_spec_shared (&md_exec_prefix, MD_EXEC_PREFIX);
11134 set_static_spec_shared (&md_startfile_prefix, MD_STARTFILE_PREFIX);
11135 set_static_spec_shared (&md_startfile_prefix_1, MD_STARTFILE_PREFIX_1);
11136 multilib_dir = 0;
11137 multilib_os_dir = 0;
11138 multiarch_dir = 0;
11139
11140 /* Free any specs dynamically-allocated by set_spec.
11141 These will be at the head of the list, before the
11142 statically-allocated ones. */
11143 if (specs)
11144 {
11145 while (specs != static_specs)
11146 {
11147 spec_list *next = specs->next;
11148 free (const_cast <char *> (specs->name));
11149 XDELETE (specs);
11150 specs = next;
11151 }
11152 specs = 0;
11153 }
11154 for (unsigned i = 0; i < ARRAY_SIZE (static_specs); i++)
11155 {
11156 spec_list *sl = &static_specs[i];
11157 if (sl->alloc_p)
11158 {
11159 free (const_cast <char *> (*(sl->ptr_spec)));
11160 sl->alloc_p = false;
11161 }
11162 *(sl->ptr_spec) = sl->default_ptr;
11163 }
11164 #ifdef EXTRA_SPECS
11165 extra_specs = NULL;
11166 #endif
11167
11168 processing_spec_function = 0;
11169
11170 clear_args ();
11171
11172 have_c = 0;
11173 have_o = 0;
11174
11175 temp_names = NULL;
11176 execution_count = 0;
11177 signal_count = 0;
11178
11179 temp_filename = NULL;
11180 temp_filename_length = 0;
11181 always_delete_queue = NULL;
11182 failure_delete_queue = NULL;
11183
11184 XDELETEVEC (switches);
11185 switches = NULL;
11186 n_switches = 0;
11187 n_switches_alloc = 0;
11188
11189 compare_debug = 0;
11190 compare_debug_second = 0;
11191 compare_debug_opt = NULL;
11192 for (int i = 0; i < 2; i++)
11193 {
11194 switches_debug_check[i] = NULL;
11195 n_switches_debug_check[i] = 0;
11196 n_switches_alloc_debug_check[i] = 0;
11197 debug_check_temp_file[i] = NULL;
11198 }
11199
11200 XDELETEVEC (infiles);
11201 infiles = NULL;
11202 n_infiles = 0;
11203 n_infiles_alloc = 0;
11204
11205 combine_inputs = false;
11206 added_libraries = 0;
11207 XDELETEVEC (outfiles);
11208 outfiles = NULL;
11209 spec_lang = 0;
11210 last_language_n_infiles = 0;
11211 gcc_input_filename = NULL;
11212 input_file_number = 0;
11213 input_filename_length = 0;
11214 basename_length = 0;
11215 suffixed_basename_length = 0;
11216 input_basename = NULL;
11217 input_suffix = NULL;
11218 /* We don't need to purge "input_stat", just to unset "input_stat_set". */
11219 input_stat_set = 0;
11220 input_file_compiler = NULL;
11221 arg_going = 0;
11222 delete_this_arg = 0;
11223 this_is_output_file = 0;
11224 this_is_library_file = 0;
11225 this_is_linker_script = 0;
11226 input_from_pipe = 0;
11227 suffix_subst = NULL;
11228
11229 mdswitches = NULL;
11230 n_mdswitches = 0;
11231
11232 used_arg.finalize ();
11233 }
11234
11235 /* PR jit/64810.
11236 Targets can provide configure-time default options in
11237 OPTION_DEFAULT_SPECS. The jit needs to access these, but
11238 they are expressed in the spec language.
11239
11240 Run just enough of the driver to be able to expand these
11241 specs, and then call the callback CB on each
11242 such option. The options strings are *without* a leading
11243 '-' character e.g. ("march=x86-64"). Finally, clean up. */
11244
11245 void
11246 driver_get_configure_time_options (void (*cb) (const char *option,
11247 void *user_data),
11248 void *user_data)
11249 {
11250 size_t i;
11251
11252 obstack_init (&obstack);
11253 init_opts_obstack ();
11254 n_switches = 0;
11255
11256 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
11257 do_option_spec (option_default_specs[i].name,
11258 option_default_specs[i].spec);
11259
11260 for (i = 0; (int) i < n_switches; i++)
11261 {
11262 gcc_assert (switches[i].part1);
11263 (*cb) (switches[i].part1, user_data);
11264 }
11265
11266 obstack_free (&opts_obstack, NULL);
11267 obstack_free (&obstack, NULL);
11268 n_switches = 0;
11269 }