[AArch64] Wire up vqdmullh_laneq_s16 and vqdmullh_laneq_s32
[official-gcc.git] / gcc / gcc.c
blob47c4e283bcd07366c75debbc7276bb58198e9f98
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987-2014 Free Software Foundation, Inc.
4 This file is part of GCC.
6 GCC is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 3, or (at your option) any later
9 version.
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14 for more details.
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING3. If not see
18 <http://www.gnu.org/licenses/>. */
20 /* This program is the user interface to the C compiler and possibly to
21 other compilers. It is used because compilation is a complicated procedure
22 which involves running several programs and passing temporary files between
23 them, forwarding the users switches to those programs selectively,
24 and deleting the temporary files at the end.
26 CC recognizes how to compile each input file by suffixes in the file names.
27 Once it knows which kind of compilation to perform, the procedure for
28 compilation is specified by a string called a "spec". */
30 #include "config.h"
31 #include "system.h"
32 #include "coretypes.h"
33 #include "multilib.h" /* before tm.h */
34 #include "tm.h"
35 #include "xregex.h"
36 #include "obstack.h"
37 #include "intl.h"
38 #include "prefix.h"
39 #include "gcc.h"
40 #include "diagnostic.h"
41 #include "flags.h"
42 #include "opts.h"
43 #include "params.h"
44 #include "vec.h"
45 #include "filenames.h"
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
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
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
67 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
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
74 /* If a stage of compilation returns an exit status >= 1,
75 compilation of that file ceases. */
77 #define MIN_FATAL_STATUS 1
79 /* Flag set by cppspec.c to 1. */
80 int is_cpp_driver;
82 /* Flag set to nonzero if an @file argument has been supplied to gcc. */
83 static bool at_file_supplied;
85 /* Definition of string containing the arguments given to configure. */
86 #include "configargs.h"
88 /* Flag saying to print the command line options understood by gcc and its
89 sub-processes. */
91 static int print_help_list;
93 /* Flag saying to print the version of gcc and its sub-processes. */
95 static int print_version;
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;
104 /* Flag indicating how to print command line options of sub-processes. */
106 static int print_subprocess_help;
108 /* Linker suffix passed to -fuse-ld=... */
109 static const char *use_ld;
111 /* Whether we should report subprocess execution times to a file. */
113 FILE *report_times_to_file = NULL;
115 /* Nonzero means place this string before uses of /, so that include
116 and library files can be found in an alternate location. */
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
124 /* Nonzero means pass the updated target_system_root to the compiler. */
126 static int target_system_root_changed;
128 /* Nonzero means append this string to target_system_root. */
130 static const char *target_sysroot_suffix = 0;
132 /* Nonzero means append this string to target_system_root for headers. */
134 static const char *target_sysroot_hdrs_suffix = 0;
136 /* Nonzero means write "temp" files in source directory
137 and use the source file's name in them, and don't delete them. */
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;
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;
149 /* The compiler version. */
151 static const char *compiler_version;
153 /* The target version. */
155 static const char *const spec_version = DEFAULT_TARGET_VERSION;
157 /* The target machine. */
159 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
161 /* Nonzero if cross-compiling.
162 When -b is used, the value comes from the `specs' file. */
164 #ifdef CROSS_DIRECTORY_STRUCTURE
165 static const char *cross_compile = "1";
166 #else
167 static const char *cross_compile = "0";
168 #endif
170 /* Greatest exit code of sub-processes that has been encountered up to
171 now. */
172 static int greatest_status = 1;
174 /* This is the obstack which we use to allocate many strings. */
176 static struct obstack obstack;
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. */
183 static struct obstack collect_obstack;
185 /* Forward declaration for prototypes. */
186 struct path_prefix;
187 struct prefix_list;
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
256 static void try_generate_repro (const char **argv);
257 static const char *getenv_spec_function (int, const char **);
258 static const char *if_exists_spec_function (int, const char **);
259 static const char *if_exists_else_spec_function (int, const char **);
260 static const char *sanitize_spec_function (int, const char **);
261 static const char *replace_outfile_spec_function (int, const char **);
262 static const char *remove_outfile_spec_function (int, const char **);
263 static const char *version_compare_spec_function (int, const char **);
264 static const char *include_spec_function (int, const char **);
265 static const char *find_file_spec_function (int, const char **);
266 static const char *find_plugindir_spec_function (int, const char **);
267 static const char *print_asm_header_spec_function (int, const char **);
268 static const char *compare_debug_dump_opt_spec_function (int, const char **);
269 static const char *compare_debug_self_opt_spec_function (int, const char **);
270 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
271 static const char *pass_through_libs_spec_func (int, const char **);
272 static const char *replace_extension_spec_func (int, const char **);
273 static char *convert_white_space (char *);
275 /* The Specs Language
277 Specs are strings containing lines, each of which (if not blank)
278 is made up of a program name, and arguments separated by spaces.
279 The program name must be exact and start from root, since no path
280 is searched and it is unreliable to depend on the current working directory.
281 Redirection of input or output is not supported; the subprograms must
282 accept filenames saying what files to read and write.
284 In addition, the specs can contain %-sequences to substitute variable text
285 or for conditional text. Here is a table of all defined %-sequences.
286 Note that spaces are not generated automatically around the results of
287 expanding these sequences; therefore, you can concatenate them together
288 or with constant text in a single argument.
290 %% substitute one % into the program name or argument.
291 %i substitute the name of the input file being processed.
292 %b substitute the basename of the input file being processed.
293 This is the substring up to (and not including) the last period
294 and not including the directory unless -save-temps was specified
295 to put temporaries in a different location.
296 %B same as %b, but include the file suffix (text after the last period).
297 %gSUFFIX
298 substitute a file name that has suffix SUFFIX and is chosen
299 once per compilation, and mark the argument a la %d. To reduce
300 exposure to denial-of-service attacks, the file name is now
301 chosen in a way that is hard to predict even when previously
302 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
303 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
304 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
305 had been pre-processed. Previously, %g was simply substituted
306 with a file name chosen once per compilation, without regard
307 to any appended suffix (which was therefore treated just like
308 ordinary text), making such attacks more likely to succeed.
309 %|SUFFIX
310 like %g, but if -pipe is in effect, expands simply to "-".
311 %mSUFFIX
312 like %g, but if -pipe is in effect, expands to nothing. (We have both
313 %| and %m to accommodate differences between system assemblers; see
314 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
315 %uSUFFIX
316 like %g, but generates a new temporary file name even if %uSUFFIX
317 was already seen.
318 %USUFFIX
319 substitutes the last file name generated with %uSUFFIX, generating a
320 new one if there is no such last file name. In the absence of any
321 %uSUFFIX, this is just like %gSUFFIX, except they don't share
322 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
323 would involve the generation of two distinct file names, one
324 for each `%g.s' and another for each `%U.s'. Previously, %U was
325 simply substituted with a file name chosen for the previous %u,
326 without regard to any appended suffix.
327 %jSUFFIX
328 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
329 writable, and if save-temps is off; otherwise, substitute the name
330 of a temporary file, just like %u. This temporary file is not
331 meant for communication between processes, but rather as a junk
332 disposal mechanism.
333 %.SUFFIX
334 substitutes .SUFFIX for the suffixes of a matched switch's args when
335 it is subsequently output with %*. SUFFIX is terminated by the next
336 space or %.
337 %d marks the argument containing or following the %d as a
338 temporary file name, so that that file will be deleted if GCC exits
339 successfully. Unlike %g, this contributes no text to the argument.
340 %w marks the argument containing or following the %w as the
341 "output file" of this compilation. This puts the argument
342 into the sequence of arguments that %o will substitute later.
343 %V indicates that this compilation produces no "output file".
344 %W{...}
345 like %{...} but mark last argument supplied within
346 as a file to be deleted on failure.
347 %o substitutes the names of all the output files, with spaces
348 automatically placed around them. You should write spaces
349 around the %o as well or the results are undefined.
350 %o is for use in the specs for running the linker.
351 Input files whose names have no recognized suffix are not compiled
352 at all, but they are included among the output files, so they will
353 be linked.
354 %O substitutes the suffix for object files. Note that this is
355 handled specially when it immediately follows %g, %u, or %U
356 (with or without a suffix argument) because of the need for
357 those to form complete file names. The handling is such that
358 %O is treated exactly as if it had already been substituted,
359 except that %g, %u, and %U do not currently support additional
360 SUFFIX characters following %O as they would following, for
361 example, `.o'.
362 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
363 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
364 and -B options) and -imultilib as necessary.
365 %s current argument is the name of a library or startup file of some sort.
366 Search for that file in a standard list of directories
367 and substitute the full name found.
368 %eSTR Print STR as an error message. STR is terminated by a newline.
369 Use this when inconsistent options are detected.
370 %nSTR Print STR as a notice. STR is terminated by a newline.
371 %x{OPTION} Accumulate an option for %X.
372 %X Output the accumulated linker options specified by compilations.
373 %Y Output the accumulated assembler options specified by compilations.
374 %Z Output the accumulated preprocessor options specified by compilations.
375 %a process ASM_SPEC as a spec.
376 This allows config.h to specify part of the spec for running as.
377 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
378 used here. This can be used to run a post-processor after the
379 assembler has done its job.
380 %D Dump out a -L option for each directory in startfile_prefixes.
381 If multilib_dir is set, extra entries are generated with it affixed.
382 %l process LINK_SPEC as a spec.
383 %L process LIB_SPEC as a spec.
384 %M Output multilib_os_dir.
385 %G process LIBGCC_SPEC as a spec.
386 %R Output the concatenation of target_system_root and
387 target_sysroot_suffix.
388 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
389 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
390 %C process CPP_SPEC as a spec.
391 %1 process CC1_SPEC as a spec.
392 %2 process CC1PLUS_SPEC as a spec.
393 %* substitute the variable part of a matched option. (See below.)
394 Note that each comma in the substituted string is replaced by
395 a single space. A space is appended after the last substition
396 unless there is more text in current sequence.
397 %<S remove all occurrences of -S from the command line.
398 Note - this command is position dependent. % commands in the
399 spec string before this one will see -S, % commands in the
400 spec string after this one will not.
401 %>S Similar to "%<S", but keep it in the GCC command line.
402 %<S* remove all occurrences of all switches beginning with -S from the
403 command line.
404 %:function(args)
405 Call the named function FUNCTION, passing it ARGS. ARGS is
406 first processed as a nested spec string, then split into an
407 argument vector in the usual fashion. The function returns
408 a string which is processed as if it had appeared literally
409 as part of the current spec.
410 %{S} substitutes the -S switch, if that switch was given to GCC.
411 If that switch was not specified, this substitutes nothing.
412 Here S is a metasyntactic variable.
413 %{S*} substitutes all the switches specified to GCC whose names start
414 with -S. This is used for -o, -I, etc; switches that take
415 arguments. GCC considers `-o foo' as being one switch whose
416 name starts with `o'. %{o*} would substitute this text,
417 including the space; thus, two arguments would be generated.
418 %{S*&T*} likewise, but preserve order of S and T options (the order
419 of S and T in the spec is not significant). Can be any number
420 of ampersand-separated variables; for each the wild card is
421 optional. Useful for CPP as %{D*&U*&A*}.
423 %{S:X} substitutes X, if the -S switch was given to GCC.
424 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
425 %{S*:X} substitutes X if one or more switches whose names start
426 with -S was given to GCC. Normally X is substituted only
427 once, no matter how many such switches appeared. However,
428 if %* appears somewhere in X, then X will be substituted
429 once for each matching switch, with the %* replaced by the
430 part of that switch that matched the '*'. A space will be
431 appended after the last substition unless there is more
432 text in current sequence.
433 %{.S:X} substitutes X, if processing a file with suffix S.
434 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
435 %{,S:X} substitutes X, if processing a file which will use spec S.
436 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
438 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
439 combined with '!', '.', ',', and '*' as above binding stronger
440 than the OR.
441 If %* appears in X, all of the alternatives must be starred, and
442 only the first matching alternative is substituted.
443 %{%:function(args):X}
444 Call function named FUNCTION with args ARGS. If the function
445 returns non-NULL, then X is substituted, if it returns
446 NULL, it isn't substituted.
447 %{S:X; if S was given to GCC, substitutes X;
448 T:Y; else if T was given to GCC, substitutes Y;
449 :D} else substitutes D. There can be as many clauses as you need.
450 This may be combined with '.', '!', ',', '|', and '*' as above.
452 %(Spec) processes a specification defined in a specs file as *Spec:
454 The conditional text X in a %{S:X} or similar construct may contain
455 other nested % constructs or spaces, or even newlines. They are
456 processed as usual, as described above. Trailing white space in X is
457 ignored. White space may also appear anywhere on the left side of the
458 colon in these constructs, except between . or * and the corresponding
459 word.
461 The -O, -f, -g, -m, and -W switches are handled specifically in these
462 constructs. If another value of -O or the negated form of a -f, -m, or
463 -W switch is found later in the command line, the earlier switch
464 value is ignored, except with {S*} where S is just one letter; this
465 passes all matching options.
467 The character | at the beginning of the predicate text is used to indicate
468 that a command should be piped to the following command, but only if -pipe
469 is specified.
471 Note that it is built into GCC which switches take arguments and which
472 do not. You might think it would be useful to generalize this to
473 allow each compiler's spec to say which switches take arguments. But
474 this cannot be done in a consistent fashion. GCC cannot even decide
475 which input files have been specified without knowing which switches
476 take arguments, and it must know which input files to compile in order
477 to tell which compilers to run.
479 GCC also knows implicitly that arguments starting in `-l' are to be
480 treated as compiler output files, and passed to the linker in their
481 proper position among the other output files. */
483 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
485 /* config.h can define ASM_SPEC to provide extra args to the assembler
486 or extra switch-translations. */
487 #ifndef ASM_SPEC
488 #define ASM_SPEC ""
489 #endif
491 /* config.h can define ASM_FINAL_SPEC to run a post processor after
492 the assembler has run. */
493 #ifndef ASM_FINAL_SPEC
494 #define ASM_FINAL_SPEC \
495 "%{gsplit-dwarf: \n\
496 objcopy --extract-dwo \
497 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
498 %{c:%{o*:%:replace-extension(%{o*:%*} .dwo)}%{!o*:%b.dwo}}%{!c:%b.dwo} \n\
499 objcopy --strip-dwo \
500 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
502 #endif
504 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
505 or extra switch-translations. */
506 #ifndef CPP_SPEC
507 #define CPP_SPEC ""
508 #endif
510 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
511 or extra switch-translations. */
512 #ifndef CC1_SPEC
513 #define CC1_SPEC ""
514 #endif
516 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
517 or extra switch-translations. */
518 #ifndef CC1PLUS_SPEC
519 #define CC1PLUS_SPEC ""
520 #endif
522 /* config.h can define LINK_SPEC to provide extra args to the linker
523 or extra switch-translations. */
524 #ifndef LINK_SPEC
525 #define LINK_SPEC ""
526 #endif
528 /* config.h can define LIB_SPEC to override the default libraries. */
529 #ifndef LIB_SPEC
530 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
531 #endif
533 /* When using -fsplit-stack we need to wrap pthread_create, in order
534 to initialize the stack guard. We always use wrapping, rather than
535 shared library ordering, and we keep the wrapper function in
536 libgcc. This is not yet a real spec, though it could become one;
537 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
538 only works with GNU ld and gold. */
539 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
541 #ifndef LIBASAN_SPEC
542 #define STATIC_LIBASAN_LIBS \
543 " %{static-libasan:%:include(libsanitizer.spec)%(link_libasan)}"
544 #ifdef LIBASAN_EARLY_SPEC
545 #define LIBASAN_SPEC STATIC_LIBASAN_LIBS
546 #elif defined(HAVE_LD_STATIC_DYNAMIC)
547 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
548 "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
549 STATIC_LIBASAN_LIBS
550 #else
551 #define LIBASAN_SPEC "-lasan" STATIC_LIBASAN_LIBS
552 #endif
553 #endif
555 #ifndef LIBASAN_EARLY_SPEC
556 #define LIBASAN_EARLY_SPEC ""
557 #endif
559 #ifndef LIBTSAN_SPEC
560 #define STATIC_LIBTSAN_LIBS \
561 " %{static-libtsan:%:include(libsanitizer.spec)%(link_libtsan)}"
562 #ifdef LIBTSAN_EARLY_SPEC
563 #define LIBTSAN_SPEC STATIC_LIBTSAN_LIBS
564 #elif defined(HAVE_LD_STATIC_DYNAMIC)
565 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
566 "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}" \
567 STATIC_LIBTSAN_LIBS
568 #else
569 #define LIBTSAN_SPEC "-ltsan" STATIC_LIBTSAN_LIBS
570 #endif
571 #endif
573 #ifndef LIBTSAN_EARLY_SPEC
574 #define LIBTSAN_EARLY_SPEC ""
575 #endif
577 #ifndef LIBLSAN_SPEC
578 #define STATIC_LIBLSAN_LIBS \
579 " %{static-liblsan:%:include(libsanitizer.spec)%(link_liblsan)}"
580 #ifdef LIBLSAN_EARLY_SPEC
581 #define LIBLSAN_SPEC STATIC_LIBLSAN_LIBS
582 #elif defined(HAVE_LD_STATIC_DYNAMIC)
583 #define LIBLSAN_SPEC "%{static-liblsan:" LD_STATIC_OPTION \
584 "} -llsan %{static-liblsan:" LD_DYNAMIC_OPTION "}" \
585 STATIC_LIBLSAN_LIBS
586 #else
587 #define LIBLSAN_SPEC "-llsan" STATIC_LIBLSAN_LIBS
588 #endif
589 #endif
591 #ifndef LIBLSAN_EARLY_SPEC
592 #define LIBLSAN_EARLY_SPEC ""
593 #endif
595 #ifndef LIBUBSAN_SPEC
596 #define STATIC_LIBUBSAN_LIBS \
597 " %{static-libubsan:%:include(libsanitizer.spec)%(link_libubsan)}"
598 #ifdef HAVE_LD_STATIC_DYNAMIC
599 #define LIBUBSAN_SPEC "%{static-libubsan:" LD_STATIC_OPTION \
600 "} -lubsan %{static-libubsan:" LD_DYNAMIC_OPTION "}" \
601 STATIC_LIBUBSAN_LIBS
602 #else
603 #define LIBUBSAN_SPEC "-lubsan" STATIC_LIBUBSAN_LIBS
604 #endif
605 #endif
607 /* Linker options for compressed debug sections. */
608 #if HAVE_LD_COMPRESS_DEBUG == 0
609 /* No linker support. */
610 #define LINK_COMPRESS_DEBUG_SPEC \
611 " %{gz*:%e-gz is not supported in this configuration} "
612 #elif HAVE_LD_COMPRESS_DEBUG == 1
613 /* GNU style on input, GNU ld options. Reject, not useful. */
614 #define LINK_COMPRESS_DEBUG_SPEC \
615 " %{gz*:%e-gz is not supported in this configuration} "
616 #elif HAVE_LD_COMPRESS_DEBUG == 2
617 /* GNU style, GNU gold options. */
618 #define LINK_COMPRESS_DEBUG_SPEC \
619 " %{gz|gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
620 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
621 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
622 #elif HAVE_LD_COMPRESS_DEBUG == 3
623 /* ELF gABI style. */
624 #define LINK_COMPRESS_DEBUG_SPEC \
625 " %{gz|gz=zlib:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
626 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
627 " %{gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
628 #else
629 #error Unknown value for HAVE_LD_COMPRESS_DEBUG.
630 #endif
632 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
633 included. */
634 #ifndef LIBGCC_SPEC
635 #if defined(REAL_LIBGCC_SPEC)
636 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
637 #elif defined(LINK_LIBGCC_SPECIAL_1)
638 /* Have gcc do the search for libgcc.a. */
639 #define LIBGCC_SPEC "libgcc.a%s"
640 #else
641 #define LIBGCC_SPEC "-lgcc"
642 #endif
643 #endif
645 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
646 #ifndef STARTFILE_SPEC
647 #define STARTFILE_SPEC \
648 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
649 #endif
651 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
652 #ifndef ENDFILE_SPEC
653 #define ENDFILE_SPEC ""
654 #endif
656 #ifndef LINKER_NAME
657 #define LINKER_NAME "collect2"
658 #endif
660 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
661 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
662 #else
663 #define ASM_MAP ""
664 #endif
666 /* Assembler options for compressed debug sections. */
667 #if HAVE_LD_COMPRESS_DEBUG < 2
668 /* Reject if the linker cannot write compressed debug sections. */
669 #define ASM_COMPRESS_DEBUG_SPEC \
670 " %{gz*:%e-gz is not supported in this configuration} "
671 #else /* HAVE_LD_COMPRESS_DEBUG >= 2 */
672 #if HAVE_AS_COMPRESS_DEBUG == 0
673 /* No assembler support. Ignore silently. */
674 #define ASM_COMPRESS_DEBUG_SPEC \
675 " %{gz*:} "
676 #elif HAVE_AS_COMPRESS_DEBUG == 1
677 /* GNU style, GNU as options. */
678 #define ASM_COMPRESS_DEBUG_SPEC \
679 " %{gz|gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "}" \
680 " %{gz=none:" AS_NO_COMPRESS_DEBUG_OPTION "}" \
681 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
682 #elif HAVE_AS_COMPRESS_DEBUG == 2
683 /* ELF gABI style. */
684 #define ASM_COMPRESS_DEBUG_SPEC \
685 " %{gz|gz=zlib:" AS_COMPRESS_DEBUG_OPTION "=zlib}" \
686 " %{gz=none:" AS_COMPRESS_DEBUG_OPTION "=none}" \
687 " %{gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
688 #else
689 #error Unknown value for HAVE_AS_COMPRESS_DEBUG.
690 #endif
691 #endif /* HAVE_LD_COMPRESS_DEBUG >= 2 */
693 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
694 to the assembler. */
695 #ifndef ASM_DEBUG_SPEC
696 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
697 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
698 # define ASM_DEBUG_SPEC \
699 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
700 ? "%{!g0:%{gdwarf*:--gdwarf2}%{!gdwarf*:%{g*:--gstabs}}}" ASM_MAP \
701 : "%{!g0:%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
702 # else
703 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
704 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gstabs}}" ASM_MAP
705 # endif
706 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
707 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gdwarf2}}" ASM_MAP
708 # endif
709 # endif
710 #endif
711 #ifndef ASM_DEBUG_SPEC
712 # define ASM_DEBUG_SPEC ""
713 #endif
715 /* Here is the spec for running the linker, after compiling all files. */
717 /* This is overridable by the target in case they need to specify the
718 -lgcc and -lc order specially, yet not require them to override all
719 of LINK_COMMAND_SPEC. */
720 #ifndef LINK_GCC_C_SEQUENCE_SPEC
721 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
722 #endif
724 #ifndef LINK_SSP_SPEC
725 #ifdef TARGET_LIBC_PROVIDES_SSP
726 #define LINK_SSP_SPEC "%{fstack-protector:}"
727 #else
728 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-strong|fstack-protector-all:-lssp_nonshared -lssp}"
729 #endif
730 #endif
732 #ifndef LINK_PIE_SPEC
733 #ifdef HAVE_LD_PIE
734 #define LINK_PIE_SPEC "%{pie:-pie} "
735 #else
736 #define LINK_PIE_SPEC "%{pie:} "
737 #endif
738 #endif
740 #ifndef LINK_BUILDID_SPEC
741 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
742 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
743 # endif
744 #endif
746 /* Conditional to test whether the LTO plugin is used or not.
747 FIXME: For slim LTO we will need to enable plugin unconditionally. This
748 still cause problems with PLUGIN_LD != LD and when plugin is built but
749 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
750 plugin only when LTO is enabled. We still honor explicit
751 -fuse-linker-plugin if the linker used understands -plugin. */
753 /* The linker has some plugin support. */
754 #if HAVE_LTO_PLUGIN > 0
755 /* The linker used has full plugin support, use LTO plugin by default. */
756 #if HAVE_LTO_PLUGIN == 2
757 #define PLUGIN_COND "!fno-use-linker-plugin:%{!fno-lto"
758 #define PLUGIN_COND_CLOSE "}"
759 #else
760 /* The linker used has limited plugin support, use LTO plugin with explicit
761 -fuse-linker-plugin. */
762 #define PLUGIN_COND "fuse-linker-plugin"
763 #define PLUGIN_COND_CLOSE ""
764 #endif
765 #define LINK_PLUGIN_SPEC \
766 "%{"PLUGIN_COND": \
767 -plugin %(linker_plugin_file) \
768 -plugin-opt=%(lto_wrapper) \
769 -plugin-opt=-fresolution=%u.res \
770 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
771 }"PLUGIN_COND_CLOSE
772 #else
773 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
774 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
775 %e-fuse-linker-plugin is not supported in this configuration}"
776 #endif
778 /* Linker command line options for -fsanitize= early on the command line. */
779 #ifndef SANITIZER_EARLY_SPEC
780 #define SANITIZER_EARLY_SPEC "\
781 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_EARLY_SPEC "} \
782 %{%:sanitize(thread):" LIBTSAN_EARLY_SPEC "} \
783 %{%:sanitize(leak):" LIBLSAN_EARLY_SPEC "}}}"
784 #endif
786 /* Linker command line options for -fsanitize= late on the command line. */
787 #ifndef SANITIZER_SPEC
788 #define SANITIZER_SPEC "\
789 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_SPEC "\
790 %{static:%ecannot specify -static with -fsanitize=address}}\
791 %{%:sanitize(thread):" LIBTSAN_SPEC "\
792 %{!pie:%{!shared:%e-fsanitize=thread linking must be done with -pie or -shared}}}\
793 %{%:sanitize(undefined):" LIBUBSAN_SPEC "}\
794 %{%:sanitize(leak):" LIBLSAN_SPEC "}}}"
795 #endif
797 /* This is the spec to use, once the code for creating the vtable
798 verification runtime library, libvtv.so, has been created. Currently
799 the vtable verification runtime functions are in libstdc++, so we use
800 the spec just below this one. */
801 #ifndef VTABLE_VERIFICATION_SPEC
802 #define VTABLE_VERIFICATION_SPEC "\
803 %{!nostdlib:%{fvtable-verify=std: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}\
804 %{fvtable-verify=preinit: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}}"
805 #endif
807 /* -u* was put back because both BSD and SysV seem to support it. */
808 /* %{static:} simply prevents an error message if the target machine
809 doesn't handle -static. */
810 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
811 scripts which exist in user specified directories, or in standard
812 directories. */
813 /* We pass any -flto flags on to the linker, which is expected
814 to understand them. In practice, this means it had better be collect2. */
815 /* %{e*} includes -export-dynamic; see comment in common.opt. */
816 #ifndef LINK_COMMAND_SPEC
817 #define LINK_COMMAND_SPEC "\
818 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
819 %(linker) " \
820 LINK_PLUGIN_SPEC \
821 "%{flto|flto=*:%<fcompare-debug*} \
822 %{flto} %{flto=*} %l " LINK_PIE_SPEC \
823 "%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
824 "%X %{o*} %{e*} %{N} %{n} %{r}\
825 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}} " VTABLE_VERIFICATION_SPEC " \
826 %{static:} %{L*} %(mfwrap) %(link_libgcc) " SANITIZER_EARLY_SPEC " %o\
827 %{fopenmp|ftree-parallelize-loops=*:%:include(libgomp.spec)%(link_gomp)}\
828 %{fcilkplus:%:include(libcilkrts.spec)%(link_cilkrts)}\
829 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
830 %(mflib) " STACK_SPLIT_SPEC "\
831 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
832 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
833 %{!nostdlib:%{!nostartfiles:%E}} %{T*} }}}}}}"
834 #endif
836 #ifndef LINK_LIBGCC_SPEC
837 /* Generate -L options for startfile prefix list. */
838 # define LINK_LIBGCC_SPEC "%D"
839 #endif
841 #ifndef STARTFILE_PREFIX_SPEC
842 # define STARTFILE_PREFIX_SPEC ""
843 #endif
845 #ifndef SYSROOT_SPEC
846 # define SYSROOT_SPEC "--sysroot=%R"
847 #endif
849 #ifndef SYSROOT_SUFFIX_SPEC
850 # define SYSROOT_SUFFIX_SPEC ""
851 #endif
853 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
854 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
855 #endif
857 static const char *asm_debug = ASM_DEBUG_SPEC;
858 static const char *cpp_spec = CPP_SPEC;
859 static const char *cc1_spec = CC1_SPEC;
860 static const char *cc1plus_spec = CC1PLUS_SPEC;
861 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
862 static const char *link_ssp_spec = LINK_SSP_SPEC;
863 static const char *asm_spec = ASM_SPEC;
864 static const char *asm_final_spec = ASM_FINAL_SPEC;
865 static const char *link_spec = LINK_SPEC;
866 static const char *lib_spec = LIB_SPEC;
867 static const char *link_gomp_spec = "";
868 static const char *libgcc_spec = LIBGCC_SPEC;
869 static const char *endfile_spec = ENDFILE_SPEC;
870 static const char *startfile_spec = STARTFILE_SPEC;
871 static const char *linker_name_spec = LINKER_NAME;
872 static const char *linker_plugin_file_spec = "";
873 static const char *lto_wrapper_spec = "";
874 static const char *lto_gcc_spec = "";
875 static const char *link_command_spec = LINK_COMMAND_SPEC;
876 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
877 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
878 static const char *sysroot_spec = SYSROOT_SPEC;
879 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
880 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
881 static const char *self_spec = "";
883 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
884 There should be no need to override these in target dependent files,
885 but we need to copy them to the specs file so that newer versions
886 of the GCC driver can correctly drive older tool chains with the
887 appropriate -B options. */
889 /* When cpplib handles traditional preprocessing, get rid of this, and
890 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
891 that we default the front end language better. */
892 static const char *trad_capable_cpp =
893 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
895 /* We don't wrap .d files in %W{} since a missing .d file, and
896 therefore no dependency entry, confuses make into thinking a .o
897 file that happens to exist is up-to-date. */
898 static const char *cpp_unique_options =
899 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
900 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
901 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
902 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
903 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
904 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
905 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
906 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
907 %{E|M|MM:%W{o*}}";
909 /* This contains cpp options which are common with cc1_options and are passed
910 only when preprocessing only to avoid duplication. We pass the cc1 spec
911 options to the preprocessor so that it the cc1 spec may manipulate
912 options used to set target flags. Those special target flags settings may
913 in turn cause preprocessor symbols to be defined specially. */
914 static const char *cpp_options =
915 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
916 %{f*} %{g*:%{!g0:%{g*} %{!fno-working-directory:-fworking-directory}}} %{O*}\
917 %{undef} %{save-temps*:-fpch-preprocess}";
919 /* This contains cpp options which are not passed when the preprocessor
920 output will be used by another program. */
921 static const char *cpp_debug_options = "%{d*}";
923 /* NB: This is shared amongst all front-ends, except for Ada. */
924 static const char *cc1_options =
925 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
926 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
927 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
928 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
929 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
930 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
931 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
932 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
933 %{-target-help:--target-help}\
934 %{-version:--version}\
935 %{-help=*:--help=%*}\
936 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
937 %{fsyntax-only:-o %j} %{-param*}\
938 %{coverage:-fprofile-arcs -ftest-coverage}";
940 static const char *asm_options =
941 "%{-target-help:%:print-asm-header()} "
942 #if HAVE_GNU_AS
943 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
944 to the assembler equivalents. */
945 "%{v} %{w:-W} %{I*} "
946 #endif
947 ASM_COMPRESS_DEBUG_SPEC
948 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
950 static const char *invoke_as =
951 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
952 "%{!fwpa*:\
953 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
954 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
956 #else
957 "%{!fwpa*:\
958 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
959 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
961 #endif
963 /* Some compilers have limits on line lengths, and the multilib_select
964 and/or multilib_matches strings can be very long, so we build them at
965 run time. */
966 static struct obstack multilib_obstack;
967 static const char *multilib_select;
968 static const char *multilib_matches;
969 static const char *multilib_defaults;
970 static const char *multilib_exclusions;
971 static const char *multilib_reuse;
973 /* Check whether a particular argument is a default argument. */
975 #ifndef MULTILIB_DEFAULTS
976 #define MULTILIB_DEFAULTS { "" }
977 #endif
979 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
981 #ifndef DRIVER_SELF_SPECS
982 #define DRIVER_SELF_SPECS ""
983 #endif
985 /* Linking to libgomp implies pthreads. This is particularly important
986 for targets that use different start files and suchlike. */
987 #ifndef GOMP_SELF_SPECS
988 #define GOMP_SELF_SPECS "%{fopenmp|ftree-parallelize-loops=*: -pthread}"
989 #endif
991 /* Likewise for -fgnu-tm. */
992 #ifndef GTM_SELF_SPECS
993 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
994 #endif
996 /* Likewise for -fcilkplus. */
997 #ifndef CILK_SELF_SPECS
998 #define CILK_SELF_SPECS "%{fcilkplus: -pthread}"
999 #endif
1001 static const char *const driver_self_specs[] = {
1002 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
1003 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS,
1004 CILK_SELF_SPECS
1007 #ifndef OPTION_DEFAULT_SPECS
1008 #define OPTION_DEFAULT_SPECS { "", "" }
1009 #endif
1011 struct default_spec
1013 const char *name;
1014 const char *spec;
1017 static const struct default_spec
1018 option_default_specs[] = { OPTION_DEFAULT_SPECS };
1020 struct user_specs
1022 struct user_specs *next;
1023 const char *filename;
1026 static struct user_specs *user_specs_head, *user_specs_tail;
1029 /* Record the mapping from file suffixes for compilation specs. */
1031 struct compiler
1033 const char *suffix; /* Use this compiler for input files
1034 whose names end in this suffix. */
1036 const char *spec; /* To use this compiler, run this spec. */
1038 const char *cpp_spec; /* If non-NULL, substitute this spec
1039 for `%C', rather than the usual
1040 cpp_spec. */
1041 const int combinable; /* If nonzero, compiler can deal with
1042 multiple source files at once (IMA). */
1043 const int needs_preprocessing; /* If nonzero, source files need to
1044 be run through a preprocessor. */
1047 /* Pointer to a vector of `struct compiler' that gives the spec for
1048 compiling a file, based on its suffix.
1049 A file that does not end in any of these suffixes will be passed
1050 unchanged to the loader and nothing else will be done to it.
1052 An entry containing two 0s is used to terminate the vector.
1054 If multiple entries match a file, the last matching one is used. */
1056 static struct compiler *compilers;
1058 /* Number of entries in `compilers', not counting the null terminator. */
1060 static int n_compilers;
1062 /* The default list of file name suffixes and their compilation specs. */
1064 static const struct compiler default_compilers[] =
1066 /* Add lists of suffixes of known languages here. If those languages
1067 were not present when we built the driver, we will hit these copies
1068 and be given a more meaningful error than "file not used since
1069 linking is not done". */
1070 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
1071 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
1072 {".mii", "#Objective-C++", 0, 0, 0},
1073 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
1074 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
1075 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
1076 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
1077 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
1078 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
1079 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
1080 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
1081 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
1082 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
1083 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
1084 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1085 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1086 {".r", "#Ratfor", 0, 0, 0},
1087 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
1088 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
1089 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
1090 {".go", "#Go", 0, 1, 0},
1091 /* Next come the entries for C. */
1092 {".c", "@c", 0, 0, 1},
1093 {"@c",
1094 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1095 external preprocessor if -save-temps is given. */
1096 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1097 %{!E:%{!M:%{!MM:\
1098 %{traditional:\
1099 %eGNU C no longer supports -traditional without -E}\
1100 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1101 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1102 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1103 %(cc1_options)}\
1104 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1105 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1106 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1107 {"-",
1108 "%{!E:%e-E or -x required when input is from standard input}\
1109 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1110 {".h", "@c-header", 0, 0, 0},
1111 {"@c-header",
1112 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1113 external preprocessor if -save-temps is given. */
1114 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1115 %{!E:%{!M:%{!MM:\
1116 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1117 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1118 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1119 %(cc1_options)\
1120 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1121 %W{o*:--output-pch=%*}}%V}\
1122 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1123 cc1 %(cpp_unique_options) %(cc1_options)\
1124 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1125 %W{o*:--output-pch=%*}}%V}}}}}}", 0, 0, 0},
1126 {".i", "@cpp-output", 0, 0, 0},
1127 {"@cpp-output",
1128 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1129 {".s", "@assembler", 0, 0, 0},
1130 {"@assembler",
1131 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1132 {".sx", "@assembler-with-cpp", 0, 0, 0},
1133 {".S", "@assembler-with-cpp", 0, 0, 0},
1134 {"@assembler-with-cpp",
1135 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1136 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1137 %{E|M|MM:%(cpp_debug_options)}\
1138 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1139 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1140 #else
1141 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1142 %{E|M|MM:%(cpp_debug_options)}\
1143 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1144 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1145 #endif
1146 , 0, 0, 0},
1148 #include "specs.h"
1149 /* Mark end of table. */
1150 {0, 0, 0, 0, 0}
1153 /* Number of elements in default_compilers, not counting the terminator. */
1155 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1157 typedef char *char_p; /* For DEF_VEC_P. */
1159 /* A vector of options to give to the linker.
1160 These options are accumulated by %x,
1161 and substituted into the linker command with %X. */
1162 static vec<char_p> linker_options;
1164 /* A vector of options to give to the assembler.
1165 These options are accumulated by -Wa,
1166 and substituted into the assembler command with %Y. */
1167 static vec<char_p> assembler_options;
1169 /* A vector of options to give to the preprocessor.
1170 These options are accumulated by -Wp,
1171 and substituted into the preprocessor command with %Z. */
1172 static vec<char_p> preprocessor_options;
1174 static char *
1175 skip_whitespace (char *p)
1177 while (1)
1179 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1180 be considered whitespace. */
1181 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1182 return p + 1;
1183 else if (*p == '\n' || *p == ' ' || *p == '\t')
1184 p++;
1185 else if (*p == '#')
1187 while (*p != '\n')
1188 p++;
1189 p++;
1191 else
1192 break;
1195 return p;
1197 /* Structures to keep track of prefixes to try when looking for files. */
1199 struct prefix_list
1201 const char *prefix; /* String to prepend to the path. */
1202 struct prefix_list *next; /* Next in linked list. */
1203 int require_machine_suffix; /* Don't use without machine_suffix. */
1204 /* 2 means try both machine_suffix and just_machine_suffix. */
1205 int priority; /* Sort key - priority within list. */
1206 int os_multilib; /* 1 if OS multilib scheme should be used,
1207 0 for GCC multilib scheme. */
1210 struct path_prefix
1212 struct prefix_list *plist; /* List of prefixes to try */
1213 int max_len; /* Max length of a prefix in PLIST */
1214 const char *name; /* Name of this list (used in config stuff) */
1217 /* List of prefixes to try when looking for executables. */
1219 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1221 /* List of prefixes to try when looking for startup (crt0) files. */
1223 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1225 /* List of prefixes to try when looking for include files. */
1227 static struct path_prefix include_prefixes = { 0, 0, "include" };
1229 /* Suffix to attach to directories searched for commands.
1230 This looks like `MACHINE/VERSION/'. */
1232 static const char *machine_suffix = 0;
1234 /* Suffix to attach to directories searched for commands.
1235 This is just `MACHINE/'. */
1237 static const char *just_machine_suffix = 0;
1239 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1241 static const char *gcc_exec_prefix;
1243 /* Adjusted value of standard_libexec_prefix. */
1245 static const char *gcc_libexec_prefix;
1247 /* Default prefixes to attach to command names. */
1249 #ifndef STANDARD_STARTFILE_PREFIX_1
1250 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1251 #endif
1252 #ifndef STANDARD_STARTFILE_PREFIX_2
1253 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1254 #endif
1256 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1257 #undef MD_EXEC_PREFIX
1258 #undef MD_STARTFILE_PREFIX
1259 #undef MD_STARTFILE_PREFIX_1
1260 #endif
1262 /* If no prefixes defined, use the null string, which will disable them. */
1263 #ifndef MD_EXEC_PREFIX
1264 #define MD_EXEC_PREFIX ""
1265 #endif
1266 #ifndef MD_STARTFILE_PREFIX
1267 #define MD_STARTFILE_PREFIX ""
1268 #endif
1269 #ifndef MD_STARTFILE_PREFIX_1
1270 #define MD_STARTFILE_PREFIX_1 ""
1271 #endif
1273 /* These directories are locations set at configure-time based on the
1274 --prefix option provided to configure. Their initializers are
1275 defined in Makefile.in. These paths are not *directly* used when
1276 gcc_exec_prefix is set because, in that case, we know where the
1277 compiler has been installed, and use paths relative to that
1278 location instead. */
1279 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1280 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1281 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1282 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1284 /* For native compilers, these are well-known paths containing
1285 components that may be provided by the system. For cross
1286 compilers, these paths are not used. */
1287 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1288 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1289 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1290 static const char *const standard_startfile_prefix_1
1291 = STANDARD_STARTFILE_PREFIX_1;
1292 static const char *const standard_startfile_prefix_2
1293 = STANDARD_STARTFILE_PREFIX_2;
1295 /* A relative path to be used in finding the location of tools
1296 relative to the driver. */
1297 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1299 /* Subdirectory to use for locating libraries. Set by
1300 set_multilib_dir based on the compilation options. */
1302 static const char *multilib_dir;
1304 /* Subdirectory to use for locating libraries in OS conventions. Set by
1305 set_multilib_dir based on the compilation options. */
1307 static const char *multilib_os_dir;
1309 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1310 set_multilib_dir based on the compilation options. */
1312 static const char *multiarch_dir;
1314 /* Structure to keep track of the specs that have been defined so far.
1315 These are accessed using %(specname) in a compiler or link
1316 spec. */
1318 struct spec_list
1320 /* The following 2 fields must be first */
1321 /* to allow EXTRA_SPECS to be initialized */
1322 const char *name; /* name of the spec. */
1323 const char *ptr; /* available ptr if no static pointer */
1325 /* The following fields are not initialized */
1326 /* by EXTRA_SPECS */
1327 const char **ptr_spec; /* pointer to the spec itself. */
1328 struct spec_list *next; /* Next spec in linked list. */
1329 int name_len; /* length of the name */
1330 bool user_p; /* whether string come from file spec. */
1331 bool alloc_p; /* whether string was allocated */
1334 #define INIT_STATIC_SPEC(NAME,PTR) \
1335 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false }
1337 /* List of statically defined specs. */
1338 static struct spec_list static_specs[] =
1340 INIT_STATIC_SPEC ("asm", &asm_spec),
1341 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1342 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1343 INIT_STATIC_SPEC ("asm_options", &asm_options),
1344 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1345 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1346 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1347 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1348 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1349 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1350 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1351 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1352 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1353 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1354 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1355 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1356 INIT_STATIC_SPEC ("link", &link_spec),
1357 INIT_STATIC_SPEC ("lib", &lib_spec),
1358 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1359 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1360 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1361 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1362 INIT_STATIC_SPEC ("version", &compiler_version),
1363 INIT_STATIC_SPEC ("multilib", &multilib_select),
1364 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1365 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1366 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1367 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1368 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1369 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1370 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1371 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1372 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1373 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1374 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1375 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1376 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1377 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1378 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1379 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1380 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1381 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1382 INIT_STATIC_SPEC ("self_spec", &self_spec),
1385 #ifdef EXTRA_SPECS /* additional specs needed */
1386 /* Structure to keep track of just the first two args of a spec_list.
1387 That is all that the EXTRA_SPECS macro gives us. */
1388 struct spec_list_1
1390 const char *const name;
1391 const char *const ptr;
1394 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1395 static struct spec_list *extra_specs = (struct spec_list *) 0;
1396 #endif
1398 /* List of dynamically allocates specs that have been defined so far. */
1400 static struct spec_list *specs = (struct spec_list *) 0;
1402 /* List of static spec functions. */
1404 static const struct spec_function static_spec_functions[] =
1406 { "getenv", getenv_spec_function },
1407 { "if-exists", if_exists_spec_function },
1408 { "if-exists-else", if_exists_else_spec_function },
1409 { "sanitize", sanitize_spec_function },
1410 { "replace-outfile", replace_outfile_spec_function },
1411 { "remove-outfile", remove_outfile_spec_function },
1412 { "version-compare", version_compare_spec_function },
1413 { "include", include_spec_function },
1414 { "find-file", find_file_spec_function },
1415 { "find-plugindir", find_plugindir_spec_function },
1416 { "print-asm-header", print_asm_header_spec_function },
1417 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1418 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1419 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1420 { "pass-through-libs", pass_through_libs_spec_func },
1421 { "replace-extension", replace_extension_spec_func },
1422 #ifdef EXTRA_SPEC_FUNCTIONS
1423 EXTRA_SPEC_FUNCTIONS
1424 #endif
1425 { 0, 0 }
1428 static int processing_spec_function;
1430 /* Add appropriate libgcc specs to OBSTACK, taking into account
1431 various permutations of -shared-libgcc, -shared, and such. */
1433 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1435 #ifndef USE_LD_AS_NEEDED
1436 #define USE_LD_AS_NEEDED 0
1437 #endif
1439 static void
1440 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1441 const char *static_name, const char *eh_name)
1443 char *buf;
1445 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1446 "%{!static:%{!static-libgcc:"
1447 #if USE_LD_AS_NEEDED
1448 "%{!shared-libgcc:",
1449 static_name, " " LD_AS_NEEDED_OPTION " ",
1450 shared_name, " " LD_NO_AS_NEEDED_OPTION
1452 "%{shared-libgcc:",
1453 shared_name, "%{!shared: ", static_name, "}"
1455 #else
1456 "%{!shared:"
1457 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1458 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1460 #ifdef LINK_EH_SPEC
1461 "%{shared:"
1462 "%{shared-libgcc:", shared_name, "}"
1463 "%{!shared-libgcc:", static_name, "}"
1465 #else
1466 "%{shared:", shared_name, "}"
1467 #endif
1468 #endif
1469 "}}", NULL);
1471 obstack_grow (obstack, buf, strlen (buf));
1472 free (buf);
1474 #endif /* ENABLE_SHARED_LIBGCC */
1476 /* Initialize the specs lookup routines. */
1478 static void
1479 init_spec (void)
1481 struct spec_list *next = (struct spec_list *) 0;
1482 struct spec_list *sl = (struct spec_list *) 0;
1483 int i;
1485 if (specs)
1486 return; /* Already initialized. */
1488 if (verbose_flag)
1489 fnotice (stderr, "Using built-in specs.\n");
1491 #ifdef EXTRA_SPECS
1492 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1494 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1496 sl = &extra_specs[i];
1497 sl->name = extra_specs_1[i].name;
1498 sl->ptr = extra_specs_1[i].ptr;
1499 sl->next = next;
1500 sl->name_len = strlen (sl->name);
1501 sl->ptr_spec = &sl->ptr;
1502 next = sl;
1504 #endif
1506 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1508 sl = &static_specs[i];
1509 sl->next = next;
1510 next = sl;
1513 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1514 /* ??? If neither -shared-libgcc nor --static-libgcc was
1515 seen, then we should be making an educated guess. Some proposed
1516 heuristics for ELF include:
1518 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1519 program will be doing dynamic loading, which will likely
1520 need the shared libgcc.
1522 (2) If "-ldl", then it's also a fair bet that we're doing
1523 dynamic loading.
1525 (3) For each ET_DYN we're linking against (either through -lfoo
1526 or /some/path/foo.so), check to see whether it or one of
1527 its dependencies depends on a shared libgcc.
1529 (4) If "-shared"
1531 If the runtime is fixed to look for program headers instead
1532 of calling __register_frame_info at all, for each object,
1533 use the shared libgcc if any EH symbol referenced.
1535 If crtstuff is fixed to not invoke __register_frame_info
1536 automatically, for each object, use the shared libgcc if
1537 any non-empty unwind section found.
1539 Doing any of this probably requires invoking an external program to
1540 do the actual object file scanning. */
1542 const char *p = libgcc_spec;
1543 int in_sep = 1;
1545 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1546 when given the proper command line arguments. */
1547 while (*p)
1549 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1551 init_gcc_specs (&obstack,
1552 "-lgcc_s"
1553 #ifdef USE_LIBUNWIND_EXCEPTIONS
1554 " -lunwind"
1555 #endif
1557 "-lgcc",
1558 "-lgcc_eh"
1559 #ifdef USE_LIBUNWIND_EXCEPTIONS
1560 # ifdef HAVE_LD_STATIC_DYNAMIC
1561 " %{!static:" LD_STATIC_OPTION "} -lunwind"
1562 " %{!static:" LD_DYNAMIC_OPTION "}"
1563 # else
1564 " -lunwind"
1565 # endif
1566 #endif
1569 p += 5;
1570 in_sep = 0;
1572 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1574 /* Ug. We don't know shared library extensions. Hope that
1575 systems that use this form don't do shared libraries. */
1576 init_gcc_specs (&obstack,
1577 "-lgcc_s",
1578 "libgcc.a%s",
1579 "libgcc_eh.a%s"
1580 #ifdef USE_LIBUNWIND_EXCEPTIONS
1581 " -lunwind"
1582 #endif
1584 p += 10;
1585 in_sep = 0;
1587 else
1589 obstack_1grow (&obstack, *p);
1590 in_sep = (*p == ' ');
1591 p += 1;
1595 obstack_1grow (&obstack, '\0');
1596 libgcc_spec = XOBFINISH (&obstack, const char *);
1598 #endif
1599 #ifdef USE_AS_TRADITIONAL_FORMAT
1600 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1602 static const char tf[] = "--traditional-format ";
1603 obstack_grow (&obstack, tf, sizeof (tf) - 1);
1604 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1605 asm_spec = XOBFINISH (&obstack, const char *);
1607 #endif
1609 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1610 defined LINKER_HASH_STYLE
1611 # ifdef LINK_BUILDID_SPEC
1612 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1613 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof (LINK_BUILDID_SPEC) - 1);
1614 # endif
1615 # ifdef LINK_EH_SPEC
1616 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1617 obstack_grow (&obstack, LINK_EH_SPEC, sizeof (LINK_EH_SPEC) - 1);
1618 # endif
1619 # ifdef LINKER_HASH_STYLE
1620 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1621 before. */
1623 static const char hash_style[] = "--hash-style=";
1624 obstack_grow (&obstack, hash_style, sizeof (hash_style) - 1);
1625 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof (LINKER_HASH_STYLE) - 1);
1626 obstack_1grow (&obstack, ' ');
1628 # endif
1629 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1630 link_spec = XOBFINISH (&obstack, const char *);
1631 #endif
1633 specs = sl;
1636 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1637 removed; If the spec starts with a + then SPEC is added to the end of the
1638 current spec. */
1640 static void
1641 set_spec (const char *name, const char *spec, bool user_p)
1643 struct spec_list *sl;
1644 const char *old_spec;
1645 int name_len = strlen (name);
1646 int i;
1648 /* If this is the first call, initialize the statically allocated specs. */
1649 if (!specs)
1651 struct spec_list *next = (struct spec_list *) 0;
1652 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1654 sl = &static_specs[i];
1655 sl->next = next;
1656 next = sl;
1658 specs = sl;
1661 /* See if the spec already exists. */
1662 for (sl = specs; sl; sl = sl->next)
1663 if (name_len == sl->name_len && !strcmp (sl->name, name))
1664 break;
1666 if (!sl)
1668 /* Not found - make it. */
1669 sl = XNEW (struct spec_list);
1670 sl->name = xstrdup (name);
1671 sl->name_len = name_len;
1672 sl->ptr_spec = &sl->ptr;
1673 sl->alloc_p = 0;
1674 *(sl->ptr_spec) = "";
1675 sl->next = specs;
1676 specs = sl;
1679 old_spec = *(sl->ptr_spec);
1680 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1681 ? concat (old_spec, spec + 1, NULL)
1682 : xstrdup (spec));
1684 #ifdef DEBUG_SPECS
1685 if (verbose_flag)
1686 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1687 #endif
1689 /* Free the old spec. */
1690 if (old_spec && sl->alloc_p)
1691 free (CONST_CAST (char *, old_spec));
1693 sl->user_p = user_p;
1694 sl->alloc_p = true;
1697 /* Accumulate a command (program name and args), and run it. */
1699 typedef const char *const_char_p; /* For DEF_VEC_P. */
1701 /* Vector of pointers to arguments in the current line of specifications. */
1703 static vec<const_char_p> argbuf;
1705 /* Position in the argbuf vector containing the name of the output file
1706 (the value associated with the "-o" flag). */
1708 static int have_o_argbuf_index = 0;
1710 /* Were the options -c, -S or -E passed. */
1711 static int have_c = 0;
1713 /* Was the option -o passed. */
1714 static int have_o = 0;
1716 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1717 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1718 it here. */
1720 static struct temp_name {
1721 const char *suffix; /* suffix associated with the code. */
1722 int length; /* strlen (suffix). */
1723 int unique; /* Indicates whether %g or %u/%U was used. */
1724 const char *filename; /* associated filename. */
1725 int filename_length; /* strlen (filename). */
1726 struct temp_name *next;
1727 } *temp_names;
1729 /* Number of commands executed so far. */
1731 static int execution_count;
1733 /* Number of commands that exited with a signal. */
1735 static int signal_count;
1737 /* Allocate the argument vector. */
1739 static void
1740 alloc_args (void)
1742 argbuf.create (10);
1745 /* Clear out the vector of arguments (after a command is executed). */
1747 static void
1748 clear_args (void)
1750 argbuf.truncate (0);
1753 /* Add one argument to the vector at the end.
1754 This is done when a space is seen or at the end of the line.
1755 If DELETE_ALWAYS is nonzero, the arg is a filename
1756 and the file should be deleted eventually.
1757 If DELETE_FAILURE is nonzero, the arg is a filename
1758 and the file should be deleted if this compilation fails. */
1760 static void
1761 store_arg (const char *arg, int delete_always, int delete_failure)
1763 argbuf.safe_push (arg);
1765 if (strcmp (arg, "-o") == 0)
1766 have_o_argbuf_index = argbuf.length ();
1767 if (delete_always || delete_failure)
1769 const char *p;
1770 /* If the temporary file we should delete is specified as
1771 part of a joined argument extract the filename. */
1772 if (arg[0] == '-'
1773 && (p = strrchr (arg, '=')))
1774 arg = p + 1;
1775 record_temp_file (arg, delete_always, delete_failure);
1779 /* Load specs from a file name named FILENAME, replacing occurrences of
1780 various different types of line-endings, \r\n, \n\r and just \r, with
1781 a single \n. */
1783 static char *
1784 load_specs (const char *filename)
1786 int desc;
1787 int readlen;
1788 struct stat statbuf;
1789 char *buffer;
1790 char *buffer_p;
1791 char *specs;
1792 char *specs_p;
1794 if (verbose_flag)
1795 fnotice (stderr, "Reading specs from %s\n", filename);
1797 /* Open and stat the file. */
1798 desc = open (filename, O_RDONLY, 0);
1799 if (desc < 0)
1800 pfatal_with_name (filename);
1801 if (stat (filename, &statbuf) < 0)
1802 pfatal_with_name (filename);
1804 /* Read contents of file into BUFFER. */
1805 buffer = XNEWVEC (char, statbuf.st_size + 1);
1806 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1807 if (readlen < 0)
1808 pfatal_with_name (filename);
1809 buffer[readlen] = 0;
1810 close (desc);
1812 specs = XNEWVEC (char, readlen + 1);
1813 specs_p = specs;
1814 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1816 int skip = 0;
1817 char c = *buffer_p;
1818 if (c == '\r')
1820 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1821 skip = 1;
1822 else if (*(buffer_p + 1) == '\n') /* \r\n */
1823 skip = 1;
1824 else /* \r */
1825 c = '\n';
1827 if (! skip)
1828 *specs_p++ = c;
1830 *specs_p = '\0';
1832 free (buffer);
1833 return (specs);
1836 /* Read compilation specs from a file named FILENAME,
1837 replacing the default ones.
1839 A suffix which starts with `*' is a definition for
1840 one of the machine-specific sub-specs. The "suffix" should be
1841 *asm, *cc1, *cpp, *link, *startfile, etc.
1842 The corresponding spec is stored in asm_spec, etc.,
1843 rather than in the `compilers' vector.
1845 Anything invalid in the file is a fatal error. */
1847 static void
1848 read_specs (const char *filename, bool main_p, bool user_p)
1850 char *buffer;
1851 char *p;
1853 buffer = load_specs (filename);
1855 /* Scan BUFFER for specs, putting them in the vector. */
1856 p = buffer;
1857 while (1)
1859 char *suffix;
1860 char *spec;
1861 char *in, *out, *p1, *p2, *p3;
1863 /* Advance P in BUFFER to the next nonblank nocomment line. */
1864 p = skip_whitespace (p);
1865 if (*p == 0)
1866 break;
1868 /* Is this a special command that starts with '%'? */
1869 /* Don't allow this for the main specs file, since it would
1870 encourage people to overwrite it. */
1871 if (*p == '%' && !main_p)
1873 p1 = p;
1874 while (*p && *p != '\n')
1875 p++;
1877 /* Skip '\n'. */
1878 p++;
1880 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1881 && (p1[sizeof "%include" - 1] == ' '
1882 || p1[sizeof "%include" - 1] == '\t'))
1884 char *new_filename;
1886 p1 += sizeof ("%include");
1887 while (*p1 == ' ' || *p1 == '\t')
1888 p1++;
1890 if (*p1++ != '<' || p[-2] != '>')
1891 fatal_error ("specs %%include syntax malformed after "
1892 "%ld characters",
1893 (long) (p1 - buffer + 1));
1895 p[-2] = '\0';
1896 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1897 read_specs (new_filename ? new_filename : p1, false, user_p);
1898 continue;
1900 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1901 && (p1[sizeof "%include_noerr" - 1] == ' '
1902 || p1[sizeof "%include_noerr" - 1] == '\t'))
1904 char *new_filename;
1906 p1 += sizeof "%include_noerr";
1907 while (*p1 == ' ' || *p1 == '\t')
1908 p1++;
1910 if (*p1++ != '<' || p[-2] != '>')
1911 fatal_error ("specs %%include syntax malformed after "
1912 "%ld characters",
1913 (long) (p1 - buffer + 1));
1915 p[-2] = '\0';
1916 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1917 if (new_filename)
1918 read_specs (new_filename, false, user_p);
1919 else if (verbose_flag)
1920 fnotice (stderr, "could not find specs file %s\n", p1);
1921 continue;
1923 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1924 && (p1[sizeof "%rename" - 1] == ' '
1925 || p1[sizeof "%rename" - 1] == '\t'))
1927 int name_len;
1928 struct spec_list *sl;
1929 struct spec_list *newsl;
1931 /* Get original name. */
1932 p1 += sizeof "%rename";
1933 while (*p1 == ' ' || *p1 == '\t')
1934 p1++;
1936 if (! ISALPHA ((unsigned char) *p1))
1937 fatal_error ("specs %%rename syntax malformed after "
1938 "%ld characters",
1939 (long) (p1 - buffer));
1941 p2 = p1;
1942 while (*p2 && !ISSPACE ((unsigned char) *p2))
1943 p2++;
1945 if (*p2 != ' ' && *p2 != '\t')
1946 fatal_error ("specs %%rename syntax malformed after "
1947 "%ld characters",
1948 (long) (p2 - buffer));
1950 name_len = p2 - p1;
1951 *p2++ = '\0';
1952 while (*p2 == ' ' || *p2 == '\t')
1953 p2++;
1955 if (! ISALPHA ((unsigned char) *p2))
1956 fatal_error ("specs %%rename syntax malformed after "
1957 "%ld characters",
1958 (long) (p2 - buffer));
1960 /* Get new spec name. */
1961 p3 = p2;
1962 while (*p3 && !ISSPACE ((unsigned char) *p3))
1963 p3++;
1965 if (p3 != p - 1)
1966 fatal_error ("specs %%rename syntax malformed after "
1967 "%ld characters",
1968 (long) (p3 - buffer));
1969 *p3 = '\0';
1971 for (sl = specs; sl; sl = sl->next)
1972 if (name_len == sl->name_len && !strcmp (sl->name, p1))
1973 break;
1975 if (!sl)
1976 fatal_error ("specs %s spec was not found to be renamed", p1);
1978 if (strcmp (p1, p2) == 0)
1979 continue;
1981 for (newsl = specs; newsl; newsl = newsl->next)
1982 if (strcmp (newsl->name, p2) == 0)
1983 fatal_error ("%s: attempt to rename spec %qs to "
1984 "already defined spec %qs",
1985 filename, p1, p2);
1987 if (verbose_flag)
1989 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
1990 #ifdef DEBUG_SPECS
1991 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
1992 #endif
1995 set_spec (p2, *(sl->ptr_spec), user_p);
1996 if (sl->alloc_p)
1997 free (CONST_CAST (char *, *(sl->ptr_spec)));
1999 *(sl->ptr_spec) = "";
2000 sl->alloc_p = 0;
2001 continue;
2003 else
2004 fatal_error ("specs unknown %% command after %ld characters",
2005 (long) (p1 - buffer));
2008 /* Find the colon that should end the suffix. */
2009 p1 = p;
2010 while (*p1 && *p1 != ':' && *p1 != '\n')
2011 p1++;
2013 /* The colon shouldn't be missing. */
2014 if (*p1 != ':')
2015 fatal_error ("specs file malformed after %ld characters",
2016 (long) (p1 - buffer));
2018 /* Skip back over trailing whitespace. */
2019 p2 = p1;
2020 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2021 p2--;
2023 /* Copy the suffix to a string. */
2024 suffix = save_string (p, p2 - p);
2025 /* Find the next line. */
2026 p = skip_whitespace (p1 + 1);
2027 if (p[1] == 0)
2028 fatal_error ("specs file malformed after %ld characters",
2029 (long) (p - buffer));
2031 p1 = p;
2032 /* Find next blank line or end of string. */
2033 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2034 p1++;
2036 /* Specs end at the blank line and do not include the newline. */
2037 spec = save_string (p, p1 - p);
2038 p = p1;
2040 /* Delete backslash-newline sequences from the spec. */
2041 in = spec;
2042 out = spec;
2043 while (*in != 0)
2045 if (in[0] == '\\' && in[1] == '\n')
2046 in += 2;
2047 else if (in[0] == '#')
2048 while (*in && *in != '\n')
2049 in++;
2051 else
2052 *out++ = *in++;
2054 *out = 0;
2056 if (suffix[0] == '*')
2058 if (! strcmp (suffix, "*link_command"))
2059 link_command_spec = spec;
2060 else
2061 set_spec (suffix + 1, spec, user_p);
2063 else
2065 /* Add this pair to the vector. */
2066 compilers
2067 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
2069 compilers[n_compilers].suffix = suffix;
2070 compilers[n_compilers].spec = spec;
2071 n_compilers++;
2072 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2075 if (*suffix == 0)
2076 link_command_spec = spec;
2079 if (link_command_spec == 0)
2080 fatal_error ("spec file has no spec for linking");
2083 /* Record the names of temporary files we tell compilers to write,
2084 and delete them at the end of the run. */
2086 /* This is the common prefix we use to make temp file names.
2087 It is chosen once for each run of this program.
2088 It is substituted into a spec by %g or %j.
2089 Thus, all temp file names contain this prefix.
2090 In practice, all temp file names start with this prefix.
2092 This prefix comes from the envvar TMPDIR if it is defined;
2093 otherwise, from the P_tmpdir macro if that is defined;
2094 otherwise, in /usr/tmp or /tmp;
2095 or finally the current directory if all else fails. */
2097 static const char *temp_filename;
2099 /* Length of the prefix. */
2101 static int temp_filename_length;
2103 /* Define the list of temporary files to delete. */
2105 struct temp_file
2107 const char *name;
2108 struct temp_file *next;
2111 /* Queue of files to delete on success or failure of compilation. */
2112 static struct temp_file *always_delete_queue;
2113 /* Queue of files to delete on failure of compilation. */
2114 static struct temp_file *failure_delete_queue;
2116 /* Record FILENAME as a file to be deleted automatically.
2117 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2118 otherwise delete it in any case.
2119 FAIL_DELETE nonzero means delete it if a compilation step fails;
2120 otherwise delete it in any case. */
2122 void
2123 record_temp_file (const char *filename, int always_delete, int fail_delete)
2125 char *const name = xstrdup (filename);
2127 if (always_delete)
2129 struct temp_file *temp;
2130 for (temp = always_delete_queue; temp; temp = temp->next)
2131 if (! filename_cmp (name, temp->name))
2132 goto already1;
2134 temp = XNEW (struct temp_file);
2135 temp->next = always_delete_queue;
2136 temp->name = name;
2137 always_delete_queue = temp;
2139 already1:;
2142 if (fail_delete)
2144 struct temp_file *temp;
2145 for (temp = failure_delete_queue; temp; temp = temp->next)
2146 if (! filename_cmp (name, temp->name))
2148 free (name);
2149 goto already2;
2152 temp = XNEW (struct temp_file);
2153 temp->next = failure_delete_queue;
2154 temp->name = name;
2155 failure_delete_queue = temp;
2157 already2:;
2161 /* Delete all the temporary files whose names we previously recorded. */
2163 #ifndef DELETE_IF_ORDINARY
2164 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2165 do \
2167 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2168 if (unlink (NAME) < 0) \
2169 if (VERBOSE_FLAG) \
2170 perror_with_name (NAME); \
2171 } while (0)
2172 #endif
2174 static void
2175 delete_if_ordinary (const char *name)
2177 struct stat st;
2178 #ifdef DEBUG
2179 int i, c;
2181 printf ("Delete %s? (y or n) ", name);
2182 fflush (stdout);
2183 i = getchar ();
2184 if (i != '\n')
2185 while ((c = getchar ()) != '\n' && c != EOF)
2188 if (i == 'y' || i == 'Y')
2189 #endif /* DEBUG */
2190 DELETE_IF_ORDINARY (name, st, verbose_flag);
2193 static void
2194 delete_temp_files (void)
2196 struct temp_file *temp;
2198 for (temp = always_delete_queue; temp; temp = temp->next)
2199 delete_if_ordinary (temp->name);
2200 always_delete_queue = 0;
2203 /* Delete all the files to be deleted on error. */
2205 static void
2206 delete_failure_queue (void)
2208 struct temp_file *temp;
2210 for (temp = failure_delete_queue; temp; temp = temp->next)
2211 delete_if_ordinary (temp->name);
2214 static void
2215 clear_failure_queue (void)
2217 failure_delete_queue = 0;
2220 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2221 returns non-NULL.
2222 If DO_MULTI is true iterate over the paths twice, first with multilib
2223 suffix then without, otherwise iterate over the paths once without
2224 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2225 to avoid visiting the same path twice, but we could do better. For
2226 instance, /usr/lib/../lib is considered different from /usr/lib.
2227 At least EXTRA_SPACE chars past the end of the path passed to
2228 CALLBACK are available for use by the callback.
2229 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2231 Returns the value returned by CALLBACK. */
2233 static void *
2234 for_each_path (const struct path_prefix *paths,
2235 bool do_multi,
2236 size_t extra_space,
2237 void *(*callback) (char *, void *),
2238 void *callback_info)
2240 struct prefix_list *pl;
2241 const char *multi_dir = NULL;
2242 const char *multi_os_dir = NULL;
2243 const char *multiarch_suffix = NULL;
2244 const char *multi_suffix;
2245 const char *just_multi_suffix;
2246 char *path = NULL;
2247 void *ret = NULL;
2248 bool skip_multi_dir = false;
2249 bool skip_multi_os_dir = false;
2251 multi_suffix = machine_suffix;
2252 just_multi_suffix = just_machine_suffix;
2253 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2255 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2256 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2257 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2259 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2260 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2261 if (multiarch_dir)
2262 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2264 while (1)
2266 size_t multi_dir_len = 0;
2267 size_t multi_os_dir_len = 0;
2268 size_t multiarch_len = 0;
2269 size_t suffix_len;
2270 size_t just_suffix_len;
2271 size_t len;
2273 if (multi_dir)
2274 multi_dir_len = strlen (multi_dir);
2275 if (multi_os_dir)
2276 multi_os_dir_len = strlen (multi_os_dir);
2277 if (multiarch_suffix)
2278 multiarch_len = strlen (multiarch_suffix);
2279 suffix_len = strlen (multi_suffix);
2280 just_suffix_len = strlen (just_multi_suffix);
2282 if (path == NULL)
2284 len = paths->max_len + extra_space + 1;
2285 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2286 path = XNEWVEC (char, len);
2289 for (pl = paths->plist; pl != 0; pl = pl->next)
2291 len = strlen (pl->prefix);
2292 memcpy (path, pl->prefix, len);
2294 /* Look first in MACHINE/VERSION subdirectory. */
2295 if (!skip_multi_dir)
2297 memcpy (path + len, multi_suffix, suffix_len + 1);
2298 ret = callback (path, callback_info);
2299 if (ret)
2300 break;
2303 /* Some paths are tried with just the machine (ie. target)
2304 subdir. This is used for finding as, ld, etc. */
2305 if (!skip_multi_dir
2306 && pl->require_machine_suffix == 2)
2308 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2309 ret = callback (path, callback_info);
2310 if (ret)
2311 break;
2314 /* Now try the multiarch path. */
2315 if (!skip_multi_dir
2316 && !pl->require_machine_suffix && multiarch_dir)
2318 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2319 ret = callback (path, callback_info);
2320 if (ret)
2321 break;
2324 /* Now try the base path. */
2325 if (!pl->require_machine_suffix
2326 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2328 const char *this_multi;
2329 size_t this_multi_len;
2331 if (pl->os_multilib)
2333 this_multi = multi_os_dir;
2334 this_multi_len = multi_os_dir_len;
2336 else
2338 this_multi = multi_dir;
2339 this_multi_len = multi_dir_len;
2342 if (this_multi_len)
2343 memcpy (path + len, this_multi, this_multi_len + 1);
2344 else
2345 path[len] = '\0';
2347 ret = callback (path, callback_info);
2348 if (ret)
2349 break;
2352 if (pl)
2353 break;
2355 if (multi_dir == NULL && multi_os_dir == NULL)
2356 break;
2358 /* Run through the paths again, this time without multilibs.
2359 Don't repeat any we have already seen. */
2360 if (multi_dir)
2362 free (CONST_CAST (char *, multi_dir));
2363 multi_dir = NULL;
2364 free (CONST_CAST (char *, multi_suffix));
2365 multi_suffix = machine_suffix;
2366 free (CONST_CAST (char *, just_multi_suffix));
2367 just_multi_suffix = just_machine_suffix;
2369 else
2370 skip_multi_dir = true;
2371 if (multi_os_dir)
2373 free (CONST_CAST (char *, multi_os_dir));
2374 multi_os_dir = NULL;
2376 else
2377 skip_multi_os_dir = true;
2380 if (multi_dir)
2382 free (CONST_CAST (char *, multi_dir));
2383 free (CONST_CAST (char *, multi_suffix));
2384 free (CONST_CAST (char *, just_multi_suffix));
2386 if (multi_os_dir)
2387 free (CONST_CAST (char *, multi_os_dir));
2388 if (ret != path)
2389 free (path);
2390 return ret;
2393 /* Callback for build_search_list. Adds path to obstack being built. */
2395 struct add_to_obstack_info {
2396 struct obstack *ob;
2397 bool check_dir;
2398 bool first_time;
2401 static void *
2402 add_to_obstack (char *path, void *data)
2404 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2406 if (info->check_dir && !is_directory (path, false))
2407 return NULL;
2409 if (!info->first_time)
2410 obstack_1grow (info->ob, PATH_SEPARATOR);
2412 obstack_grow (info->ob, path, strlen (path));
2414 info->first_time = false;
2415 return NULL;
2418 /* Add or change the value of an environment variable, outputting the
2419 change to standard error if in verbose mode. */
2420 static void
2421 xputenv (const char *string)
2423 if (verbose_flag)
2424 fnotice (stderr, "%s\n", string);
2425 putenv (CONST_CAST (char *, string));
2428 /* Build a list of search directories from PATHS.
2429 PREFIX is a string to prepend to the list.
2430 If CHECK_DIR_P is true we ensure the directory exists.
2431 If DO_MULTI is true, multilib paths are output first, then
2432 non-multilib paths.
2433 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2434 It is also used by the --print-search-dirs flag. */
2436 static char *
2437 build_search_list (const struct path_prefix *paths, const char *prefix,
2438 bool check_dir, bool do_multi)
2440 struct add_to_obstack_info info;
2442 info.ob = &collect_obstack;
2443 info.check_dir = check_dir;
2444 info.first_time = true;
2446 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2447 obstack_1grow (&collect_obstack, '=');
2449 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2451 obstack_1grow (&collect_obstack, '\0');
2452 return XOBFINISH (&collect_obstack, char *);
2455 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2456 for collect. */
2458 static void
2459 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2460 bool do_multi)
2462 xputenv (build_search_list (paths, env_var, true, do_multi));
2465 /* Check whether NAME can be accessed in MODE. This is like access,
2466 except that it never considers directories to be executable. */
2468 static int
2469 access_check (const char *name, int mode)
2471 if (mode == X_OK)
2473 struct stat st;
2475 if (stat (name, &st) < 0
2476 || S_ISDIR (st.st_mode))
2477 return -1;
2480 return access (name, mode);
2483 /* Callback for find_a_file. Appends the file name to the directory
2484 path. If the resulting file exists in the right mode, return the
2485 full pathname to the file. */
2487 struct file_at_path_info {
2488 const char *name;
2489 const char *suffix;
2490 int name_len;
2491 int suffix_len;
2492 int mode;
2495 static void *
2496 file_at_path (char *path, void *data)
2498 struct file_at_path_info *info = (struct file_at_path_info *) data;
2499 size_t len = strlen (path);
2501 memcpy (path + len, info->name, info->name_len);
2502 len += info->name_len;
2504 /* Some systems have a suffix for executable files.
2505 So try appending that first. */
2506 if (info->suffix_len)
2508 memcpy (path + len, info->suffix, info->suffix_len + 1);
2509 if (access_check (path, info->mode) == 0)
2510 return path;
2513 path[len] = '\0';
2514 if (access_check (path, info->mode) == 0)
2515 return path;
2517 return NULL;
2520 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2521 access to check permissions. If DO_MULTI is true, search multilib
2522 paths then non-multilib paths, otherwise do not search multilib paths.
2523 Return 0 if not found, otherwise return its name, allocated with malloc. */
2525 static char *
2526 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2527 bool do_multi)
2529 struct file_at_path_info info;
2531 #ifdef DEFAULT_ASSEMBLER
2532 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2533 return xstrdup (DEFAULT_ASSEMBLER);
2534 #endif
2536 #ifdef DEFAULT_LINKER
2537 if (! strcmp (name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2538 return xstrdup (DEFAULT_LINKER);
2539 #endif
2541 /* Determine the filename to execute (special case for absolute paths). */
2543 if (IS_ABSOLUTE_PATH (name))
2545 if (access (name, mode) == 0)
2546 return xstrdup (name);
2548 return NULL;
2551 info.name = name;
2552 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2553 info.name_len = strlen (info.name);
2554 info.suffix_len = strlen (info.suffix);
2555 info.mode = mode;
2557 return (char*) for_each_path (pprefix, do_multi,
2558 info.name_len + info.suffix_len,
2559 file_at_path, &info);
2562 /* Ranking of prefixes in the sort list. -B prefixes are put before
2563 all others. */
2565 enum path_prefix_priority
2567 PREFIX_PRIORITY_B_OPT,
2568 PREFIX_PRIORITY_LAST
2571 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2572 order according to PRIORITY. Within each PRIORITY, new entries are
2573 appended.
2575 If WARN is nonzero, we will warn if no file is found
2576 through this prefix. WARN should point to an int
2577 which will be set to 1 if this entry is used.
2579 COMPONENT is the value to be passed to update_path.
2581 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2582 the complete value of machine_suffix.
2583 2 means try both machine_suffix and just_machine_suffix. */
2585 static void
2586 add_prefix (struct path_prefix *pprefix, const char *prefix,
2587 const char *component, /* enum prefix_priority */ int priority,
2588 int require_machine_suffix, int os_multilib)
2590 struct prefix_list *pl, **prev;
2591 int len;
2593 for (prev = &pprefix->plist;
2594 (*prev) != NULL && (*prev)->priority <= priority;
2595 prev = &(*prev)->next)
2598 /* Keep track of the longest prefix. */
2600 prefix = update_path (prefix, component);
2601 len = strlen (prefix);
2602 if (len > pprefix->max_len)
2603 pprefix->max_len = len;
2605 pl = XNEW (struct prefix_list);
2606 pl->prefix = prefix;
2607 pl->require_machine_suffix = require_machine_suffix;
2608 pl->priority = priority;
2609 pl->os_multilib = os_multilib;
2611 /* Insert after PREV. */
2612 pl->next = (*prev);
2613 (*prev) = pl;
2616 /* Same as add_prefix, but prepending target_system_root to prefix. */
2617 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2618 static void
2619 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2620 const char *component,
2621 /* enum prefix_priority */ int priority,
2622 int require_machine_suffix, int os_multilib)
2624 if (!IS_ABSOLUTE_PATH (prefix))
2625 fatal_error ("system path %qs is not absolute", prefix);
2627 if (target_system_root)
2629 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2630 size_t sysroot_len = strlen (target_system_root);
2632 if (sysroot_len > 0
2633 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2634 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2636 if (target_sysroot_suffix)
2637 prefix = concat (sysroot_no_trailing_dir_separator,
2638 target_sysroot_suffix, prefix, NULL);
2639 else
2640 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2642 free (sysroot_no_trailing_dir_separator);
2644 /* We have to override this because GCC's notion of sysroot
2645 moves along with GCC. */
2646 component = "GCC";
2649 add_prefix (pprefix, prefix, component, priority,
2650 require_machine_suffix, os_multilib);
2653 /* Execute the command specified by the arguments on the current line of spec.
2654 When using pipes, this includes several piped-together commands
2655 with `|' between them.
2657 Return 0 if successful, -1 if failed. */
2659 static int
2660 execute (void)
2662 int i;
2663 int n_commands; /* # of command. */
2664 char *string;
2665 struct pex_obj *pex;
2666 struct command
2668 const char *prog; /* program name. */
2669 const char **argv; /* vector of args. */
2671 const char *arg;
2673 struct command *commands; /* each command buffer with above info. */
2675 gcc_assert (!processing_spec_function);
2677 if (wrapper_string)
2679 string = find_a_file (&exec_prefixes,
2680 argbuf[0], X_OK, false);
2681 if (string)
2682 argbuf[0] = string;
2683 insert_wrapper (wrapper_string);
2686 /* Count # of piped commands. */
2687 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2688 if (strcmp (arg, "|") == 0)
2689 n_commands++;
2691 /* Get storage for each command. */
2692 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2694 /* Split argbuf into its separate piped processes,
2695 and record info about each one.
2696 Also search for the programs that are to be run. */
2698 argbuf.safe_push (0);
2700 commands[0].prog = argbuf[0]; /* first command. */
2701 commands[0].argv = argbuf.address ();
2703 if (!wrapper_string)
2705 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2706 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2709 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2710 if (arg && strcmp (arg, "|") == 0)
2711 { /* each command. */
2712 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2713 fatal_error ("-pipe not supported");
2714 #endif
2715 argbuf[i] = 0; /* Termination of
2716 command args. */
2717 commands[n_commands].prog = argbuf[i + 1];
2718 commands[n_commands].argv
2719 = &(argbuf.address ())[i + 1];
2720 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2721 X_OK, false);
2722 if (string)
2723 commands[n_commands].argv[0] = string;
2724 n_commands++;
2727 /* If -v, print what we are about to do, and maybe query. */
2729 if (verbose_flag)
2731 /* For help listings, put a blank line between sub-processes. */
2732 if (print_help_list)
2733 fputc ('\n', stderr);
2735 /* Print each piped command as a separate line. */
2736 for (i = 0; i < n_commands; i++)
2738 const char *const *j;
2740 if (verbose_only_flag)
2742 for (j = commands[i].argv; *j; j++)
2744 const char *p;
2745 for (p = *j; *p; ++p)
2746 if (!ISALNUM ((unsigned char) *p)
2747 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2748 break;
2749 if (*p || !*j)
2751 fprintf (stderr, " \"");
2752 for (p = *j; *p; ++p)
2754 if (*p == '"' || *p == '\\' || *p == '$')
2755 fputc ('\\', stderr);
2756 fputc (*p, stderr);
2758 fputc ('"', stderr);
2760 /* If it's empty, print "". */
2761 else if (!**j)
2762 fprintf (stderr, " \"\"");
2763 else
2764 fprintf (stderr, " %s", *j);
2767 else
2768 for (j = commands[i].argv; *j; j++)
2769 /* If it's empty, print "". */
2770 if (!**j)
2771 fprintf (stderr, " \"\"");
2772 else
2773 fprintf (stderr, " %s", *j);
2775 /* Print a pipe symbol after all but the last command. */
2776 if (i + 1 != n_commands)
2777 fprintf (stderr, " |");
2778 fprintf (stderr, "\n");
2780 fflush (stderr);
2781 if (verbose_only_flag != 0)
2783 /* verbose_only_flag should act as if the spec was
2784 executed, so increment execution_count before
2785 returning. This prevents spurious warnings about
2786 unused linker input files, etc. */
2787 execution_count++;
2788 return 0;
2790 #ifdef DEBUG
2791 fnotice (stderr, "\nGo ahead? (y or n) ");
2792 fflush (stderr);
2793 i = getchar ();
2794 if (i != '\n')
2795 while (getchar () != '\n')
2798 if (i != 'y' && i != 'Y')
2799 return 0;
2800 #endif /* DEBUG */
2803 #ifdef ENABLE_VALGRIND_CHECKING
2804 /* Run the each command through valgrind. To simplify prepending the
2805 path to valgrind and the option "-q" (for quiet operation unless
2806 something triggers), we allocate a separate argv array. */
2808 for (i = 0; i < n_commands; i++)
2810 const char **argv;
2811 int argc;
2812 int j;
2814 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2817 argv = XALLOCAVEC (const char *, argc + 3);
2819 argv[0] = VALGRIND_PATH;
2820 argv[1] = "-q";
2821 for (j = 2; j < argc + 2; j++)
2822 argv[j] = commands[i].argv[j - 2];
2823 argv[j] = NULL;
2825 commands[i].argv = argv;
2826 commands[i].prog = argv[0];
2828 #endif
2830 /* Run each piped subprocess. */
2832 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
2833 ? PEX_RECORD_TIMES : 0),
2834 progname, temp_filename);
2835 if (pex == NULL)
2836 fatal_error ("pex_init failed: %m");
2838 for (i = 0; i < n_commands; i++)
2840 const char *errmsg;
2841 int err;
2842 const char *string = commands[i].argv[0];
2844 errmsg = pex_run (pex,
2845 ((i + 1 == n_commands ? PEX_LAST : 0)
2846 | (string == commands[i].prog ? PEX_SEARCH : 0)),
2847 string, CONST_CAST (char **, commands[i].argv),
2848 NULL, NULL, &err);
2849 if (errmsg != NULL)
2851 if (err == 0)
2852 fatal_error (errmsg);
2853 else
2855 errno = err;
2856 pfatal_with_name (errmsg);
2860 if (i && string != commands[i].prog)
2861 free (CONST_CAST (char *, string));
2864 execution_count++;
2866 /* Wait for all the subprocesses to finish. */
2869 int *statuses;
2870 struct pex_time *times = NULL;
2871 int ret_code = 0;
2873 statuses = (int *) alloca (n_commands * sizeof (int));
2874 if (!pex_get_status (pex, n_commands, statuses))
2875 fatal_error ("failed to get exit status: %m");
2877 if (report_times || report_times_to_file)
2879 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
2880 if (!pex_get_times (pex, n_commands, times))
2881 fatal_error ("failed to get process times: %m");
2884 pex_free (pex);
2886 for (i = 0; i < n_commands; ++i)
2888 int status = statuses[i];
2890 if (WIFSIGNALED (status))
2892 #ifdef SIGPIPE
2893 /* SIGPIPE is a special case. It happens in -pipe mode
2894 when the compiler dies before the preprocessor is done,
2895 or the assembler dies before the compiler is done.
2896 There's generally been an error already, and this is
2897 just fallout. So don't generate another error unless
2898 we would otherwise have succeeded. */
2899 if (WTERMSIG (status) == SIGPIPE
2900 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2902 signal_count++;
2903 ret_code = -1;
2905 else
2906 #endif
2907 internal_error ("%s (program %s)",
2908 strsignal (WTERMSIG (status)), commands[i].prog);
2910 else if (WIFEXITED (status)
2911 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2913 /* For ICEs in cc1, cc1obj, cc1plus see if it is
2914 reproducible or not. */
2915 const char *p;
2916 if (flag_report_bug
2917 && WEXITSTATUS (status) == ICE_EXIT_CODE
2918 && i == 0
2919 && (p = strrchr (commands[0].argv[0], DIR_SEPARATOR))
2920 && ! strncmp (p + 1, "cc1", 3))
2921 try_generate_repro (commands[0].argv);
2922 if (WEXITSTATUS (status) > greatest_status)
2923 greatest_status = WEXITSTATUS (status);
2924 ret_code = -1;
2927 if (report_times || report_times_to_file)
2929 struct pex_time *pt = &times[i];
2930 double ut, st;
2932 ut = ((double) pt->user_seconds
2933 + (double) pt->user_microseconds / 1.0e6);
2934 st = ((double) pt->system_seconds
2935 + (double) pt->system_microseconds / 1.0e6);
2937 if (ut + st != 0)
2939 if (report_times)
2940 fnotice (stderr, "# %s %.2f %.2f\n",
2941 commands[i].prog, ut, st);
2943 if (report_times_to_file)
2945 int c = 0;
2946 const char *const *j;
2948 fprintf (report_times_to_file, "%g %g", ut, st);
2950 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
2952 const char *p;
2953 for (p = *j; *p; ++p)
2954 if (*p == '"' || *p == '\\' || *p == '$'
2955 || ISSPACE (*p))
2956 break;
2958 if (*p)
2960 fprintf (report_times_to_file, " \"");
2961 for (p = *j; *p; ++p)
2963 if (*p == '"' || *p == '\\' || *p == '$')
2964 fputc ('\\', report_times_to_file);
2965 fputc (*p, report_times_to_file);
2967 fputc ('"', report_times_to_file);
2969 else
2970 fprintf (report_times_to_file, " %s", *j);
2973 fputc ('\n', report_times_to_file);
2979 if (commands[0].argv[0] != commands[0].prog)
2980 free (CONST_CAST (char *, commands[0].argv[0]));
2982 return ret_code;
2986 /* Find all the switches given to us
2987 and make a vector describing them.
2988 The elements of the vector are strings, one per switch given.
2989 If a switch uses following arguments, then the `part1' field
2990 is the switch itself and the `args' field
2991 is a null-terminated vector containing the following arguments.
2992 Bits in the `live_cond' field are:
2993 SWITCH_LIVE to indicate this switch is true in a conditional spec.
2994 SWITCH_FALSE to indicate this switch is overridden by a later switch.
2995 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
2996 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored
2997 in all do_spec calls afterwards. Used for %<S from self specs.
2998 The `validated' field is nonzero if any spec has looked at this switch;
2999 if it remains zero at the end of the run, it must be meaningless. */
3001 #define SWITCH_LIVE (1 << 0)
3002 #define SWITCH_FALSE (1 << 1)
3003 #define SWITCH_IGNORE (1 << 2)
3004 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
3005 #define SWITCH_KEEP_FOR_GCC (1 << 4)
3007 struct switchstr
3009 const char *part1;
3010 const char **args;
3011 unsigned int live_cond;
3012 bool known;
3013 bool validated;
3014 bool ordering;
3017 static struct switchstr *switches;
3019 static int n_switches;
3021 static int n_switches_alloc;
3023 /* Set to zero if -fcompare-debug is disabled, positive if it's
3024 enabled and we're running the first compilation, negative if it's
3025 enabled and we're running the second compilation. For most of the
3026 time, it's in the range -1..1, but it can be temporarily set to 2
3027 or 3 to indicate that the -fcompare-debug flags didn't come from
3028 the command-line, but rather from the GCC_COMPARE_DEBUG environment
3029 variable, until a synthesized -fcompare-debug flag is added to the
3030 command line. */
3031 int compare_debug;
3033 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
3034 int compare_debug_second;
3036 /* Set to the flags that should be passed to the second compilation in
3037 a -fcompare-debug compilation. */
3038 const char *compare_debug_opt;
3040 static struct switchstr *switches_debug_check[2];
3042 static int n_switches_debug_check[2];
3044 static int n_switches_alloc_debug_check[2];
3046 static char *debug_check_temp_file[2];
3048 /* Language is one of three things:
3050 1) The name of a real programming language.
3051 2) NULL, indicating that no one has figured out
3052 what it is yet.
3053 3) '*', indicating that the file should be passed
3054 to the linker. */
3055 struct infile
3057 const char *name;
3058 const char *language;
3059 struct compiler *incompiler;
3060 bool compiled;
3061 bool preprocessed;
3064 /* Also a vector of input files specified. */
3066 static struct infile *infiles;
3068 int n_infiles;
3070 static int n_infiles_alloc;
3072 /* True if multiple input files are being compiled to a single
3073 assembly file. */
3075 static bool combine_inputs;
3077 /* This counts the number of libraries added by lang_specific_driver, so that
3078 we can tell if there were any user supplied any files or libraries. */
3080 static int added_libraries;
3082 /* And a vector of corresponding output files is made up later. */
3084 const char **outfiles;
3086 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3088 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3089 is true if we should look for an executable suffix. DO_OBJ
3090 is true if we should look for an object suffix. */
3092 static const char *
3093 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3094 int do_obj ATTRIBUTE_UNUSED)
3096 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3097 int i;
3098 #endif
3099 int len;
3101 if (name == NULL)
3102 return NULL;
3104 len = strlen (name);
3106 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3107 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3108 if (do_obj && len > 2
3109 && name[len - 2] == '.'
3110 && name[len - 1] == 'o')
3112 obstack_grow (&obstack, name, len - 2);
3113 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3114 name = XOBFINISH (&obstack, const char *);
3116 #endif
3118 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3119 /* If there is no filetype, make it the executable suffix (which includes
3120 the "."). But don't get confused if we have just "-o". */
3121 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3122 return name;
3124 for (i = len - 1; i >= 0; i--)
3125 if (IS_DIR_SEPARATOR (name[i]))
3126 break;
3128 for (i++; i < len; i++)
3129 if (name[i] == '.')
3130 return name;
3132 obstack_grow (&obstack, name, len);
3133 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3134 strlen (TARGET_EXECUTABLE_SUFFIX));
3135 name = XOBFINISH (&obstack, const char *);
3136 #endif
3138 return name;
3140 #endif
3142 /* Display the command line switches accepted by gcc. */
3143 static void
3144 display_help (void)
3146 printf (_("Usage: %s [options] file...\n"), progname);
3147 fputs (_("Options:\n"), stdout);
3149 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3150 fputs (_(" --help Display this information\n"), stdout);
3151 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3152 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...]\n"), stdout);
3153 fputs (_(" Display specific types of command line options\n"), stdout);
3154 if (! verbose_flag)
3155 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3156 fputs (_(" --version Display compiler version information\n"), stdout);
3157 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3158 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3159 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3160 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3161 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3162 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3163 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3164 fputs (_("\
3165 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3166 a component in the library path\n"), stdout);
3167 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3168 fputs (_("\
3169 -print-multi-lib Display the mapping between command line options and\n\
3170 multiple library search directories\n"), stdout);
3171 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3172 fputs (_(" -print-sysroot Display the target libraries directory\n"), stdout);
3173 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
3174 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3175 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3176 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3177 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3178 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3179 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3180 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3181 fputs (_(" -save-temps=<arg> Do not delete intermediate files\n"), stdout);
3182 fputs (_("\
3183 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3184 prefixes to other gcc components\n"), stdout);
3185 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3186 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3187 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3188 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3189 fputs (_("\
3190 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3191 and libraries\n"), stdout);
3192 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3193 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3194 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3195 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3196 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3197 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3198 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3199 fputs (_(" -pie Create a position independent executable\n"), stdout);
3200 fputs (_(" -shared Create a shared library\n"), stdout);
3201 fputs (_("\
3202 -x <language> Specify the language of the following input files\n\
3203 Permissible languages include: c c++ assembler none\n\
3204 'none' means revert to the default behavior of\n\
3205 guessing the language based on the file's extension\n\
3206 "), stdout);
3208 printf (_("\
3209 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3210 passed on to the various sub-processes invoked by %s. In order to pass\n\
3211 other options on to these processes the -W<letter> options must be used.\n\
3212 "), progname);
3214 /* The rest of the options are displayed by invocations of the various
3215 sub-processes. */
3218 static void
3219 add_preprocessor_option (const char *option, int len)
3221 preprocessor_options.safe_push (save_string (option, len));
3224 static void
3225 add_assembler_option (const char *option, int len)
3227 assembler_options.safe_push (save_string (option, len));
3230 static void
3231 add_linker_option (const char *option, int len)
3233 linker_options.safe_push (save_string (option, len));
3236 /* Allocate space for an input file in infiles. */
3238 static void
3239 alloc_infile (void)
3241 if (n_infiles_alloc == 0)
3243 n_infiles_alloc = 16;
3244 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3246 else if (n_infiles_alloc == n_infiles)
3248 n_infiles_alloc *= 2;
3249 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3253 /* Store an input file with the given NAME and LANGUAGE in
3254 infiles. */
3256 static void
3257 add_infile (const char *name, const char *language)
3259 alloc_infile ();
3260 infiles[n_infiles].name = name;
3261 infiles[n_infiles++].language = language;
3264 /* Allocate space for a switch in switches. */
3266 static void
3267 alloc_switch (void)
3269 if (n_switches_alloc == 0)
3271 n_switches_alloc = 16;
3272 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3274 else if (n_switches_alloc == n_switches)
3276 n_switches_alloc *= 2;
3277 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3281 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3282 as validated if VALIDATED and KNOWN if it is an internal switch. */
3284 static void
3285 save_switch (const char *opt, size_t n_args, const char *const *args,
3286 bool validated, bool known)
3288 alloc_switch ();
3289 switches[n_switches].part1 = opt + 1;
3290 if (n_args == 0)
3291 switches[n_switches].args = 0;
3292 else
3294 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3295 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3296 switches[n_switches].args[n_args] = NULL;
3299 switches[n_switches].live_cond = 0;
3300 switches[n_switches].validated = validated;
3301 switches[n_switches].known = known;
3302 switches[n_switches].ordering = 0;
3303 n_switches++;
3306 /* Handle an option DECODED that is unknown to the option-processing
3307 machinery. */
3309 static bool
3310 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3312 const char *opt = decoded->arg;
3313 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3314 && !(decoded->errors & CL_ERR_NEGATIVE))
3316 /* Leave unknown -Wno-* options for the compiler proper, to be
3317 diagnosed only if there are warnings. */
3318 save_switch (decoded->canonical_option[0],
3319 decoded->canonical_option_num_elements - 1,
3320 &decoded->canonical_option[1], false, true);
3321 return false;
3323 if (decoded->opt_index == OPT_SPECIAL_unknown)
3325 /* Give it a chance to define it a a spec file. */
3326 save_switch (decoded->canonical_option[0],
3327 decoded->canonical_option_num_elements - 1,
3328 &decoded->canonical_option[1], false, false);
3329 return false;
3331 else
3332 return true;
3335 /* Handle an option DECODED that is not marked as CL_DRIVER.
3336 LANG_MASK will always be CL_DRIVER. */
3338 static void
3339 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3340 unsigned int lang_mask ATTRIBUTE_UNUSED)
3342 /* At this point, non-driver options are accepted (and expected to
3343 be passed down by specs) unless marked to be rejected by the
3344 driver. Options to be rejected by the driver but accepted by the
3345 compilers proper are treated just like completely unknown
3346 options. */
3347 const struct cl_option *option = &cl_options[decoded->opt_index];
3349 if (option->cl_reject_driver)
3350 error ("unrecognized command line option %qs",
3351 decoded->orig_option_with_args_text);
3352 else
3353 save_switch (decoded->canonical_option[0],
3354 decoded->canonical_option_num_elements - 1,
3355 &decoded->canonical_option[1], false, true);
3358 static const char *spec_lang = 0;
3359 static int last_language_n_infiles;
3361 /* Handle a driver option; arguments and return value as for
3362 handle_option. */
3364 static bool
3365 driver_handle_option (struct gcc_options *opts,
3366 struct gcc_options *opts_set,
3367 const struct cl_decoded_option *decoded,
3368 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3369 location_t loc,
3370 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3371 diagnostic_context *dc)
3373 size_t opt_index = decoded->opt_index;
3374 const char *arg = decoded->arg;
3375 const char *compare_debug_replacement_opt;
3376 int value = decoded->value;
3377 bool validated = false;
3378 bool do_save = true;
3380 gcc_assert (opts == &global_options);
3381 gcc_assert (opts_set == &global_options_set);
3382 gcc_assert (kind == DK_UNSPECIFIED);
3383 gcc_assert (loc == UNKNOWN_LOCATION);
3384 gcc_assert (dc == global_dc);
3386 switch (opt_index)
3388 case OPT_dumpspecs:
3390 struct spec_list *sl;
3391 init_spec ();
3392 for (sl = specs; sl; sl = sl->next)
3393 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3394 if (link_command_spec)
3395 printf ("*link_command:\n%s\n\n", link_command_spec);
3396 exit (0);
3399 case OPT_dumpversion:
3400 printf ("%s\n", spec_version);
3401 exit (0);
3403 case OPT_dumpmachine:
3404 printf ("%s\n", spec_machine);
3405 exit (0);
3407 case OPT__version:
3408 print_version = 1;
3410 /* CPP driver cannot obtain switch from cc1_options. */
3411 if (is_cpp_driver)
3412 add_preprocessor_option ("--version", strlen ("--version"));
3413 add_assembler_option ("--version", strlen ("--version"));
3414 add_linker_option ("--version", strlen ("--version"));
3415 break;
3417 case OPT__help:
3418 print_help_list = 1;
3420 /* CPP driver cannot obtain switch from cc1_options. */
3421 if (is_cpp_driver)
3422 add_preprocessor_option ("--help", 6);
3423 add_assembler_option ("--help", 6);
3424 add_linker_option ("--help", 6);
3425 break;
3427 case OPT__help_:
3428 print_subprocess_help = 2;
3429 break;
3431 case OPT__target_help:
3432 print_subprocess_help = 1;
3434 /* CPP driver cannot obtain switch from cc1_options. */
3435 if (is_cpp_driver)
3436 add_preprocessor_option ("--target-help", 13);
3437 add_assembler_option ("--target-help", 13);
3438 add_linker_option ("--target-help", 13);
3439 break;
3441 case OPT__no_sysroot_suffix:
3442 case OPT_pass_exit_codes:
3443 case OPT_print_search_dirs:
3444 case OPT_print_file_name_:
3445 case OPT_print_prog_name_:
3446 case OPT_print_multi_lib:
3447 case OPT_print_multi_directory:
3448 case OPT_print_sysroot:
3449 case OPT_print_multi_os_directory:
3450 case OPT_print_multiarch:
3451 case OPT_print_sysroot_headers_suffix:
3452 case OPT_time:
3453 case OPT_wrapper:
3454 /* These options set the variables specified in common.opt
3455 automatically, and do not need to be saved for spec
3456 processing. */
3457 do_save = false;
3458 break;
3460 case OPT_print_libgcc_file_name:
3461 print_file_name = "libgcc.a";
3462 do_save = false;
3463 break;
3465 case OPT_fuse_ld_bfd:
3466 use_ld = ".bfd";
3467 break;
3469 case OPT_fuse_ld_gold:
3470 use_ld = ".gold";
3471 break;
3473 case OPT_fcompare_debug_second:
3474 compare_debug_second = 1;
3475 break;
3477 case OPT_fcompare_debug:
3478 switch (value)
3480 case 0:
3481 compare_debug_replacement_opt = "-fcompare-debug=";
3482 arg = "";
3483 goto compare_debug_with_arg;
3485 case 1:
3486 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3487 arg = "-gtoggle";
3488 goto compare_debug_with_arg;
3490 default:
3491 gcc_unreachable ();
3493 break;
3495 case OPT_fcompare_debug_:
3496 compare_debug_replacement_opt = decoded->canonical_option[0];
3497 compare_debug_with_arg:
3498 gcc_assert (decoded->canonical_option_num_elements == 1);
3499 gcc_assert (arg != NULL);
3500 if (*arg)
3501 compare_debug = 1;
3502 else
3503 compare_debug = -1;
3504 if (compare_debug < 0)
3505 compare_debug_opt = NULL;
3506 else
3507 compare_debug_opt = arg;
3508 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3509 return true;
3511 case OPT_Wa_:
3513 int prev, j;
3514 /* Pass the rest of this option to the assembler. */
3516 /* Split the argument at commas. */
3517 prev = 0;
3518 for (j = 0; arg[j]; j++)
3519 if (arg[j] == ',')
3521 add_assembler_option (arg + prev, j - prev);
3522 prev = j + 1;
3525 /* Record the part after the last comma. */
3526 add_assembler_option (arg + prev, j - prev);
3528 do_save = false;
3529 break;
3531 case OPT_Wp_:
3533 int prev, j;
3534 /* Pass the rest of this option to the preprocessor. */
3536 /* Split the argument at commas. */
3537 prev = 0;
3538 for (j = 0; arg[j]; j++)
3539 if (arg[j] == ',')
3541 add_preprocessor_option (arg + prev, j - prev);
3542 prev = j + 1;
3545 /* Record the part after the last comma. */
3546 add_preprocessor_option (arg + prev, j - prev);
3548 do_save = false;
3549 break;
3551 case OPT_Wl_:
3553 int prev, j;
3554 /* Split the argument at commas. */
3555 prev = 0;
3556 for (j = 0; arg[j]; j++)
3557 if (arg[j] == ',')
3559 add_infile (save_string (arg + prev, j - prev), "*");
3560 prev = j + 1;
3562 /* Record the part after the last comma. */
3563 add_infile (arg + prev, "*");
3565 do_save = false;
3566 break;
3568 case OPT_Xlinker:
3569 add_infile (arg, "*");
3570 do_save = false;
3571 break;
3573 case OPT_Xpreprocessor:
3574 add_preprocessor_option (arg, strlen (arg));
3575 do_save = false;
3576 break;
3578 case OPT_Xassembler:
3579 add_assembler_option (arg, strlen (arg));
3580 do_save = false;
3581 break;
3583 case OPT_l:
3584 /* POSIX allows separation of -l and the lib arg; canonicalize
3585 by concatenating -l with its arg */
3586 add_infile (concat ("-l", arg, NULL), "*");
3587 do_save = false;
3588 break;
3590 case OPT_L:
3591 /* Similarly, canonicalize -L for linkers that may not accept
3592 separate arguments. */
3593 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
3594 return true;
3596 case OPT_F:
3597 /* Likewise -F. */
3598 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
3599 return true;
3601 case OPT_save_temps:
3602 save_temps_flag = SAVE_TEMPS_CWD;
3603 validated = true;
3604 break;
3606 case OPT_save_temps_:
3607 if (strcmp (arg, "cwd") == 0)
3608 save_temps_flag = SAVE_TEMPS_CWD;
3609 else if (strcmp (arg, "obj") == 0
3610 || strcmp (arg, "object") == 0)
3611 save_temps_flag = SAVE_TEMPS_OBJ;
3612 else
3613 fatal_error ("%qs is an unknown -save-temps option",
3614 decoded->orig_option_with_args_text);
3615 break;
3617 case OPT_no_canonical_prefixes:
3618 /* Already handled as a special case, so ignored here. */
3619 do_save = false;
3620 break;
3622 case OPT_pipe:
3623 validated = true;
3624 /* These options set the variables specified in common.opt
3625 automatically, but do need to be saved for spec
3626 processing. */
3627 break;
3629 case OPT_specs_:
3631 struct user_specs *user = XNEW (struct user_specs);
3633 user->next = (struct user_specs *) 0;
3634 user->filename = arg;
3635 if (user_specs_tail)
3636 user_specs_tail->next = user;
3637 else
3638 user_specs_head = user;
3639 user_specs_tail = user;
3641 validated = true;
3642 break;
3644 case OPT__sysroot_:
3645 target_system_root = arg;
3646 target_system_root_changed = 1;
3647 do_save = false;
3648 break;
3650 case OPT_time_:
3651 if (report_times_to_file)
3652 fclose (report_times_to_file);
3653 report_times_to_file = fopen (arg, "a");
3654 do_save = false;
3655 break;
3657 case OPT____:
3658 /* "-###"
3659 This is similar to -v except that there is no execution
3660 of the commands and the echoed arguments are quoted. It
3661 is intended for use in shell scripts to capture the
3662 driver-generated command line. */
3663 verbose_only_flag++;
3664 verbose_flag = 1;
3665 do_save = false;
3666 break;
3668 case OPT_B:
3670 size_t len = strlen (arg);
3672 /* Catch the case where the user has forgotten to append a
3673 directory separator to the path. Note, they may be using
3674 -B to add an executable name prefix, eg "i386-elf-", in
3675 order to distinguish between multiple installations of
3676 GCC in the same directory. Hence we must check to see
3677 if appending a directory separator actually makes a
3678 valid directory name. */
3679 if (!IS_DIR_SEPARATOR (arg[len - 1])
3680 && is_directory (arg, false))
3682 char *tmp = XNEWVEC (char, len + 2);
3683 strcpy (tmp, arg);
3684 tmp[len] = DIR_SEPARATOR;
3685 tmp[++len] = 0;
3686 arg = tmp;
3689 add_prefix (&exec_prefixes, arg, NULL,
3690 PREFIX_PRIORITY_B_OPT, 0, 0);
3691 add_prefix (&startfile_prefixes, arg, NULL,
3692 PREFIX_PRIORITY_B_OPT, 0, 0);
3693 add_prefix (&include_prefixes, arg, NULL,
3694 PREFIX_PRIORITY_B_OPT, 0, 0);
3696 validated = true;
3697 break;
3699 case OPT_x:
3700 spec_lang = arg;
3701 if (!strcmp (spec_lang, "none"))
3702 /* Suppress the warning if -xnone comes after the last input
3703 file, because alternate command interfaces like g++ might
3704 find it useful to place -xnone after each input file. */
3705 spec_lang = 0;
3706 else
3707 last_language_n_infiles = n_infiles;
3708 do_save = false;
3709 break;
3711 case OPT_o:
3712 have_o = 1;
3713 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3714 arg = convert_filename (arg, ! have_c, 0);
3715 #endif
3716 /* Save the output name in case -save-temps=obj was used. */
3717 save_temps_prefix = xstrdup (arg);
3718 /* On some systems, ld cannot handle "-o" without a space. So
3719 split the option from its argument. */
3720 save_switch ("-o", 1, &arg, validated, true);
3721 return true;
3723 case OPT_static_libgcc:
3724 case OPT_shared_libgcc:
3725 case OPT_static_libgfortran:
3726 case OPT_static_libstdc__:
3727 /* These are always valid, since gcc.c itself understands the
3728 first two, gfortranspec.c understands -static-libgfortran and
3729 g++spec.c understands -static-libstdc++ */
3730 validated = true;
3731 break;
3733 case OPT_fwpa:
3734 flag_wpa = "";
3735 break;
3737 default:
3738 /* Various driver options need no special processing at this
3739 point, having been handled in a prescan above or being
3740 handled by specs. */
3741 break;
3744 if (do_save)
3745 save_switch (decoded->canonical_option[0],
3746 decoded->canonical_option_num_elements - 1,
3747 &decoded->canonical_option[1], validated, true);
3748 return true;
3751 /* Put the driver's standard set of option handlers in *HANDLERS. */
3753 static void
3754 set_option_handlers (struct cl_option_handlers *handlers)
3756 handlers->unknown_option_callback = driver_unknown_option_callback;
3757 handlers->wrong_lang_callback = driver_wrong_lang_callback;
3758 handlers->num_handlers = 3;
3759 handlers->handlers[0].handler = driver_handle_option;
3760 handlers->handlers[0].mask = CL_DRIVER;
3761 handlers->handlers[1].handler = common_handle_option;
3762 handlers->handlers[1].mask = CL_COMMON;
3763 handlers->handlers[2].handler = target_handle_option;
3764 handlers->handlers[2].mask = CL_TARGET;
3767 /* Create the vector `switches' and its contents.
3768 Store its length in `n_switches'. */
3770 static void
3771 process_command (unsigned int decoded_options_count,
3772 struct cl_decoded_option *decoded_options)
3774 const char *temp;
3775 char *temp1;
3776 char *tooldir_prefix, *tooldir_prefix2;
3777 char *(*get_relative_prefix) (const char *, const char *,
3778 const char *) = NULL;
3779 struct cl_option_handlers handlers;
3780 unsigned int j;
3782 gcc_exec_prefix = getenv ("GCC_EXEC_PREFIX");
3784 n_switches = 0;
3785 n_infiles = 0;
3786 added_libraries = 0;
3788 /* Figure compiler version from version string. */
3790 compiler_version = temp1 = xstrdup (version_string);
3792 for (; *temp1; ++temp1)
3794 if (*temp1 == ' ')
3796 *temp1 = '\0';
3797 break;
3801 /* Handle any -no-canonical-prefixes flag early, to assign the function
3802 that builds relative prefixes. This function creates default search
3803 paths that are needed later in normal option handling. */
3805 for (j = 1; j < decoded_options_count; j++)
3807 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
3809 get_relative_prefix = make_relative_prefix_ignore_links;
3810 break;
3813 if (! get_relative_prefix)
3814 get_relative_prefix = make_relative_prefix;
3816 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3817 see if we can create it from the pathname specified in
3818 decoded_options[0].arg. */
3820 gcc_libexec_prefix = standard_libexec_prefix;
3821 #ifndef VMS
3822 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3823 if (!gcc_exec_prefix)
3825 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
3826 standard_bindir_prefix,
3827 standard_exec_prefix);
3828 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
3829 standard_bindir_prefix,
3830 standard_libexec_prefix);
3831 if (gcc_exec_prefix)
3832 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3834 else
3836 /* make_relative_prefix requires a program name, but
3837 GCC_EXEC_PREFIX is typically a directory name with a trailing
3838 / (which is ignored by make_relative_prefix), so append a
3839 program name. */
3840 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
3841 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
3842 standard_exec_prefix,
3843 standard_libexec_prefix);
3845 /* The path is unrelocated, so fallback to the original setting. */
3846 if (!gcc_libexec_prefix)
3847 gcc_libexec_prefix = standard_libexec_prefix;
3849 free (tmp_prefix);
3851 #else
3852 #endif
3853 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
3854 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
3855 or an automatically created GCC_EXEC_PREFIX from
3856 decoded_options[0].arg. */
3858 /* Do language-specific adjustment/addition of flags. */
3859 lang_specific_driver (&decoded_options, &decoded_options_count,
3860 &added_libraries);
3862 if (gcc_exec_prefix)
3864 int len = strlen (gcc_exec_prefix);
3866 if (len > (int) sizeof ("/lib/gcc/") - 1
3867 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3869 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3870 if (IS_DIR_SEPARATOR (*temp)
3871 && filename_ncmp (temp + 1, "lib", 3) == 0
3872 && IS_DIR_SEPARATOR (temp[4])
3873 && filename_ncmp (temp + 5, "gcc", 3) == 0)
3874 len -= sizeof ("/lib/gcc/") - 1;
3877 set_std_prefix (gcc_exec_prefix, len);
3878 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3879 PREFIX_PRIORITY_LAST, 0, 0);
3880 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3881 PREFIX_PRIORITY_LAST, 0, 0);
3884 /* COMPILER_PATH and LIBRARY_PATH have values
3885 that are lists of directory names with colons. */
3887 temp = getenv ("COMPILER_PATH");
3888 if (temp)
3890 const char *startp, *endp;
3891 char *nstore = (char *) alloca (strlen (temp) + 3);
3893 startp = endp = temp;
3894 while (1)
3896 if (*endp == PATH_SEPARATOR || *endp == 0)
3898 strncpy (nstore, startp, endp - startp);
3899 if (endp == startp)
3900 strcpy (nstore, concat (".", dir_separator_str, NULL));
3901 else if (!IS_DIR_SEPARATOR (endp[-1]))
3903 nstore[endp - startp] = DIR_SEPARATOR;
3904 nstore[endp - startp + 1] = 0;
3906 else
3907 nstore[endp - startp] = 0;
3908 add_prefix (&exec_prefixes, nstore, 0,
3909 PREFIX_PRIORITY_LAST, 0, 0);
3910 add_prefix (&include_prefixes, nstore, 0,
3911 PREFIX_PRIORITY_LAST, 0, 0);
3912 if (*endp == 0)
3913 break;
3914 endp = startp = endp + 1;
3916 else
3917 endp++;
3921 temp = getenv (LIBRARY_PATH_ENV);
3922 if (temp && *cross_compile == '0')
3924 const char *startp, *endp;
3925 char *nstore = (char *) alloca (strlen (temp) + 3);
3927 startp = endp = temp;
3928 while (1)
3930 if (*endp == PATH_SEPARATOR || *endp == 0)
3932 strncpy (nstore, startp, endp - startp);
3933 if (endp == startp)
3934 strcpy (nstore, concat (".", dir_separator_str, NULL));
3935 else if (!IS_DIR_SEPARATOR (endp[-1]))
3937 nstore[endp - startp] = DIR_SEPARATOR;
3938 nstore[endp - startp + 1] = 0;
3940 else
3941 nstore[endp - startp] = 0;
3942 add_prefix (&startfile_prefixes, nstore, NULL,
3943 PREFIX_PRIORITY_LAST, 0, 1);
3944 if (*endp == 0)
3945 break;
3946 endp = startp = endp + 1;
3948 else
3949 endp++;
3953 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3954 temp = getenv ("LPATH");
3955 if (temp && *cross_compile == '0')
3957 const char *startp, *endp;
3958 char *nstore = (char *) alloca (strlen (temp) + 3);
3960 startp = endp = temp;
3961 while (1)
3963 if (*endp == PATH_SEPARATOR || *endp == 0)
3965 strncpy (nstore, startp, endp - startp);
3966 if (endp == startp)
3967 strcpy (nstore, concat (".", dir_separator_str, NULL));
3968 else if (!IS_DIR_SEPARATOR (endp[-1]))
3970 nstore[endp - startp] = DIR_SEPARATOR;
3971 nstore[endp - startp + 1] = 0;
3973 else
3974 nstore[endp - startp] = 0;
3975 add_prefix (&startfile_prefixes, nstore, NULL,
3976 PREFIX_PRIORITY_LAST, 0, 1);
3977 if (*endp == 0)
3978 break;
3979 endp = startp = endp + 1;
3981 else
3982 endp++;
3986 /* Process the options and store input files and switches in their
3987 vectors. */
3989 last_language_n_infiles = -1;
3991 set_option_handlers (&handlers);
3993 for (j = 1; j < decoded_options_count; j++)
3995 switch (decoded_options[j].opt_index)
3997 case OPT_S:
3998 case OPT_c:
3999 case OPT_E:
4000 have_c = 1;
4001 break;
4003 if (have_c)
4004 break;
4007 for (j = 1; j < decoded_options_count; j++)
4009 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
4011 const char *arg = decoded_options[j].arg;
4012 const char *p = strrchr (arg, '@');
4013 char *fname;
4014 long offset;
4015 int consumed;
4016 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4017 arg = convert_filename (arg, 0, access (arg, F_OK));
4018 #endif
4019 /* For LTO static archive support we handle input file
4020 specifications that are composed of a filename and
4021 an offset like FNAME@OFFSET. */
4022 if (p
4023 && p != arg
4024 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
4025 && strlen (p) == (unsigned int)consumed)
4027 fname = (char *)xmalloc (p - arg + 1);
4028 memcpy (fname, arg, p - arg);
4029 fname[p - arg] = '\0';
4030 /* Only accept non-stdin and existing FNAME parts, otherwise
4031 try with the full name. */
4032 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
4034 free (fname);
4035 fname = xstrdup (arg);
4038 else
4039 fname = xstrdup (arg);
4041 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
4042 perror_with_name (fname);
4043 else
4044 add_infile (arg, spec_lang);
4046 free (fname);
4047 continue;
4050 read_cmdline_option (&global_options, &global_options_set,
4051 decoded_options + j, UNKNOWN_LOCATION,
4052 CL_DRIVER, &handlers, global_dc);
4055 /* If -save-temps=obj and -o name, create the prefix to use for %b.
4056 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
4057 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
4059 save_temps_length = strlen (save_temps_prefix);
4060 temp = strrchr (lbasename (save_temps_prefix), '.');
4061 if (temp)
4063 save_temps_length -= strlen (temp);
4064 save_temps_prefix[save_temps_length] = '\0';
4068 else if (save_temps_prefix != NULL)
4070 free (save_temps_prefix);
4071 save_temps_prefix = NULL;
4074 if (save_temps_flag && use_pipes)
4076 /* -save-temps overrides -pipe, so that temp files are produced */
4077 if (save_temps_flag)
4078 warning (0, "-pipe ignored because -save-temps specified");
4079 use_pipes = 0;
4082 if (!compare_debug)
4084 const char *gcd = getenv ("GCC_COMPARE_DEBUG");
4086 if (gcd && gcd[0] == '-')
4088 compare_debug = 2;
4089 compare_debug_opt = gcd;
4091 else if (gcd && *gcd && strcmp (gcd, "0"))
4093 compare_debug = 3;
4094 compare_debug_opt = "-gtoggle";
4097 else if (compare_debug < 0)
4099 compare_debug = 0;
4100 gcc_assert (!compare_debug_opt);
4103 /* Set up the search paths. We add directories that we expect to
4104 contain GNU Toolchain components before directories specified by
4105 the machine description so that we will find GNU components (like
4106 the GNU assembler) before those of the host system. */
4108 /* If we don't know where the toolchain has been installed, use the
4109 configured-in locations. */
4110 if (!gcc_exec_prefix)
4112 #ifndef OS2
4113 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
4114 PREFIX_PRIORITY_LAST, 1, 0);
4115 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
4116 PREFIX_PRIORITY_LAST, 2, 0);
4117 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
4118 PREFIX_PRIORITY_LAST, 2, 0);
4119 #endif
4120 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
4121 PREFIX_PRIORITY_LAST, 1, 0);
4124 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
4125 tooldir_prefix2 = concat (tooldir_base_prefix, spec_machine,
4126 dir_separator_str, NULL);
4128 /* Look for tools relative to the location from which the driver is
4129 running, or, if that is not available, the configured prefix. */
4130 tooldir_prefix
4131 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4132 spec_machine, dir_separator_str,
4133 spec_version, dir_separator_str, tooldir_prefix2, NULL);
4134 free (tooldir_prefix2);
4136 add_prefix (&exec_prefixes,
4137 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4138 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4139 add_prefix (&startfile_prefixes,
4140 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4141 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4142 free (tooldir_prefix);
4144 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4145 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4146 then consider it to relocate with the rest of the GCC installation
4147 if GCC_EXEC_PREFIX is set.
4148 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4149 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
4151 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
4152 standard_bindir_prefix,
4153 target_system_root);
4154 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4156 target_system_root = tmp_prefix;
4157 target_system_root_changed = 1;
4160 #endif
4162 /* More prefixes are enabled in main, after we read the specs file
4163 and determine whether this is cross-compilation or not. */
4165 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4166 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
4168 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
4169 environment variable. */
4170 if (compare_debug == 2 || compare_debug == 3)
4172 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
4173 save_switch (opt, 0, NULL, false, true);
4174 compare_debug = 1;
4177 /* Ensure we only invoke each subprocess once. */
4178 if (print_subprocess_help || print_help_list || print_version)
4180 n_infiles = 0;
4182 /* Create a dummy input file, so that we can pass
4183 the help option on to the various sub-processes. */
4184 add_infile ("help-dummy", "c");
4187 alloc_switch ();
4188 switches[n_switches].part1 = 0;
4189 alloc_infile ();
4190 infiles[n_infiles].name = 0;
4193 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4194 and place that in the environment. */
4196 static void
4197 set_collect_gcc_options (void)
4199 int i;
4200 int first_time;
4202 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4203 the compiler. */
4204 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4205 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4207 first_time = TRUE;
4208 for (i = 0; (int) i < n_switches; i++)
4210 const char *const *args;
4211 const char *p, *q;
4212 if (!first_time)
4213 obstack_grow (&collect_obstack, " ", 1);
4215 first_time = FALSE;
4217 /* Ignore elided switches. */
4218 if ((switches[i].live_cond
4219 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4220 == SWITCH_IGNORE)
4221 continue;
4223 obstack_grow (&collect_obstack, "'-", 2);
4224 q = switches[i].part1;
4225 while ((p = strchr (q, '\'')))
4227 obstack_grow (&collect_obstack, q, p - q);
4228 obstack_grow (&collect_obstack, "'\\''", 4);
4229 q = ++p;
4231 obstack_grow (&collect_obstack, q, strlen (q));
4232 obstack_grow (&collect_obstack, "'", 1);
4234 for (args = switches[i].args; args && *args; args++)
4236 obstack_grow (&collect_obstack, " '", 2);
4237 q = *args;
4238 while ((p = strchr (q, '\'')))
4240 obstack_grow (&collect_obstack, q, p - q);
4241 obstack_grow (&collect_obstack, "'\\''", 4);
4242 q = ++p;
4244 obstack_grow (&collect_obstack, q, strlen (q));
4245 obstack_grow (&collect_obstack, "'", 1);
4248 obstack_grow (&collect_obstack, "\0", 1);
4249 xputenv (XOBFINISH (&collect_obstack, char *));
4252 /* Process a spec string, accumulating and running commands. */
4254 /* These variables describe the input file name.
4255 input_file_number is the index on outfiles of this file,
4256 so that the output file name can be stored for later use by %o.
4257 input_basename is the start of the part of the input file
4258 sans all directory names, and basename_length is the number
4259 of characters starting there excluding the suffix .c or whatever. */
4261 static const char *gcc_input_filename;
4262 static int input_file_number;
4263 size_t input_filename_length;
4264 static int basename_length;
4265 static int suffixed_basename_length;
4266 static const char *input_basename;
4267 static const char *input_suffix;
4268 #ifndef HOST_LACKS_INODE_NUMBERS
4269 static struct stat input_stat;
4270 #endif
4271 static int input_stat_set;
4273 /* The compiler used to process the current input file. */
4274 static struct compiler *input_file_compiler;
4276 /* These are variables used within do_spec and do_spec_1. */
4278 /* Nonzero if an arg has been started and not yet terminated
4279 (with space, tab or newline). */
4280 static int arg_going;
4282 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4283 is a temporary file name. */
4284 static int delete_this_arg;
4286 /* Nonzero means %w has been seen; the next arg to be terminated
4287 is the output file name of this compilation. */
4288 static int this_is_output_file;
4290 /* Nonzero means %s has been seen; the next arg to be terminated
4291 is the name of a library file and we should try the standard
4292 search dirs for it. */
4293 static int this_is_library_file;
4295 /* Nonzero means %T has been seen; the next arg to be terminated
4296 is the name of a linker script and we should try all of the
4297 standard search dirs for it. If it is found insert a --script
4298 command line switch and then substitute the full path in place,
4299 otherwise generate an error message. */
4300 static int this_is_linker_script;
4302 /* Nonzero means that the input of this command is coming from a pipe. */
4303 static int input_from_pipe;
4305 /* Nonnull means substitute this for any suffix when outputting a switches
4306 arguments. */
4307 static const char *suffix_subst;
4309 /* If there is an argument being accumulated, terminate it and store it. */
4311 static void
4312 end_going_arg (void)
4314 if (arg_going)
4316 const char *string;
4318 obstack_1grow (&obstack, 0);
4319 string = XOBFINISH (&obstack, const char *);
4320 if (this_is_library_file)
4321 string = find_file (string);
4322 if (this_is_linker_script)
4324 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4326 if (full_script_path == NULL)
4328 error ("unable to locate default linker script %qs in the library search paths", string);
4329 /* Script was not found on search path. */
4330 return;
4332 store_arg ("--script", false, false);
4333 string = full_script_path;
4335 store_arg (string, delete_this_arg, this_is_output_file);
4336 if (this_is_output_file)
4337 outfiles[input_file_number] = string;
4338 arg_going = 0;
4343 /* Parse the WRAPPER string which is a comma separated list of the command line
4344 and insert them into the beginning of argbuf. */
4346 static void
4347 insert_wrapper (const char *wrapper)
4349 int n = 0;
4350 int i;
4351 char *buf = xstrdup (wrapper);
4352 char *p = buf;
4353 unsigned int old_length = argbuf.length ();
4357 n++;
4358 while (*p == ',')
4359 p++;
4361 while ((p = strchr (p, ',')) != NULL);
4363 argbuf.safe_grow (old_length + n);
4364 memmove (argbuf.address () + n,
4365 argbuf.address (),
4366 old_length * sizeof (const_char_p));
4368 i = 0;
4369 p = buf;
4372 while (*p == ',')
4374 *p = 0;
4375 p++;
4377 argbuf[i] = p;
4378 i++;
4380 while ((p = strchr (p, ',')) != NULL);
4381 gcc_assert (i == n);
4384 /* Process the spec SPEC and run the commands specified therein.
4385 Returns 0 if the spec is successfully processed; -1 if failed. */
4388 do_spec (const char *spec)
4390 int value;
4392 value = do_spec_2 (spec);
4394 /* Force out any unfinished command.
4395 If -pipe, this forces out the last command if it ended in `|'. */
4396 if (value == 0)
4398 if (argbuf.length () > 0
4399 && !strcmp (argbuf.last (), "|"))
4400 argbuf.pop ();
4402 set_collect_gcc_options ();
4404 if (argbuf.length () > 0)
4405 value = execute ();
4408 return value;
4411 static int
4412 do_spec_2 (const char *spec)
4414 int result;
4416 clear_args ();
4417 arg_going = 0;
4418 delete_this_arg = 0;
4419 this_is_output_file = 0;
4420 this_is_library_file = 0;
4421 this_is_linker_script = 0;
4422 input_from_pipe = 0;
4423 suffix_subst = NULL;
4425 result = do_spec_1 (spec, 0, NULL);
4427 end_going_arg ();
4429 return result;
4433 /* Process the given spec string and add any new options to the end
4434 of the switches/n_switches array. */
4436 static void
4437 do_option_spec (const char *name, const char *spec)
4439 unsigned int i, value_count, value_len;
4440 const char *p, *q, *value;
4441 char *tmp_spec, *tmp_spec_p;
4443 if (configure_default_options[0].name == NULL)
4444 return;
4446 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4447 if (strcmp (configure_default_options[i].name, name) == 0)
4448 break;
4449 if (i == ARRAY_SIZE (configure_default_options))
4450 return;
4452 value = configure_default_options[i].value;
4453 value_len = strlen (value);
4455 /* Compute the size of the final spec. */
4456 value_count = 0;
4457 p = spec;
4458 while ((p = strstr (p, "%(VALUE)")) != NULL)
4460 p ++;
4461 value_count ++;
4464 /* Replace each %(VALUE) by the specified value. */
4465 tmp_spec = (char *) alloca (strlen (spec) + 1
4466 + value_count * (value_len - strlen ("%(VALUE)")));
4467 tmp_spec_p = tmp_spec;
4468 q = spec;
4469 while ((p = strstr (q, "%(VALUE)")) != NULL)
4471 memcpy (tmp_spec_p, q, p - q);
4472 tmp_spec_p = tmp_spec_p + (p - q);
4473 memcpy (tmp_spec_p, value, value_len);
4474 tmp_spec_p += value_len;
4475 q = p + strlen ("%(VALUE)");
4477 strcpy (tmp_spec_p, q);
4479 do_self_spec (tmp_spec);
4482 /* Process the given spec string and add any new options to the end
4483 of the switches/n_switches array. */
4485 static void
4486 do_self_spec (const char *spec)
4488 int i;
4490 do_spec_2 (spec);
4491 do_spec_1 (" ", 0, NULL);
4493 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4494 do_self_specs adds the replacements to switches array, so it shouldn't
4495 be processed afterwards. */
4496 for (i = 0; i < n_switches; i++)
4497 if ((switches[i].live_cond & SWITCH_IGNORE))
4498 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4500 if (argbuf.length () > 0)
4502 const char **argbuf_copy;
4503 struct cl_decoded_option *decoded_options;
4504 struct cl_option_handlers handlers;
4505 unsigned int decoded_options_count;
4506 unsigned int j;
4508 /* Create a copy of argbuf with a dummy argv[0] entry for
4509 decode_cmdline_options_to_array. */
4510 argbuf_copy = XNEWVEC (const char *,
4511 argbuf.length () + 1);
4512 argbuf_copy[0] = "";
4513 memcpy (argbuf_copy + 1, argbuf.address (),
4514 argbuf.length () * sizeof (const char *));
4516 decode_cmdline_options_to_array (argbuf.length () + 1,
4517 argbuf_copy,
4518 CL_DRIVER, &decoded_options,
4519 &decoded_options_count);
4520 free (argbuf_copy);
4522 set_option_handlers (&handlers);
4524 for (j = 1; j < decoded_options_count; j++)
4526 switch (decoded_options[j].opt_index)
4528 case OPT_SPECIAL_input_file:
4529 /* Specs should only generate options, not input
4530 files. */
4531 if (strcmp (decoded_options[j].arg, "-") != 0)
4532 fatal_error ("switch %qs does not start with %<-%>",
4533 decoded_options[j].arg);
4534 else
4535 fatal_error ("spec-generated switch is just %<-%>");
4536 break;
4538 case OPT_fcompare_debug_second:
4539 case OPT_fcompare_debug:
4540 case OPT_fcompare_debug_:
4541 case OPT_o:
4542 /* Avoid duplicate processing of some options from
4543 compare-debug specs; just save them here. */
4544 save_switch (decoded_options[j].canonical_option[0],
4545 (decoded_options[j].canonical_option_num_elements
4546 - 1),
4547 &decoded_options[j].canonical_option[1], false, true);
4548 break;
4550 default:
4551 read_cmdline_option (&global_options, &global_options_set,
4552 decoded_options + j, UNKNOWN_LOCATION,
4553 CL_DRIVER, &handlers, global_dc);
4554 break;
4558 alloc_switch ();
4559 switches[n_switches].part1 = 0;
4563 /* Callback for processing %D and %I specs. */
4565 struct spec_path_info {
4566 const char *option;
4567 const char *append;
4568 size_t append_len;
4569 bool omit_relative;
4570 bool separate_options;
4573 static void *
4574 spec_path (char *path, void *data)
4576 struct spec_path_info *info = (struct spec_path_info *) data;
4577 size_t len = 0;
4578 char save = 0;
4580 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4581 return NULL;
4583 if (info->append_len != 0)
4585 len = strlen (path);
4586 memcpy (path + len, info->append, info->append_len + 1);
4589 if (!is_directory (path, true))
4590 return NULL;
4592 do_spec_1 (info->option, 1, NULL);
4593 if (info->separate_options)
4594 do_spec_1 (" ", 0, NULL);
4596 if (info->append_len == 0)
4598 len = strlen (path);
4599 save = path[len - 1];
4600 if (IS_DIR_SEPARATOR (path[len - 1]))
4601 path[len - 1] = '\0';
4604 do_spec_1 (path, 1, NULL);
4605 do_spec_1 (" ", 0, NULL);
4607 /* Must not damage the original path. */
4608 if (info->append_len == 0)
4609 path[len - 1] = save;
4611 return NULL;
4614 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
4615 argument list. */
4617 static void
4618 create_at_file (char **argv)
4620 char *temp_file = make_temp_file ("");
4621 char *at_argument = concat ("@", temp_file, NULL);
4622 FILE *f = fopen (temp_file, "w");
4623 int status;
4625 if (f == NULL)
4626 fatal_error ("could not open temporary response file %s",
4627 temp_file);
4629 status = writeargv (argv, f);
4631 if (status)
4632 fatal_error ("could not write to temporary response file %s",
4633 temp_file);
4635 status = fclose (f);
4637 if (EOF == status)
4638 fatal_error ("could not close temporary response file %s",
4639 temp_file);
4641 store_arg (at_argument, 0, 0);
4643 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
4646 /* True if we should compile INFILE. */
4648 static bool
4649 compile_input_file_p (struct infile *infile)
4651 if ((!infile->language) || (infile->language[0] != '*'))
4652 if (infile->incompiler == input_file_compiler)
4653 return true;
4654 return false;
4657 /* Process each member of VEC as a spec. */
4659 static void
4660 do_specs_vec (vec<char_p> vec)
4662 unsigned ix;
4663 char *opt;
4665 FOR_EACH_VEC_ELT (vec, ix, opt)
4667 do_spec_1 (opt, 1, NULL);
4668 /* Make each accumulated option a separate argument. */
4669 do_spec_1 (" ", 0, NULL);
4673 /* Process the sub-spec SPEC as a portion of a larger spec.
4674 This is like processing a whole spec except that we do
4675 not initialize at the beginning and we do not supply a
4676 newline by default at the end.
4677 INSWITCH nonzero means don't process %-sequences in SPEC;
4678 in this case, % is treated as an ordinary character.
4679 This is used while substituting switches.
4680 INSWITCH nonzero also causes SPC not to terminate an argument.
4682 Value is zero unless a line was finished
4683 and the command on that line reported an error. */
4685 static int
4686 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4688 const char *p = spec;
4689 int c;
4690 int i;
4691 int value;
4693 /* If it's an empty string argument to a switch, keep it as is. */
4694 if (inswitch && !*p)
4695 arg_going = 1;
4697 while ((c = *p++))
4698 /* If substituting a switch, treat all chars like letters.
4699 Otherwise, NL, SPC, TAB and % are special. */
4700 switch (inswitch ? 'a' : c)
4702 case '\n':
4703 end_going_arg ();
4705 if (argbuf.length () > 0
4706 && !strcmp (argbuf.last (), "|"))
4708 /* A `|' before the newline means use a pipe here,
4709 but only if -pipe was specified.
4710 Otherwise, execute now and don't pass the `|' as an arg. */
4711 if (use_pipes)
4713 input_from_pipe = 1;
4714 break;
4716 else
4717 argbuf.pop ();
4720 set_collect_gcc_options ();
4722 if (argbuf.length () > 0)
4724 value = execute ();
4725 if (value)
4726 return value;
4728 /* Reinitialize for a new command, and for a new argument. */
4729 clear_args ();
4730 arg_going = 0;
4731 delete_this_arg = 0;
4732 this_is_output_file = 0;
4733 this_is_library_file = 0;
4734 this_is_linker_script = 0;
4735 input_from_pipe = 0;
4736 break;
4738 case '|':
4739 end_going_arg ();
4741 /* Use pipe */
4742 obstack_1grow (&obstack, c);
4743 arg_going = 1;
4744 break;
4746 case '\t':
4747 case ' ':
4748 end_going_arg ();
4750 /* Reinitialize for a new argument. */
4751 delete_this_arg = 0;
4752 this_is_output_file = 0;
4753 this_is_library_file = 0;
4754 this_is_linker_script = 0;
4755 break;
4757 case '%':
4758 switch (c = *p++)
4760 case 0:
4761 fatal_error ("spec %qs invalid", spec);
4763 case 'b':
4764 if (save_temps_length)
4765 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4766 else
4767 obstack_grow (&obstack, input_basename, basename_length);
4768 if (compare_debug < 0)
4769 obstack_grow (&obstack, ".gk", 3);
4770 arg_going = 1;
4771 break;
4773 case 'B':
4774 if (save_temps_length)
4775 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4776 else
4777 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4778 if (compare_debug < 0)
4779 obstack_grow (&obstack, ".gk", 3);
4780 arg_going = 1;
4781 break;
4783 case 'd':
4784 delete_this_arg = 2;
4785 break;
4787 /* Dump out the directories specified with LIBRARY_PATH,
4788 followed by the absolute directories
4789 that we search for startfiles. */
4790 case 'D':
4792 struct spec_path_info info;
4794 info.option = "-L";
4795 info.append_len = 0;
4796 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4797 /* Used on systems which record the specified -L dirs
4798 and use them to search for dynamic linking.
4799 Relative directories always come from -B,
4800 and it is better not to use them for searching
4801 at run time. In particular, stage1 loses. */
4802 info.omit_relative = true;
4803 #else
4804 info.omit_relative = false;
4805 #endif
4806 info.separate_options = false;
4808 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
4810 break;
4812 case 'e':
4813 /* %efoo means report an error with `foo' as error message
4814 and don't execute any more commands for this file. */
4816 const char *q = p;
4817 char *buf;
4818 while (*p != 0 && *p != '\n')
4819 p++;
4820 buf = (char *) alloca (p - q + 1);
4821 strncpy (buf, q, p - q);
4822 buf[p - q] = 0;
4823 error ("%s", _(buf));
4824 return -1;
4826 break;
4827 case 'n':
4828 /* %nfoo means report a notice with `foo' on stderr. */
4830 const char *q = p;
4831 char *buf;
4832 while (*p != 0 && *p != '\n')
4833 p++;
4834 buf = (char *) alloca (p - q + 1);
4835 strncpy (buf, q, p - q);
4836 buf[p - q] = 0;
4837 inform (0, "%s", _(buf));
4838 if (*p)
4839 p++;
4841 break;
4843 case 'j':
4845 struct stat st;
4847 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4848 defined, and it is not a directory, and it is
4849 writable, use it. Otherwise, treat this like any
4850 other temporary file. */
4852 if ((!save_temps_flag)
4853 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4854 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4856 obstack_grow (&obstack, HOST_BIT_BUCKET,
4857 strlen (HOST_BIT_BUCKET));
4858 delete_this_arg = 0;
4859 arg_going = 1;
4860 break;
4863 goto create_temp_file;
4864 case '|':
4865 if (use_pipes)
4867 obstack_1grow (&obstack, '-');
4868 delete_this_arg = 0;
4869 arg_going = 1;
4871 /* consume suffix */
4872 while (*p == '.' || ISALNUM ((unsigned char) *p))
4873 p++;
4874 if (p[0] == '%' && p[1] == 'O')
4875 p += 2;
4877 break;
4879 goto create_temp_file;
4880 case 'm':
4881 if (use_pipes)
4883 /* consume suffix */
4884 while (*p == '.' || ISALNUM ((unsigned char) *p))
4885 p++;
4886 if (p[0] == '%' && p[1] == 'O')
4887 p += 2;
4889 break;
4891 goto create_temp_file;
4892 case 'g':
4893 case 'u':
4894 case 'U':
4895 create_temp_file:
4897 struct temp_name *t;
4898 int suffix_length;
4899 const char *suffix = p;
4900 char *saved_suffix = NULL;
4902 while (*p == '.' || ISALNUM ((unsigned char) *p))
4903 p++;
4904 suffix_length = p - suffix;
4905 if (p[0] == '%' && p[1] == 'O')
4907 p += 2;
4908 /* We don't support extra suffix characters after %O. */
4909 if (*p == '.' || ISALNUM ((unsigned char) *p))
4910 fatal_error ("spec %qs has invalid %<%%0%c%>", spec, *p);
4911 if (suffix_length == 0)
4912 suffix = TARGET_OBJECT_SUFFIX;
4913 else
4915 saved_suffix
4916 = XNEWVEC (char, suffix_length
4917 + strlen (TARGET_OBJECT_SUFFIX) + 1);
4918 strncpy (saved_suffix, suffix, suffix_length);
4919 strcpy (saved_suffix + suffix_length,
4920 TARGET_OBJECT_SUFFIX);
4922 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4925 if (compare_debug < 0)
4927 suffix = concat (".gk", suffix, NULL);
4928 suffix_length += 3;
4931 /* If -save-temps=obj and -o were specified, use that for the
4932 temp file. */
4933 if (save_temps_length)
4935 char *tmp;
4936 temp_filename_length
4937 = save_temps_length + suffix_length + 1;
4938 tmp = (char *) alloca (temp_filename_length);
4939 memcpy (tmp, save_temps_prefix, save_temps_length);
4940 memcpy (tmp + save_temps_length, suffix, suffix_length);
4941 tmp[save_temps_length + suffix_length] = '\0';
4942 temp_filename = save_string (tmp, save_temps_length
4943 + suffix_length);
4944 obstack_grow (&obstack, temp_filename,
4945 temp_filename_length);
4946 arg_going = 1;
4947 delete_this_arg = 0;
4948 break;
4951 /* If the gcc_input_filename has the same suffix specified
4952 for the %g, %u, or %U, and -save-temps is specified,
4953 we could end up using that file as an intermediate
4954 thus clobbering the user's source file (.e.g.,
4955 gcc -save-temps foo.s would clobber foo.s with the
4956 output of cpp0). So check for this condition and
4957 generate a temp file as the intermediate. */
4959 if (save_temps_flag)
4961 char *tmp;
4962 temp_filename_length = basename_length + suffix_length + 1;
4963 tmp = (char *) alloca (temp_filename_length);
4964 memcpy (tmp, input_basename, basename_length);
4965 memcpy (tmp + basename_length, suffix, suffix_length);
4966 tmp[basename_length + suffix_length] = '\0';
4967 temp_filename = tmp;
4969 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
4971 #ifndef HOST_LACKS_INODE_NUMBERS
4972 struct stat st_temp;
4974 /* Note, set_input() resets input_stat_set to 0. */
4975 if (input_stat_set == 0)
4977 input_stat_set = stat (gcc_input_filename,
4978 &input_stat);
4979 if (input_stat_set >= 0)
4980 input_stat_set = 1;
4983 /* If we have the stat for the gcc_input_filename
4984 and we can do the stat for the temp_filename
4985 then the they could still refer to the same
4986 file if st_dev/st_ino's are the same. */
4987 if (input_stat_set != 1
4988 || stat (temp_filename, &st_temp) < 0
4989 || input_stat.st_dev != st_temp.st_dev
4990 || input_stat.st_ino != st_temp.st_ino)
4991 #else
4992 /* Just compare canonical pathnames. */
4993 char* input_realname = lrealpath (gcc_input_filename);
4994 char* temp_realname = lrealpath (temp_filename);
4995 bool files_differ = filename_cmp (input_realname, temp_realname);
4996 free (input_realname);
4997 free (temp_realname);
4998 if (files_differ)
4999 #endif
5001 temp_filename = save_string (temp_filename,
5002 temp_filename_length + 1);
5003 obstack_grow (&obstack, temp_filename,
5004 temp_filename_length);
5005 arg_going = 1;
5006 delete_this_arg = 0;
5007 break;
5012 /* See if we already have an association of %g/%u/%U and
5013 suffix. */
5014 for (t = temp_names; t; t = t->next)
5015 if (t->length == suffix_length
5016 && strncmp (t->suffix, suffix, suffix_length) == 0
5017 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
5018 break;
5020 /* Make a new association if needed. %u and %j
5021 require one. */
5022 if (t == 0 || c == 'u' || c == 'j')
5024 if (t == 0)
5026 t = XNEW (struct temp_name);
5027 t->next = temp_names;
5028 temp_names = t;
5030 t->length = suffix_length;
5031 if (saved_suffix)
5033 t->suffix = saved_suffix;
5034 saved_suffix = NULL;
5036 else
5037 t->suffix = save_string (suffix, suffix_length);
5038 t->unique = (c == 'u' || c == 'U' || c == 'j');
5039 temp_filename = make_temp_file (t->suffix);
5040 temp_filename_length = strlen (temp_filename);
5041 t->filename = temp_filename;
5042 t->filename_length = temp_filename_length;
5045 free (saved_suffix);
5047 obstack_grow (&obstack, t->filename, t->filename_length);
5048 delete_this_arg = 1;
5050 arg_going = 1;
5051 break;
5053 case 'i':
5054 if (combine_inputs)
5056 if (at_file_supplied)
5058 /* We are going to expand `%i' to `@FILE', where FILE
5059 is a newly-created temporary filename. The filenames
5060 that would usually be expanded in place of %o will be
5061 written to the temporary file. */
5062 char **argv;
5063 int n_files = 0;
5064 int j;
5066 for (i = 0; i < n_infiles; i++)
5067 if (compile_input_file_p (&infiles[i]))
5068 n_files++;
5070 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5072 /* Copy the strings over. */
5073 for (i = 0, j = 0; i < n_infiles; i++)
5074 if (compile_input_file_p (&infiles[i]))
5076 argv[j] = CONST_CAST (char *, infiles[i].name);
5077 infiles[i].compiled = true;
5078 j++;
5080 argv[j] = NULL;
5082 create_at_file (argv);
5084 else
5085 for (i = 0; (int) i < n_infiles; i++)
5086 if (compile_input_file_p (&infiles[i]))
5088 store_arg (infiles[i].name, 0, 0);
5089 infiles[i].compiled = true;
5092 else
5094 obstack_grow (&obstack, gcc_input_filename,
5095 input_filename_length);
5096 arg_going = 1;
5098 break;
5100 case 'I':
5102 struct spec_path_info info;
5104 if (multilib_dir)
5106 do_spec_1 ("-imultilib", 1, NULL);
5107 /* Make this a separate argument. */
5108 do_spec_1 (" ", 0, NULL);
5109 do_spec_1 (multilib_dir, 1, NULL);
5110 do_spec_1 (" ", 0, NULL);
5113 if (multiarch_dir)
5115 do_spec_1 ("-imultiarch", 1, NULL);
5116 /* Make this a separate argument. */
5117 do_spec_1 (" ", 0, NULL);
5118 do_spec_1 (multiarch_dir, 1, NULL);
5119 do_spec_1 (" ", 0, NULL);
5122 if (gcc_exec_prefix)
5124 do_spec_1 ("-iprefix", 1, NULL);
5125 /* Make this a separate argument. */
5126 do_spec_1 (" ", 0, NULL);
5127 do_spec_1 (gcc_exec_prefix, 1, NULL);
5128 do_spec_1 (" ", 0, NULL);
5131 if (target_system_root_changed ||
5132 (target_system_root && target_sysroot_hdrs_suffix))
5134 do_spec_1 ("-isysroot", 1, NULL);
5135 /* Make this a separate argument. */
5136 do_spec_1 (" ", 0, NULL);
5137 do_spec_1 (target_system_root, 1, NULL);
5138 if (target_sysroot_hdrs_suffix)
5139 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
5140 do_spec_1 (" ", 0, NULL);
5143 info.option = "-isystem";
5144 info.append = "include";
5145 info.append_len = strlen (info.append);
5146 info.omit_relative = false;
5147 info.separate_options = true;
5149 for_each_path (&include_prefixes, false, info.append_len,
5150 spec_path, &info);
5152 info.append = "include-fixed";
5153 if (*sysroot_hdrs_suffix_spec)
5154 info.append = concat (info.append, dir_separator_str,
5155 multilib_dir, NULL);
5156 info.append_len = strlen (info.append);
5157 for_each_path (&include_prefixes, false, info.append_len,
5158 spec_path, &info);
5160 break;
5162 case 'o':
5164 int max = n_infiles;
5165 max += lang_specific_extra_outfiles;
5167 if (HAVE_GNU_LD && at_file_supplied)
5169 /* We are going to expand `%o' to `@FILE', where FILE
5170 is a newly-created temporary filename. The filenames
5171 that would usually be expanded in place of %o will be
5172 written to the temporary file. */
5174 char **argv;
5175 int n_files, j;
5177 /* Convert OUTFILES into a form suitable for writeargv. */
5179 /* Determine how many are non-NULL. */
5180 for (n_files = 0, i = 0; i < max; i++)
5181 n_files += outfiles[i] != NULL;
5183 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5185 /* Copy the strings over. */
5186 for (i = 0, j = 0; i < max; i++)
5187 if (outfiles[i])
5189 argv[j] = CONST_CAST (char *, outfiles[i]);
5190 j++;
5192 argv[j] = NULL;
5194 create_at_file (argv);
5196 else
5197 for (i = 0; i < max; i++)
5198 if (outfiles[i])
5199 store_arg (outfiles[i], 0, 0);
5200 break;
5203 case 'O':
5204 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5205 arg_going = 1;
5206 break;
5208 case 's':
5209 this_is_library_file = 1;
5210 break;
5212 case 'T':
5213 this_is_linker_script = 1;
5214 break;
5216 case 'V':
5217 outfiles[input_file_number] = NULL;
5218 break;
5220 case 'w':
5221 this_is_output_file = 1;
5222 break;
5224 case 'W':
5226 unsigned int cur_index = argbuf.length ();
5227 /* Handle the {...} following the %W. */
5228 if (*p != '{')
5229 fatal_error ("spec %qs has invalid %<%%W%c%>", spec, *p);
5230 p = handle_braces (p + 1);
5231 if (p == 0)
5232 return -1;
5233 end_going_arg ();
5234 /* If any args were output, mark the last one for deletion
5235 on failure. */
5236 if (argbuf.length () != cur_index)
5237 record_temp_file (argbuf.last (), 0, 1);
5238 break;
5241 /* %x{OPTION} records OPTION for %X to output. */
5242 case 'x':
5244 const char *p1 = p;
5245 char *string;
5246 char *opt;
5247 unsigned ix;
5249 /* Skip past the option value and make a copy. */
5250 if (*p != '{')
5251 fatal_error ("spec %qs has invalid %<%%x%c%>", spec, *p);
5252 while (*p++ != '}')
5254 string = save_string (p1 + 1, p - p1 - 2);
5256 /* See if we already recorded this option. */
5257 FOR_EACH_VEC_ELT (linker_options, ix, opt)
5258 if (! strcmp (string, opt))
5260 free (string);
5261 return 0;
5264 /* This option is new; add it. */
5265 add_linker_option (string, strlen (string));
5266 free (string);
5268 break;
5270 /* Dump out the options accumulated previously using %x. */
5271 case 'X':
5272 do_specs_vec (linker_options);
5273 break;
5275 /* Dump out the options accumulated previously using -Wa,. */
5276 case 'Y':
5277 do_specs_vec (assembler_options);
5278 break;
5280 /* Dump out the options accumulated previously using -Wp,. */
5281 case 'Z':
5282 do_specs_vec (preprocessor_options);
5283 break;
5285 /* Here are digits and numbers that just process
5286 a certain constant string as a spec. */
5288 case '1':
5289 value = do_spec_1 (cc1_spec, 0, NULL);
5290 if (value != 0)
5291 return value;
5292 break;
5294 case '2':
5295 value = do_spec_1 (cc1plus_spec, 0, NULL);
5296 if (value != 0)
5297 return value;
5298 break;
5300 case 'a':
5301 value = do_spec_1 (asm_spec, 0, NULL);
5302 if (value != 0)
5303 return value;
5304 break;
5306 case 'A':
5307 value = do_spec_1 (asm_final_spec, 0, NULL);
5308 if (value != 0)
5309 return value;
5310 break;
5312 case 'C':
5314 const char *const spec
5315 = (input_file_compiler->cpp_spec
5316 ? input_file_compiler->cpp_spec
5317 : cpp_spec);
5318 value = do_spec_1 (spec, 0, NULL);
5319 if (value != 0)
5320 return value;
5322 break;
5324 case 'E':
5325 value = do_spec_1 (endfile_spec, 0, NULL);
5326 if (value != 0)
5327 return value;
5328 break;
5330 case 'l':
5331 value = do_spec_1 (link_spec, 0, NULL);
5332 if (value != 0)
5333 return value;
5334 break;
5336 case 'L':
5337 value = do_spec_1 (lib_spec, 0, NULL);
5338 if (value != 0)
5339 return value;
5340 break;
5342 case 'M':
5343 if (multilib_os_dir == NULL)
5344 obstack_1grow (&obstack, '.');
5345 else
5346 obstack_grow (&obstack, multilib_os_dir,
5347 strlen (multilib_os_dir));
5348 break;
5350 case 'G':
5351 value = do_spec_1 (libgcc_spec, 0, NULL);
5352 if (value != 0)
5353 return value;
5354 break;
5356 case 'R':
5357 /* We assume there is a directory
5358 separator at the end of this string. */
5359 if (target_system_root)
5361 obstack_grow (&obstack, target_system_root,
5362 strlen (target_system_root));
5363 if (target_sysroot_suffix)
5364 obstack_grow (&obstack, target_sysroot_suffix,
5365 strlen (target_sysroot_suffix));
5367 break;
5369 case 'S':
5370 value = do_spec_1 (startfile_spec, 0, NULL);
5371 if (value != 0)
5372 return value;
5373 break;
5375 /* Here we define characters other than letters and digits. */
5377 case '{':
5378 p = handle_braces (p);
5379 if (p == 0)
5380 return -1;
5381 break;
5383 case ':':
5384 p = handle_spec_function (p, NULL);
5385 if (p == 0)
5386 return -1;
5387 break;
5389 case '%':
5390 obstack_1grow (&obstack, '%');
5391 break;
5393 case '.':
5395 unsigned len = 0;
5397 while (p[len] && p[len] != ' ' && p[len] != '%')
5398 len++;
5399 suffix_subst = save_string (p - 1, len + 1);
5400 p += len;
5402 break;
5404 /* Henceforth ignore the option(s) matching the pattern
5405 after the %<. */
5406 case '<':
5407 case '>':
5409 unsigned len = 0;
5410 int have_wildcard = 0;
5411 int i;
5412 int switch_option;
5414 if (c == '>')
5415 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5416 else
5417 switch_option = SWITCH_IGNORE;
5419 while (p[len] && p[len] != ' ' && p[len] != '\t')
5420 len++;
5422 if (p[len-1] == '*')
5423 have_wildcard = 1;
5425 for (i = 0; i < n_switches; i++)
5426 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5427 && (have_wildcard || switches[i].part1[len] == '\0'))
5429 switches[i].live_cond |= switch_option;
5430 /* User switch be validated from validate_all_switches.
5431 when the definition is seen from the spec file.
5432 If not defined anywhere, will be rejected. */
5433 if (switches[i].known)
5434 switches[i].validated = true;
5437 p += len;
5439 break;
5441 case '*':
5442 if (soft_matched_part)
5444 if (soft_matched_part[0])
5445 do_spec_1 (soft_matched_part, 1, NULL);
5446 /* Only insert a space after the substitution if it is at the
5447 end of the current sequence. So if:
5449 "%{foo=*:bar%*}%{foo=*:one%*two}"
5451 matches -foo=hello then it will produce:
5453 barhello onehellotwo
5455 if (*p == 0 || *p == '}')
5456 do_spec_1 (" ", 0, NULL);
5458 else
5459 /* Catch the case where a spec string contains something like
5460 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5461 hand side of the :. */
5462 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5463 break;
5465 /* Process a string found as the value of a spec given by name.
5466 This feature allows individual machine descriptions
5467 to add and use their own specs. */
5468 case '(':
5470 const char *name = p;
5471 struct spec_list *sl;
5472 int len;
5474 /* The string after the S/P is the name of a spec that is to be
5475 processed. */
5476 while (*p && *p != ')')
5477 p++;
5479 /* See if it's in the list. */
5480 for (len = p - name, sl = specs; sl; sl = sl->next)
5481 if (sl->name_len == len && !strncmp (sl->name, name, len))
5483 name = *(sl->ptr_spec);
5484 #ifdef DEBUG_SPECS
5485 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5486 sl->name, name);
5487 #endif
5488 break;
5491 if (sl)
5493 value = do_spec_1 (name, 0, NULL);
5494 if (value != 0)
5495 return value;
5498 /* Discard the closing paren. */
5499 if (*p)
5500 p++;
5502 break;
5504 default:
5505 error ("spec failure: unrecognized spec option %qc", c);
5506 break;
5508 break;
5510 case '\\':
5511 /* Backslash: treat next character as ordinary. */
5512 c = *p++;
5514 /* Fall through. */
5515 default:
5516 /* Ordinary character: put it into the current argument. */
5517 obstack_1grow (&obstack, c);
5518 arg_going = 1;
5521 /* End of string. If we are processing a spec function, we need to
5522 end any pending argument. */
5523 if (processing_spec_function)
5524 end_going_arg ();
5526 return 0;
5529 /* Look up a spec function. */
5531 static const struct spec_function *
5532 lookup_spec_function (const char *name)
5534 const struct spec_function *sf;
5536 for (sf = static_spec_functions; sf->name != NULL; sf++)
5537 if (strcmp (sf->name, name) == 0)
5538 return sf;
5540 return NULL;
5543 /* Evaluate a spec function. */
5545 static const char *
5546 eval_spec_function (const char *func, const char *args)
5548 const struct spec_function *sf;
5549 const char *funcval;
5551 /* Saved spec processing context. */
5552 vec<const_char_p> save_argbuf;
5554 int save_arg_going;
5555 int save_delete_this_arg;
5556 int save_this_is_output_file;
5557 int save_this_is_library_file;
5558 int save_input_from_pipe;
5559 int save_this_is_linker_script;
5560 const char *save_suffix_subst;
5562 int save_growing_size;
5563 void *save_growing_value = NULL;
5565 sf = lookup_spec_function (func);
5566 if (sf == NULL)
5567 fatal_error ("unknown spec function %qs", func);
5569 /* Push the spec processing context. */
5570 save_argbuf = argbuf;
5572 save_arg_going = arg_going;
5573 save_delete_this_arg = delete_this_arg;
5574 save_this_is_output_file = this_is_output_file;
5575 save_this_is_library_file = this_is_library_file;
5576 save_this_is_linker_script = this_is_linker_script;
5577 save_input_from_pipe = input_from_pipe;
5578 save_suffix_subst = suffix_subst;
5580 /* If we have some object growing now, finalize it so the args and function
5581 eval proceed from a cleared context. This is needed to prevent the first
5582 constructed arg from mistakenly including the growing value. We'll push
5583 this value back on the obstack once the function evaluation is done, to
5584 restore a consistent processing context for our caller. This is fine as
5585 the address of growing objects isn't guaranteed to remain stable until
5586 they are finalized, and we expect this situation to be rare enough for
5587 the extra copy not to be an issue. */
5588 save_growing_size = obstack_object_size (&obstack);
5589 if (save_growing_size > 0)
5590 save_growing_value = obstack_finish (&obstack);
5592 /* Create a new spec processing context, and build the function
5593 arguments. */
5595 alloc_args ();
5596 if (do_spec_2 (args) < 0)
5597 fatal_error ("error in args to spec function %qs", func);
5599 /* argbuf_index is an index for the next argument to be inserted, and
5600 so contains the count of the args already inserted. */
5602 funcval = (*sf->func) (argbuf.length (),
5603 argbuf.address ());
5605 /* Pop the spec processing context. */
5606 argbuf.release ();
5607 argbuf = save_argbuf;
5609 arg_going = save_arg_going;
5610 delete_this_arg = save_delete_this_arg;
5611 this_is_output_file = save_this_is_output_file;
5612 this_is_library_file = save_this_is_library_file;
5613 this_is_linker_script = save_this_is_linker_script;
5614 input_from_pipe = save_input_from_pipe;
5615 suffix_subst = save_suffix_subst;
5617 if (save_growing_size > 0)
5618 obstack_grow (&obstack, save_growing_value, save_growing_size);
5620 return funcval;
5623 /* Handle a spec function call of the form:
5625 %:function(args)
5627 ARGS is processed as a spec in a separate context and split into an
5628 argument vector in the normal fashion. The function returns a string
5629 containing a spec which we then process in the caller's context, or
5630 NULL if no processing is required.
5632 If RETVAL_NONNULL is not NULL, then store a bool whether function
5633 returned non-NULL. */
5635 static const char *
5636 handle_spec_function (const char *p, bool *retval_nonnull)
5638 char *func, *args;
5639 const char *endp, *funcval;
5640 int count;
5642 processing_spec_function++;
5644 /* Get the function name. */
5645 for (endp = p; *endp != '\0'; endp++)
5647 if (*endp == '(') /* ) */
5648 break;
5649 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5650 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5651 fatal_error ("malformed spec function name");
5653 if (*endp != '(') /* ) */
5654 fatal_error ("no arguments for spec function");
5655 func = save_string (p, endp - p);
5656 p = ++endp;
5658 /* Get the arguments. */
5659 for (count = 0; *endp != '\0'; endp++)
5661 /* ( */
5662 if (*endp == ')')
5664 if (count == 0)
5665 break;
5666 count--;
5668 else if (*endp == '(') /* ) */
5669 count++;
5671 /* ( */
5672 if (*endp != ')')
5673 fatal_error ("malformed spec function arguments");
5674 args = save_string (p, endp - p);
5675 p = ++endp;
5677 /* p now points to just past the end of the spec function expression. */
5679 funcval = eval_spec_function (func, args);
5680 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5681 p = NULL;
5682 if (retval_nonnull)
5683 *retval_nonnull = funcval != NULL;
5685 free (func);
5686 free (args);
5688 processing_spec_function--;
5690 return p;
5693 /* Inline subroutine of handle_braces. Returns true if the current
5694 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5695 static inline bool
5696 input_suffix_matches (const char *atom, const char *end_atom)
5698 return (input_suffix
5699 && !strncmp (input_suffix, atom, end_atom - atom)
5700 && input_suffix[end_atom - atom] == '\0');
5703 /* Subroutine of handle_braces. Returns true if the current
5704 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
5705 static bool
5706 input_spec_matches (const char *atom, const char *end_atom)
5708 return (input_file_compiler
5709 && input_file_compiler->suffix
5710 && input_file_compiler->suffix[0] != '\0'
5711 && !strncmp (input_file_compiler->suffix + 1, atom,
5712 end_atom - atom)
5713 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
5716 /* Subroutine of handle_braces. Returns true if a switch
5717 matching the atom bracketed by ATOM and END_ATOM appeared on the
5718 command line. */
5719 static bool
5720 switch_matches (const char *atom, const char *end_atom, int starred)
5722 int i;
5723 int len = end_atom - atom;
5724 int plen = starred ? len : -1;
5726 for (i = 0; i < n_switches; i++)
5727 if (!strncmp (switches[i].part1, atom, len)
5728 && (starred || switches[i].part1[len] == '\0')
5729 && check_live_switch (i, plen))
5730 return true;
5732 /* Check if a switch with separated form matching the atom.
5733 We check -D and -U switches. */
5734 else if (switches[i].args != 0)
5736 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
5737 && *switches[i].part1 == atom[0])
5739 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
5740 && (starred || (switches[i].part1[1] == '\0'
5741 && switches[i].args[0][len - 1] == '\0'))
5742 && check_live_switch (i, (starred ? 1 : -1)))
5743 return true;
5747 return false;
5750 /* Inline subroutine of handle_braces. Mark all of the switches which
5751 match ATOM (extends to END_ATOM; STARRED indicates whether there
5752 was a star after the atom) for later processing. */
5753 static inline void
5754 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5756 int i;
5757 int len = end_atom - atom;
5758 int plen = starred ? len : -1;
5760 for (i = 0; i < n_switches; i++)
5761 if (!strncmp (switches[i].part1, atom, len)
5762 && (starred || switches[i].part1[len] == '\0')
5763 && check_live_switch (i, plen))
5764 switches[i].ordering = 1;
5767 /* Inline subroutine of handle_braces. Process all the currently
5768 marked switches through give_switch, and clear the marks. */
5769 static inline void
5770 process_marked_switches (void)
5772 int i;
5774 for (i = 0; i < n_switches; i++)
5775 if (switches[i].ordering == 1)
5777 switches[i].ordering = 0;
5778 give_switch (i, 0);
5782 /* Handle a %{ ... } construct. P points just inside the leading {.
5783 Returns a pointer one past the end of the brace block, or 0
5784 if we call do_spec_1 and that returns -1. */
5786 static const char *
5787 handle_braces (const char *p)
5789 const char *atom, *end_atom;
5790 const char *d_atom = NULL, *d_end_atom = NULL;
5791 const char *orig = p;
5793 bool a_is_suffix;
5794 bool a_is_spectype;
5795 bool a_is_starred;
5796 bool a_is_negated;
5797 bool a_matched;
5799 bool a_must_be_last = false;
5800 bool ordered_set = false;
5801 bool disjunct_set = false;
5802 bool disj_matched = false;
5803 bool disj_starred = true;
5804 bool n_way_choice = false;
5805 bool n_way_matched = false;
5807 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5811 if (a_must_be_last)
5812 goto invalid;
5814 /* Scan one "atom" (S in the description above of %{}, possibly
5815 with '!', '.', '@', ',', or '*' modifiers). */
5816 a_matched = false;
5817 a_is_suffix = false;
5818 a_is_starred = false;
5819 a_is_negated = false;
5820 a_is_spectype = false;
5822 SKIP_WHITE ();
5823 if (*p == '!')
5824 p++, a_is_negated = true;
5826 SKIP_WHITE ();
5827 if (*p == '%' && p[1] == ':')
5829 atom = NULL;
5830 end_atom = NULL;
5831 p = handle_spec_function (p + 2, &a_matched);
5833 else
5835 if (*p == '.')
5836 p++, a_is_suffix = true;
5837 else if (*p == ',')
5838 p++, a_is_spectype = true;
5840 atom = p;
5841 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
5842 || *p == ',' || *p == '.' || *p == '@')
5843 p++;
5844 end_atom = p;
5846 if (*p == '*')
5847 p++, a_is_starred = 1;
5850 SKIP_WHITE ();
5851 switch (*p)
5853 case '&': case '}':
5854 /* Substitute the switch(es) indicated by the current atom. */
5855 ordered_set = true;
5856 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5857 || a_is_spectype || atom == end_atom)
5858 goto invalid;
5860 mark_matching_switches (atom, end_atom, a_is_starred);
5862 if (*p == '}')
5863 process_marked_switches ();
5864 break;
5866 case '|': case ':':
5867 /* Substitute some text if the current atom appears as a switch
5868 or suffix. */
5869 disjunct_set = true;
5870 if (ordered_set)
5871 goto invalid;
5873 if (atom && atom == end_atom)
5875 if (!n_way_choice || disj_matched || *p == '|'
5876 || a_is_negated || a_is_suffix || a_is_spectype
5877 || a_is_starred)
5878 goto invalid;
5880 /* An empty term may appear as the last choice of an
5881 N-way choice set; it means "otherwise". */
5882 a_must_be_last = true;
5883 disj_matched = !n_way_matched;
5884 disj_starred = false;
5886 else
5888 if ((a_is_suffix || a_is_spectype) && a_is_starred)
5889 goto invalid;
5891 if (!a_is_starred)
5892 disj_starred = false;
5894 /* Don't bother testing this atom if we already have a
5895 match. */
5896 if (!disj_matched && !n_way_matched)
5898 if (atom == NULL)
5899 /* a_matched is already set by handle_spec_function. */;
5900 else if (a_is_suffix)
5901 a_matched = input_suffix_matches (atom, end_atom);
5902 else if (a_is_spectype)
5903 a_matched = input_spec_matches (atom, end_atom);
5904 else
5905 a_matched = switch_matches (atom, end_atom, a_is_starred);
5907 if (a_matched != a_is_negated)
5909 disj_matched = true;
5910 d_atom = atom;
5911 d_end_atom = end_atom;
5916 if (*p == ':')
5918 /* Found the body, that is, the text to substitute if the
5919 current disjunction matches. */
5920 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5921 disj_matched && !n_way_matched);
5922 if (p == 0)
5923 return 0;
5925 /* If we have an N-way choice, reset state for the next
5926 disjunction. */
5927 if (*p == ';')
5929 n_way_choice = true;
5930 n_way_matched |= disj_matched;
5931 disj_matched = false;
5932 disj_starred = true;
5933 d_atom = d_end_atom = NULL;
5936 break;
5938 default:
5939 goto invalid;
5942 while (*p++ != '}');
5944 return p;
5946 invalid:
5947 fatal_error ("braced spec %qs is invalid at %qc", orig, *p);
5949 #undef SKIP_WHITE
5952 /* Subroutine of handle_braces. Scan and process a brace substitution body
5953 (X in the description of %{} syntax). P points one past the colon;
5954 ATOM and END_ATOM bracket the first atom which was found to be true
5955 (present) in the current disjunction; STARRED indicates whether all
5956 the atoms in the current disjunction were starred (for syntax validation);
5957 MATCHED indicates whether the disjunction matched or not, and therefore
5958 whether or not the body is to be processed through do_spec_1 or just
5959 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5960 returns -1. */
5962 static const char *
5963 process_brace_body (const char *p, const char *atom, const char *end_atom,
5964 int starred, int matched)
5966 const char *body, *end_body;
5967 unsigned int nesting_level;
5968 bool have_subst = false;
5970 /* Locate the closing } or ;, honoring nested braces.
5971 Trim trailing whitespace. */
5972 body = p;
5973 nesting_level = 1;
5974 for (;;)
5976 if (*p == '{')
5977 nesting_level++;
5978 else if (*p == '}')
5980 if (!--nesting_level)
5981 break;
5983 else if (*p == ';' && nesting_level == 1)
5984 break;
5985 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5986 have_subst = true;
5987 else if (*p == '\0')
5988 goto invalid;
5989 p++;
5992 end_body = p;
5993 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5994 end_body--;
5996 if (have_subst && !starred)
5997 goto invalid;
5999 if (matched)
6001 /* Copy the substitution body to permanent storage and execute it.
6002 If have_subst is false, this is a simple matter of running the
6003 body through do_spec_1... */
6004 char *string = save_string (body, end_body - body);
6005 if (!have_subst)
6007 if (do_spec_1 (string, 0, NULL) < 0)
6008 return 0;
6010 else
6012 /* ... but if have_subst is true, we have to process the
6013 body once for each matching switch, with %* set to the
6014 variant part of the switch. */
6015 unsigned int hard_match_len = end_atom - atom;
6016 int i;
6018 for (i = 0; i < n_switches; i++)
6019 if (!strncmp (switches[i].part1, atom, hard_match_len)
6020 && check_live_switch (i, hard_match_len))
6022 if (do_spec_1 (string, 0,
6023 &switches[i].part1[hard_match_len]) < 0)
6024 return 0;
6025 /* Pass any arguments this switch has. */
6026 give_switch (i, 1);
6027 suffix_subst = NULL;
6032 return p;
6034 invalid:
6035 fatal_error ("braced spec body %qs is invalid", body);
6038 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
6039 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
6040 spec, or -1 if either exact match or %* is used.
6042 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
6043 whose value does not begin with "no-" is obsoleted by the same value
6044 with the "no-", similarly for a switch with the "no-" prefix. */
6046 static int
6047 check_live_switch (int switchnum, int prefix_length)
6049 const char *name = switches[switchnum].part1;
6050 int i;
6052 /* If we already processed this switch and determined if it was
6053 live or not, return our past determination. */
6054 if (switches[switchnum].live_cond != 0)
6055 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
6056 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
6057 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
6058 == 0);
6060 /* In the common case of {<at-most-one-letter>*}, a negating
6061 switch would always match, so ignore that case. We will just
6062 send the conflicting switches to the compiler phase. */
6063 if (prefix_length >= 0 && prefix_length <= 1)
6064 return 1;
6066 /* Now search for duplicate in a manner that depends on the name. */
6067 switch (*name)
6069 case 'O':
6070 for (i = switchnum + 1; i < n_switches; i++)
6071 if (switches[i].part1[0] == 'O')
6073 switches[switchnum].validated = true;
6074 switches[switchnum].live_cond = SWITCH_FALSE;
6075 return 0;
6077 break;
6079 case 'W': case 'f': case 'm': case 'g':
6080 if (! strncmp (name + 1, "no-", 3))
6082 /* We have Xno-YYY, search for XYYY. */
6083 for (i = switchnum + 1; i < n_switches; i++)
6084 if (switches[i].part1[0] == name[0]
6085 && ! strcmp (&switches[i].part1[1], &name[4]))
6087 /* --specs are validated with the validate_switches mechanism. */
6088 if (switches[switchnum].known)
6089 switches[switchnum].validated = true;
6090 switches[switchnum].live_cond = SWITCH_FALSE;
6091 return 0;
6094 else
6096 /* We have XYYY, search for Xno-YYY. */
6097 for (i = switchnum + 1; i < n_switches; i++)
6098 if (switches[i].part1[0] == name[0]
6099 && switches[i].part1[1] == 'n'
6100 && switches[i].part1[2] == 'o'
6101 && switches[i].part1[3] == '-'
6102 && !strcmp (&switches[i].part1[4], &name[1]))
6104 /* --specs are validated with the validate_switches mechanism. */
6105 if (switches[switchnum].known)
6106 switches[switchnum].validated = true;
6107 switches[switchnum].live_cond = SWITCH_FALSE;
6108 return 0;
6111 break;
6114 /* Otherwise the switch is live. */
6115 switches[switchnum].live_cond |= SWITCH_LIVE;
6116 return 1;
6119 /* Pass a switch to the current accumulating command
6120 in the same form that we received it.
6121 SWITCHNUM identifies the switch; it is an index into
6122 the vector of switches gcc received, which is `switches'.
6123 This cannot fail since it never finishes a command line.
6125 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
6127 static void
6128 give_switch (int switchnum, int omit_first_word)
6130 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
6131 return;
6133 if (!omit_first_word)
6135 do_spec_1 ("-", 0, NULL);
6136 do_spec_1 (switches[switchnum].part1, 1, NULL);
6139 if (switches[switchnum].args != 0)
6141 const char **p;
6142 for (p = switches[switchnum].args; *p; p++)
6144 const char *arg = *p;
6146 do_spec_1 (" ", 0, NULL);
6147 if (suffix_subst)
6149 unsigned length = strlen (arg);
6150 int dot = 0;
6152 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
6153 if (arg[length] == '.')
6155 (CONST_CAST (char *, arg))[length] = 0;
6156 dot = 1;
6157 break;
6159 do_spec_1 (arg, 1, NULL);
6160 if (dot)
6161 (CONST_CAST (char *, arg))[length] = '.';
6162 do_spec_1 (suffix_subst, 1, NULL);
6164 else
6165 do_spec_1 (arg, 1, NULL);
6169 do_spec_1 (" ", 0, NULL);
6170 switches[switchnum].validated = true;
6173 /* Print GCC configuration (e.g. version, thread model, target,
6174 configuration_arguments) to a given FILE. */
6176 static void
6177 print_configuration (FILE *file)
6179 int n;
6180 const char *thrmod;
6182 fnotice (file, "Target: %s\n", spec_machine);
6183 fnotice (file, "Configured with: %s\n", configuration_arguments);
6185 #ifdef THREAD_MODEL_SPEC
6186 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6187 but there's no point in doing all this processing just to get
6188 thread_model back. */
6189 obstack_init (&obstack);
6190 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6191 obstack_1grow (&obstack, '\0');
6192 thrmod = XOBFINISH (&obstack, const char *);
6193 #else
6194 thrmod = thread_model;
6195 #endif
6197 fnotice (file, "Thread model: %s\n", thrmod);
6199 /* compiler_version is truncated at the first space when initialized
6200 from version string, so truncate version_string at the first space
6201 before comparing. */
6202 for (n = 0; version_string[n]; n++)
6203 if (version_string[n] == ' ')
6204 break;
6206 if (! strncmp (version_string, compiler_version, n)
6207 && compiler_version[n] == 0)
6208 fnotice (file, "gcc version %s %s\n\n", version_string,
6209 pkgversion_string);
6210 else
6211 fnotice (file, "gcc driver version %s %sexecuting gcc version %s\n\n",
6212 version_string, pkgversion_string, compiler_version);
6216 #define RETRY_ICE_ATTEMPTS 3
6218 /* Returns true if FILE1 and FILE2 contain equivalent data, 0 otherwise. */
6220 static bool
6221 files_equal_p (char *file1, char *file2)
6223 struct stat st1, st2;
6224 off_t n, len;
6225 int fd1, fd2;
6226 const int bufsize = 8192;
6227 char *buf = XNEWVEC (char, bufsize);
6229 fd1 = open (file1, O_RDONLY);
6230 fd2 = open (file2, O_RDONLY);
6232 if (fd1 < 0 || fd2 < 0)
6233 goto error;
6235 if (fstat (fd1, &st1) < 0 || fstat (fd2, &st2) < 0)
6236 goto error;
6238 if (st1.st_size != st2.st_size)
6239 goto error;
6241 for (n = st1.st_size; n; n -= len)
6243 len = n;
6244 if ((int) len > bufsize / 2)
6245 len = bufsize / 2;
6247 if (read (fd1, buf, len) != (int) len
6248 || read (fd2, buf + bufsize / 2, len) != (int) len)
6250 goto error;
6253 if (memcmp (buf, buf + bufsize / 2, len) != 0)
6254 goto error;
6257 free (buf);
6258 close (fd1);
6259 close (fd2);
6261 return 1;
6263 error:
6264 free (buf);
6265 close (fd1);
6266 close (fd2);
6267 return 0;
6270 /* Check that compiler's output doesn't differ across runs.
6271 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are arrays of files, containing
6272 stdout and stderr for each compiler run. Return true if all of
6273 TEMP_STDOUT_FILES and TEMP_STDERR_FILES are equivalent. */
6275 static bool
6276 check_repro (char **temp_stdout_files, char **temp_stderr_files)
6278 int i;
6279 for (i = 0; i < RETRY_ICE_ATTEMPTS - 2; ++i)
6281 if (!files_equal_p (temp_stdout_files[i], temp_stdout_files[i + 1])
6282 || !files_equal_p (temp_stderr_files[i], temp_stderr_files[i + 1]))
6284 fnotice (stderr, "The bug is not reproducible, so it is"
6285 " likely a hardware or OS problem.\n");
6286 break;
6289 return i == RETRY_ICE_ATTEMPTS - 2;
6292 enum attempt_status {
6293 ATTEMPT_STATUS_FAIL_TO_RUN,
6294 ATTEMPT_STATUS_SUCCESS,
6295 ATTEMPT_STATUS_ICE
6299 /* Run compiler with arguments NEW_ARGV to reproduce the ICE, storing stdout
6300 to OUT_TEMP and stderr to ERR_TEMP. If APPEND is TRUE, append to OUT_TEMP
6301 and ERR_TEMP instead of truncating. If EMIT_SYSTEM_INFO is TRUE, also write
6302 GCC configuration into to ERR_TEMP. Return ATTEMPT_STATUS_FAIL_TO_RUN if
6303 compiler failed to run, ATTEMPT_STATUS_ICE if compiled ICE-ed and
6304 ATTEMPT_STATUS_SUCCESS otherwise. */
6306 static enum attempt_status
6307 run_attempt (const char **new_argv, const char *out_temp,
6308 const char *err_temp, int emit_system_info, int append)
6311 if (emit_system_info)
6313 FILE *file_out = fopen (err_temp, "a");
6314 print_configuration (file_out);
6315 fclose (file_out);
6318 int exit_status;
6319 const char *errmsg;
6320 struct pex_obj *pex;
6321 int err;
6322 int pex_flags = PEX_USE_PIPES | PEX_LAST;
6323 enum attempt_status status = ATTEMPT_STATUS_FAIL_TO_RUN;
6325 if (append)
6326 pex_flags |= PEX_STDOUT_APPEND | PEX_STDERR_APPEND;
6328 pex = pex_init (PEX_USE_PIPES, new_argv[0], NULL);
6329 if (!pex)
6330 fatal_error ("pex_init failed: %m");
6332 errmsg = pex_run (pex, pex_flags, new_argv[0],
6333 CONST_CAST2 (char *const *, const char **, &new_argv[1]), out_temp,
6334 err_temp, &err);
6335 if (errmsg != NULL)
6337 if (err == 0)
6338 fatal_error (errmsg);
6339 else
6341 errno = err;
6342 pfatal_with_name (errmsg);
6346 if (!pex_get_status (pex, 1, &exit_status))
6347 goto out;
6349 switch (WEXITSTATUS (exit_status))
6351 case ICE_EXIT_CODE:
6352 status = ATTEMPT_STATUS_ICE;
6353 break;
6355 case SUCCESS_EXIT_CODE:
6356 status = ATTEMPT_STATUS_SUCCESS;
6357 break;
6359 default:
6363 out:
6364 pex_free (pex);
6365 return status;
6368 /* This routine adds preprocessed source code into the given ERR_FILE.
6369 To do this, it adds "-E" to NEW_ARGV and execute RUN_ATTEMPT routine to
6370 add information in report file. RUN_ATTEMPT should return
6371 ATTEMPT_STATUS_SUCCESS, in other case we cannot generate the report. */
6373 static void
6374 do_report_bug (const char **new_argv, const int nargs,
6375 char **out_file, char **err_file)
6377 int i, status;
6378 int fd = open (*out_file, O_RDWR | O_APPEND);
6379 if (fd < 0)
6380 return;
6381 write (fd, "\n//", 3);
6382 for (i = 0; i < nargs; i++)
6384 write (fd, " ", 1);
6385 write (fd, new_argv[i], strlen (new_argv[i]));
6387 write (fd, "\n\n", 2);
6388 close (fd);
6389 new_argv[nargs] = "-E";
6390 new_argv[nargs + 1] = NULL;
6392 status = run_attempt (new_argv, *out_file, *err_file, 0, 1);
6394 if (status == ATTEMPT_STATUS_SUCCESS)
6396 fnotice (stderr, "Preprocessed source stored into %s file,"
6397 " please attach this to your bugreport.\n", *out_file);
6398 /* Make sure it is not deleted. */
6399 free (*out_file);
6400 *out_file = NULL;
6404 /* Append string STR to file FILE. */
6406 static void
6407 append_text (char *file, const char *str)
6409 int fd = open (file, O_RDWR | O_APPEND);
6410 if (fd < 0)
6411 return;
6413 write (fd, str, strlen (str));
6414 close (fd);
6417 /* Try to reproduce ICE. If bug is reproducible, generate report .err file
6418 containing GCC configuration, backtrace, compiler's command line options
6419 and preprocessed source code. */
6421 static void
6422 try_generate_repro (const char **argv)
6424 int i, nargs, out_arg = -1, quiet = 0, attempt;
6425 const char **new_argv;
6426 char *temp_files[RETRY_ICE_ATTEMPTS * 2];
6427 char **temp_stdout_files = &temp_files[0];
6428 char **temp_stderr_files = &temp_files[RETRY_ICE_ATTEMPTS];
6430 if (gcc_input_filename == NULL || ! strcmp (gcc_input_filename, "-"))
6431 return;
6433 for (nargs = 0; argv[nargs] != NULL; ++nargs)
6434 /* Only retry compiler ICEs, not preprocessor ones. */
6435 if (! strcmp (argv[nargs], "-E"))
6436 return;
6437 else if (argv[nargs][0] == '-' && argv[nargs][1] == 'o')
6439 if (out_arg == -1)
6440 out_arg = nargs;
6441 else
6442 return;
6444 /* If the compiler is going to output any time information,
6445 it might varry between invocations. */
6446 else if (! strcmp (argv[nargs], "-quiet"))
6447 quiet = 1;
6448 else if (! strcmp (argv[nargs], "-ftime-report"))
6449 return;
6451 if (out_arg == -1 || !quiet)
6452 return;
6454 memset (temp_files, '\0', sizeof (temp_files));
6455 new_argv = XALLOCAVEC (const char *, nargs + 4);
6456 memcpy (new_argv, argv, (nargs + 1) * sizeof (const char *));
6457 new_argv[nargs++] = "-frandom-seed=0";
6458 new_argv[nargs++] = "-fdump-noaddr";
6459 new_argv[nargs] = NULL;
6460 if (new_argv[out_arg][2] == '\0')
6461 new_argv[out_arg + 1] = "-";
6462 else
6463 new_argv[out_arg] = "-o-";
6465 int status;
6466 for (attempt = 0; attempt < RETRY_ICE_ATTEMPTS; ++attempt)
6468 int emit_system_info = 0;
6469 int append = 0;
6470 temp_stdout_files[attempt] = make_temp_file (".out");
6471 temp_stderr_files[attempt] = make_temp_file (".err");
6473 if (attempt == RETRY_ICE_ATTEMPTS - 1)
6475 append = 1;
6476 emit_system_info = 1;
6479 if (emit_system_info)
6480 append_text (temp_stderr_files[attempt], "/*\n");
6482 status = run_attempt (new_argv, temp_stdout_files[attempt],
6483 temp_stderr_files[attempt], emit_system_info,
6484 append);
6486 if (emit_system_info)
6487 append_text (temp_stderr_files[attempt], "*/\n");
6489 if (status != ATTEMPT_STATUS_ICE)
6491 fnotice (stderr, "The bug is not reproducible, so it is"
6492 " likely a hardware or OS problem.\n");
6493 goto out;
6497 if (!check_repro (temp_stdout_files, temp_stderr_files))
6498 goto out;
6500 /* In final attempt we append compiler options and preprocesssed code to last
6501 generated .err file with configuration and backtrace. */
6502 do_report_bug (new_argv, nargs,
6503 &temp_stderr_files[RETRY_ICE_ATTEMPTS - 1],
6504 &temp_stdout_files[RETRY_ICE_ATTEMPTS - 1]);
6506 out:
6507 for (i = 0; i < RETRY_ICE_ATTEMPTS * 2; i++)
6508 if (temp_files[i])
6510 unlink (temp_stdout_files[i]);
6511 free (temp_stdout_files[i]);
6515 /* Search for a file named NAME trying various prefixes including the
6516 user's -B prefix and some standard ones.
6517 Return the absolute file name found. If nothing is found, return NAME. */
6519 static const char *
6520 find_file (const char *name)
6522 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
6523 return newname ? newname : name;
6526 /* Determine whether a directory exists. If LINKER, return 0 for
6527 certain fixed names not needed by the linker. */
6529 static int
6530 is_directory (const char *path1, bool linker)
6532 int len1;
6533 char *path;
6534 char *cp;
6535 struct stat st;
6537 /* Ensure the string ends with "/.". The resulting path will be a
6538 directory even if the given path is a symbolic link. */
6539 len1 = strlen (path1);
6540 path = (char *) alloca (3 + len1);
6541 memcpy (path, path1, len1);
6542 cp = path + len1;
6543 if (!IS_DIR_SEPARATOR (cp[-1]))
6544 *cp++ = DIR_SEPARATOR;
6545 *cp++ = '.';
6546 *cp = '\0';
6548 /* Exclude directories that the linker is known to search. */
6549 if (linker
6550 && IS_DIR_SEPARATOR (path[0])
6551 && ((cp - path == 6
6552 && filename_ncmp (path + 1, "lib", 3) == 0)
6553 || (cp - path == 10
6554 && filename_ncmp (path + 1, "usr", 3) == 0
6555 && IS_DIR_SEPARATOR (path[4])
6556 && filename_ncmp (path + 5, "lib", 3) == 0)))
6557 return 0;
6559 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
6562 /* Set up the various global variables to indicate that we're processing
6563 the input file named FILENAME. */
6565 void
6566 set_input (const char *filename)
6568 const char *p;
6570 gcc_input_filename = filename;
6571 input_filename_length = strlen (gcc_input_filename);
6572 input_basename = lbasename (gcc_input_filename);
6574 /* Find a suffix starting with the last period,
6575 and set basename_length to exclude that suffix. */
6576 basename_length = strlen (input_basename);
6577 suffixed_basename_length = basename_length;
6578 p = input_basename + basename_length;
6579 while (p != input_basename && *p != '.')
6580 --p;
6581 if (*p == '.' && p != input_basename)
6583 basename_length = p - input_basename;
6584 input_suffix = p + 1;
6586 else
6587 input_suffix = "";
6589 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6590 we will need to do a stat on the gcc_input_filename. The
6591 INPUT_STAT_SET signals that the stat is needed. */
6592 input_stat_set = 0;
6595 /* On fatal signals, delete all the temporary files. */
6597 static void
6598 fatal_signal (int signum)
6600 signal (signum, SIG_DFL);
6601 delete_failure_queue ();
6602 delete_temp_files ();
6603 /* Get the same signal again, this time not handled,
6604 so its normal effect occurs. */
6605 kill (getpid (), signum);
6608 /* Compare the contents of the two files named CMPFILE[0] and
6609 CMPFILE[1]. Return zero if they're identical, nonzero
6610 otherwise. */
6612 static int
6613 compare_files (char *cmpfile[])
6615 int ret = 0;
6616 FILE *temp[2] = { NULL, NULL };
6617 int i;
6619 #if HAVE_MMAP_FILE
6621 size_t length[2];
6622 void *map[2] = { NULL, NULL };
6624 for (i = 0; i < 2; i++)
6626 struct stat st;
6628 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
6630 error ("%s: could not determine length of compare-debug file %s",
6631 gcc_input_filename, cmpfile[i]);
6632 ret = 1;
6633 break;
6636 length[i] = st.st_size;
6639 if (!ret && length[0] != length[1])
6641 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
6642 ret = 1;
6645 if (!ret)
6646 for (i = 0; i < 2; i++)
6648 int fd = open (cmpfile[i], O_RDONLY);
6649 if (fd < 0)
6651 error ("%s: could not open compare-debug file %s",
6652 gcc_input_filename, cmpfile[i]);
6653 ret = 1;
6654 break;
6657 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
6658 close (fd);
6660 if (map[i] == (void *) MAP_FAILED)
6662 ret = -1;
6663 break;
6667 if (!ret)
6669 if (memcmp (map[0], map[1], length[0]) != 0)
6671 error ("%s: -fcompare-debug failure", gcc_input_filename);
6672 ret = 1;
6676 for (i = 0; i < 2; i++)
6677 if (map[i])
6678 munmap ((caddr_t) map[i], length[i]);
6680 if (ret >= 0)
6681 return ret;
6683 ret = 0;
6685 #endif
6687 for (i = 0; i < 2; i++)
6689 temp[i] = fopen (cmpfile[i], "r");
6690 if (!temp[i])
6692 error ("%s: could not open compare-debug file %s",
6693 gcc_input_filename, cmpfile[i]);
6694 ret = 1;
6695 break;
6699 if (!ret && temp[0] && temp[1])
6700 for (;;)
6702 int c0, c1;
6703 c0 = fgetc (temp[0]);
6704 c1 = fgetc (temp[1]);
6706 if (c0 != c1)
6708 error ("%s: -fcompare-debug failure",
6709 gcc_input_filename);
6710 ret = 1;
6711 break;
6714 if (c0 == EOF)
6715 break;
6718 for (i = 1; i >= 0; i--)
6720 if (temp[i])
6721 fclose (temp[i]);
6724 return ret;
6727 extern int main (int, char **);
6730 main (int argc, char **argv)
6732 size_t i;
6733 int value;
6734 int linker_was_run = 0;
6735 int lang_n_infiles = 0;
6736 int num_linker_inputs = 0;
6737 char *explicit_link_files;
6738 char *specs_file;
6739 char *lto_wrapper_file;
6740 const char *p;
6741 struct user_specs *uptr;
6742 char **old_argv = argv;
6743 struct cl_decoded_option *decoded_options;
6744 unsigned int decoded_options_count;
6746 p = argv[0] + strlen (argv[0]);
6747 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
6748 --p;
6749 progname = p;
6751 xmalloc_set_program_name (progname);
6753 expandargv (&argc, &argv);
6755 /* Determine if any expansions were made. */
6756 if (argv != old_argv)
6757 at_file_supplied = true;
6759 /* Register the language-independent parameters. */
6760 global_init_params ();
6761 finish_params ();
6763 init_options_struct (&global_options, &global_options_set);
6765 decode_cmdline_options_to_array (argc, CONST_CAST2 (const char **, char **,
6766 argv),
6767 CL_DRIVER,
6768 &decoded_options, &decoded_options_count);
6770 /* Unlock the stdio streams. */
6771 unlock_std_streams ();
6773 gcc_init_libintl ();
6775 diagnostic_initialize (global_dc, 0);
6777 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6778 /* Perform host dependent initialization when needed. */
6779 GCC_DRIVER_HOST_INITIALIZATION;
6780 #endif
6782 if (atexit (delete_temp_files) != 0)
6783 fatal_error ("atexit failed");
6785 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6786 signal (SIGINT, fatal_signal);
6787 #ifdef SIGHUP
6788 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6789 signal (SIGHUP, fatal_signal);
6790 #endif
6791 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6792 signal (SIGTERM, fatal_signal);
6793 #ifdef SIGPIPE
6794 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6795 signal (SIGPIPE, fatal_signal);
6796 #endif
6797 #ifdef SIGCHLD
6798 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6799 receive the signal. A different setting is inheritable */
6800 signal (SIGCHLD, SIG_DFL);
6801 #endif
6803 /* Parsing and gimplification sometimes need quite large stack.
6804 Increase stack size limits if possible. */
6805 stack_limit_increase (64 * 1024 * 1024);
6807 /* Allocate the argument vector. */
6808 alloc_args ();
6810 obstack_init (&obstack);
6812 /* Build multilib_select, et. al from the separate lines that make up each
6813 multilib selection. */
6815 const char *const *q = multilib_raw;
6816 int need_space;
6818 obstack_init (&multilib_obstack);
6819 while ((p = *q++) != (char *) 0)
6820 obstack_grow (&multilib_obstack, p, strlen (p));
6822 obstack_1grow (&multilib_obstack, 0);
6823 multilib_select = XOBFINISH (&multilib_obstack, const char *);
6825 q = multilib_matches_raw;
6826 while ((p = *q++) != (char *) 0)
6827 obstack_grow (&multilib_obstack, p, strlen (p));
6829 obstack_1grow (&multilib_obstack, 0);
6830 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
6832 q = multilib_exclusions_raw;
6833 while ((p = *q++) != (char *) 0)
6834 obstack_grow (&multilib_obstack, p, strlen (p));
6836 obstack_1grow (&multilib_obstack, 0);
6837 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
6839 q = multilib_reuse_raw;
6840 while ((p = *q++) != (char *) 0)
6841 obstack_grow (&multilib_obstack, p, strlen (p));
6843 obstack_1grow (&multilib_obstack, 0);
6844 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
6846 need_space = FALSE;
6847 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6849 if (need_space)
6850 obstack_1grow (&multilib_obstack, ' ');
6851 obstack_grow (&multilib_obstack,
6852 multilib_defaults_raw[i],
6853 strlen (multilib_defaults_raw[i]));
6854 need_space = TRUE;
6857 obstack_1grow (&multilib_obstack, 0);
6858 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
6861 #ifdef INIT_ENVIRONMENT
6862 /* Set up any other necessary machine specific environment variables. */
6863 xputenv (INIT_ENVIRONMENT);
6864 #endif
6866 /* Make a table of what switches there are (switches, n_switches).
6867 Make a table of specified input files (infiles, n_infiles).
6868 Decode switches that are handled locally. */
6870 process_command (decoded_options_count, decoded_options);
6872 /* Initialize the vector of specs to just the default.
6873 This means one element containing 0s, as a terminator. */
6875 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
6876 memcpy (compilers, default_compilers, sizeof default_compilers);
6877 n_compilers = n_default_compilers;
6879 /* Read specs from a file if there is one. */
6881 machine_suffix = concat (spec_machine, dir_separator_str,
6882 spec_version, dir_separator_str, NULL);
6883 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6885 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
6886 /* Read the specs file unless it is a default one. */
6887 if (specs_file != 0 && strcmp (specs_file, "specs"))
6888 read_specs (specs_file, true, false);
6889 else
6890 init_spec ();
6892 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6893 for any override of as, ld and libraries. */
6894 specs_file = (char *) alloca (strlen (standard_exec_prefix)
6895 + strlen (just_machine_suffix) + sizeof ("specs"));
6897 strcpy (specs_file, standard_exec_prefix);
6898 strcat (specs_file, just_machine_suffix);
6899 strcat (specs_file, "specs");
6900 if (access (specs_file, R_OK) == 0)
6901 read_specs (specs_file, true, false);
6903 /* Process any configure-time defaults specified for the command line
6904 options, via OPTION_DEFAULT_SPECS. */
6905 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6906 do_option_spec (option_default_specs[i].name,
6907 option_default_specs[i].spec);
6909 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6910 of the command line. */
6912 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6913 do_self_spec (driver_self_specs[i]);
6915 /* If not cross-compiling, look for executables in the standard
6916 places. */
6917 if (*cross_compile == '0')
6919 if (*md_exec_prefix)
6921 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6922 PREFIX_PRIORITY_LAST, 0, 0);
6926 /* Process sysroot_suffix_spec. */
6927 if (*sysroot_suffix_spec != 0
6928 && !no_sysroot_suffix
6929 && do_spec_2 (sysroot_suffix_spec) == 0)
6931 if (argbuf.length () > 1)
6932 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
6933 else if (argbuf.length () == 1)
6934 target_sysroot_suffix = xstrdup (argbuf.last ());
6937 #ifdef HAVE_LD_SYSROOT
6938 /* Pass the --sysroot option to the linker, if it supports that. If
6939 there is a sysroot_suffix_spec, it has already been processed by
6940 this point, so target_system_root really is the system root we
6941 should be using. */
6942 if (target_system_root)
6944 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
6945 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
6946 set_spec ("link", XOBFINISH (&obstack, const char *), false);
6948 #endif
6950 /* Process sysroot_hdrs_suffix_spec. */
6951 if (*sysroot_hdrs_suffix_spec != 0
6952 && !no_sysroot_suffix
6953 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6955 if (argbuf.length () > 1)
6956 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
6957 else if (argbuf.length () == 1)
6958 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
6961 /* Look for startfiles in the standard places. */
6962 if (*startfile_prefix_spec != 0
6963 && do_spec_2 (startfile_prefix_spec) == 0
6964 && do_spec_1 (" ", 0, NULL) == 0)
6966 const char *arg;
6967 int ndx;
6968 FOR_EACH_VEC_ELT (argbuf, ndx, arg)
6969 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
6970 PREFIX_PRIORITY_LAST, 0, 1);
6972 /* We should eventually get rid of all these and stick to
6973 startfile_prefix_spec exclusively. */
6974 else if (*cross_compile == '0' || target_system_root)
6976 if (*md_startfile_prefix)
6977 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6978 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6980 if (*md_startfile_prefix_1)
6981 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6982 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6984 /* If standard_startfile_prefix is relative, base it on
6985 standard_exec_prefix. This lets us move the installed tree
6986 as a unit. If GCC_EXEC_PREFIX is defined, base
6987 standard_startfile_prefix on that as well.
6989 If the prefix is relative, only search it for native compilers;
6990 otherwise we will search a directory containing host libraries. */
6991 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6992 add_sysrooted_prefix (&startfile_prefixes,
6993 standard_startfile_prefix, "BINUTILS",
6994 PREFIX_PRIORITY_LAST, 0, 1);
6995 else if (*cross_compile == '0')
6997 add_prefix (&startfile_prefixes,
6998 concat (gcc_exec_prefix
6999 ? gcc_exec_prefix : standard_exec_prefix,
7000 machine_suffix,
7001 standard_startfile_prefix, NULL),
7002 NULL, PREFIX_PRIORITY_LAST, 0, 1);
7005 /* Sysrooted prefixes are relocated because target_system_root is
7006 also relocated by gcc_exec_prefix. */
7007 if (*standard_startfile_prefix_1)
7008 add_sysrooted_prefix (&startfile_prefixes,
7009 standard_startfile_prefix_1, "BINUTILS",
7010 PREFIX_PRIORITY_LAST, 0, 1);
7011 if (*standard_startfile_prefix_2)
7012 add_sysrooted_prefix (&startfile_prefixes,
7013 standard_startfile_prefix_2, "BINUTILS",
7014 PREFIX_PRIORITY_LAST, 0, 1);
7017 /* Process any user specified specs in the order given on the command
7018 line. */
7019 for (uptr = user_specs_head; uptr; uptr = uptr->next)
7021 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
7022 R_OK, true);
7023 read_specs (filename ? filename : uptr->filename, false, true);
7026 /* Process any user self specs. */
7028 struct spec_list *sl;
7029 for (sl = specs; sl; sl = sl->next)
7030 if (sl->name_len == sizeof "self_spec" - 1
7031 && !strcmp (sl->name, "self_spec"))
7032 do_self_spec (*sl->ptr_spec);
7035 if (compare_debug)
7037 enum save_temps save;
7039 if (!compare_debug_second)
7041 n_switches_debug_check[1] = n_switches;
7042 n_switches_alloc_debug_check[1] = n_switches_alloc;
7043 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
7044 n_switches_alloc);
7046 do_self_spec ("%:compare-debug-self-opt()");
7047 n_switches_debug_check[0] = n_switches;
7048 n_switches_alloc_debug_check[0] = n_switches_alloc;
7049 switches_debug_check[0] = switches;
7051 n_switches = n_switches_debug_check[1];
7052 n_switches_alloc = n_switches_alloc_debug_check[1];
7053 switches = switches_debug_check[1];
7056 /* Avoid crash when computing %j in this early. */
7057 save = save_temps_flag;
7058 save_temps_flag = SAVE_TEMPS_NONE;
7060 compare_debug = -compare_debug;
7061 do_self_spec ("%:compare-debug-self-opt()");
7063 save_temps_flag = save;
7065 if (!compare_debug_second)
7067 n_switches_debug_check[1] = n_switches;
7068 n_switches_alloc_debug_check[1] = n_switches_alloc;
7069 switches_debug_check[1] = switches;
7070 compare_debug = -compare_debug;
7071 n_switches = n_switches_debug_check[0];
7072 n_switches_alloc = n_switches_debug_check[0];
7073 switches = switches_debug_check[0];
7078 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
7079 if (gcc_exec_prefix)
7080 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
7081 spec_version, dir_separator_str, NULL);
7083 /* Now we have the specs.
7084 Set the `valid' bits for switches that match anything in any spec. */
7086 validate_all_switches ();
7088 /* Now that we have the switches and the specs, set
7089 the subdirectory based on the options. */
7090 set_multilib_dir ();
7092 /* Set up to remember the pathname of gcc and any options
7093 needed for collect. We use argv[0] instead of progname because
7094 we need the complete pathname. */
7095 obstack_init (&collect_obstack);
7096 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
7097 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
7098 xputenv (XOBFINISH (&collect_obstack, char *));
7100 /* Set up to remember the pathname of the lto wrapper. */
7102 if (have_c)
7103 lto_wrapper_file = NULL;
7104 else
7105 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
7106 X_OK, false);
7107 if (lto_wrapper_file)
7109 lto_wrapper_file = convert_white_space (lto_wrapper_file);
7110 lto_wrapper_spec = lto_wrapper_file;
7111 obstack_init (&collect_obstack);
7112 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
7113 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
7114 obstack_grow (&collect_obstack, lto_wrapper_spec,
7115 strlen (lto_wrapper_spec) + 1);
7116 xputenv (XOBFINISH (&collect_obstack, char *));
7119 /* Reject switches that no pass was interested in. */
7121 for (i = 0; (int) i < n_switches; i++)
7122 if (! switches[i].validated)
7123 error ("unrecognized command line option %<-%s%>", switches[i].part1);
7125 /* Obey some of the options. */
7127 if (print_search_dirs)
7129 printf (_("install: %s%s\n"),
7130 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
7131 gcc_exec_prefix ? "" : machine_suffix);
7132 printf (_("programs: %s\n"),
7133 build_search_list (&exec_prefixes, "", false, false));
7134 printf (_("libraries: %s\n"),
7135 build_search_list (&startfile_prefixes, "", false, true));
7136 return (0);
7139 if (print_file_name)
7141 printf ("%s\n", find_file (print_file_name));
7142 return (0);
7145 if (print_prog_name)
7147 if (use_ld != NULL && ! strcmp (print_prog_name, "ld"))
7149 /* Append USE_LD to to the default linker. */
7150 #ifdef DEFAULT_LINKER
7151 char *ld;
7152 # ifdef HAVE_HOST_EXECUTABLE_SUFFIX
7153 int len = (sizeof (DEFAULT_LINKER)
7154 - sizeof (HOST_EXECUTABLE_SUFFIX));
7155 ld = NULL;
7156 if (len > 0)
7158 char *default_linker = xstrdup (DEFAULT_LINKER);
7159 /* Strip HOST_EXECUTABLE_SUFFIX if DEFAULT_LINKER contains
7160 HOST_EXECUTABLE_SUFFIX. */
7161 if (! strcmp (&default_linker[len], HOST_EXECUTABLE_SUFFIX))
7163 default_linker[len] = '\0';
7164 ld = concat (default_linker, use_ld,
7165 HOST_EXECUTABLE_SUFFIX, NULL);
7168 if (ld == NULL)
7169 # endif
7170 ld = concat (DEFAULT_LINKER, use_ld, NULL);
7171 if (access (ld, X_OK) == 0)
7173 printf ("%s\n", ld);
7174 return (0);
7176 #endif
7177 print_prog_name = concat (print_prog_name, use_ld, NULL);
7179 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
7180 printf ("%s\n", (newname ? newname : print_prog_name));
7181 return (0);
7184 if (print_multi_lib)
7186 print_multilib_info ();
7187 return (0);
7190 if (print_multi_directory)
7192 if (multilib_dir == NULL)
7193 printf (".\n");
7194 else
7195 printf ("%s\n", multilib_dir);
7196 return (0);
7199 if (print_multiarch)
7201 if (multiarch_dir == NULL)
7202 printf ("\n");
7203 else
7204 printf ("%s\n", multiarch_dir);
7205 return (0);
7208 if (print_sysroot)
7210 if (target_system_root)
7212 if (target_sysroot_suffix)
7213 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
7214 else
7215 printf ("%s\n", target_system_root);
7217 return (0);
7220 if (print_multi_os_directory)
7222 if (multilib_os_dir == NULL)
7223 printf (".\n");
7224 else
7225 printf ("%s\n", multilib_os_dir);
7226 return (0);
7229 if (print_sysroot_headers_suffix)
7231 if (*sysroot_hdrs_suffix_spec)
7233 printf("%s\n", (target_sysroot_hdrs_suffix
7234 ? target_sysroot_hdrs_suffix
7235 : ""));
7236 return (0);
7238 else
7239 /* The error status indicates that only one set of fixed
7240 headers should be built. */
7241 fatal_error ("not configured with sysroot headers suffix");
7244 if (print_help_list)
7246 display_help ();
7248 if (! verbose_flag)
7250 printf (_("\nFor bug reporting instructions, please see:\n"));
7251 printf ("%s.\n", bug_report_url);
7253 return (0);
7256 /* We do not exit here. Instead we have created a fake input file
7257 called 'help-dummy' which needs to be compiled, and we pass this
7258 on the various sub-processes, along with the --help switch.
7259 Ensure their output appears after ours. */
7260 fputc ('\n', stdout);
7261 fflush (stdout);
7264 if (print_version)
7266 printf (_("%s %s%s\n"), progname, pkgversion_string,
7267 version_string);
7268 printf ("Copyright %s 2014 Free Software Foundation, Inc.\n",
7269 _("(C)"));
7270 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
7271 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
7272 stdout);
7273 if (! verbose_flag)
7274 return 0;
7276 /* We do not exit here. We use the same mechanism of --help to print
7277 the version of the sub-processes. */
7278 fputc ('\n', stdout);
7279 fflush (stdout);
7282 if (verbose_flag)
7284 print_configuration (stderr);
7285 if (n_infiles == 0)
7286 return (0);
7289 if (n_infiles == added_libraries)
7290 fatal_error ("no input files");
7292 if (seen_error ())
7293 goto out;
7295 /* Make a place to record the compiler output file names
7296 that correspond to the input files. */
7298 i = n_infiles;
7299 i += lang_specific_extra_outfiles;
7300 outfiles = XCNEWVEC (const char *, i);
7302 /* Record which files were specified explicitly as link input. */
7304 explicit_link_files = XCNEWVEC (char, n_infiles);
7306 combine_inputs = have_o || flag_wpa;
7308 for (i = 0; (int) i < n_infiles; i++)
7310 const char *name = infiles[i].name;
7311 struct compiler *compiler = lookup_compiler (name,
7312 strlen (name),
7313 infiles[i].language);
7315 if (compiler && !(compiler->combinable))
7316 combine_inputs = false;
7318 if (lang_n_infiles > 0 && compiler != input_file_compiler
7319 && infiles[i].language && infiles[i].language[0] != '*')
7320 infiles[i].incompiler = compiler;
7321 else if (compiler)
7323 lang_n_infiles++;
7324 input_file_compiler = compiler;
7325 infiles[i].incompiler = compiler;
7327 else
7329 /* Since there is no compiler for this input file, assume it is a
7330 linker file. */
7331 explicit_link_files[i] = 1;
7332 infiles[i].incompiler = NULL;
7334 infiles[i].compiled = false;
7335 infiles[i].preprocessed = false;
7338 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
7339 fatal_error ("cannot specify -o with -c, -S or -E with multiple files");
7341 for (i = 0; (int) i < n_infiles; i++)
7343 int this_file_error = 0;
7345 /* Tell do_spec what to substitute for %i. */
7347 input_file_number = i;
7348 set_input (infiles[i].name);
7350 if (infiles[i].compiled)
7351 continue;
7353 /* Use the same thing in %o, unless cp->spec says otherwise. */
7355 outfiles[i] = gcc_input_filename;
7357 /* Figure out which compiler from the file's suffix. */
7359 input_file_compiler
7360 = lookup_compiler (infiles[i].name, input_filename_length,
7361 infiles[i].language);
7363 if (input_file_compiler)
7365 /* Ok, we found an applicable compiler. Run its spec. */
7367 if (input_file_compiler->spec[0] == '#')
7369 error ("%s: %s compiler not installed on this system",
7370 gcc_input_filename, &input_file_compiler->spec[1]);
7371 this_file_error = 1;
7373 else
7375 if (compare_debug)
7377 free (debug_check_temp_file[0]);
7378 debug_check_temp_file[0] = NULL;
7380 free (debug_check_temp_file[1]);
7381 debug_check_temp_file[1] = NULL;
7384 value = do_spec (input_file_compiler->spec);
7385 infiles[i].compiled = true;
7386 if (value < 0)
7387 this_file_error = 1;
7388 else if (compare_debug && debug_check_temp_file[0])
7390 if (verbose_flag)
7391 inform (0, "recompiling with -fcompare-debug");
7393 compare_debug = -compare_debug;
7394 n_switches = n_switches_debug_check[1];
7395 n_switches_alloc = n_switches_alloc_debug_check[1];
7396 switches = switches_debug_check[1];
7398 value = do_spec (input_file_compiler->spec);
7400 compare_debug = -compare_debug;
7401 n_switches = n_switches_debug_check[0];
7402 n_switches_alloc = n_switches_alloc_debug_check[0];
7403 switches = switches_debug_check[0];
7405 if (value < 0)
7407 error ("during -fcompare-debug recompilation");
7408 this_file_error = 1;
7411 gcc_assert (debug_check_temp_file[1]
7412 && filename_cmp (debug_check_temp_file[0],
7413 debug_check_temp_file[1]));
7415 if (verbose_flag)
7416 inform (0, "comparing final insns dumps");
7418 if (compare_files (debug_check_temp_file))
7419 this_file_error = 1;
7422 if (compare_debug)
7424 free (debug_check_temp_file[0]);
7425 debug_check_temp_file[0] = NULL;
7427 free (debug_check_temp_file[1]);
7428 debug_check_temp_file[1] = NULL;
7433 /* If this file's name does not contain a recognized suffix,
7434 record it as explicit linker input. */
7436 else
7437 explicit_link_files[i] = 1;
7439 /* Clear the delete-on-failure queue, deleting the files in it
7440 if this compilation failed. */
7442 if (this_file_error)
7444 delete_failure_queue ();
7445 errorcount++;
7447 /* If this compilation succeeded, don't delete those files later. */
7448 clear_failure_queue ();
7451 /* Reset the input file name to the first compile/object file name, for use
7452 with %b in LINK_SPEC. We use the first input file that we can find
7453 a compiler to compile it instead of using infiles.language since for
7454 languages other than C we use aliases that we then lookup later. */
7455 if (n_infiles > 0)
7457 int i;
7459 for (i = 0; i < n_infiles ; i++)
7460 if (infiles[i].incompiler
7461 || (infiles[i].language && infiles[i].language[0] != '*'))
7463 set_input (infiles[i].name);
7464 break;
7468 if (!seen_error ())
7470 /* Make sure INPUT_FILE_NUMBER points to first available open
7471 slot. */
7472 input_file_number = n_infiles;
7473 if (lang_specific_pre_link ())
7474 errorcount++;
7477 /* Determine if there are any linker input files. */
7478 num_linker_inputs = 0;
7479 for (i = 0; (int) i < n_infiles; i++)
7480 if (explicit_link_files[i] || outfiles[i] != NULL)
7481 num_linker_inputs++;
7483 /* Run ld to link all the compiler output files. */
7485 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
7487 int tmp = execution_count;
7489 if (! have_c)
7491 #if HAVE_LTO_PLUGIN > 0
7492 #if HAVE_LTO_PLUGIN == 2
7493 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
7494 #else
7495 const char *fuse_linker_plugin = "fuse-linker-plugin";
7496 #endif
7497 #endif
7499 /* We'll use ld if we can't find collect2. */
7500 if (! strcmp (linker_name_spec, "collect2"))
7502 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
7503 if (s == NULL)
7504 linker_name_spec = "ld";
7507 #if HAVE_LTO_PLUGIN > 0
7508 #if HAVE_LTO_PLUGIN == 2
7509 if (!switch_matches (fno_use_linker_plugin,
7510 fno_use_linker_plugin
7511 + strlen (fno_use_linker_plugin), 0))
7512 #else
7513 if (switch_matches (fuse_linker_plugin,
7514 fuse_linker_plugin
7515 + strlen (fuse_linker_plugin), 0))
7516 #endif
7518 char *temp_spec = find_a_file (&exec_prefixes,
7519 LTOPLUGINSONAME, R_OK,
7520 false);
7521 if (!temp_spec)
7522 fatal_error ("-fuse-linker-plugin, but %s not found",
7523 LTOPLUGINSONAME);
7524 linker_plugin_file_spec = convert_white_space (temp_spec);
7526 #endif
7527 lto_gcc_spec = argv[0];
7530 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
7531 for collect. */
7532 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
7533 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
7535 if (print_subprocess_help == 1)
7537 printf (_("\nLinker options\n==============\n\n"));
7538 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
7539 " to the linker.\n\n"));
7540 fflush (stdout);
7542 value = do_spec (link_command_spec);
7543 if (value < 0)
7544 errorcount = 1;
7545 linker_was_run = (tmp != execution_count);
7548 /* If options said don't run linker,
7549 complain about input files to be given to the linker. */
7551 if (! linker_was_run && !seen_error ())
7552 for (i = 0; (int) i < n_infiles; i++)
7553 if (explicit_link_files[i]
7554 && !(infiles[i].language && infiles[i].language[0] == '*'))
7555 warning (0, "%s: linker input file unused because linking not done",
7556 outfiles[i]);
7558 /* Delete some or all of the temporary files we made. */
7560 if (seen_error ())
7561 delete_failure_queue ();
7562 delete_temp_files ();
7564 if (print_help_list)
7566 printf (("\nFor bug reporting instructions, please see:\n"));
7567 printf ("%s\n", bug_report_url);
7570 out:
7571 return (signal_count != 0 ? 2
7572 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
7573 : 0);
7576 /* Find the proper compilation spec for the file name NAME,
7577 whose length is LENGTH. LANGUAGE is the specified language,
7578 or 0 if this file is to be passed to the linker. */
7580 static struct compiler *
7581 lookup_compiler (const char *name, size_t length, const char *language)
7583 struct compiler *cp;
7585 /* If this was specified by the user to be a linker input, indicate that. */
7586 if (language != 0 && language[0] == '*')
7587 return 0;
7589 /* Otherwise, look for the language, if one is spec'd. */
7590 if (language != 0)
7592 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7593 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
7594 return cp;
7596 error ("language %s not recognized", language);
7597 return 0;
7600 /* Look for a suffix. */
7601 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7603 if (/* The suffix `-' matches only the file name `-'. */
7604 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7605 || (strlen (cp->suffix) < length
7606 /* See if the suffix matches the end of NAME. */
7607 && !strcmp (cp->suffix,
7608 name + length - strlen (cp->suffix))
7610 break;
7613 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
7614 /* Look again, but case-insensitively this time. */
7615 if (cp < compilers)
7616 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7618 if (/* The suffix `-' matches only the file name `-'. */
7619 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7620 || (strlen (cp->suffix) < length
7621 /* See if the suffix matches the end of NAME. */
7622 && ((!strcmp (cp->suffix,
7623 name + length - strlen (cp->suffix))
7624 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
7625 && !strcasecmp (cp->suffix,
7626 name + length - strlen (cp->suffix)))
7628 break;
7630 #endif
7632 if (cp >= compilers)
7634 if (cp->spec[0] != '@')
7635 /* A non-alias entry: return it. */
7636 return cp;
7638 /* An alias entry maps a suffix to a language.
7639 Search for the language; pass 0 for NAME and LENGTH
7640 to avoid infinite recursion if language not found. */
7641 return lookup_compiler (NULL, 0, cp->spec + 1);
7643 return 0;
7646 static char *
7647 save_string (const char *s, int len)
7649 char *result = XNEWVEC (char, len + 1);
7651 memcpy (result, s, len);
7652 result[len] = 0;
7653 return result;
7656 void
7657 pfatal_with_name (const char *name)
7659 perror_with_name (name);
7660 delete_temp_files ();
7661 exit (1);
7664 static void
7665 perror_with_name (const char *name)
7667 error ("%s: %m", name);
7670 static inline void
7671 validate_switches_from_spec (const char *spec, bool user)
7673 const char *p = spec;
7674 char c;
7675 while ((c = *p++))
7676 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
7677 /* We have a switch spec. */
7678 p = validate_switches (p + 1, user);
7681 static void
7682 validate_all_switches (void)
7684 struct compiler *comp;
7685 struct spec_list *spec;
7687 for (comp = compilers; comp->spec; comp++)
7688 validate_switches_from_spec (comp->spec, false);
7690 /* Look through the linked list of specs read from the specs file. */
7691 for (spec = specs; spec; spec = spec->next)
7692 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
7694 validate_switches_from_spec (link_command_spec, false);
7697 /* Look at the switch-name that comes after START
7698 and mark as valid all supplied switches that match it. */
7700 static const char *
7701 validate_switches (const char *start, bool user_spec)
7703 const char *p = start;
7704 const char *atom;
7705 size_t len;
7706 int i;
7707 bool suffix = false;
7708 bool starred = false;
7710 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
7712 next_member:
7713 SKIP_WHITE ();
7715 if (*p == '!')
7716 p++;
7718 SKIP_WHITE ();
7719 if (*p == '.' || *p == ',')
7720 suffix = true, p++;
7722 atom = p;
7723 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
7724 || *p == ',' || *p == '.' || *p == '@')
7725 p++;
7726 len = p - atom;
7728 if (*p == '*')
7729 starred = true, p++;
7731 SKIP_WHITE ();
7733 if (!suffix)
7735 /* Mark all matching switches as valid. */
7736 for (i = 0; i < n_switches; i++)
7737 if (!strncmp (switches[i].part1, atom, len)
7738 && (starred || switches[i].part1[len] == '\0')
7739 && (switches[i].known || user_spec))
7740 switches[i].validated = true;
7743 if (*p) p++;
7744 if (*p && (p[-1] == '|' || p[-1] == '&'))
7745 goto next_member;
7747 if (*p && p[-1] == ':')
7749 while (*p && *p != ';' && *p != '}')
7751 if (*p == '%')
7753 p++;
7754 if (*p == '{' || *p == '<')
7755 p = validate_switches (p+1, user_spec);
7756 else if (p[0] == 'W' && p[1] == '{')
7757 p = validate_switches (p+2, user_spec);
7759 else
7760 p++;
7763 if (*p) p++;
7764 if (*p && p[-1] == ';')
7765 goto next_member;
7768 return p;
7769 #undef SKIP_WHITE
7772 struct mdswitchstr
7774 const char *str;
7775 int len;
7778 static struct mdswitchstr *mdswitches;
7779 static int n_mdswitches;
7781 /* Check whether a particular argument was used. The first time we
7782 canonicalize the switches to keep only the ones we care about. */
7784 static int
7785 used_arg (const char *p, int len)
7787 struct mswitchstr
7789 const char *str;
7790 const char *replace;
7791 int len;
7792 int rep_len;
7795 static struct mswitchstr *mswitches;
7796 static int n_mswitches;
7797 int i, j;
7799 if (!mswitches)
7801 struct mswitchstr *matches;
7802 const char *q;
7803 int cnt = 0;
7805 /* Break multilib_matches into the component strings of string
7806 and replacement string. */
7807 for (q = multilib_matches; *q != '\0'; q++)
7808 if (*q == ';')
7809 cnt++;
7811 matches
7812 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
7813 i = 0;
7814 q = multilib_matches;
7815 while (*q != '\0')
7817 matches[i].str = q;
7818 while (*q != ' ')
7820 if (*q == '\0')
7822 invalid_matches:
7823 fatal_error ("multilib spec %qs is invalid",
7824 multilib_matches);
7826 q++;
7828 matches[i].len = q - matches[i].str;
7830 matches[i].replace = ++q;
7831 while (*q != ';' && *q != '\0')
7833 if (*q == ' ')
7834 goto invalid_matches;
7835 q++;
7837 matches[i].rep_len = q - matches[i].replace;
7838 i++;
7839 if (*q == ';')
7840 q++;
7843 /* Now build a list of the replacement string for switches that we care
7844 about. Make sure we allocate at least one entry. This prevents
7845 xmalloc from calling fatal, and prevents us from re-executing this
7846 block of code. */
7847 mswitches
7848 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
7849 for (i = 0; i < n_switches; i++)
7850 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
7852 int xlen = strlen (switches[i].part1);
7853 for (j = 0; j < cnt; j++)
7854 if (xlen == matches[j].len
7855 && ! strncmp (switches[i].part1, matches[j].str, xlen))
7857 mswitches[n_mswitches].str = matches[j].replace;
7858 mswitches[n_mswitches].len = matches[j].rep_len;
7859 mswitches[n_mswitches].replace = (char *) 0;
7860 mswitches[n_mswitches].rep_len = 0;
7861 n_mswitches++;
7862 break;
7866 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
7867 on the command line nor any options mutually incompatible with
7868 them. */
7869 for (i = 0; i < n_mdswitches; i++)
7871 const char *r;
7873 for (q = multilib_options; *q != '\0'; *q && q++)
7875 while (*q == ' ')
7876 q++;
7878 r = q;
7879 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
7880 || strchr (" /", q[mdswitches[i].len]) == NULL)
7882 while (*q != ' ' && *q != '/' && *q != '\0')
7883 q++;
7884 if (*q != '/')
7885 break;
7886 q++;
7889 if (*q != ' ' && *q != '\0')
7891 while (*r != ' ' && *r != '\0')
7893 q = r;
7894 while (*q != ' ' && *q != '/' && *q != '\0')
7895 q++;
7897 if (used_arg (r, q - r))
7898 break;
7900 if (*q != '/')
7902 mswitches[n_mswitches].str = mdswitches[i].str;
7903 mswitches[n_mswitches].len = mdswitches[i].len;
7904 mswitches[n_mswitches].replace = (char *) 0;
7905 mswitches[n_mswitches].rep_len = 0;
7906 n_mswitches++;
7907 break;
7910 r = q + 1;
7912 break;
7918 for (i = 0; i < n_mswitches; i++)
7919 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7920 return 1;
7922 return 0;
7925 static int
7926 default_arg (const char *p, int len)
7928 int i;
7930 for (i = 0; i < n_mdswitches; i++)
7931 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7932 return 1;
7934 return 0;
7937 /* Work out the subdirectory to use based on the options. The format of
7938 multilib_select is a list of elements. Each element is a subdirectory
7939 name followed by a list of options followed by a semicolon. The format
7940 of multilib_exclusions is the same, but without the preceding
7941 directory. First gcc will check the exclusions, if none of the options
7942 beginning with an exclamation point are present, and all of the other
7943 options are present, then we will ignore this completely. Passing
7944 that, gcc will consider each multilib_select in turn using the same
7945 rules for matching the options. If a match is found, that subdirectory
7946 will be used.
7947 A subdirectory name is optionally followed by a colon and the corresponding
7948 multiarch name. */
7950 static void
7951 set_multilib_dir (void)
7953 const char *p;
7954 unsigned int this_path_len;
7955 const char *this_path, *this_arg;
7956 const char *start, *end;
7957 int not_arg;
7958 int ok, ndfltok, first;
7960 n_mdswitches = 0;
7961 start = multilib_defaults;
7962 while (*start == ' ' || *start == '\t')
7963 start++;
7964 while (*start != '\0')
7966 n_mdswitches++;
7967 while (*start != ' ' && *start != '\t' && *start != '\0')
7968 start++;
7969 while (*start == ' ' || *start == '\t')
7970 start++;
7973 if (n_mdswitches)
7975 int i = 0;
7977 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
7978 for (start = multilib_defaults; *start != '\0'; start = end + 1)
7980 while (*start == ' ' || *start == '\t')
7981 start++;
7983 if (*start == '\0')
7984 break;
7986 for (end = start + 1;
7987 *end != ' ' && *end != '\t' && *end != '\0'; end++)
7990 obstack_grow (&multilib_obstack, start, end - start);
7991 obstack_1grow (&multilib_obstack, 0);
7992 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
7993 mdswitches[i++].len = end - start;
7995 if (*end == '\0')
7996 break;
8000 p = multilib_exclusions;
8001 while (*p != '\0')
8003 /* Ignore newlines. */
8004 if (*p == '\n')
8006 ++p;
8007 continue;
8010 /* Check the arguments. */
8011 ok = 1;
8012 while (*p != ';')
8014 if (*p == '\0')
8016 invalid_exclusions:
8017 fatal_error ("multilib exclusions %qs is invalid",
8018 multilib_exclusions);
8021 if (! ok)
8023 ++p;
8024 continue;
8027 this_arg = p;
8028 while (*p != ' ' && *p != ';')
8030 if (*p == '\0')
8031 goto invalid_exclusions;
8032 ++p;
8035 if (*this_arg != '!')
8036 not_arg = 0;
8037 else
8039 not_arg = 1;
8040 ++this_arg;
8043 ok = used_arg (this_arg, p - this_arg);
8044 if (not_arg)
8045 ok = ! ok;
8047 if (*p == ' ')
8048 ++p;
8051 if (ok)
8052 return;
8054 ++p;
8057 first = 1;
8058 p = multilib_select;
8060 /* Append multilib reuse rules if any. With those rules, we can reuse
8061 one multilib for certain different options sets. */
8062 if (strlen (multilib_reuse) > 0)
8063 p = concat (p, multilib_reuse, NULL);
8065 while (*p != '\0')
8067 /* Ignore newlines. */
8068 if (*p == '\n')
8070 ++p;
8071 continue;
8074 /* Get the initial path. */
8075 this_path = p;
8076 while (*p != ' ')
8078 if (*p == '\0')
8080 invalid_select:
8081 fatal_error ("multilib select %qs %qs is invalid",
8082 multilib_select, multilib_reuse);
8084 ++p;
8086 this_path_len = p - this_path;
8088 /* Check the arguments. */
8089 ok = 1;
8090 ndfltok = 1;
8091 ++p;
8092 while (*p != ';')
8094 if (*p == '\0')
8095 goto invalid_select;
8097 if (! ok)
8099 ++p;
8100 continue;
8103 this_arg = p;
8104 while (*p != ' ' && *p != ';')
8106 if (*p == '\0')
8107 goto invalid_select;
8108 ++p;
8111 if (*this_arg != '!')
8112 not_arg = 0;
8113 else
8115 not_arg = 1;
8116 ++this_arg;
8119 /* If this is a default argument, we can just ignore it.
8120 This is true even if this_arg begins with '!'. Beginning
8121 with '!' does not mean that this argument is necessarily
8122 inappropriate for this library: it merely means that
8123 there is a more specific library which uses this
8124 argument. If this argument is a default, we need not
8125 consider that more specific library. */
8126 ok = used_arg (this_arg, p - this_arg);
8127 if (not_arg)
8128 ok = ! ok;
8130 if (! ok)
8131 ndfltok = 0;
8133 if (default_arg (this_arg, p - this_arg))
8134 ok = 1;
8136 if (*p == ' ')
8137 ++p;
8140 if (ok && first)
8142 if (this_path_len != 1
8143 || this_path[0] != '.')
8145 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
8146 char *q;
8148 strncpy (new_multilib_dir, this_path, this_path_len);
8149 new_multilib_dir[this_path_len] = '\0';
8150 q = strchr (new_multilib_dir, ':');
8151 if (q != NULL)
8152 *q = '\0';
8153 multilib_dir = new_multilib_dir;
8155 first = 0;
8158 if (ndfltok)
8160 const char *q = this_path, *end = this_path + this_path_len;
8162 while (q < end && *q != ':')
8163 q++;
8164 if (q < end)
8166 const char *q2 = q + 1, *ml_end = end;
8167 char *new_multilib_os_dir;
8169 while (q2 < end && *q2 != ':')
8170 q2++;
8171 if (*q2 == ':')
8172 ml_end = q2;
8173 if (ml_end - q == 1)
8174 multilib_os_dir = xstrdup (".");
8175 else
8177 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
8178 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
8179 new_multilib_os_dir[ml_end - q - 1] = '\0';
8180 multilib_os_dir = new_multilib_os_dir;
8183 if (q2 < end && *q2 == ':')
8185 char *new_multiarch_dir = XNEWVEC (char, end - q2);
8186 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
8187 new_multiarch_dir[end - q2 - 1] = '\0';
8188 multiarch_dir = new_multiarch_dir;
8190 break;
8194 ++p;
8197 if (multilib_dir == NULL && multilib_os_dir != NULL
8198 && strcmp (multilib_os_dir, ".") == 0)
8200 free (CONST_CAST (char *, multilib_os_dir));
8201 multilib_os_dir = NULL;
8203 else if (multilib_dir != NULL && multilib_os_dir == NULL)
8204 multilib_os_dir = multilib_dir;
8207 /* Print out the multiple library subdirectory selection
8208 information. This prints out a series of lines. Each line looks
8209 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
8210 required. Only the desired options are printed out, the negative
8211 matches. The options are print without a leading dash. There are
8212 no spaces to make it easy to use the information in the shell.
8213 Each subdirectory is printed only once. This assumes the ordering
8214 generated by the genmultilib script. Also, we leave out ones that match
8215 the exclusions. */
8217 static void
8218 print_multilib_info (void)
8220 const char *p = multilib_select;
8221 const char *last_path = 0, *this_path;
8222 int skip;
8223 unsigned int last_path_len = 0;
8225 while (*p != '\0')
8227 skip = 0;
8228 /* Ignore newlines. */
8229 if (*p == '\n')
8231 ++p;
8232 continue;
8235 /* Get the initial path. */
8236 this_path = p;
8237 while (*p != ' ')
8239 if (*p == '\0')
8241 invalid_select:
8242 fatal_error ("multilib select %qs is invalid", multilib_select);
8245 ++p;
8248 /* When --disable-multilib was used but target defines
8249 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
8250 with .:: for multiarch configurations) are there just to find
8251 multilib_os_dir, so skip them from output. */
8252 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
8253 skip = 1;
8255 /* Check for matches with the multilib_exclusions. We don't bother
8256 with the '!' in either list. If any of the exclusion rules match
8257 all of its options with the select rule, we skip it. */
8259 const char *e = multilib_exclusions;
8260 const char *this_arg;
8262 while (*e != '\0')
8264 int m = 1;
8265 /* Ignore newlines. */
8266 if (*e == '\n')
8268 ++e;
8269 continue;
8272 /* Check the arguments. */
8273 while (*e != ';')
8275 const char *q;
8276 int mp = 0;
8278 if (*e == '\0')
8280 invalid_exclusion:
8281 fatal_error ("multilib exclusion %qs is invalid",
8282 multilib_exclusions);
8285 if (! m)
8287 ++e;
8288 continue;
8291 this_arg = e;
8293 while (*e != ' ' && *e != ';')
8295 if (*e == '\0')
8296 goto invalid_exclusion;
8297 ++e;
8300 q = p + 1;
8301 while (*q != ';')
8303 const char *arg;
8304 int len = e - this_arg;
8306 if (*q == '\0')
8307 goto invalid_select;
8309 arg = q;
8311 while (*q != ' ' && *q != ';')
8313 if (*q == '\0')
8314 goto invalid_select;
8315 ++q;
8318 if (! strncmp (arg, this_arg,
8319 (len < q - arg) ? q - arg : len)
8320 || default_arg (this_arg, e - this_arg))
8322 mp = 1;
8323 break;
8326 if (*q == ' ')
8327 ++q;
8330 if (! mp)
8331 m = 0;
8333 if (*e == ' ')
8334 ++e;
8337 if (m)
8339 skip = 1;
8340 break;
8343 if (*e != '\0')
8344 ++e;
8348 if (! skip)
8350 /* If this is a duplicate, skip it. */
8351 skip = (last_path != 0
8352 && (unsigned int) (p - this_path) == last_path_len
8353 && ! filename_ncmp (last_path, this_path, last_path_len));
8355 last_path = this_path;
8356 last_path_len = p - this_path;
8359 /* If this directory requires any default arguments, we can skip
8360 it. We will already have printed a directory identical to
8361 this one which does not require that default argument. */
8362 if (! skip)
8364 const char *q;
8366 q = p + 1;
8367 while (*q != ';')
8369 const char *arg;
8371 if (*q == '\0')
8372 goto invalid_select;
8374 if (*q == '!')
8375 arg = NULL;
8376 else
8377 arg = q;
8379 while (*q != ' ' && *q != ';')
8381 if (*q == '\0')
8382 goto invalid_select;
8383 ++q;
8386 if (arg != NULL
8387 && default_arg (arg, q - arg))
8389 skip = 1;
8390 break;
8393 if (*q == ' ')
8394 ++q;
8398 if (! skip)
8400 const char *p1;
8402 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
8403 putchar (*p1);
8404 putchar (';');
8407 ++p;
8408 while (*p != ';')
8410 int use_arg;
8412 if (*p == '\0')
8413 goto invalid_select;
8415 if (skip)
8417 ++p;
8418 continue;
8421 use_arg = *p != '!';
8423 if (use_arg)
8424 putchar ('@');
8426 while (*p != ' ' && *p != ';')
8428 if (*p == '\0')
8429 goto invalid_select;
8430 if (use_arg)
8431 putchar (*p);
8432 ++p;
8435 if (*p == ' ')
8436 ++p;
8439 if (! skip)
8441 /* If there are extra options, print them now. */
8442 if (multilib_extra && *multilib_extra)
8444 int print_at = TRUE;
8445 const char *q;
8447 for (q = multilib_extra; *q != '\0'; q++)
8449 if (*q == ' ')
8450 print_at = TRUE;
8451 else
8453 if (print_at)
8454 putchar ('@');
8455 putchar (*q);
8456 print_at = FALSE;
8461 putchar ('\n');
8464 ++p;
8468 /* getenv built-in spec function.
8470 Returns the value of the environment variable given by its first
8471 argument, concatenated with the second argument. If the
8472 environment variable is not defined, a fatal error is issued. */
8474 static const char *
8475 getenv_spec_function (int argc, const char **argv)
8477 char *value;
8478 char *result;
8479 char *ptr;
8480 size_t len;
8482 if (argc != 2)
8483 return NULL;
8485 value = getenv (argv[0]);
8486 if (!value)
8487 fatal_error ("environment variable %qs not defined", argv[0]);
8489 /* We have to escape every character of the environment variable so
8490 they are not interpreted as active spec characters. A
8491 particularly painful case is when we are reading a variable
8492 holding a windows path complete with \ separators. */
8493 len = strlen (value) * 2 + strlen (argv[1]) + 1;
8494 result = XNEWVAR (char, len);
8495 for (ptr = result; *value; ptr += 2)
8497 ptr[0] = '\\';
8498 ptr[1] = *value++;
8501 strcpy (ptr, argv[1]);
8503 return result;
8506 /* if-exists built-in spec function.
8508 Checks to see if the file specified by the absolute pathname in
8509 ARGS exists. Returns that pathname if found.
8511 The usual use for this function is to check for a library file
8512 (whose name has been expanded with %s). */
8514 static const char *
8515 if_exists_spec_function (int argc, const char **argv)
8517 /* Must have only one argument. */
8518 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8519 return argv[0];
8521 return NULL;
8524 /* if-exists-else built-in spec function.
8526 This is like if-exists, but takes an additional argument which
8527 is returned if the first argument does not exist. */
8529 static const char *
8530 if_exists_else_spec_function (int argc, const char **argv)
8532 /* Must have exactly two arguments. */
8533 if (argc != 2)
8534 return NULL;
8536 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8537 return argv[0];
8539 return argv[1];
8542 /* sanitize built-in spec function.
8544 This returns non-NULL, if sanitizing address, thread or
8545 any of the undefined behavior sanitizers. */
8547 static const char *
8548 sanitize_spec_function (int argc, const char **argv)
8550 if (argc != 1)
8551 return NULL;
8553 if (strcmp (argv[0], "address") == 0)
8554 return (flag_sanitize & SANITIZE_USER_ADDRESS) ? "" : NULL;
8555 if (strcmp (argv[0], "kernel-address") == 0)
8556 return (flag_sanitize & SANITIZE_KERNEL_ADDRESS) ? "" : NULL;
8557 if (strcmp (argv[0], "thread") == 0)
8558 return (flag_sanitize & SANITIZE_THREAD) ? "" : NULL;
8559 if (strcmp (argv[0], "undefined") == 0)
8560 return ((flag_sanitize & (SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT))
8561 && !flag_sanitize_undefined_trap_on_error) ? "" : NULL;
8562 if (strcmp (argv[0], "leak") == 0)
8563 return ((flag_sanitize
8564 & (SANITIZE_ADDRESS | SANITIZE_LEAK | SANITIZE_THREAD))
8565 == SANITIZE_LEAK) ? "" : NULL;
8566 return NULL;
8569 /* replace-outfile built-in spec function.
8571 This looks for the first argument in the outfiles array's name and
8572 replaces it with the second argument. */
8574 static const char *
8575 replace_outfile_spec_function (int argc, const char **argv)
8577 int i;
8578 /* Must have exactly two arguments. */
8579 if (argc != 2)
8580 abort ();
8582 for (i = 0; i < n_infiles; i++)
8584 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8585 outfiles[i] = xstrdup (argv[1]);
8587 return NULL;
8590 /* remove-outfile built-in spec function.
8592 * This looks for the first argument in the outfiles array's name and
8593 * removes it. */
8595 static const char *
8596 remove_outfile_spec_function (int argc, const char **argv)
8598 int i;
8599 /* Must have exactly one argument. */
8600 if (argc != 1)
8601 abort ();
8603 for (i = 0; i < n_infiles; i++)
8605 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8606 outfiles[i] = NULL;
8608 return NULL;
8611 /* Given two version numbers, compares the two numbers.
8612 A version number must match the regular expression
8613 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
8615 static int
8616 compare_version_strings (const char *v1, const char *v2)
8618 int rresult;
8619 regex_t r;
8621 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
8622 REG_EXTENDED | REG_NOSUB) != 0)
8623 abort ();
8624 rresult = regexec (&r, v1, 0, NULL, 0);
8625 if (rresult == REG_NOMATCH)
8626 fatal_error ("invalid version number %qs", v1);
8627 else if (rresult != 0)
8628 abort ();
8629 rresult = regexec (&r, v2, 0, NULL, 0);
8630 if (rresult == REG_NOMATCH)
8631 fatal_error ("invalid version number %qs", v2);
8632 else if (rresult != 0)
8633 abort ();
8635 return strverscmp (v1, v2);
8639 /* version_compare built-in spec function.
8641 This takes an argument of the following form:
8643 <comparison-op> <arg1> [<arg2>] <switch> <result>
8645 and produces "result" if the comparison evaluates to true,
8646 and nothing if it doesn't.
8648 The supported <comparison-op> values are:
8650 >= true if switch is a later (or same) version than arg1
8651 !> opposite of >=
8652 < true if switch is an earlier version than arg1
8653 !< opposite of <
8654 >< true if switch is arg1 or later, and earlier than arg2
8655 <> true if switch is earlier than arg1 or is arg2 or later
8657 If the switch is not present, the condition is false unless
8658 the first character of the <comparison-op> is '!'.
8660 For example,
8661 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
8662 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
8664 static const char *
8665 version_compare_spec_function (int argc, const char **argv)
8667 int comp1, comp2;
8668 size_t switch_len;
8669 const char *switch_value = NULL;
8670 int nargs = 1, i;
8671 bool result;
8673 if (argc < 3)
8674 fatal_error ("too few arguments to %%:version-compare");
8675 if (argv[0][0] == '\0')
8676 abort ();
8677 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
8678 nargs = 2;
8679 if (argc != nargs + 3)
8680 fatal_error ("too many arguments to %%:version-compare");
8682 switch_len = strlen (argv[nargs + 1]);
8683 for (i = 0; i < n_switches; i++)
8684 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
8685 && check_live_switch (i, switch_len))
8686 switch_value = switches[i].part1 + switch_len;
8688 if (switch_value == NULL)
8689 comp1 = comp2 = -1;
8690 else
8692 comp1 = compare_version_strings (switch_value, argv[1]);
8693 if (nargs == 2)
8694 comp2 = compare_version_strings (switch_value, argv[2]);
8695 else
8696 comp2 = -1; /* This value unused. */
8699 switch (argv[0][0] << 8 | argv[0][1])
8701 case '>' << 8 | '=':
8702 result = comp1 >= 0;
8703 break;
8704 case '!' << 8 | '<':
8705 result = comp1 >= 0 || switch_value == NULL;
8706 break;
8707 case '<' << 8:
8708 result = comp1 < 0;
8709 break;
8710 case '!' << 8 | '>':
8711 result = comp1 < 0 || switch_value == NULL;
8712 break;
8713 case '>' << 8 | '<':
8714 result = comp1 >= 0 && comp2 < 0;
8715 break;
8716 case '<' << 8 | '>':
8717 result = comp1 < 0 || comp2 >= 0;
8718 break;
8720 default:
8721 fatal_error ("unknown operator %qs in %%:version-compare", argv[0]);
8723 if (! result)
8724 return NULL;
8726 return argv[nargs + 2];
8729 /* %:include builtin spec function. This differs from %include in that it
8730 can be nested inside a spec, and thus be conditionalized. It takes
8731 one argument, the filename, and looks for it in the startfile path.
8732 The result is always NULL, i.e. an empty expansion. */
8734 static const char *
8735 include_spec_function (int argc, const char **argv)
8737 char *file;
8739 if (argc != 1)
8740 abort ();
8742 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
8743 read_specs (file ? file : argv[0], false, false);
8745 return NULL;
8748 /* %:find-file spec function. This function replaces its argument by
8749 the file found through find_file, that is the -print-file-name gcc
8750 program option. */
8751 static const char *
8752 find_file_spec_function (int argc, const char **argv)
8754 const char *file;
8756 if (argc != 1)
8757 abort ();
8759 file = find_file (argv[0]);
8760 return file;
8764 /* %:find-plugindir spec function. This function replaces its argument
8765 by the -iplugindir=<dir> option. `dir' is found through find_file, that
8766 is the -print-file-name gcc program option. */
8767 static const char *
8768 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
8770 const char *option;
8772 if (argc != 0)
8773 abort ();
8775 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
8776 return option;
8780 /* %:print-asm-header spec function. Print a banner to say that the
8781 following output is from the assembler. */
8783 static const char *
8784 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
8785 const char **argv ATTRIBUTE_UNUSED)
8787 printf (_("Assembler options\n=================\n\n"));
8788 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
8789 fflush (stdout);
8790 return NULL;
8793 /* Get a random number for -frandom-seed */
8795 static unsigned HOST_WIDE_INT
8796 get_random_number (void)
8798 unsigned HOST_WIDE_INT ret = 0;
8799 int fd;
8801 fd = open ("/dev/urandom", O_RDONLY);
8802 if (fd >= 0)
8804 read (fd, &ret, sizeof (HOST_WIDE_INT));
8805 close (fd);
8806 if (ret)
8807 return ret;
8810 /* Get some more or less random data. */
8811 #ifdef HAVE_GETTIMEOFDAY
8813 struct timeval tv;
8815 gettimeofday (&tv, NULL);
8816 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
8818 #else
8820 time_t now = time (NULL);
8822 if (now != (time_t)-1)
8823 ret = (unsigned) now;
8825 #endif
8827 return ret ^ getpid ();
8830 /* %:compare-debug-dump-opt spec function. Save the last argument,
8831 expected to be the last -fdump-final-insns option, or generate a
8832 temporary. */
8834 static const char *
8835 compare_debug_dump_opt_spec_function (int arg,
8836 const char **argv ATTRIBUTE_UNUSED)
8838 char *ret;
8839 char *name;
8840 int which;
8841 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
8843 if (arg != 0)
8844 fatal_error ("too many arguments to %%:compare-debug-dump-opt");
8846 do_spec_2 ("%{fdump-final-insns=*:%*}");
8847 do_spec_1 (" ", 0, NULL);
8849 if (argbuf.length () > 0
8850 && strcmp (argv[argbuf.length () - 1], "."))
8852 if (!compare_debug)
8853 return NULL;
8855 name = xstrdup (argv[argbuf.length () - 1]);
8856 ret = NULL;
8858 else
8860 const char *ext = NULL;
8862 if (argbuf.length () > 0)
8864 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
8865 ext = ".gkd";
8867 else if (!compare_debug)
8868 return NULL;
8869 else
8870 do_spec_2 ("%g.gkd");
8872 do_spec_1 (" ", 0, NULL);
8874 gcc_assert (argbuf.length () > 0);
8876 name = concat (argbuf.last (), ext, NULL);
8878 ret = concat ("-fdump-final-insns=", name, NULL);
8881 which = compare_debug < 0;
8882 debug_check_temp_file[which] = name;
8884 if (!which)
8886 unsigned HOST_WIDE_INT value = get_random_number ();
8888 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
8891 if (*random_seed)
8893 char *tmp = ret;
8894 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
8895 ret, NULL);
8896 free (tmp);
8899 if (which)
8900 *random_seed = 0;
8902 return ret;
8905 static const char *debug_auxbase_opt;
8907 /* %:compare-debug-self-opt spec function. Expands to the options
8908 that are to be passed in the second compilation of
8909 compare-debug. */
8911 static const char *
8912 compare_debug_self_opt_spec_function (int arg,
8913 const char **argv ATTRIBUTE_UNUSED)
8915 if (arg != 0)
8916 fatal_error ("too many arguments to %%:compare-debug-self-opt");
8918 if (compare_debug >= 0)
8919 return NULL;
8921 do_spec_2 ("%{c|S:%{o*:%*}}");
8922 do_spec_1 (" ", 0, NULL);
8924 if (argbuf.length () > 0)
8925 debug_auxbase_opt = concat ("-auxbase-strip ",
8926 argbuf.last (),
8927 NULL);
8928 else
8929 debug_auxbase_opt = NULL;
8931 return concat ("\
8932 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
8933 %<fdump-final-insns=* -w -S -o %j \
8934 %{!fcompare-debug-second:-fcompare-debug-second} \
8935 ", compare_debug_opt, NULL);
8938 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
8939 options that are to be passed in the second compilation of
8940 compare-debug. It expects, as an argument, the basename of the
8941 current input file name, with the .gk suffix appended to it. */
8943 static const char *
8944 compare_debug_auxbase_opt_spec_function (int arg,
8945 const char **argv)
8947 char *name;
8948 int len;
8950 if (arg == 0)
8951 fatal_error ("too few arguments to %%:compare-debug-auxbase-opt");
8953 if (arg != 1)
8954 fatal_error ("too many arguments to %%:compare-debug-auxbase-opt");
8956 if (compare_debug >= 0)
8957 return NULL;
8959 len = strlen (argv[0]);
8960 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
8961 fatal_error ("argument to %%:compare-debug-auxbase-opt "
8962 "does not end in .gk");
8964 if (debug_auxbase_opt)
8965 return debug_auxbase_opt;
8967 #define OPT "-auxbase "
8969 len -= 3;
8970 name = (char*) xmalloc (sizeof (OPT) + len);
8971 memcpy (name, OPT, sizeof (OPT) - 1);
8972 memcpy (name + sizeof (OPT) - 1, argv[0], len);
8973 name[sizeof (OPT) - 1 + len] = '\0';
8975 #undef OPT
8977 return name;
8980 /* %:pass-through-libs spec function. Finds all -l options and input
8981 file names in the lib spec passed to it, and makes a list of them
8982 prepended with the plugin option to cause them to be passed through
8983 to the final link after all the new object files have been added. */
8985 const char *
8986 pass_through_libs_spec_func (int argc, const char **argv)
8988 char *prepended = xstrdup (" ");
8989 int n;
8990 /* Shlemiel the painter's algorithm. Innately horrible, but at least
8991 we know that there will never be more than a handful of strings to
8992 concat, and it's only once per run, so it's not worth optimising. */
8993 for (n = 0; n < argc; n++)
8995 char *old = prepended;
8996 /* Anything that isn't an option is a full path to an output
8997 file; pass it through if it ends in '.a'. Among options,
8998 pass only -l. */
8999 if (argv[n][0] == '-' && argv[n][1] == 'l')
9001 const char *lopt = argv[n] + 2;
9002 /* Handle both joined and non-joined -l options. If for any
9003 reason there's a trailing -l with no joined or following
9004 arg just discard it. */
9005 if (!*lopt && ++n >= argc)
9006 break;
9007 else if (!*lopt)
9008 lopt = argv[n];
9009 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
9010 lopt, " ", NULL);
9012 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
9014 prepended = concat (prepended, "-plugin-opt=-pass-through=",
9015 argv[n], " ", NULL);
9017 if (prepended != old)
9018 free (old);
9020 return prepended;
9023 /* %:replace-extension spec function. Replaces the extension of the
9024 first argument with the second argument. */
9026 const char *
9027 replace_extension_spec_func (int argc, const char **argv)
9029 char *name;
9030 char *p;
9031 char *result;
9032 int i;
9034 if (argc != 2)
9035 fatal_error ("too few arguments to %%:replace-extension");
9037 name = xstrdup (argv[0]);
9039 for (i = strlen (name) - 1; i >= 0; i--)
9040 if (IS_DIR_SEPARATOR (name[i]))
9041 break;
9043 p = strrchr (name + i + 1, '.');
9044 if (p != NULL)
9045 *p = '\0';
9047 result = concat (name, argv[1], NULL);
9049 free (name);
9050 return result;
9053 /* Insert backslash before spaces in ORIG (usually a file path), to
9054 avoid being broken by spec parser.
9056 This function is needed as do_spec_1 treats white space (' ' and '\t')
9057 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
9058 the file name should be treated as a single argument rather than being
9059 broken into multiple. Solution is to insert '\\' before the space in a
9060 file name.
9062 This function converts and only converts all occurrence of ' '
9063 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
9064 "a b" -> "a\\ b"
9065 "a b" -> "a\\ \\ b"
9066 "a\tb" -> "a\\\tb"
9067 "a\\ b" -> "a\\\\ b"
9069 orig: input null-terminating string that was allocated by xalloc. The
9070 memory it points to might be freed in this function. Behavior undefined
9071 if ORIG wasn't xalloced or was freed already at entry.
9073 Return: ORIG if no conversion needed. Otherwise a newly allocated string
9074 that was converted from ORIG. */
9076 static char *
9077 convert_white_space (char *orig)
9079 int len, number_of_space = 0;
9081 for (len = 0; orig[len]; len++)
9082 if (orig[len] == ' ' || orig[len] == '\t') number_of_space++;
9084 if (number_of_space)
9086 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
9087 int j, k;
9088 for (j = 0, k = 0; j <= len; j++, k++)
9090 if (orig[j] == ' ' || orig[j] == '\t')
9091 new_spec[k++] = '\\';
9092 new_spec[k] = orig[j];
9094 free (orig);
9095 return new_spec;
9097 else
9098 return orig;