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