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