Add missing break statement.
[official-gcc.git] / gcc / gcc.c
blob6cd08eab8b55ca3503b9537df97fd07b3e7e2f8d
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 const char *getenv_spec_function (int, const char **);
257 static const char *if_exists_spec_function (int, const char **);
258 static const char *if_exists_else_spec_function (int, const char **);
259 static const char *sanitize_spec_function (int, const char **);
260 static const char *replace_outfile_spec_function (int, const char **);
261 static const char *remove_outfile_spec_function (int, const char **);
262 static const char *version_compare_spec_function (int, const char **);
263 static const char *include_spec_function (int, const char **);
264 static const char *find_file_spec_function (int, const char **);
265 static const char *find_plugindir_spec_function (int, const char **);
266 static const char *print_asm_header_spec_function (int, const char **);
267 static const char *compare_debug_dump_opt_spec_function (int, const char **);
268 static const char *compare_debug_self_opt_spec_function (int, const char **);
269 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
270 static const char *pass_through_libs_spec_func (int, const char **);
271 static const char *replace_extension_spec_func (int, const char **);
272 static char *convert_white_space (char *);
274 /* The Specs Language
276 Specs are strings containing lines, each of which (if not blank)
277 is made up of a program name, and arguments separated by spaces.
278 The program name must be exact and start from root, since no path
279 is searched and it is unreliable to depend on the current working directory.
280 Redirection of input or output is not supported; the subprograms must
281 accept filenames saying what files to read and write.
283 In addition, the specs can contain %-sequences to substitute variable text
284 or for conditional text. Here is a table of all defined %-sequences.
285 Note that spaces are not generated automatically around the results of
286 expanding these sequences; therefore, you can concatenate them together
287 or with constant text in a single argument.
289 %% substitute one % into the program name or argument.
290 %i substitute the name of the input file being processed.
291 %b substitute the basename of the input file being processed.
292 This is the substring up to (and not including) the last period
293 and not including the directory unless -save-temps was specified
294 to put temporaries in a different location.
295 %B same as %b, but include the file suffix (text after the last period).
296 %gSUFFIX
297 substitute a file name that has suffix SUFFIX and is chosen
298 once per compilation, and mark the argument a la %d. To reduce
299 exposure to denial-of-service attacks, the file name is now
300 chosen in a way that is hard to predict even when previously
301 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
302 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
303 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
304 had been pre-processed. Previously, %g was simply substituted
305 with a file name chosen once per compilation, without regard
306 to any appended suffix (which was therefore treated just like
307 ordinary text), making such attacks more likely to succeed.
308 %|SUFFIX
309 like %g, but if -pipe is in effect, expands simply to "-".
310 %mSUFFIX
311 like %g, but if -pipe is in effect, expands to nothing. (We have both
312 %| and %m to accommodate differences between system assemblers; see
313 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
314 %uSUFFIX
315 like %g, but generates a new temporary file name even if %uSUFFIX
316 was already seen.
317 %USUFFIX
318 substitutes the last file name generated with %uSUFFIX, generating a
319 new one if there is no such last file name. In the absence of any
320 %uSUFFIX, this is just like %gSUFFIX, except they don't share
321 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
322 would involve the generation of two distinct file names, one
323 for each `%g.s' and another for each `%U.s'. Previously, %U was
324 simply substituted with a file name chosen for the previous %u,
325 without regard to any appended suffix.
326 %jSUFFIX
327 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
328 writable, and if save-temps is off; otherwise, substitute the name
329 of a temporary file, just like %u. This temporary file is not
330 meant for communication between processes, but rather as a junk
331 disposal mechanism.
332 %.SUFFIX
333 substitutes .SUFFIX for the suffixes of a matched switch's args when
334 it is subsequently output with %*. SUFFIX is terminated by the next
335 space or %.
336 %d marks the argument containing or following the %d as a
337 temporary file name, so that that file will be deleted if GCC exits
338 successfully. Unlike %g, this contributes no text to the argument.
339 %w marks the argument containing or following the %w as the
340 "output file" of this compilation. This puts the argument
341 into the sequence of arguments that %o will substitute later.
342 %V indicates that this compilation produces no "output file".
343 %W{...}
344 like %{...} but mark last argument supplied within
345 as a file to be deleted on failure.
346 %o substitutes the names of all the output files, with spaces
347 automatically placed around them. You should write spaces
348 around the %o as well or the results are undefined.
349 %o is for use in the specs for running the linker.
350 Input files whose names have no recognized suffix are not compiled
351 at all, but they are included among the output files, so they will
352 be linked.
353 %O substitutes the suffix for object files. Note that this is
354 handled specially when it immediately follows %g, %u, or %U
355 (with or without a suffix argument) because of the need for
356 those to form complete file names. The handling is such that
357 %O is treated exactly as if it had already been substituted,
358 except that %g, %u, and %U do not currently support additional
359 SUFFIX characters following %O as they would following, for
360 example, `.o'.
361 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
362 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
363 and -B options) and -imultilib as necessary.
364 %s current argument is the name of a library or startup file of some sort.
365 Search for that file in a standard list of directories
366 and substitute the full name found.
367 %eSTR Print STR as an error message. STR is terminated by a newline.
368 Use this when inconsistent options are detected.
369 %nSTR Print STR as a notice. STR is terminated by a newline.
370 %x{OPTION} Accumulate an option for %X.
371 %X Output the accumulated linker options specified by compilations.
372 %Y Output the accumulated assembler options specified by compilations.
373 %Z Output the accumulated preprocessor options specified by compilations.
374 %a process ASM_SPEC as a spec.
375 This allows config.h to specify part of the spec for running as.
376 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
377 used here. This can be used to run a post-processor after the
378 assembler has done its job.
379 %D Dump out a -L option for each directory in startfile_prefixes.
380 If multilib_dir is set, extra entries are generated with it affixed.
381 %l process LINK_SPEC as a spec.
382 %L process LIB_SPEC as a spec.
383 %M Output multilib_os_dir.
384 %G process LIBGCC_SPEC as a spec.
385 %R Output the concatenation of target_system_root and
386 target_sysroot_suffix.
387 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
388 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
389 %C process CPP_SPEC as a spec.
390 %1 process CC1_SPEC as a spec.
391 %2 process CC1PLUS_SPEC as a spec.
392 %* substitute the variable part of a matched option. (See below.)
393 Note that each comma in the substituted string is replaced by
394 a single space. A space is appended after the last substition
395 unless there is more text in current sequence.
396 %<S remove all occurrences of -S from the command line.
397 Note - this command is position dependent. % commands in the
398 spec string before this one will see -S, % commands in the
399 spec string after this one will not.
400 %>S Similar to "%<S", but keep it in the GCC command line.
401 %<S* remove all occurrences of all switches beginning with -S from the
402 command line.
403 %:function(args)
404 Call the named function FUNCTION, passing it ARGS. ARGS is
405 first processed as a nested spec string, then split into an
406 argument vector in the usual fashion. The function returns
407 a string which is processed as if it had appeared literally
408 as part of the current spec.
409 %{S} substitutes the -S switch, if that switch was given to GCC.
410 If that switch was not specified, this substitutes nothing.
411 Here S is a metasyntactic variable.
412 %{S*} substitutes all the switches specified to GCC whose names start
413 with -S. This is used for -o, -I, etc; switches that take
414 arguments. GCC considers `-o foo' as being one switch whose
415 name starts with `o'. %{o*} would substitute this text,
416 including the space; thus, two arguments would be generated.
417 %{S*&T*} likewise, but preserve order of S and T options (the order
418 of S and T in the spec is not significant). Can be any number
419 of ampersand-separated variables; for each the wild card is
420 optional. Useful for CPP as %{D*&U*&A*}.
422 %{S:X} substitutes X, if the -S switch was given to GCC.
423 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
424 %{S*:X} substitutes X if one or more switches whose names start
425 with -S was given to GCC. Normally X is substituted only
426 once, no matter how many such switches appeared. However,
427 if %* appears somewhere in X, then X will be substituted
428 once for each matching switch, with the %* replaced by the
429 part of that switch that matched the '*'. A space will be
430 appended after the last substition unless there is more
431 text in current sequence.
432 %{.S:X} substitutes X, if processing a file with suffix S.
433 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
434 %{,S:X} substitutes X, if processing a file which will use spec S.
435 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
437 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
438 combined with '!', '.', ',', and '*' as above binding stronger
439 than the OR.
440 If %* appears in X, all of the alternatives must be starred, and
441 only the first matching alternative is substituted.
442 %{%:function(args):X}
443 Call function named FUNCTION with args ARGS. If the function
444 returns non-NULL, then X is substituted, if it returns
445 NULL, it isn't substituted.
446 %{S:X; if S was given to GCC, substitutes X;
447 T:Y; else if T was given to GCC, substitutes Y;
448 :D} else substitutes D. There can be as many clauses as you need.
449 This may be combined with '.', '!', ',', '|', and '*' as above.
451 %(Spec) processes a specification defined in a specs file as *Spec:
453 The conditional text X in a %{S:X} or similar construct may contain
454 other nested % constructs or spaces, or even newlines. They are
455 processed as usual, as described above. Trailing white space in X is
456 ignored. White space may also appear anywhere on the left side of the
457 colon in these constructs, except between . or * and the corresponding
458 word.
460 The -O, -f, -g, -m, and -W switches are handled specifically in these
461 constructs. If another value of -O or the negated form of a -f, -m, or
462 -W switch is found later in the command line, the earlier switch
463 value is ignored, except with {S*} where S is just one letter; this
464 passes all matching options.
466 The character | at the beginning of the predicate text is used to indicate
467 that a command should be piped to the following command, but only if -pipe
468 is specified.
470 Note that it is built into GCC which switches take arguments and which
471 do not. You might think it would be useful to generalize this to
472 allow each compiler's spec to say which switches take arguments. But
473 this cannot be done in a consistent fashion. GCC cannot even decide
474 which input files have been specified without knowing which switches
475 take arguments, and it must know which input files to compile in order
476 to tell which compilers to run.
478 GCC also knows implicitly that arguments starting in `-l' are to be
479 treated as compiler output files, and passed to the linker in their
480 proper position among the other output files. */
482 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
484 /* config.h can define ASM_SPEC to provide extra args to the assembler
485 or extra switch-translations. */
486 #ifndef ASM_SPEC
487 #define ASM_SPEC ""
488 #endif
490 /* config.h can define ASM_FINAL_SPEC to run a post processor after
491 the assembler has run. */
492 #ifndef ASM_FINAL_SPEC
493 #define ASM_FINAL_SPEC \
494 "%{gsplit-dwarf: \n\
495 objcopy --extract-dwo \
496 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
497 %{c:%{o*:%:replace-extension(%{o*:%*} .dwo)}%{!o*:%b.dwo}}%{!c:%b.dwo} \n\
498 objcopy --strip-dwo \
499 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
501 #endif
503 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
504 or extra switch-translations. */
505 #ifndef CPP_SPEC
506 #define CPP_SPEC ""
507 #endif
509 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
510 or extra switch-translations. */
511 #ifndef CC1_SPEC
512 #define CC1_SPEC ""
513 #endif
515 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
516 or extra switch-translations. */
517 #ifndef CC1PLUS_SPEC
518 #define CC1PLUS_SPEC ""
519 #endif
521 /* config.h can define LINK_SPEC to provide extra args to the linker
522 or extra switch-translations. */
523 #ifndef LINK_SPEC
524 #define LINK_SPEC ""
525 #endif
527 /* config.h can define LIB_SPEC to override the default libraries. */
528 #ifndef LIB_SPEC
529 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
530 #endif
532 /* When using -fsplit-stack we need to wrap pthread_create, in order
533 to initialize the stack guard. We always use wrapping, rather than
534 shared library ordering, and we keep the wrapper function in
535 libgcc. This is not yet a real spec, though it could become one;
536 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
537 only works with GNU ld and gold. */
538 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
540 #ifndef LIBASAN_SPEC
541 #define STATIC_LIBASAN_LIBS \
542 " %{static-libasan:%:include(libsanitizer.spec)%(link_libasan)}"
543 #ifdef LIBASAN_EARLY_SPEC
544 #define LIBASAN_SPEC STATIC_LIBASAN_LIBS
545 #elif defined(HAVE_LD_STATIC_DYNAMIC)
546 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
547 "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
548 STATIC_LIBASAN_LIBS
549 #else
550 #define LIBASAN_SPEC "-lasan" STATIC_LIBASAN_LIBS
551 #endif
552 #endif
554 #ifndef LIBASAN_EARLY_SPEC
555 #define LIBASAN_EARLY_SPEC ""
556 #endif
558 #ifndef LIBTSAN_SPEC
559 #define STATIC_LIBTSAN_LIBS \
560 " %{static-libtsan:%:include(libsanitizer.spec)%(link_libtsan)}"
561 #ifdef LIBTSAN_EARLY_SPEC
562 #define LIBTSAN_SPEC STATIC_LIBTSAN_LIBS
563 #elif defined(HAVE_LD_STATIC_DYNAMIC)
564 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
565 "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}" \
566 STATIC_LIBTSAN_LIBS
567 #else
568 #define LIBTSAN_SPEC "-ltsan" STATIC_LIBTSAN_LIBS
569 #endif
570 #endif
572 #ifndef LIBTSAN_EARLY_SPEC
573 #define LIBTSAN_EARLY_SPEC ""
574 #endif
576 #ifndef LIBLSAN_SPEC
577 #define STATIC_LIBLSAN_LIBS \
578 " %{static-liblsan:%:include(libsanitizer.spec)%(link_liblsan)}"
579 #ifdef HAVE_LD_STATIC_DYNAMIC
580 #define LIBLSAN_SPEC "%{!shared:%{static-liblsan:" LD_STATIC_OPTION \
581 "} -llsan %{static-liblsan:" LD_DYNAMIC_OPTION "}" \
582 STATIC_LIBLSAN_LIBS "}"
583 #else
584 #define LIBLSAN_SPEC "%{!shared:-llsan" STATIC_LIBLSAN_LIBS "}"
585 #endif
586 #endif
588 #ifndef LIBUBSAN_SPEC
589 #define STATIC_LIBUBSAN_LIBS \
590 " %{static-libubsan:%:include(libsanitizer.spec)%(link_libubsan)}"
591 #ifdef HAVE_LD_STATIC_DYNAMIC
592 #define LIBUBSAN_SPEC "%{static-libubsan:" LD_STATIC_OPTION \
593 "} -lubsan %{static-libubsan:" LD_DYNAMIC_OPTION "}" \
594 STATIC_LIBUBSAN_LIBS
595 #else
596 #define LIBUBSAN_SPEC "-lubsan" STATIC_LIBUBSAN_LIBS
597 #endif
598 #endif
600 /* Linker options for compressed debug sections. */
601 #if HAVE_LD_COMPRESS_DEBUG == 0
602 /* No linker support. */
603 #define LINK_COMPRESS_DEBUG_SPEC \
604 " %{gz*:%e-gz is not supported in this configuration} "
605 #elif HAVE_LD_COMPRESS_DEBUG == 1
606 /* GNU style on input, GNU ld options. Reject, not useful. */
607 #define LINK_COMPRESS_DEBUG_SPEC \
608 " %{gz*:%e-gz is not supported in this configuration} "
609 #elif HAVE_LD_COMPRESS_DEBUG == 2
610 /* GNU style, GNU gold options. */
611 #define LINK_COMPRESS_DEBUG_SPEC \
612 " %{gz|gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
613 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
614 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
615 #elif HAVE_LD_COMPRESS_DEBUG == 3
616 /* ELF gABI style. */
617 #define LINK_COMPRESS_DEBUG_SPEC \
618 " %{gz|gz=zlib:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
619 " %{gz=none:" LD_COMPRESS_DEBUG_OPTION "=none}" \
620 " %{gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
621 #else
622 #error Unknown value for HAVE_LD_COMPRESS_DEBUG.
623 #endif
625 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
626 included. */
627 #ifndef LIBGCC_SPEC
628 #if defined(REAL_LIBGCC_SPEC)
629 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
630 #elif defined(LINK_LIBGCC_SPECIAL_1)
631 /* Have gcc do the search for libgcc.a. */
632 #define LIBGCC_SPEC "libgcc.a%s"
633 #else
634 #define LIBGCC_SPEC "-lgcc"
635 #endif
636 #endif
638 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
639 #ifndef STARTFILE_SPEC
640 #define STARTFILE_SPEC \
641 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
642 #endif
644 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
645 #ifndef ENDFILE_SPEC
646 #define ENDFILE_SPEC ""
647 #endif
649 #ifndef LINKER_NAME
650 #define LINKER_NAME "collect2"
651 #endif
653 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
654 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
655 #else
656 #define ASM_MAP ""
657 #endif
659 /* Assembler options for compressed debug sections. */
660 #if HAVE_LD_COMPRESS_DEBUG < 2
661 /* Reject if the linker cannot write compressed debug sections. */
662 #define ASM_COMPRESS_DEBUG_SPEC \
663 " %{gz*:%e-gz is not supported in this configuration} "
664 #else /* HAVE_LD_COMPRESS_DEBUG >= 2 */
665 #if HAVE_AS_COMPRESS_DEBUG == 0
666 /* No assembler support. Ignore silently. */
667 #define ASM_COMPRESS_DEBUG_SPEC \
668 " %{gz*:} "
669 #elif HAVE_AS_COMPRESS_DEBUG == 1
670 /* GNU style, GNU as options. */
671 #define ASM_COMPRESS_DEBUG_SPEC \
672 " %{gz|gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "}" \
673 " %{gz=none:" AS_NO_COMPRESS_DEBUG_OPTION "}" \
674 " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
675 #elif HAVE_AS_COMPRESS_DEBUG == 2
676 /* ELF gABI style. */
677 #define ASM_COMPRESS_DEBUG_SPEC \
678 " %{gz|gz=zlib:" AS_COMPRESS_DEBUG_OPTION "=zlib}" \
679 " %{gz=none:" AS_COMPRESS_DEBUG_OPTION "=none}" \
680 " %{gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
681 #else
682 #error Unknown value for HAVE_AS_COMPRESS_DEBUG.
683 #endif
684 #endif /* HAVE_LD_COMPRESS_DEBUG >= 2 */
686 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
687 to the assembler. */
688 #ifndef ASM_DEBUG_SPEC
689 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
690 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
691 # define ASM_DEBUG_SPEC \
692 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
693 ? "%{!g0:%{gdwarf*:--gdwarf2}%{!gdwarf*:%{g*:--gstabs}}}" ASM_MAP \
694 : "%{!g0:%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
695 # else
696 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
697 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gstabs}}" ASM_MAP
698 # endif
699 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
700 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gdwarf2}}" ASM_MAP
701 # endif
702 # endif
703 #endif
704 #ifndef ASM_DEBUG_SPEC
705 # define ASM_DEBUG_SPEC ""
706 #endif
708 /* Here is the spec for running the linker, after compiling all files. */
710 /* This is overridable by the target in case they need to specify the
711 -lgcc and -lc order specially, yet not require them to override all
712 of LINK_COMMAND_SPEC. */
713 #ifndef LINK_GCC_C_SEQUENCE_SPEC
714 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
715 #endif
717 #ifndef LINK_SSP_SPEC
718 #ifdef TARGET_LIBC_PROVIDES_SSP
719 #define LINK_SSP_SPEC "%{fstack-protector:}"
720 #else
721 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-strong|fstack-protector-all:-lssp_nonshared -lssp}"
722 #endif
723 #endif
725 #ifndef LINK_PIE_SPEC
726 #ifdef HAVE_LD_PIE
727 #define LINK_PIE_SPEC "%{pie:-pie} "
728 #else
729 #define LINK_PIE_SPEC "%{pie:} "
730 #endif
731 #endif
733 #ifndef LINK_BUILDID_SPEC
734 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
735 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
736 # endif
737 #endif
739 /* Conditional to test whether the LTO plugin is used or not.
740 FIXME: For slim LTO we will need to enable plugin unconditionally. This
741 still cause problems with PLUGIN_LD != LD and when plugin is built but
742 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
743 plugin only when LTO is enabled. We still honor explicit
744 -fuse-linker-plugin if the linker used understands -plugin. */
746 /* The linker has some plugin support. */
747 #if HAVE_LTO_PLUGIN > 0
748 /* The linker used has full plugin support, use LTO plugin by default. */
749 #if HAVE_LTO_PLUGIN == 2
750 #define PLUGIN_COND "!fno-use-linker-plugin:%{!fno-lto"
751 #define PLUGIN_COND_CLOSE "}"
752 #else
753 /* The linker used has limited plugin support, use LTO plugin with explicit
754 -fuse-linker-plugin. */
755 #define PLUGIN_COND "fuse-linker-plugin"
756 #define PLUGIN_COND_CLOSE ""
757 #endif
758 #define LINK_PLUGIN_SPEC \
759 "%{"PLUGIN_COND": \
760 -plugin %(linker_plugin_file) \
761 -plugin-opt=%(lto_wrapper) \
762 -plugin-opt=-fresolution=%u.res \
763 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
764 }"PLUGIN_COND_CLOSE
765 #else
766 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
767 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
768 %e-fuse-linker-plugin is not supported in this configuration}"
769 #endif
771 /* Linker command line options for -fsanitize= early on the command line. */
772 #ifndef SANITIZER_EARLY_SPEC
773 #define SANITIZER_EARLY_SPEC "\
774 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_EARLY_SPEC "} \
775 %{%:sanitize(thread):" LIBTSAN_EARLY_SPEC "}}}"
776 #endif
778 /* Linker command line options for -fsanitize= late on the command line. */
779 #ifndef SANITIZER_SPEC
780 #define SANITIZER_SPEC "\
781 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_SPEC "\
782 %{static:%ecannot specify -static with -fsanitize=address}\
783 %{%:sanitize(thread):%e-fsanitize=address is incompatible with -fsanitize=thread}}\
784 %{%:sanitize(thread):" LIBTSAN_SPEC "\
785 %{!pie:%{!shared:%e-fsanitize=thread linking must be done with -pie or -shared}}}\
786 %{%:sanitize(undefined):" LIBUBSAN_SPEC "}\
787 %{%:sanitize(leak):" LIBLSAN_SPEC "}}}"
788 #endif
790 /* This is the spec to use, once the code for creating the vtable
791 verification runtime library, libvtv.so, has been created. Currently
792 the vtable verification runtime functions are in libstdc++, so we use
793 the spec just below this one. */
794 #ifndef VTABLE_VERIFICATION_SPEC
795 #define VTABLE_VERIFICATION_SPEC "\
796 %{!nostdlib:%{fvtable-verify=std: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}\
797 %{fvtable-verify=preinit: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}}"
798 #endif
800 /* -u* was put back because both BSD and SysV seem to support it. */
801 /* %{static:} simply prevents an error message if the target machine
802 doesn't handle -static. */
803 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
804 scripts which exist in user specified directories, or in standard
805 directories. */
806 /* We pass any -flto flags on to the linker, which is expected
807 to understand them. In practice, this means it had better be collect2. */
808 /* %{e*} includes -export-dynamic; see comment in common.opt. */
809 #ifndef LINK_COMMAND_SPEC
810 #define LINK_COMMAND_SPEC "\
811 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
812 %(linker) " \
813 LINK_PLUGIN_SPEC \
814 "%{flto|flto=*:%<fcompare-debug*} \
815 %{flto} %{flto=*} %l " LINK_PIE_SPEC \
816 "%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
817 "%X %{o*} %{e*} %{N} %{n} %{r}\
818 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}} " VTABLE_VERIFICATION_SPEC " \
819 %{static:} %{L*} %(mfwrap) %(link_libgcc) " SANITIZER_EARLY_SPEC " %o\
820 %{fopenmp|ftree-parallelize-loops=*:%:include(libgomp.spec)%(link_gomp)}\
821 %{fcilkplus:%:include(libcilkrts.spec)%(link_cilkrts)}\
822 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
823 %(mflib) " STACK_SPLIT_SPEC "\
824 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
825 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
826 %{!nostdlib:%{!nostartfiles:%E}} %{T*} }}}}}}"
827 #endif
829 #ifndef LINK_LIBGCC_SPEC
830 /* Generate -L options for startfile prefix list. */
831 # define LINK_LIBGCC_SPEC "%D"
832 #endif
834 #ifndef STARTFILE_PREFIX_SPEC
835 # define STARTFILE_PREFIX_SPEC ""
836 #endif
838 #ifndef SYSROOT_SPEC
839 # define SYSROOT_SPEC "--sysroot=%R"
840 #endif
842 #ifndef SYSROOT_SUFFIX_SPEC
843 # define SYSROOT_SUFFIX_SPEC ""
844 #endif
846 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
847 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
848 #endif
850 static const char *asm_debug = ASM_DEBUG_SPEC;
851 static const char *cpp_spec = CPP_SPEC;
852 static const char *cc1_spec = CC1_SPEC;
853 static const char *cc1plus_spec = CC1PLUS_SPEC;
854 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
855 static const char *link_ssp_spec = LINK_SSP_SPEC;
856 static const char *asm_spec = ASM_SPEC;
857 static const char *asm_final_spec = ASM_FINAL_SPEC;
858 static const char *link_spec = LINK_SPEC;
859 static const char *lib_spec = LIB_SPEC;
860 static const char *link_gomp_spec = "";
861 static const char *libgcc_spec = LIBGCC_SPEC;
862 static const char *endfile_spec = ENDFILE_SPEC;
863 static const char *startfile_spec = STARTFILE_SPEC;
864 static const char *linker_name_spec = LINKER_NAME;
865 static const char *linker_plugin_file_spec = "";
866 static const char *lto_wrapper_spec = "";
867 static const char *lto_gcc_spec = "";
868 static const char *link_command_spec = LINK_COMMAND_SPEC;
869 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
870 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
871 static const char *sysroot_spec = SYSROOT_SPEC;
872 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
873 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
874 static const char *self_spec = "";
876 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
877 There should be no need to override these in target dependent files,
878 but we need to copy them to the specs file so that newer versions
879 of the GCC driver can correctly drive older tool chains with the
880 appropriate -B options. */
882 /* When cpplib handles traditional preprocessing, get rid of this, and
883 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
884 that we default the front end language better. */
885 static const char *trad_capable_cpp =
886 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
888 /* We don't wrap .d files in %W{} since a missing .d file, and
889 therefore no dependency entry, confuses make into thinking a .o
890 file that happens to exist is up-to-date. */
891 static const char *cpp_unique_options =
892 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
893 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
894 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
895 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
896 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
897 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
898 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
899 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
900 %{E|M|MM:%W{o*}}";
902 /* This contains cpp options which are common with cc1_options and are passed
903 only when preprocessing only to avoid duplication. We pass the cc1 spec
904 options to the preprocessor so that it the cc1 spec may manipulate
905 options used to set target flags. Those special target flags settings may
906 in turn cause preprocessor symbols to be defined specially. */
907 static const char *cpp_options =
908 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
909 %{f*} %{g*:%{!g0:%{g*} %{!fno-working-directory:-fworking-directory}}} %{O*}\
910 %{undef} %{save-temps*:-fpch-preprocess}";
912 /* This contains cpp options which are not passed when the preprocessor
913 output will be used by another program. */
914 static const char *cpp_debug_options = "%{d*}";
916 /* NB: This is shared amongst all front-ends, except for Ada. */
917 static const char *cc1_options =
918 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
919 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
920 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
921 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
922 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
923 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
924 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
925 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
926 %{-target-help:--target-help}\
927 %{-version:--version}\
928 %{-help=*:--help=%*}\
929 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
930 %{fsyntax-only:-o %j} %{-param*}\
931 %{coverage:-fprofile-arcs -ftest-coverage}";
933 static const char *asm_options =
934 "%{-target-help:%:print-asm-header()} "
935 #if HAVE_GNU_AS
936 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
937 to the assembler equivalents. */
938 "%{v} %{w:-W} %{I*} "
939 #endif
940 ASM_COMPRESS_DEBUG_SPEC
941 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
943 static const char *invoke_as =
944 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
945 "%{!fwpa*:\
946 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
947 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
949 #else
950 "%{!fwpa*:\
951 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
952 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
954 #endif
956 /* Some compilers have limits on line lengths, and the multilib_select
957 and/or multilib_matches strings can be very long, so we build them at
958 run time. */
959 static struct obstack multilib_obstack;
960 static const char *multilib_select;
961 static const char *multilib_matches;
962 static const char *multilib_defaults;
963 static const char *multilib_exclusions;
964 static const char *multilib_reuse;
966 /* Check whether a particular argument is a default argument. */
968 #ifndef MULTILIB_DEFAULTS
969 #define MULTILIB_DEFAULTS { "" }
970 #endif
972 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
974 #ifndef DRIVER_SELF_SPECS
975 #define DRIVER_SELF_SPECS ""
976 #endif
978 /* Linking to libgomp implies pthreads. This is particularly important
979 for targets that use different start files and suchlike. */
980 #ifndef GOMP_SELF_SPECS
981 #define GOMP_SELF_SPECS "%{fopenmp|ftree-parallelize-loops=*: -pthread}"
982 #endif
984 /* Likewise for -fgnu-tm. */
985 #ifndef GTM_SELF_SPECS
986 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
987 #endif
989 /* Likewise for -fcilkplus. */
990 #ifndef CILK_SELF_SPECS
991 #define CILK_SELF_SPECS "%{fcilkplus: -pthread}"
992 #endif
994 static const char *const driver_self_specs[] = {
995 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
996 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS,
997 CILK_SELF_SPECS
1000 #ifndef OPTION_DEFAULT_SPECS
1001 #define OPTION_DEFAULT_SPECS { "", "" }
1002 #endif
1004 struct default_spec
1006 const char *name;
1007 const char *spec;
1010 static const struct default_spec
1011 option_default_specs[] = { OPTION_DEFAULT_SPECS };
1013 struct user_specs
1015 struct user_specs *next;
1016 const char *filename;
1019 static struct user_specs *user_specs_head, *user_specs_tail;
1022 /* Record the mapping from file suffixes for compilation specs. */
1024 struct compiler
1026 const char *suffix; /* Use this compiler for input files
1027 whose names end in this suffix. */
1029 const char *spec; /* To use this compiler, run this spec. */
1031 const char *cpp_spec; /* If non-NULL, substitute this spec
1032 for `%C', rather than the usual
1033 cpp_spec. */
1034 const int combinable; /* If nonzero, compiler can deal with
1035 multiple source files at once (IMA). */
1036 const int needs_preprocessing; /* If nonzero, source files need to
1037 be run through a preprocessor. */
1040 /* Pointer to a vector of `struct compiler' that gives the spec for
1041 compiling a file, based on its suffix.
1042 A file that does not end in any of these suffixes will be passed
1043 unchanged to the loader and nothing else will be done to it.
1045 An entry containing two 0s is used to terminate the vector.
1047 If multiple entries match a file, the last matching one is used. */
1049 static struct compiler *compilers;
1051 /* Number of entries in `compilers', not counting the null terminator. */
1053 static int n_compilers;
1055 /* The default list of file name suffixes and their compilation specs. */
1057 static const struct compiler default_compilers[] =
1059 /* Add lists of suffixes of known languages here. If those languages
1060 were not present when we built the driver, we will hit these copies
1061 and be given a more meaningful error than "file not used since
1062 linking is not done". */
1063 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
1064 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
1065 {".mii", "#Objective-C++", 0, 0, 0},
1066 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
1067 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
1068 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
1069 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
1070 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
1071 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
1072 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
1073 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
1074 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
1075 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
1076 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
1077 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1078 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1079 {".r", "#Ratfor", 0, 0, 0},
1080 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
1081 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
1082 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
1083 {".go", "#Go", 0, 1, 0},
1084 /* Next come the entries for C. */
1085 {".c", "@c", 0, 0, 1},
1086 {"@c",
1087 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1088 external preprocessor if -save-temps is given. */
1089 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1090 %{!E:%{!M:%{!MM:\
1091 %{traditional:\
1092 %eGNU C no longer supports -traditional without -E}\
1093 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1094 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1095 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1096 %(cc1_options)}\
1097 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1098 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1099 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1100 {"-",
1101 "%{!E:%e-E or -x required when input is from standard input}\
1102 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1103 {".h", "@c-header", 0, 0, 0},
1104 {"@c-header",
1105 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1106 external preprocessor if -save-temps is given. */
1107 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1108 %{!E:%{!M:%{!MM:\
1109 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1110 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1111 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1112 %(cc1_options)\
1113 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1114 %W{o*:--output-pch=%*}}%V}\
1115 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1116 cc1 %(cpp_unique_options) %(cc1_options)\
1117 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1118 %W{o*:--output-pch=%*}}%V}}}}}}", 0, 0, 0},
1119 {".i", "@cpp-output", 0, 0, 0},
1120 {"@cpp-output",
1121 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1122 {".s", "@assembler", 0, 0, 0},
1123 {"@assembler",
1124 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1125 {".sx", "@assembler-with-cpp", 0, 0, 0},
1126 {".S", "@assembler-with-cpp", 0, 0, 0},
1127 {"@assembler-with-cpp",
1128 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1129 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1130 %{E|M|MM:%(cpp_debug_options)}\
1131 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1132 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1133 #else
1134 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1135 %{E|M|MM:%(cpp_debug_options)}\
1136 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1137 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1138 #endif
1139 , 0, 0, 0},
1141 #include "specs.h"
1142 /* Mark end of table. */
1143 {0, 0, 0, 0, 0}
1146 /* Number of elements in default_compilers, not counting the terminator. */
1148 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1150 typedef char *char_p; /* For DEF_VEC_P. */
1152 /* A vector of options to give to the linker.
1153 These options are accumulated by %x,
1154 and substituted into the linker command with %X. */
1155 static vec<char_p> linker_options;
1157 /* A vector of options to give to the assembler.
1158 These options are accumulated by -Wa,
1159 and substituted into the assembler command with %Y. */
1160 static vec<char_p> assembler_options;
1162 /* A vector of options to give to the preprocessor.
1163 These options are accumulated by -Wp,
1164 and substituted into the preprocessor command with %Z. */
1165 static vec<char_p> preprocessor_options;
1167 static char *
1168 skip_whitespace (char *p)
1170 while (1)
1172 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1173 be considered whitespace. */
1174 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1175 return p + 1;
1176 else if (*p == '\n' || *p == ' ' || *p == '\t')
1177 p++;
1178 else if (*p == '#')
1180 while (*p != '\n')
1181 p++;
1182 p++;
1184 else
1185 break;
1188 return p;
1190 /* Structures to keep track of prefixes to try when looking for files. */
1192 struct prefix_list
1194 const char *prefix; /* String to prepend to the path. */
1195 struct prefix_list *next; /* Next in linked list. */
1196 int require_machine_suffix; /* Don't use without machine_suffix. */
1197 /* 2 means try both machine_suffix and just_machine_suffix. */
1198 int priority; /* Sort key - priority within list. */
1199 int os_multilib; /* 1 if OS multilib scheme should be used,
1200 0 for GCC multilib scheme. */
1203 struct path_prefix
1205 struct prefix_list *plist; /* List of prefixes to try */
1206 int max_len; /* Max length of a prefix in PLIST */
1207 const char *name; /* Name of this list (used in config stuff) */
1210 /* List of prefixes to try when looking for executables. */
1212 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1214 /* List of prefixes to try when looking for startup (crt0) files. */
1216 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1218 /* List of prefixes to try when looking for include files. */
1220 static struct path_prefix include_prefixes = { 0, 0, "include" };
1222 /* Suffix to attach to directories searched for commands.
1223 This looks like `MACHINE/VERSION/'. */
1225 static const char *machine_suffix = 0;
1227 /* Suffix to attach to directories searched for commands.
1228 This is just `MACHINE/'. */
1230 static const char *just_machine_suffix = 0;
1232 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1234 static const char *gcc_exec_prefix;
1236 /* Adjusted value of standard_libexec_prefix. */
1238 static const char *gcc_libexec_prefix;
1240 /* Default prefixes to attach to command names. */
1242 #ifndef STANDARD_STARTFILE_PREFIX_1
1243 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1244 #endif
1245 #ifndef STANDARD_STARTFILE_PREFIX_2
1246 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1247 #endif
1249 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1250 #undef MD_EXEC_PREFIX
1251 #undef MD_STARTFILE_PREFIX
1252 #undef MD_STARTFILE_PREFIX_1
1253 #endif
1255 /* If no prefixes defined, use the null string, which will disable them. */
1256 #ifndef MD_EXEC_PREFIX
1257 #define MD_EXEC_PREFIX ""
1258 #endif
1259 #ifndef MD_STARTFILE_PREFIX
1260 #define MD_STARTFILE_PREFIX ""
1261 #endif
1262 #ifndef MD_STARTFILE_PREFIX_1
1263 #define MD_STARTFILE_PREFIX_1 ""
1264 #endif
1266 /* These directories are locations set at configure-time based on the
1267 --prefix option provided to configure. Their initializers are
1268 defined in Makefile.in. These paths are not *directly* used when
1269 gcc_exec_prefix is set because, in that case, we know where the
1270 compiler has been installed, and use paths relative to that
1271 location instead. */
1272 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1273 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1274 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1275 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1277 /* For native compilers, these are well-known paths containing
1278 components that may be provided by the system. For cross
1279 compilers, these paths are not used. */
1280 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1281 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1282 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1283 static const char *const standard_startfile_prefix_1
1284 = STANDARD_STARTFILE_PREFIX_1;
1285 static const char *const standard_startfile_prefix_2
1286 = STANDARD_STARTFILE_PREFIX_2;
1288 /* A relative path to be used in finding the location of tools
1289 relative to the driver. */
1290 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1292 /* Subdirectory to use for locating libraries. Set by
1293 set_multilib_dir based on the compilation options. */
1295 static const char *multilib_dir;
1297 /* Subdirectory to use for locating libraries in OS conventions. Set by
1298 set_multilib_dir based on the compilation options. */
1300 static const char *multilib_os_dir;
1302 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1303 set_multilib_dir based on the compilation options. */
1305 static const char *multiarch_dir;
1307 /* Structure to keep track of the specs that have been defined so far.
1308 These are accessed using %(specname) in a compiler or link
1309 spec. */
1311 struct spec_list
1313 /* The following 2 fields must be first */
1314 /* to allow EXTRA_SPECS to be initialized */
1315 const char *name; /* name of the spec. */
1316 const char *ptr; /* available ptr if no static pointer */
1318 /* The following fields are not initialized */
1319 /* by EXTRA_SPECS */
1320 const char **ptr_spec; /* pointer to the spec itself. */
1321 struct spec_list *next; /* Next spec in linked list. */
1322 int name_len; /* length of the name */
1323 bool user_p; /* whether string come from file spec. */
1324 bool alloc_p; /* whether string was allocated */
1327 #define INIT_STATIC_SPEC(NAME,PTR) \
1328 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false }
1330 /* List of statically defined specs. */
1331 static struct spec_list static_specs[] =
1333 INIT_STATIC_SPEC ("asm", &asm_spec),
1334 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1335 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1336 INIT_STATIC_SPEC ("asm_options", &asm_options),
1337 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1338 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1339 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1340 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1341 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1342 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1343 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1344 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1345 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1346 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1347 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1348 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1349 INIT_STATIC_SPEC ("link", &link_spec),
1350 INIT_STATIC_SPEC ("lib", &lib_spec),
1351 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1352 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1353 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1354 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1355 INIT_STATIC_SPEC ("version", &compiler_version),
1356 INIT_STATIC_SPEC ("multilib", &multilib_select),
1357 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1358 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1359 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1360 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1361 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1362 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1363 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1364 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1365 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1366 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1367 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1368 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1369 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1370 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1371 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1372 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1373 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1374 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1375 INIT_STATIC_SPEC ("self_spec", &self_spec),
1378 #ifdef EXTRA_SPECS /* additional specs needed */
1379 /* Structure to keep track of just the first two args of a spec_list.
1380 That is all that the EXTRA_SPECS macro gives us. */
1381 struct spec_list_1
1383 const char *const name;
1384 const char *const ptr;
1387 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1388 static struct spec_list *extra_specs = (struct spec_list *) 0;
1389 #endif
1391 /* List of dynamically allocates specs that have been defined so far. */
1393 static struct spec_list *specs = (struct spec_list *) 0;
1395 /* List of static spec functions. */
1397 static const struct spec_function static_spec_functions[] =
1399 { "getenv", getenv_spec_function },
1400 { "if-exists", if_exists_spec_function },
1401 { "if-exists-else", if_exists_else_spec_function },
1402 { "sanitize", sanitize_spec_function },
1403 { "replace-outfile", replace_outfile_spec_function },
1404 { "remove-outfile", remove_outfile_spec_function },
1405 { "version-compare", version_compare_spec_function },
1406 { "include", include_spec_function },
1407 { "find-file", find_file_spec_function },
1408 { "find-plugindir", find_plugindir_spec_function },
1409 { "print-asm-header", print_asm_header_spec_function },
1410 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1411 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1412 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1413 { "pass-through-libs", pass_through_libs_spec_func },
1414 { "replace-extension", replace_extension_spec_func },
1415 #ifdef EXTRA_SPEC_FUNCTIONS
1416 EXTRA_SPEC_FUNCTIONS
1417 #endif
1418 { 0, 0 }
1421 static int processing_spec_function;
1423 /* Add appropriate libgcc specs to OBSTACK, taking into account
1424 various permutations of -shared-libgcc, -shared, and such. */
1426 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1428 #ifndef USE_LD_AS_NEEDED
1429 #define USE_LD_AS_NEEDED 0
1430 #endif
1432 static void
1433 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1434 const char *static_name, const char *eh_name)
1436 char *buf;
1438 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1439 "%{!static:%{!static-libgcc:"
1440 #if USE_LD_AS_NEEDED
1441 "%{!shared-libgcc:",
1442 static_name, " " LD_AS_NEEDED_OPTION " ",
1443 shared_name, " " LD_NO_AS_NEEDED_OPTION
1445 "%{shared-libgcc:",
1446 shared_name, "%{!shared: ", static_name, "}"
1448 #else
1449 "%{!shared:"
1450 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1451 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1453 #ifdef LINK_EH_SPEC
1454 "%{shared:"
1455 "%{shared-libgcc:", shared_name, "}"
1456 "%{!shared-libgcc:", static_name, "}"
1458 #else
1459 "%{shared:", shared_name, "}"
1460 #endif
1461 #endif
1462 "}}", NULL);
1464 obstack_grow (obstack, buf, strlen (buf));
1465 free (buf);
1467 #endif /* ENABLE_SHARED_LIBGCC */
1469 /* Initialize the specs lookup routines. */
1471 static void
1472 init_spec (void)
1474 struct spec_list *next = (struct spec_list *) 0;
1475 struct spec_list *sl = (struct spec_list *) 0;
1476 int i;
1478 if (specs)
1479 return; /* Already initialized. */
1481 if (verbose_flag)
1482 fnotice (stderr, "Using built-in specs.\n");
1484 #ifdef EXTRA_SPECS
1485 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1487 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1489 sl = &extra_specs[i];
1490 sl->name = extra_specs_1[i].name;
1491 sl->ptr = extra_specs_1[i].ptr;
1492 sl->next = next;
1493 sl->name_len = strlen (sl->name);
1494 sl->ptr_spec = &sl->ptr;
1495 next = sl;
1497 #endif
1499 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1501 sl = &static_specs[i];
1502 sl->next = next;
1503 next = sl;
1506 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1507 /* ??? If neither -shared-libgcc nor --static-libgcc was
1508 seen, then we should be making an educated guess. Some proposed
1509 heuristics for ELF include:
1511 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1512 program will be doing dynamic loading, which will likely
1513 need the shared libgcc.
1515 (2) If "-ldl", then it's also a fair bet that we're doing
1516 dynamic loading.
1518 (3) For each ET_DYN we're linking against (either through -lfoo
1519 or /some/path/foo.so), check to see whether it or one of
1520 its dependencies depends on a shared libgcc.
1522 (4) If "-shared"
1524 If the runtime is fixed to look for program headers instead
1525 of calling __register_frame_info at all, for each object,
1526 use the shared libgcc if any EH symbol referenced.
1528 If crtstuff is fixed to not invoke __register_frame_info
1529 automatically, for each object, use the shared libgcc if
1530 any non-empty unwind section found.
1532 Doing any of this probably requires invoking an external program to
1533 do the actual object file scanning. */
1535 const char *p = libgcc_spec;
1536 int in_sep = 1;
1538 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1539 when given the proper command line arguments. */
1540 while (*p)
1542 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1544 init_gcc_specs (&obstack,
1545 "-lgcc_s"
1546 #ifdef USE_LIBUNWIND_EXCEPTIONS
1547 " -lunwind"
1548 #endif
1550 "-lgcc",
1551 "-lgcc_eh"
1552 #ifdef USE_LIBUNWIND_EXCEPTIONS
1553 # ifdef HAVE_LD_STATIC_DYNAMIC
1554 " %{!static:" LD_STATIC_OPTION "} -lunwind"
1555 " %{!static:" LD_DYNAMIC_OPTION "}"
1556 # else
1557 " -lunwind"
1558 # endif
1559 #endif
1562 p += 5;
1563 in_sep = 0;
1565 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1567 /* Ug. We don't know shared library extensions. Hope that
1568 systems that use this form don't do shared libraries. */
1569 init_gcc_specs (&obstack,
1570 "-lgcc_s",
1571 "libgcc.a%s",
1572 "libgcc_eh.a%s"
1573 #ifdef USE_LIBUNWIND_EXCEPTIONS
1574 " -lunwind"
1575 #endif
1577 p += 10;
1578 in_sep = 0;
1580 else
1582 obstack_1grow (&obstack, *p);
1583 in_sep = (*p == ' ');
1584 p += 1;
1588 obstack_1grow (&obstack, '\0');
1589 libgcc_spec = XOBFINISH (&obstack, const char *);
1591 #endif
1592 #ifdef USE_AS_TRADITIONAL_FORMAT
1593 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1595 static const char tf[] = "--traditional-format ";
1596 obstack_grow (&obstack, tf, sizeof (tf) - 1);
1597 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1598 asm_spec = XOBFINISH (&obstack, const char *);
1600 #endif
1602 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1603 defined LINKER_HASH_STYLE
1604 # ifdef LINK_BUILDID_SPEC
1605 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1606 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof (LINK_BUILDID_SPEC) - 1);
1607 # endif
1608 # ifdef LINK_EH_SPEC
1609 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1610 obstack_grow (&obstack, LINK_EH_SPEC, sizeof (LINK_EH_SPEC) - 1);
1611 # endif
1612 # ifdef LINKER_HASH_STYLE
1613 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1614 before. */
1616 static const char hash_style[] = "--hash-style=";
1617 obstack_grow (&obstack, hash_style, sizeof (hash_style) - 1);
1618 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof (LINKER_HASH_STYLE) - 1);
1619 obstack_1grow (&obstack, ' ');
1621 # endif
1622 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1623 link_spec = XOBFINISH (&obstack, const char *);
1624 #endif
1626 specs = sl;
1629 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1630 removed; If the spec starts with a + then SPEC is added to the end of the
1631 current spec. */
1633 static void
1634 set_spec (const char *name, const char *spec, bool user_p)
1636 struct spec_list *sl;
1637 const char *old_spec;
1638 int name_len = strlen (name);
1639 int i;
1641 /* If this is the first call, initialize the statically allocated specs. */
1642 if (!specs)
1644 struct spec_list *next = (struct spec_list *) 0;
1645 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1647 sl = &static_specs[i];
1648 sl->next = next;
1649 next = sl;
1651 specs = sl;
1654 /* See if the spec already exists. */
1655 for (sl = specs; sl; sl = sl->next)
1656 if (name_len == sl->name_len && !strcmp (sl->name, name))
1657 break;
1659 if (!sl)
1661 /* Not found - make it. */
1662 sl = XNEW (struct spec_list);
1663 sl->name = xstrdup (name);
1664 sl->name_len = name_len;
1665 sl->ptr_spec = &sl->ptr;
1666 sl->alloc_p = 0;
1667 *(sl->ptr_spec) = "";
1668 sl->next = specs;
1669 specs = sl;
1672 old_spec = *(sl->ptr_spec);
1673 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1674 ? concat (old_spec, spec + 1, NULL)
1675 : xstrdup (spec));
1677 #ifdef DEBUG_SPECS
1678 if (verbose_flag)
1679 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1680 #endif
1682 /* Free the old spec. */
1683 if (old_spec && sl->alloc_p)
1684 free (CONST_CAST (char *, old_spec));
1686 sl->user_p = user_p;
1687 sl->alloc_p = true;
1690 /* Accumulate a command (program name and args), and run it. */
1692 typedef const char *const_char_p; /* For DEF_VEC_P. */
1694 /* Vector of pointers to arguments in the current line of specifications. */
1696 static vec<const_char_p> argbuf;
1698 /* Position in the argbuf vector containing the name of the output file
1699 (the value associated with the "-o" flag). */
1701 static int have_o_argbuf_index = 0;
1703 /* Were the options -c, -S or -E passed. */
1704 static int have_c = 0;
1706 /* Was the option -o passed. */
1707 static int have_o = 0;
1709 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1710 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1711 it here. */
1713 static struct temp_name {
1714 const char *suffix; /* suffix associated with the code. */
1715 int length; /* strlen (suffix). */
1716 int unique; /* Indicates whether %g or %u/%U was used. */
1717 const char *filename; /* associated filename. */
1718 int filename_length; /* strlen (filename). */
1719 struct temp_name *next;
1720 } *temp_names;
1722 /* Number of commands executed so far. */
1724 static int execution_count;
1726 /* Number of commands that exited with a signal. */
1728 static int signal_count;
1730 /* Allocate the argument vector. */
1732 static void
1733 alloc_args (void)
1735 argbuf.create (10);
1738 /* Clear out the vector of arguments (after a command is executed). */
1740 static void
1741 clear_args (void)
1743 argbuf.truncate (0);
1746 /* Add one argument to the vector at the end.
1747 This is done when a space is seen or at the end of the line.
1748 If DELETE_ALWAYS is nonzero, the arg is a filename
1749 and the file should be deleted eventually.
1750 If DELETE_FAILURE is nonzero, the arg is a filename
1751 and the file should be deleted if this compilation fails. */
1753 static void
1754 store_arg (const char *arg, int delete_always, int delete_failure)
1756 argbuf.safe_push (arg);
1758 if (strcmp (arg, "-o") == 0)
1759 have_o_argbuf_index = argbuf.length ();
1760 if (delete_always || delete_failure)
1762 const char *p;
1763 /* If the temporary file we should delete is specified as
1764 part of a joined argument extract the filename. */
1765 if (arg[0] == '-'
1766 && (p = strrchr (arg, '=')))
1767 arg = p + 1;
1768 record_temp_file (arg, delete_always, delete_failure);
1772 /* Load specs from a file name named FILENAME, replacing occurrences of
1773 various different types of line-endings, \r\n, \n\r and just \r, with
1774 a single \n. */
1776 static char *
1777 load_specs (const char *filename)
1779 int desc;
1780 int readlen;
1781 struct stat statbuf;
1782 char *buffer;
1783 char *buffer_p;
1784 char *specs;
1785 char *specs_p;
1787 if (verbose_flag)
1788 fnotice (stderr, "Reading specs from %s\n", filename);
1790 /* Open and stat the file. */
1791 desc = open (filename, O_RDONLY, 0);
1792 if (desc < 0)
1793 pfatal_with_name (filename);
1794 if (stat (filename, &statbuf) < 0)
1795 pfatal_with_name (filename);
1797 /* Read contents of file into BUFFER. */
1798 buffer = XNEWVEC (char, statbuf.st_size + 1);
1799 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1800 if (readlen < 0)
1801 pfatal_with_name (filename);
1802 buffer[readlen] = 0;
1803 close (desc);
1805 specs = XNEWVEC (char, readlen + 1);
1806 specs_p = specs;
1807 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1809 int skip = 0;
1810 char c = *buffer_p;
1811 if (c == '\r')
1813 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1814 skip = 1;
1815 else if (*(buffer_p + 1) == '\n') /* \r\n */
1816 skip = 1;
1817 else /* \r */
1818 c = '\n';
1820 if (! skip)
1821 *specs_p++ = c;
1823 *specs_p = '\0';
1825 free (buffer);
1826 return (specs);
1829 /* Read compilation specs from a file named FILENAME,
1830 replacing the default ones.
1832 A suffix which starts with `*' is a definition for
1833 one of the machine-specific sub-specs. The "suffix" should be
1834 *asm, *cc1, *cpp, *link, *startfile, etc.
1835 The corresponding spec is stored in asm_spec, etc.,
1836 rather than in the `compilers' vector.
1838 Anything invalid in the file is a fatal error. */
1840 static void
1841 read_specs (const char *filename, bool main_p, bool user_p)
1843 char *buffer;
1844 char *p;
1846 buffer = load_specs (filename);
1848 /* Scan BUFFER for specs, putting them in the vector. */
1849 p = buffer;
1850 while (1)
1852 char *suffix;
1853 char *spec;
1854 char *in, *out, *p1, *p2, *p3;
1856 /* Advance P in BUFFER to the next nonblank nocomment line. */
1857 p = skip_whitespace (p);
1858 if (*p == 0)
1859 break;
1861 /* Is this a special command that starts with '%'? */
1862 /* Don't allow this for the main specs file, since it would
1863 encourage people to overwrite it. */
1864 if (*p == '%' && !main_p)
1866 p1 = p;
1867 while (*p && *p != '\n')
1868 p++;
1870 /* Skip '\n'. */
1871 p++;
1873 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1874 && (p1[sizeof "%include" - 1] == ' '
1875 || p1[sizeof "%include" - 1] == '\t'))
1877 char *new_filename;
1879 p1 += sizeof ("%include");
1880 while (*p1 == ' ' || *p1 == '\t')
1881 p1++;
1883 if (*p1++ != '<' || p[-2] != '>')
1884 fatal_error ("specs %%include syntax malformed after "
1885 "%ld characters",
1886 (long) (p1 - buffer + 1));
1888 p[-2] = '\0';
1889 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1890 read_specs (new_filename ? new_filename : p1, false, user_p);
1891 continue;
1893 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1894 && (p1[sizeof "%include_noerr" - 1] == ' '
1895 || p1[sizeof "%include_noerr" - 1] == '\t'))
1897 char *new_filename;
1899 p1 += sizeof "%include_noerr";
1900 while (*p1 == ' ' || *p1 == '\t')
1901 p1++;
1903 if (*p1++ != '<' || p[-2] != '>')
1904 fatal_error ("specs %%include syntax malformed after "
1905 "%ld characters",
1906 (long) (p1 - buffer + 1));
1908 p[-2] = '\0';
1909 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1910 if (new_filename)
1911 read_specs (new_filename, false, user_p);
1912 else if (verbose_flag)
1913 fnotice (stderr, "could not find specs file %s\n", p1);
1914 continue;
1916 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1917 && (p1[sizeof "%rename" - 1] == ' '
1918 || p1[sizeof "%rename" - 1] == '\t'))
1920 int name_len;
1921 struct spec_list *sl;
1922 struct spec_list *newsl;
1924 /* Get original name. */
1925 p1 += sizeof "%rename";
1926 while (*p1 == ' ' || *p1 == '\t')
1927 p1++;
1929 if (! ISALPHA ((unsigned char) *p1))
1930 fatal_error ("specs %%rename syntax malformed after "
1931 "%ld characters",
1932 (long) (p1 - buffer));
1934 p2 = p1;
1935 while (*p2 && !ISSPACE ((unsigned char) *p2))
1936 p2++;
1938 if (*p2 != ' ' && *p2 != '\t')
1939 fatal_error ("specs %%rename syntax malformed after "
1940 "%ld characters",
1941 (long) (p2 - buffer));
1943 name_len = p2 - p1;
1944 *p2++ = '\0';
1945 while (*p2 == ' ' || *p2 == '\t')
1946 p2++;
1948 if (! ISALPHA ((unsigned char) *p2))
1949 fatal_error ("specs %%rename syntax malformed after "
1950 "%ld characters",
1951 (long) (p2 - buffer));
1953 /* Get new spec name. */
1954 p3 = p2;
1955 while (*p3 && !ISSPACE ((unsigned char) *p3))
1956 p3++;
1958 if (p3 != p - 1)
1959 fatal_error ("specs %%rename syntax malformed after "
1960 "%ld characters",
1961 (long) (p3 - buffer));
1962 *p3 = '\0';
1964 for (sl = specs; sl; sl = sl->next)
1965 if (name_len == sl->name_len && !strcmp (sl->name, p1))
1966 break;
1968 if (!sl)
1969 fatal_error ("specs %s spec was not found to be renamed", p1);
1971 if (strcmp (p1, p2) == 0)
1972 continue;
1974 for (newsl = specs; newsl; newsl = newsl->next)
1975 if (strcmp (newsl->name, p2) == 0)
1976 fatal_error ("%s: attempt to rename spec %qs to "
1977 "already defined spec %qs",
1978 filename, p1, p2);
1980 if (verbose_flag)
1982 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
1983 #ifdef DEBUG_SPECS
1984 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
1985 #endif
1988 set_spec (p2, *(sl->ptr_spec), user_p);
1989 if (sl->alloc_p)
1990 free (CONST_CAST (char *, *(sl->ptr_spec)));
1992 *(sl->ptr_spec) = "";
1993 sl->alloc_p = 0;
1994 continue;
1996 else
1997 fatal_error ("specs unknown %% command after %ld characters",
1998 (long) (p1 - buffer));
2001 /* Find the colon that should end the suffix. */
2002 p1 = p;
2003 while (*p1 && *p1 != ':' && *p1 != '\n')
2004 p1++;
2006 /* The colon shouldn't be missing. */
2007 if (*p1 != ':')
2008 fatal_error ("specs file malformed after %ld characters",
2009 (long) (p1 - buffer));
2011 /* Skip back over trailing whitespace. */
2012 p2 = p1;
2013 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2014 p2--;
2016 /* Copy the suffix to a string. */
2017 suffix = save_string (p, p2 - p);
2018 /* Find the next line. */
2019 p = skip_whitespace (p1 + 1);
2020 if (p[1] == 0)
2021 fatal_error ("specs file malformed after %ld characters",
2022 (long) (p - buffer));
2024 p1 = p;
2025 /* Find next blank line or end of string. */
2026 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2027 p1++;
2029 /* Specs end at the blank line and do not include the newline. */
2030 spec = save_string (p, p1 - p);
2031 p = p1;
2033 /* Delete backslash-newline sequences from the spec. */
2034 in = spec;
2035 out = spec;
2036 while (*in != 0)
2038 if (in[0] == '\\' && in[1] == '\n')
2039 in += 2;
2040 else if (in[0] == '#')
2041 while (*in && *in != '\n')
2042 in++;
2044 else
2045 *out++ = *in++;
2047 *out = 0;
2049 if (suffix[0] == '*')
2051 if (! strcmp (suffix, "*link_command"))
2052 link_command_spec = spec;
2053 else
2054 set_spec (suffix + 1, spec, user_p);
2056 else
2058 /* Add this pair to the vector. */
2059 compilers
2060 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
2062 compilers[n_compilers].suffix = suffix;
2063 compilers[n_compilers].spec = spec;
2064 n_compilers++;
2065 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2068 if (*suffix == 0)
2069 link_command_spec = spec;
2072 if (link_command_spec == 0)
2073 fatal_error ("spec file has no spec for linking");
2076 /* Record the names of temporary files we tell compilers to write,
2077 and delete them at the end of the run. */
2079 /* This is the common prefix we use to make temp file names.
2080 It is chosen once for each run of this program.
2081 It is substituted into a spec by %g or %j.
2082 Thus, all temp file names contain this prefix.
2083 In practice, all temp file names start with this prefix.
2085 This prefix comes from the envvar TMPDIR if it is defined;
2086 otherwise, from the P_tmpdir macro if that is defined;
2087 otherwise, in /usr/tmp or /tmp;
2088 or finally the current directory if all else fails. */
2090 static const char *temp_filename;
2092 /* Length of the prefix. */
2094 static int temp_filename_length;
2096 /* Define the list of temporary files to delete. */
2098 struct temp_file
2100 const char *name;
2101 struct temp_file *next;
2104 /* Queue of files to delete on success or failure of compilation. */
2105 static struct temp_file *always_delete_queue;
2106 /* Queue of files to delete on failure of compilation. */
2107 static struct temp_file *failure_delete_queue;
2109 /* Record FILENAME as a file to be deleted automatically.
2110 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2111 otherwise delete it in any case.
2112 FAIL_DELETE nonzero means delete it if a compilation step fails;
2113 otherwise delete it in any case. */
2115 void
2116 record_temp_file (const char *filename, int always_delete, int fail_delete)
2118 char *const name = xstrdup (filename);
2120 if (always_delete)
2122 struct temp_file *temp;
2123 for (temp = always_delete_queue; temp; temp = temp->next)
2124 if (! filename_cmp (name, temp->name))
2125 goto already1;
2127 temp = XNEW (struct temp_file);
2128 temp->next = always_delete_queue;
2129 temp->name = name;
2130 always_delete_queue = temp;
2132 already1:;
2135 if (fail_delete)
2137 struct temp_file *temp;
2138 for (temp = failure_delete_queue; temp; temp = temp->next)
2139 if (! filename_cmp (name, temp->name))
2141 free (name);
2142 goto already2;
2145 temp = XNEW (struct temp_file);
2146 temp->next = failure_delete_queue;
2147 temp->name = name;
2148 failure_delete_queue = temp;
2150 already2:;
2154 /* Delete all the temporary files whose names we previously recorded. */
2156 #ifndef DELETE_IF_ORDINARY
2157 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2158 do \
2160 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2161 if (unlink (NAME) < 0) \
2162 if (VERBOSE_FLAG) \
2163 perror_with_name (NAME); \
2164 } while (0)
2165 #endif
2167 static void
2168 delete_if_ordinary (const char *name)
2170 struct stat st;
2171 #ifdef DEBUG
2172 int i, c;
2174 printf ("Delete %s? (y or n) ", name);
2175 fflush (stdout);
2176 i = getchar ();
2177 if (i != '\n')
2178 while ((c = getchar ()) != '\n' && c != EOF)
2181 if (i == 'y' || i == 'Y')
2182 #endif /* DEBUG */
2183 DELETE_IF_ORDINARY (name, st, verbose_flag);
2186 static void
2187 delete_temp_files (void)
2189 struct temp_file *temp;
2191 for (temp = always_delete_queue; temp; temp = temp->next)
2192 delete_if_ordinary (temp->name);
2193 always_delete_queue = 0;
2196 /* Delete all the files to be deleted on error. */
2198 static void
2199 delete_failure_queue (void)
2201 struct temp_file *temp;
2203 for (temp = failure_delete_queue; temp; temp = temp->next)
2204 delete_if_ordinary (temp->name);
2207 static void
2208 clear_failure_queue (void)
2210 failure_delete_queue = 0;
2213 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2214 returns non-NULL.
2215 If DO_MULTI is true iterate over the paths twice, first with multilib
2216 suffix then without, otherwise iterate over the paths once without
2217 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2218 to avoid visiting the same path twice, but we could do better. For
2219 instance, /usr/lib/../lib is considered different from /usr/lib.
2220 At least EXTRA_SPACE chars past the end of the path passed to
2221 CALLBACK are available for use by the callback.
2222 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2224 Returns the value returned by CALLBACK. */
2226 static void *
2227 for_each_path (const struct path_prefix *paths,
2228 bool do_multi,
2229 size_t extra_space,
2230 void *(*callback) (char *, void *),
2231 void *callback_info)
2233 struct prefix_list *pl;
2234 const char *multi_dir = NULL;
2235 const char *multi_os_dir = NULL;
2236 const char *multiarch_suffix = NULL;
2237 const char *multi_suffix;
2238 const char *just_multi_suffix;
2239 char *path = NULL;
2240 void *ret = NULL;
2241 bool skip_multi_dir = false;
2242 bool skip_multi_os_dir = false;
2244 multi_suffix = machine_suffix;
2245 just_multi_suffix = just_machine_suffix;
2246 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2248 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2249 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2250 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2252 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2253 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2254 if (multiarch_dir)
2255 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2257 while (1)
2259 size_t multi_dir_len = 0;
2260 size_t multi_os_dir_len = 0;
2261 size_t multiarch_len = 0;
2262 size_t suffix_len;
2263 size_t just_suffix_len;
2264 size_t len;
2266 if (multi_dir)
2267 multi_dir_len = strlen (multi_dir);
2268 if (multi_os_dir)
2269 multi_os_dir_len = strlen (multi_os_dir);
2270 if (multiarch_suffix)
2271 multiarch_len = strlen (multiarch_suffix);
2272 suffix_len = strlen (multi_suffix);
2273 just_suffix_len = strlen (just_multi_suffix);
2275 if (path == NULL)
2277 len = paths->max_len + extra_space + 1;
2278 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2279 path = XNEWVEC (char, len);
2282 for (pl = paths->plist; pl != 0; pl = pl->next)
2284 len = strlen (pl->prefix);
2285 memcpy (path, pl->prefix, len);
2287 /* Look first in MACHINE/VERSION subdirectory. */
2288 if (!skip_multi_dir)
2290 memcpy (path + len, multi_suffix, suffix_len + 1);
2291 ret = callback (path, callback_info);
2292 if (ret)
2293 break;
2296 /* Some paths are tried with just the machine (ie. target)
2297 subdir. This is used for finding as, ld, etc. */
2298 if (!skip_multi_dir
2299 && pl->require_machine_suffix == 2)
2301 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2302 ret = callback (path, callback_info);
2303 if (ret)
2304 break;
2307 /* Now try the multiarch path. */
2308 if (!skip_multi_dir
2309 && !pl->require_machine_suffix && multiarch_dir)
2311 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2312 ret = callback (path, callback_info);
2313 if (ret)
2314 break;
2317 /* Now try the base path. */
2318 if (!pl->require_machine_suffix
2319 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2321 const char *this_multi;
2322 size_t this_multi_len;
2324 if (pl->os_multilib)
2326 this_multi = multi_os_dir;
2327 this_multi_len = multi_os_dir_len;
2329 else
2331 this_multi = multi_dir;
2332 this_multi_len = multi_dir_len;
2335 if (this_multi_len)
2336 memcpy (path + len, this_multi, this_multi_len + 1);
2337 else
2338 path[len] = '\0';
2340 ret = callback (path, callback_info);
2341 if (ret)
2342 break;
2345 if (pl)
2346 break;
2348 if (multi_dir == NULL && multi_os_dir == NULL)
2349 break;
2351 /* Run through the paths again, this time without multilibs.
2352 Don't repeat any we have already seen. */
2353 if (multi_dir)
2355 free (CONST_CAST (char *, multi_dir));
2356 multi_dir = NULL;
2357 free (CONST_CAST (char *, multi_suffix));
2358 multi_suffix = machine_suffix;
2359 free (CONST_CAST (char *, just_multi_suffix));
2360 just_multi_suffix = just_machine_suffix;
2362 else
2363 skip_multi_dir = true;
2364 if (multi_os_dir)
2366 free (CONST_CAST (char *, multi_os_dir));
2367 multi_os_dir = NULL;
2369 else
2370 skip_multi_os_dir = true;
2373 if (multi_dir)
2375 free (CONST_CAST (char *, multi_dir));
2376 free (CONST_CAST (char *, multi_suffix));
2377 free (CONST_CAST (char *, just_multi_suffix));
2379 if (multi_os_dir)
2380 free (CONST_CAST (char *, multi_os_dir));
2381 if (ret != path)
2382 free (path);
2383 return ret;
2386 /* Callback for build_search_list. Adds path to obstack being built. */
2388 struct add_to_obstack_info {
2389 struct obstack *ob;
2390 bool check_dir;
2391 bool first_time;
2394 static void *
2395 add_to_obstack (char *path, void *data)
2397 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2399 if (info->check_dir && !is_directory (path, false))
2400 return NULL;
2402 if (!info->first_time)
2403 obstack_1grow (info->ob, PATH_SEPARATOR);
2405 obstack_grow (info->ob, path, strlen (path));
2407 info->first_time = false;
2408 return NULL;
2411 /* Add or change the value of an environment variable, outputting the
2412 change to standard error if in verbose mode. */
2413 static void
2414 xputenv (const char *string)
2416 if (verbose_flag)
2417 fnotice (stderr, "%s\n", string);
2418 putenv (CONST_CAST (char *, string));
2421 /* Build a list of search directories from PATHS.
2422 PREFIX is a string to prepend to the list.
2423 If CHECK_DIR_P is true we ensure the directory exists.
2424 If DO_MULTI is true, multilib paths are output first, then
2425 non-multilib paths.
2426 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2427 It is also used by the --print-search-dirs flag. */
2429 static char *
2430 build_search_list (const struct path_prefix *paths, const char *prefix,
2431 bool check_dir, bool do_multi)
2433 struct add_to_obstack_info info;
2435 info.ob = &collect_obstack;
2436 info.check_dir = check_dir;
2437 info.first_time = true;
2439 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2440 obstack_1grow (&collect_obstack, '=');
2442 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2444 obstack_1grow (&collect_obstack, '\0');
2445 return XOBFINISH (&collect_obstack, char *);
2448 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2449 for collect. */
2451 static void
2452 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2453 bool do_multi)
2455 xputenv (build_search_list (paths, env_var, true, do_multi));
2458 /* Check whether NAME can be accessed in MODE. This is like access,
2459 except that it never considers directories to be executable. */
2461 static int
2462 access_check (const char *name, int mode)
2464 if (mode == X_OK)
2466 struct stat st;
2468 if (stat (name, &st) < 0
2469 || S_ISDIR (st.st_mode))
2470 return -1;
2473 return access (name, mode);
2476 /* Callback for find_a_file. Appends the file name to the directory
2477 path. If the resulting file exists in the right mode, return the
2478 full pathname to the file. */
2480 struct file_at_path_info {
2481 const char *name;
2482 const char *suffix;
2483 int name_len;
2484 int suffix_len;
2485 int mode;
2488 static void *
2489 file_at_path (char *path, void *data)
2491 struct file_at_path_info *info = (struct file_at_path_info *) data;
2492 size_t len = strlen (path);
2494 memcpy (path + len, info->name, info->name_len);
2495 len += info->name_len;
2497 /* Some systems have a suffix for executable files.
2498 So try appending that first. */
2499 if (info->suffix_len)
2501 memcpy (path + len, info->suffix, info->suffix_len + 1);
2502 if (access_check (path, info->mode) == 0)
2503 return path;
2506 path[len] = '\0';
2507 if (access_check (path, info->mode) == 0)
2508 return path;
2510 return NULL;
2513 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2514 access to check permissions. If DO_MULTI is true, search multilib
2515 paths then non-multilib paths, otherwise do not search multilib paths.
2516 Return 0 if not found, otherwise return its name, allocated with malloc. */
2518 static char *
2519 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2520 bool do_multi)
2522 struct file_at_path_info info;
2524 #ifdef DEFAULT_ASSEMBLER
2525 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2526 return xstrdup (DEFAULT_ASSEMBLER);
2527 #endif
2529 #ifdef DEFAULT_LINKER
2530 if (! strcmp (name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2531 return xstrdup (DEFAULT_LINKER);
2532 #endif
2534 /* Determine the filename to execute (special case for absolute paths). */
2536 if (IS_ABSOLUTE_PATH (name))
2538 if (access (name, mode) == 0)
2539 return xstrdup (name);
2541 return NULL;
2544 info.name = name;
2545 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2546 info.name_len = strlen (info.name);
2547 info.suffix_len = strlen (info.suffix);
2548 info.mode = mode;
2550 return (char*) for_each_path (pprefix, do_multi,
2551 info.name_len + info.suffix_len,
2552 file_at_path, &info);
2555 /* Ranking of prefixes in the sort list. -B prefixes are put before
2556 all others. */
2558 enum path_prefix_priority
2560 PREFIX_PRIORITY_B_OPT,
2561 PREFIX_PRIORITY_LAST
2564 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2565 order according to PRIORITY. Within each PRIORITY, new entries are
2566 appended.
2568 If WARN is nonzero, we will warn if no file is found
2569 through this prefix. WARN should point to an int
2570 which will be set to 1 if this entry is used.
2572 COMPONENT is the value to be passed to update_path.
2574 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2575 the complete value of machine_suffix.
2576 2 means try both machine_suffix and just_machine_suffix. */
2578 static void
2579 add_prefix (struct path_prefix *pprefix, const char *prefix,
2580 const char *component, /* enum prefix_priority */ int priority,
2581 int require_machine_suffix, int os_multilib)
2583 struct prefix_list *pl, **prev;
2584 int len;
2586 for (prev = &pprefix->plist;
2587 (*prev) != NULL && (*prev)->priority <= priority;
2588 prev = &(*prev)->next)
2591 /* Keep track of the longest prefix. */
2593 prefix = update_path (prefix, component);
2594 len = strlen (prefix);
2595 if (len > pprefix->max_len)
2596 pprefix->max_len = len;
2598 pl = XNEW (struct prefix_list);
2599 pl->prefix = prefix;
2600 pl->require_machine_suffix = require_machine_suffix;
2601 pl->priority = priority;
2602 pl->os_multilib = os_multilib;
2604 /* Insert after PREV. */
2605 pl->next = (*prev);
2606 (*prev) = pl;
2609 /* Same as add_prefix, but prepending target_system_root to prefix. */
2610 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2611 static void
2612 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2613 const char *component,
2614 /* enum prefix_priority */ int priority,
2615 int require_machine_suffix, int os_multilib)
2617 if (!IS_ABSOLUTE_PATH (prefix))
2618 fatal_error ("system path %qs is not absolute", prefix);
2620 if (target_system_root)
2622 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2623 size_t sysroot_len = strlen (target_system_root);
2625 if (sysroot_len > 0
2626 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2627 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2629 if (target_sysroot_suffix)
2630 prefix = concat (sysroot_no_trailing_dir_separator,
2631 target_sysroot_suffix, prefix, NULL);
2632 else
2633 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2635 free (sysroot_no_trailing_dir_separator);
2637 /* We have to override this because GCC's notion of sysroot
2638 moves along with GCC. */
2639 component = "GCC";
2642 add_prefix (pprefix, prefix, component, priority,
2643 require_machine_suffix, os_multilib);
2646 /* Execute the command specified by the arguments on the current line of spec.
2647 When using pipes, this includes several piped-together commands
2648 with `|' between them.
2650 Return 0 if successful, -1 if failed. */
2652 static int
2653 execute (void)
2655 int i;
2656 int n_commands; /* # of command. */
2657 char *string;
2658 struct pex_obj *pex;
2659 struct command
2661 const char *prog; /* program name. */
2662 const char **argv; /* vector of args. */
2664 const char *arg;
2666 struct command *commands; /* each command buffer with above info. */
2668 gcc_assert (!processing_spec_function);
2670 if (wrapper_string)
2672 string = find_a_file (&exec_prefixes,
2673 argbuf[0], X_OK, false);
2674 if (string)
2675 argbuf[0] = string;
2676 insert_wrapper (wrapper_string);
2679 /* Count # of piped commands. */
2680 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2681 if (strcmp (arg, "|") == 0)
2682 n_commands++;
2684 /* Get storage for each command. */
2685 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2687 /* Split argbuf into its separate piped processes,
2688 and record info about each one.
2689 Also search for the programs that are to be run. */
2691 argbuf.safe_push (0);
2693 commands[0].prog = argbuf[0]; /* first command. */
2694 commands[0].argv = argbuf.address ();
2696 if (!wrapper_string)
2698 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2699 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2702 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2703 if (arg && strcmp (arg, "|") == 0)
2704 { /* each command. */
2705 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2706 fatal_error ("-pipe not supported");
2707 #endif
2708 argbuf[i] = 0; /* Termination of
2709 command args. */
2710 commands[n_commands].prog = argbuf[i + 1];
2711 commands[n_commands].argv
2712 = &(argbuf.address ())[i + 1];
2713 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2714 X_OK, false);
2715 if (string)
2716 commands[n_commands].argv[0] = string;
2717 n_commands++;
2720 /* If -v, print what we are about to do, and maybe query. */
2722 if (verbose_flag)
2724 /* For help listings, put a blank line between sub-processes. */
2725 if (print_help_list)
2726 fputc ('\n', stderr);
2728 /* Print each piped command as a separate line. */
2729 for (i = 0; i < n_commands; i++)
2731 const char *const *j;
2733 if (verbose_only_flag)
2735 for (j = commands[i].argv; *j; j++)
2737 const char *p;
2738 for (p = *j; *p; ++p)
2739 if (!ISALNUM ((unsigned char) *p)
2740 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2741 break;
2742 if (*p || !*j)
2744 fprintf (stderr, " \"");
2745 for (p = *j; *p; ++p)
2747 if (*p == '"' || *p == '\\' || *p == '$')
2748 fputc ('\\', stderr);
2749 fputc (*p, stderr);
2751 fputc ('"', stderr);
2753 /* If it's empty, print "". */
2754 else if (!**j)
2755 fprintf (stderr, " \"\"");
2756 else
2757 fprintf (stderr, " %s", *j);
2760 else
2761 for (j = commands[i].argv; *j; j++)
2762 /* If it's empty, print "". */
2763 if (!**j)
2764 fprintf (stderr, " \"\"");
2765 else
2766 fprintf (stderr, " %s", *j);
2768 /* Print a pipe symbol after all but the last command. */
2769 if (i + 1 != n_commands)
2770 fprintf (stderr, " |");
2771 fprintf (stderr, "\n");
2773 fflush (stderr);
2774 if (verbose_only_flag != 0)
2776 /* verbose_only_flag should act as if the spec was
2777 executed, so increment execution_count before
2778 returning. This prevents spurious warnings about
2779 unused linker input files, etc. */
2780 execution_count++;
2781 return 0;
2783 #ifdef DEBUG
2784 fnotice (stderr, "\nGo ahead? (y or n) ");
2785 fflush (stderr);
2786 i = getchar ();
2787 if (i != '\n')
2788 while (getchar () != '\n')
2791 if (i != 'y' && i != 'Y')
2792 return 0;
2793 #endif /* DEBUG */
2796 #ifdef ENABLE_VALGRIND_CHECKING
2797 /* Run the each command through valgrind. To simplify prepending the
2798 path to valgrind and the option "-q" (for quiet operation unless
2799 something triggers), we allocate a separate argv array. */
2801 for (i = 0; i < n_commands; i++)
2803 const char **argv;
2804 int argc;
2805 int j;
2807 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2810 argv = XALLOCAVEC (const char *, argc + 3);
2812 argv[0] = VALGRIND_PATH;
2813 argv[1] = "-q";
2814 for (j = 2; j < argc + 2; j++)
2815 argv[j] = commands[i].argv[j - 2];
2816 argv[j] = NULL;
2818 commands[i].argv = argv;
2819 commands[i].prog = argv[0];
2821 #endif
2823 /* Run each piped subprocess. */
2825 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
2826 ? PEX_RECORD_TIMES : 0),
2827 progname, temp_filename);
2828 if (pex == NULL)
2829 fatal_error ("pex_init failed: %m");
2831 for (i = 0; i < n_commands; i++)
2833 const char *errmsg;
2834 int err;
2835 const char *string = commands[i].argv[0];
2837 errmsg = pex_run (pex,
2838 ((i + 1 == n_commands ? PEX_LAST : 0)
2839 | (string == commands[i].prog ? PEX_SEARCH : 0)),
2840 string, CONST_CAST (char **, commands[i].argv),
2841 NULL, NULL, &err);
2842 if (errmsg != NULL)
2844 if (err == 0)
2845 fatal_error (errmsg);
2846 else
2848 errno = err;
2849 pfatal_with_name (errmsg);
2853 if (string != commands[i].prog)
2854 free (CONST_CAST (char *, string));
2857 execution_count++;
2859 /* Wait for all the subprocesses to finish. */
2862 int *statuses;
2863 struct pex_time *times = NULL;
2864 int ret_code = 0;
2866 statuses = (int *) alloca (n_commands * sizeof (int));
2867 if (!pex_get_status (pex, n_commands, statuses))
2868 fatal_error ("failed to get exit status: %m");
2870 if (report_times || report_times_to_file)
2872 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
2873 if (!pex_get_times (pex, n_commands, times))
2874 fatal_error ("failed to get process times: %m");
2877 pex_free (pex);
2879 for (i = 0; i < n_commands; ++i)
2881 int status = statuses[i];
2883 if (WIFSIGNALED (status))
2885 #ifdef SIGPIPE
2886 /* SIGPIPE is a special case. It happens in -pipe mode
2887 when the compiler dies before the preprocessor is done,
2888 or the assembler dies before the compiler is done.
2889 There's generally been an error already, and this is
2890 just fallout. So don't generate another error unless
2891 we would otherwise have succeeded. */
2892 if (WTERMSIG (status) == SIGPIPE
2893 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2895 signal_count++;
2896 ret_code = -1;
2898 else
2899 #endif
2900 internal_error ("%s (program %s)",
2901 strsignal (WTERMSIG (status)), commands[i].prog);
2903 else if (WIFEXITED (status)
2904 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2906 if (WEXITSTATUS (status) > greatest_status)
2907 greatest_status = WEXITSTATUS (status);
2908 ret_code = -1;
2911 if (report_times || report_times_to_file)
2913 struct pex_time *pt = &times[i];
2914 double ut, st;
2916 ut = ((double) pt->user_seconds
2917 + (double) pt->user_microseconds / 1.0e6);
2918 st = ((double) pt->system_seconds
2919 + (double) pt->system_microseconds / 1.0e6);
2921 if (ut + st != 0)
2923 if (report_times)
2924 fnotice (stderr, "# %s %.2f %.2f\n",
2925 commands[i].prog, ut, st);
2927 if (report_times_to_file)
2929 int c = 0;
2930 const char *const *j;
2932 fprintf (report_times_to_file, "%g %g", ut, st);
2934 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
2936 const char *p;
2937 for (p = *j; *p; ++p)
2938 if (*p == '"' || *p == '\\' || *p == '$'
2939 || ISSPACE (*p))
2940 break;
2942 if (*p)
2944 fprintf (report_times_to_file, " \"");
2945 for (p = *j; *p; ++p)
2947 if (*p == '"' || *p == '\\' || *p == '$')
2948 fputc ('\\', report_times_to_file);
2949 fputc (*p, report_times_to_file);
2951 fputc ('"', report_times_to_file);
2953 else
2954 fprintf (report_times_to_file, " %s", *j);
2957 fputc ('\n', report_times_to_file);
2963 return ret_code;
2967 /* Find all the switches given to us
2968 and make a vector describing them.
2969 The elements of the vector are strings, one per switch given.
2970 If a switch uses following arguments, then the `part1' field
2971 is the switch itself and the `args' field
2972 is a null-terminated vector containing the following arguments.
2973 Bits in the `live_cond' field are:
2974 SWITCH_LIVE to indicate this switch is true in a conditional spec.
2975 SWITCH_FALSE to indicate this switch is overridden by a later switch.
2976 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
2977 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored
2978 in all do_spec calls afterwards. Used for %<S from self specs.
2979 The `validated' field is nonzero if any spec has looked at this switch;
2980 if it remains zero at the end of the run, it must be meaningless. */
2982 #define SWITCH_LIVE (1 << 0)
2983 #define SWITCH_FALSE (1 << 1)
2984 #define SWITCH_IGNORE (1 << 2)
2985 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
2986 #define SWITCH_KEEP_FOR_GCC (1 << 4)
2988 struct switchstr
2990 const char *part1;
2991 const char **args;
2992 unsigned int live_cond;
2993 bool known;
2994 bool validated;
2995 bool ordering;
2998 static struct switchstr *switches;
3000 static int n_switches;
3002 static int n_switches_alloc;
3004 /* Set to zero if -fcompare-debug is disabled, positive if it's
3005 enabled and we're running the first compilation, negative if it's
3006 enabled and we're running the second compilation. For most of the
3007 time, it's in the range -1..1, but it can be temporarily set to 2
3008 or 3 to indicate that the -fcompare-debug flags didn't come from
3009 the command-line, but rather from the GCC_COMPARE_DEBUG environment
3010 variable, until a synthesized -fcompare-debug flag is added to the
3011 command line. */
3012 int compare_debug;
3014 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
3015 int compare_debug_second;
3017 /* Set to the flags that should be passed to the second compilation in
3018 a -fcompare-debug compilation. */
3019 const char *compare_debug_opt;
3021 static struct switchstr *switches_debug_check[2];
3023 static int n_switches_debug_check[2];
3025 static int n_switches_alloc_debug_check[2];
3027 static char *debug_check_temp_file[2];
3029 /* Language is one of three things:
3031 1) The name of a real programming language.
3032 2) NULL, indicating that no one has figured out
3033 what it is yet.
3034 3) '*', indicating that the file should be passed
3035 to the linker. */
3036 struct infile
3038 const char *name;
3039 const char *language;
3040 struct compiler *incompiler;
3041 bool compiled;
3042 bool preprocessed;
3045 /* Also a vector of input files specified. */
3047 static struct infile *infiles;
3049 int n_infiles;
3051 static int n_infiles_alloc;
3053 /* True if multiple input files are being compiled to a single
3054 assembly file. */
3056 static bool combine_inputs;
3058 /* This counts the number of libraries added by lang_specific_driver, so that
3059 we can tell if there were any user supplied any files or libraries. */
3061 static int added_libraries;
3063 /* And a vector of corresponding output files is made up later. */
3065 const char **outfiles;
3067 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3069 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3070 is true if we should look for an executable suffix. DO_OBJ
3071 is true if we should look for an object suffix. */
3073 static const char *
3074 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3075 int do_obj ATTRIBUTE_UNUSED)
3077 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3078 int i;
3079 #endif
3080 int len;
3082 if (name == NULL)
3083 return NULL;
3085 len = strlen (name);
3087 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3088 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3089 if (do_obj && len > 2
3090 && name[len - 2] == '.'
3091 && name[len - 1] == 'o')
3093 obstack_grow (&obstack, name, len - 2);
3094 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3095 name = XOBFINISH (&obstack, const char *);
3097 #endif
3099 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3100 /* If there is no filetype, make it the executable suffix (which includes
3101 the "."). But don't get confused if we have just "-o". */
3102 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3103 return name;
3105 for (i = len - 1; i >= 0; i--)
3106 if (IS_DIR_SEPARATOR (name[i]))
3107 break;
3109 for (i++; i < len; i++)
3110 if (name[i] == '.')
3111 return name;
3113 obstack_grow (&obstack, name, len);
3114 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3115 strlen (TARGET_EXECUTABLE_SUFFIX));
3116 name = XOBFINISH (&obstack, const char *);
3117 #endif
3119 return name;
3121 #endif
3123 /* Display the command line switches accepted by gcc. */
3124 static void
3125 display_help (void)
3127 printf (_("Usage: %s [options] file...\n"), progname);
3128 fputs (_("Options:\n"), stdout);
3130 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3131 fputs (_(" --help Display this information\n"), stdout);
3132 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3133 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...]\n"), stdout);
3134 fputs (_(" Display specific types of command line options\n"), stdout);
3135 if (! verbose_flag)
3136 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3137 fputs (_(" --version Display compiler version information\n"), stdout);
3138 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3139 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3140 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3141 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3142 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3143 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3144 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3145 fputs (_("\
3146 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3147 a component in the library path\n"), stdout);
3148 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3149 fputs (_("\
3150 -print-multi-lib Display the mapping between command line options and\n\
3151 multiple library search directories\n"), stdout);
3152 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3153 fputs (_(" -print-sysroot Display the target libraries directory\n"), stdout);
3154 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
3155 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3156 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3157 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3158 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3159 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3160 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3161 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3162 fputs (_(" -save-temps=<arg> Do not delete intermediate files\n"), stdout);
3163 fputs (_("\
3164 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3165 prefixes to other gcc components\n"), stdout);
3166 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3167 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3168 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3169 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3170 fputs (_("\
3171 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3172 and libraries\n"), stdout);
3173 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3174 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3175 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3176 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3177 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3178 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3179 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3180 fputs (_(" -pie Create a position independent executable\n"), stdout);
3181 fputs (_(" -shared Create a shared library\n"), stdout);
3182 fputs (_("\
3183 -x <language> Specify the language of the following input files\n\
3184 Permissible languages include: c c++ assembler none\n\
3185 'none' means revert to the default behavior of\n\
3186 guessing the language based on the file's extension\n\
3187 "), stdout);
3189 printf (_("\
3190 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3191 passed on to the various sub-processes invoked by %s. In order to pass\n\
3192 other options on to these processes the -W<letter> options must be used.\n\
3193 "), progname);
3195 /* The rest of the options are displayed by invocations of the various
3196 sub-processes. */
3199 static void
3200 add_preprocessor_option (const char *option, int len)
3202 preprocessor_options.safe_push (save_string (option, len));
3205 static void
3206 add_assembler_option (const char *option, int len)
3208 assembler_options.safe_push (save_string (option, len));
3211 static void
3212 add_linker_option (const char *option, int len)
3214 linker_options.safe_push (save_string (option, len));
3217 /* Allocate space for an input file in infiles. */
3219 static void
3220 alloc_infile (void)
3222 if (n_infiles_alloc == 0)
3224 n_infiles_alloc = 16;
3225 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3227 else if (n_infiles_alloc == n_infiles)
3229 n_infiles_alloc *= 2;
3230 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3234 /* Store an input file with the given NAME and LANGUAGE in
3235 infiles. */
3237 static void
3238 add_infile (const char *name, const char *language)
3240 alloc_infile ();
3241 infiles[n_infiles].name = name;
3242 infiles[n_infiles++].language = language;
3245 /* Allocate space for a switch in switches. */
3247 static void
3248 alloc_switch (void)
3250 if (n_switches_alloc == 0)
3252 n_switches_alloc = 16;
3253 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3255 else if (n_switches_alloc == n_switches)
3257 n_switches_alloc *= 2;
3258 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3262 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3263 as validated if VALIDATED and KNOWN if it is an internal switch. */
3265 static void
3266 save_switch (const char *opt, size_t n_args, const char *const *args,
3267 bool validated, bool known)
3269 alloc_switch ();
3270 switches[n_switches].part1 = opt + 1;
3271 if (n_args == 0)
3272 switches[n_switches].args = 0;
3273 else
3275 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3276 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3277 switches[n_switches].args[n_args] = NULL;
3280 switches[n_switches].live_cond = 0;
3281 switches[n_switches].validated = validated;
3282 switches[n_switches].known = known;
3283 switches[n_switches].ordering = 0;
3284 n_switches++;
3287 /* Handle an option DECODED that is unknown to the option-processing
3288 machinery. */
3290 static bool
3291 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3293 const char *opt = decoded->arg;
3294 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3295 && !(decoded->errors & CL_ERR_NEGATIVE))
3297 /* Leave unknown -Wno-* options for the compiler proper, to be
3298 diagnosed only if there are warnings. */
3299 save_switch (decoded->canonical_option[0],
3300 decoded->canonical_option_num_elements - 1,
3301 &decoded->canonical_option[1], false, true);
3302 return false;
3304 if (decoded->opt_index == OPT_SPECIAL_unknown)
3306 /* Give it a chance to define it a a spec file. */
3307 save_switch (decoded->canonical_option[0],
3308 decoded->canonical_option_num_elements - 1,
3309 &decoded->canonical_option[1], false, false);
3310 return false;
3312 else
3313 return true;
3316 /* Handle an option DECODED that is not marked as CL_DRIVER.
3317 LANG_MASK will always be CL_DRIVER. */
3319 static void
3320 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3321 unsigned int lang_mask ATTRIBUTE_UNUSED)
3323 /* At this point, non-driver options are accepted (and expected to
3324 be passed down by specs) unless marked to be rejected by the
3325 driver. Options to be rejected by the driver but accepted by the
3326 compilers proper are treated just like completely unknown
3327 options. */
3328 const struct cl_option *option = &cl_options[decoded->opt_index];
3330 if (option->cl_reject_driver)
3331 error ("unrecognized command line option %qs",
3332 decoded->orig_option_with_args_text);
3333 else
3334 save_switch (decoded->canonical_option[0],
3335 decoded->canonical_option_num_elements - 1,
3336 &decoded->canonical_option[1], false, true);
3339 static const char *spec_lang = 0;
3340 static int last_language_n_infiles;
3342 /* Handle a driver option; arguments and return value as for
3343 handle_option. */
3345 static bool
3346 driver_handle_option (struct gcc_options *opts,
3347 struct gcc_options *opts_set,
3348 const struct cl_decoded_option *decoded,
3349 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3350 location_t loc,
3351 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3352 diagnostic_context *dc)
3354 size_t opt_index = decoded->opt_index;
3355 const char *arg = decoded->arg;
3356 const char *compare_debug_replacement_opt;
3357 int value = decoded->value;
3358 bool validated = false;
3359 bool do_save = true;
3361 gcc_assert (opts == &global_options);
3362 gcc_assert (opts_set == &global_options_set);
3363 gcc_assert (kind == DK_UNSPECIFIED);
3364 gcc_assert (loc == UNKNOWN_LOCATION);
3365 gcc_assert (dc == global_dc);
3367 switch (opt_index)
3369 case OPT_dumpspecs:
3371 struct spec_list *sl;
3372 init_spec ();
3373 for (sl = specs; sl; sl = sl->next)
3374 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3375 if (link_command_spec)
3376 printf ("*link_command:\n%s\n\n", link_command_spec);
3377 exit (0);
3380 case OPT_dumpversion:
3381 printf ("%s\n", spec_version);
3382 exit (0);
3384 case OPT_dumpmachine:
3385 printf ("%s\n", spec_machine);
3386 exit (0);
3388 case OPT__version:
3389 print_version = 1;
3391 /* CPP driver cannot obtain switch from cc1_options. */
3392 if (is_cpp_driver)
3393 add_preprocessor_option ("--version", strlen ("--version"));
3394 add_assembler_option ("--version", strlen ("--version"));
3395 add_linker_option ("--version", strlen ("--version"));
3396 break;
3398 case OPT__help:
3399 print_help_list = 1;
3401 /* CPP driver cannot obtain switch from cc1_options. */
3402 if (is_cpp_driver)
3403 add_preprocessor_option ("--help", 6);
3404 add_assembler_option ("--help", 6);
3405 add_linker_option ("--help", 6);
3406 break;
3408 case OPT__help_:
3409 print_subprocess_help = 2;
3410 break;
3412 case OPT__target_help:
3413 print_subprocess_help = 1;
3415 /* CPP driver cannot obtain switch from cc1_options. */
3416 if (is_cpp_driver)
3417 add_preprocessor_option ("--target-help", 13);
3418 add_assembler_option ("--target-help", 13);
3419 add_linker_option ("--target-help", 13);
3420 break;
3422 case OPT__no_sysroot_suffix:
3423 case OPT_pass_exit_codes:
3424 case OPT_print_search_dirs:
3425 case OPT_print_file_name_:
3426 case OPT_print_prog_name_:
3427 case OPT_print_multi_lib:
3428 case OPT_print_multi_directory:
3429 case OPT_print_sysroot:
3430 case OPT_print_multi_os_directory:
3431 case OPT_print_multiarch:
3432 case OPT_print_sysroot_headers_suffix:
3433 case OPT_time:
3434 case OPT_wrapper:
3435 /* These options set the variables specified in common.opt
3436 automatically, and do not need to be saved for spec
3437 processing. */
3438 do_save = false;
3439 break;
3441 case OPT_print_libgcc_file_name:
3442 print_file_name = "libgcc.a";
3443 do_save = false;
3444 break;
3446 case OPT_fuse_ld_bfd:
3447 use_ld = ".bfd";
3448 break;
3450 case OPT_fuse_ld_gold:
3451 use_ld = ".gold";
3452 break;
3454 case OPT_fcompare_debug_second:
3455 compare_debug_second = 1;
3456 break;
3458 case OPT_fcompare_debug:
3459 switch (value)
3461 case 0:
3462 compare_debug_replacement_opt = "-fcompare-debug=";
3463 arg = "";
3464 goto compare_debug_with_arg;
3466 case 1:
3467 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3468 arg = "-gtoggle";
3469 goto compare_debug_with_arg;
3471 default:
3472 gcc_unreachable ();
3474 break;
3476 case OPT_fcompare_debug_:
3477 compare_debug_replacement_opt = decoded->canonical_option[0];
3478 compare_debug_with_arg:
3479 gcc_assert (decoded->canonical_option_num_elements == 1);
3480 gcc_assert (arg != NULL);
3481 if (*arg)
3482 compare_debug = 1;
3483 else
3484 compare_debug = -1;
3485 if (compare_debug < 0)
3486 compare_debug_opt = NULL;
3487 else
3488 compare_debug_opt = arg;
3489 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3490 return true;
3492 case OPT_Wa_:
3494 int prev, j;
3495 /* Pass the rest of this option to the assembler. */
3497 /* Split the argument at commas. */
3498 prev = 0;
3499 for (j = 0; arg[j]; j++)
3500 if (arg[j] == ',')
3502 add_assembler_option (arg + prev, j - prev);
3503 prev = j + 1;
3506 /* Record the part after the last comma. */
3507 add_assembler_option (arg + prev, j - prev);
3509 do_save = false;
3510 break;
3512 case OPT_Wp_:
3514 int prev, j;
3515 /* Pass the rest of this option to the preprocessor. */
3517 /* Split the argument at commas. */
3518 prev = 0;
3519 for (j = 0; arg[j]; j++)
3520 if (arg[j] == ',')
3522 add_preprocessor_option (arg + prev, j - prev);
3523 prev = j + 1;
3526 /* Record the part after the last comma. */
3527 add_preprocessor_option (arg + prev, j - prev);
3529 do_save = false;
3530 break;
3532 case OPT_Wl_:
3534 int prev, j;
3535 /* Split the argument at commas. */
3536 prev = 0;
3537 for (j = 0; arg[j]; j++)
3538 if (arg[j] == ',')
3540 add_infile (save_string (arg + prev, j - prev), "*");
3541 prev = j + 1;
3543 /* Record the part after the last comma. */
3544 add_infile (arg + prev, "*");
3546 do_save = false;
3547 break;
3549 case OPT_Xlinker:
3550 add_infile (arg, "*");
3551 do_save = false;
3552 break;
3554 case OPT_Xpreprocessor:
3555 add_preprocessor_option (arg, strlen (arg));
3556 do_save = false;
3557 break;
3559 case OPT_Xassembler:
3560 add_assembler_option (arg, strlen (arg));
3561 do_save = false;
3562 break;
3564 case OPT_l:
3565 /* POSIX allows separation of -l and the lib arg; canonicalize
3566 by concatenating -l with its arg */
3567 add_infile (concat ("-l", arg, NULL), "*");
3568 do_save = false;
3569 break;
3571 case OPT_L:
3572 /* Similarly, canonicalize -L for linkers that may not accept
3573 separate arguments. */
3574 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
3575 return true;
3577 case OPT_F:
3578 /* Likewise -F. */
3579 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
3580 return true;
3582 case OPT_save_temps:
3583 save_temps_flag = SAVE_TEMPS_CWD;
3584 validated = true;
3585 break;
3587 case OPT_save_temps_:
3588 if (strcmp (arg, "cwd") == 0)
3589 save_temps_flag = SAVE_TEMPS_CWD;
3590 else if (strcmp (arg, "obj") == 0
3591 || strcmp (arg, "object") == 0)
3592 save_temps_flag = SAVE_TEMPS_OBJ;
3593 else
3594 fatal_error ("%qs is an unknown -save-temps option",
3595 decoded->orig_option_with_args_text);
3596 break;
3598 case OPT_no_canonical_prefixes:
3599 /* Already handled as a special case, so ignored here. */
3600 do_save = false;
3601 break;
3603 case OPT_pipe:
3604 validated = true;
3605 /* These options set the variables specified in common.opt
3606 automatically, but do need to be saved for spec
3607 processing. */
3608 break;
3610 case OPT_specs_:
3612 struct user_specs *user = XNEW (struct user_specs);
3614 user->next = (struct user_specs *) 0;
3615 user->filename = arg;
3616 if (user_specs_tail)
3617 user_specs_tail->next = user;
3618 else
3619 user_specs_head = user;
3620 user_specs_tail = user;
3622 validated = true;
3623 break;
3625 case OPT__sysroot_:
3626 target_system_root = arg;
3627 target_system_root_changed = 1;
3628 do_save = false;
3629 break;
3631 case OPT_time_:
3632 if (report_times_to_file)
3633 fclose (report_times_to_file);
3634 report_times_to_file = fopen (arg, "a");
3635 do_save = false;
3636 break;
3638 case OPT____:
3639 /* "-###"
3640 This is similar to -v except that there is no execution
3641 of the commands and the echoed arguments are quoted. It
3642 is intended for use in shell scripts to capture the
3643 driver-generated command line. */
3644 verbose_only_flag++;
3645 verbose_flag = 1;
3646 do_save = false;
3647 break;
3649 case OPT_B:
3651 size_t len = strlen (arg);
3653 /* Catch the case where the user has forgotten to append a
3654 directory separator to the path. Note, they may be using
3655 -B to add an executable name prefix, eg "i386-elf-", in
3656 order to distinguish between multiple installations of
3657 GCC in the same directory. Hence we must check to see
3658 if appending a directory separator actually makes a
3659 valid directory name. */
3660 if (!IS_DIR_SEPARATOR (arg[len - 1])
3661 && is_directory (arg, false))
3663 char *tmp = XNEWVEC (char, len + 2);
3664 strcpy (tmp, arg);
3665 tmp[len] = DIR_SEPARATOR;
3666 tmp[++len] = 0;
3667 arg = tmp;
3670 add_prefix (&exec_prefixes, arg, NULL,
3671 PREFIX_PRIORITY_B_OPT, 0, 0);
3672 add_prefix (&startfile_prefixes, arg, NULL,
3673 PREFIX_PRIORITY_B_OPT, 0, 0);
3674 add_prefix (&include_prefixes, arg, NULL,
3675 PREFIX_PRIORITY_B_OPT, 0, 0);
3677 validated = true;
3678 break;
3680 case OPT_x:
3681 spec_lang = arg;
3682 if (!strcmp (spec_lang, "none"))
3683 /* Suppress the warning if -xnone comes after the last input
3684 file, because alternate command interfaces like g++ might
3685 find it useful to place -xnone after each input file. */
3686 spec_lang = 0;
3687 else
3688 last_language_n_infiles = n_infiles;
3689 do_save = false;
3690 break;
3692 case OPT_o:
3693 have_o = 1;
3694 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3695 arg = convert_filename (arg, ! have_c, 0);
3696 #endif
3697 /* Save the output name in case -save-temps=obj was used. */
3698 save_temps_prefix = xstrdup (arg);
3699 /* On some systems, ld cannot handle "-o" without a space. So
3700 split the option from its argument. */
3701 save_switch ("-o", 1, &arg, validated, true);
3702 return true;
3704 case OPT_static_libgcc:
3705 case OPT_shared_libgcc:
3706 case OPT_static_libgfortran:
3707 case OPT_static_libstdc__:
3708 /* These are always valid, since gcc.c itself understands the
3709 first two, gfortranspec.c understands -static-libgfortran and
3710 g++spec.c understands -static-libstdc++ */
3711 validated = true;
3712 break;
3714 case OPT_fwpa:
3715 flag_wpa = "";
3716 break;
3718 default:
3719 /* Various driver options need no special processing at this
3720 point, having been handled in a prescan above or being
3721 handled by specs. */
3722 break;
3725 if (do_save)
3726 save_switch (decoded->canonical_option[0],
3727 decoded->canonical_option_num_elements - 1,
3728 &decoded->canonical_option[1], validated, true);
3729 return true;
3732 /* Put the driver's standard set of option handlers in *HANDLERS. */
3734 static void
3735 set_option_handlers (struct cl_option_handlers *handlers)
3737 handlers->unknown_option_callback = driver_unknown_option_callback;
3738 handlers->wrong_lang_callback = driver_wrong_lang_callback;
3739 handlers->num_handlers = 3;
3740 handlers->handlers[0].handler = driver_handle_option;
3741 handlers->handlers[0].mask = CL_DRIVER;
3742 handlers->handlers[1].handler = common_handle_option;
3743 handlers->handlers[1].mask = CL_COMMON;
3744 handlers->handlers[2].handler = target_handle_option;
3745 handlers->handlers[2].mask = CL_TARGET;
3748 /* Create the vector `switches' and its contents.
3749 Store its length in `n_switches'. */
3751 static void
3752 process_command (unsigned int decoded_options_count,
3753 struct cl_decoded_option *decoded_options)
3755 const char *temp;
3756 char *temp1;
3757 char *tooldir_prefix, *tooldir_prefix2;
3758 char *(*get_relative_prefix) (const char *, const char *,
3759 const char *) = NULL;
3760 struct cl_option_handlers handlers;
3761 unsigned int j;
3763 gcc_exec_prefix = getenv ("GCC_EXEC_PREFIX");
3765 n_switches = 0;
3766 n_infiles = 0;
3767 added_libraries = 0;
3769 /* Figure compiler version from version string. */
3771 compiler_version = temp1 = xstrdup (version_string);
3773 for (; *temp1; ++temp1)
3775 if (*temp1 == ' ')
3777 *temp1 = '\0';
3778 break;
3782 /* Handle any -no-canonical-prefixes flag early, to assign the function
3783 that builds relative prefixes. This function creates default search
3784 paths that are needed later in normal option handling. */
3786 for (j = 1; j < decoded_options_count; j++)
3788 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
3790 get_relative_prefix = make_relative_prefix_ignore_links;
3791 break;
3794 if (! get_relative_prefix)
3795 get_relative_prefix = make_relative_prefix;
3797 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3798 see if we can create it from the pathname specified in
3799 decoded_options[0].arg. */
3801 gcc_libexec_prefix = standard_libexec_prefix;
3802 #ifndef VMS
3803 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3804 if (!gcc_exec_prefix)
3806 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
3807 standard_bindir_prefix,
3808 standard_exec_prefix);
3809 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
3810 standard_bindir_prefix,
3811 standard_libexec_prefix);
3812 if (gcc_exec_prefix)
3813 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3815 else
3817 /* make_relative_prefix requires a program name, but
3818 GCC_EXEC_PREFIX is typically a directory name with a trailing
3819 / (which is ignored by make_relative_prefix), so append a
3820 program name. */
3821 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
3822 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
3823 standard_exec_prefix,
3824 standard_libexec_prefix);
3826 /* The path is unrelocated, so fallback to the original setting. */
3827 if (!gcc_libexec_prefix)
3828 gcc_libexec_prefix = standard_libexec_prefix;
3830 free (tmp_prefix);
3832 #else
3833 #endif
3834 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
3835 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
3836 or an automatically created GCC_EXEC_PREFIX from
3837 decoded_options[0].arg. */
3839 /* Do language-specific adjustment/addition of flags. */
3840 lang_specific_driver (&decoded_options, &decoded_options_count,
3841 &added_libraries);
3843 if (gcc_exec_prefix)
3845 int len = strlen (gcc_exec_prefix);
3847 if (len > (int) sizeof ("/lib/gcc/") - 1
3848 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3850 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3851 if (IS_DIR_SEPARATOR (*temp)
3852 && filename_ncmp (temp + 1, "lib", 3) == 0
3853 && IS_DIR_SEPARATOR (temp[4])
3854 && filename_ncmp (temp + 5, "gcc", 3) == 0)
3855 len -= sizeof ("/lib/gcc/") - 1;
3858 set_std_prefix (gcc_exec_prefix, len);
3859 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3860 PREFIX_PRIORITY_LAST, 0, 0);
3861 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3862 PREFIX_PRIORITY_LAST, 0, 0);
3865 /* COMPILER_PATH and LIBRARY_PATH have values
3866 that are lists of directory names with colons. */
3868 temp = getenv ("COMPILER_PATH");
3869 if (temp)
3871 const char *startp, *endp;
3872 char *nstore = (char *) alloca (strlen (temp) + 3);
3874 startp = endp = temp;
3875 while (1)
3877 if (*endp == PATH_SEPARATOR || *endp == 0)
3879 strncpy (nstore, startp, endp - startp);
3880 if (endp == startp)
3881 strcpy (nstore, concat (".", dir_separator_str, NULL));
3882 else if (!IS_DIR_SEPARATOR (endp[-1]))
3884 nstore[endp - startp] = DIR_SEPARATOR;
3885 nstore[endp - startp + 1] = 0;
3887 else
3888 nstore[endp - startp] = 0;
3889 add_prefix (&exec_prefixes, nstore, 0,
3890 PREFIX_PRIORITY_LAST, 0, 0);
3891 add_prefix (&include_prefixes, nstore, 0,
3892 PREFIX_PRIORITY_LAST, 0, 0);
3893 if (*endp == 0)
3894 break;
3895 endp = startp = endp + 1;
3897 else
3898 endp++;
3902 temp = getenv (LIBRARY_PATH_ENV);
3903 if (temp && *cross_compile == '0')
3905 const char *startp, *endp;
3906 char *nstore = (char *) alloca (strlen (temp) + 3);
3908 startp = endp = temp;
3909 while (1)
3911 if (*endp == PATH_SEPARATOR || *endp == 0)
3913 strncpy (nstore, startp, endp - startp);
3914 if (endp == startp)
3915 strcpy (nstore, concat (".", dir_separator_str, NULL));
3916 else if (!IS_DIR_SEPARATOR (endp[-1]))
3918 nstore[endp - startp] = DIR_SEPARATOR;
3919 nstore[endp - startp + 1] = 0;
3921 else
3922 nstore[endp - startp] = 0;
3923 add_prefix (&startfile_prefixes, nstore, NULL,
3924 PREFIX_PRIORITY_LAST, 0, 1);
3925 if (*endp == 0)
3926 break;
3927 endp = startp = endp + 1;
3929 else
3930 endp++;
3934 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3935 temp = getenv ("LPATH");
3936 if (temp && *cross_compile == '0')
3938 const char *startp, *endp;
3939 char *nstore = (char *) alloca (strlen (temp) + 3);
3941 startp = endp = temp;
3942 while (1)
3944 if (*endp == PATH_SEPARATOR || *endp == 0)
3946 strncpy (nstore, startp, endp - startp);
3947 if (endp == startp)
3948 strcpy (nstore, concat (".", dir_separator_str, NULL));
3949 else if (!IS_DIR_SEPARATOR (endp[-1]))
3951 nstore[endp - startp] = DIR_SEPARATOR;
3952 nstore[endp - startp + 1] = 0;
3954 else
3955 nstore[endp - startp] = 0;
3956 add_prefix (&startfile_prefixes, nstore, NULL,
3957 PREFIX_PRIORITY_LAST, 0, 1);
3958 if (*endp == 0)
3959 break;
3960 endp = startp = endp + 1;
3962 else
3963 endp++;
3967 /* Process the options and store input files and switches in their
3968 vectors. */
3970 last_language_n_infiles = -1;
3972 set_option_handlers (&handlers);
3974 for (j = 1; j < decoded_options_count; j++)
3976 switch (decoded_options[j].opt_index)
3978 case OPT_S:
3979 case OPT_c:
3980 case OPT_E:
3981 have_c = 1;
3982 break;
3984 if (have_c)
3985 break;
3988 for (j = 1; j < decoded_options_count; j++)
3990 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
3992 const char *arg = decoded_options[j].arg;
3993 const char *p = strrchr (arg, '@');
3994 char *fname;
3995 long offset;
3996 int consumed;
3997 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3998 arg = convert_filename (arg, 0, access (arg, F_OK));
3999 #endif
4000 /* For LTO static archive support we handle input file
4001 specifications that are composed of a filename and
4002 an offset like FNAME@OFFSET. */
4003 if (p
4004 && p != arg
4005 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
4006 && strlen (p) == (unsigned int)consumed)
4008 fname = (char *)xmalloc (p - arg + 1);
4009 memcpy (fname, arg, p - arg);
4010 fname[p - arg] = '\0';
4011 /* Only accept non-stdin and existing FNAME parts, otherwise
4012 try with the full name. */
4013 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
4015 free (fname);
4016 fname = xstrdup (arg);
4019 else
4020 fname = xstrdup (arg);
4022 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
4023 perror_with_name (fname);
4024 else
4025 add_infile (arg, spec_lang);
4027 free (fname);
4028 continue;
4031 read_cmdline_option (&global_options, &global_options_set,
4032 decoded_options + j, UNKNOWN_LOCATION,
4033 CL_DRIVER, &handlers, global_dc);
4036 /* If -save-temps=obj and -o name, create the prefix to use for %b.
4037 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
4038 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
4040 save_temps_length = strlen (save_temps_prefix);
4041 temp = strrchr (lbasename (save_temps_prefix), '.');
4042 if (temp)
4044 save_temps_length -= strlen (temp);
4045 save_temps_prefix[save_temps_length] = '\0';
4049 else if (save_temps_prefix != NULL)
4051 free (save_temps_prefix);
4052 save_temps_prefix = NULL;
4055 if (save_temps_flag && use_pipes)
4057 /* -save-temps overrides -pipe, so that temp files are produced */
4058 if (save_temps_flag)
4059 warning (0, "-pipe ignored because -save-temps specified");
4060 use_pipes = 0;
4063 if (!compare_debug)
4065 const char *gcd = getenv ("GCC_COMPARE_DEBUG");
4067 if (gcd && gcd[0] == '-')
4069 compare_debug = 2;
4070 compare_debug_opt = gcd;
4072 else if (gcd && *gcd && strcmp (gcd, "0"))
4074 compare_debug = 3;
4075 compare_debug_opt = "-gtoggle";
4078 else if (compare_debug < 0)
4080 compare_debug = 0;
4081 gcc_assert (!compare_debug_opt);
4084 /* Set up the search paths. We add directories that we expect to
4085 contain GNU Toolchain components before directories specified by
4086 the machine description so that we will find GNU components (like
4087 the GNU assembler) before those of the host system. */
4089 /* If we don't know where the toolchain has been installed, use the
4090 configured-in locations. */
4091 if (!gcc_exec_prefix)
4093 #ifndef OS2
4094 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
4095 PREFIX_PRIORITY_LAST, 1, 0);
4096 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
4097 PREFIX_PRIORITY_LAST, 2, 0);
4098 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
4099 PREFIX_PRIORITY_LAST, 2, 0);
4100 #endif
4101 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
4102 PREFIX_PRIORITY_LAST, 1, 0);
4105 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
4106 tooldir_prefix2 = concat (tooldir_base_prefix, spec_machine,
4107 dir_separator_str, NULL);
4109 /* Look for tools relative to the location from which the driver is
4110 running, or, if that is not available, the configured prefix. */
4111 tooldir_prefix
4112 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4113 spec_machine, dir_separator_str,
4114 spec_version, dir_separator_str, tooldir_prefix2, NULL);
4115 free (tooldir_prefix2);
4117 add_prefix (&exec_prefixes,
4118 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4119 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4120 add_prefix (&startfile_prefixes,
4121 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4122 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4123 free (tooldir_prefix);
4125 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4126 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4127 then consider it to relocate with the rest of the GCC installation
4128 if GCC_EXEC_PREFIX is set.
4129 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4130 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
4132 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
4133 standard_bindir_prefix,
4134 target_system_root);
4135 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4137 target_system_root = tmp_prefix;
4138 target_system_root_changed = 1;
4141 #endif
4143 /* More prefixes are enabled in main, after we read the specs file
4144 and determine whether this is cross-compilation or not. */
4146 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4147 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
4149 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
4150 environment variable. */
4151 if (compare_debug == 2 || compare_debug == 3)
4153 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
4154 save_switch (opt, 0, NULL, false, true);
4155 compare_debug = 1;
4158 /* Ensure we only invoke each subprocess once. */
4159 if (print_subprocess_help || print_help_list || print_version)
4161 n_infiles = 0;
4163 /* Create a dummy input file, so that we can pass
4164 the help option on to the various sub-processes. */
4165 add_infile ("help-dummy", "c");
4168 alloc_switch ();
4169 switches[n_switches].part1 = 0;
4170 alloc_infile ();
4171 infiles[n_infiles].name = 0;
4174 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4175 and place that in the environment. */
4177 static void
4178 set_collect_gcc_options (void)
4180 int i;
4181 int first_time;
4183 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4184 the compiler. */
4185 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4186 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4188 first_time = TRUE;
4189 for (i = 0; (int) i < n_switches; i++)
4191 const char *const *args;
4192 const char *p, *q;
4193 if (!first_time)
4194 obstack_grow (&collect_obstack, " ", 1);
4196 first_time = FALSE;
4198 /* Ignore elided switches. */
4199 if ((switches[i].live_cond
4200 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4201 == SWITCH_IGNORE)
4202 continue;
4204 obstack_grow (&collect_obstack, "'-", 2);
4205 q = switches[i].part1;
4206 while ((p = strchr (q, '\'')))
4208 obstack_grow (&collect_obstack, q, p - q);
4209 obstack_grow (&collect_obstack, "'\\''", 4);
4210 q = ++p;
4212 obstack_grow (&collect_obstack, q, strlen (q));
4213 obstack_grow (&collect_obstack, "'", 1);
4215 for (args = switches[i].args; args && *args; args++)
4217 obstack_grow (&collect_obstack, " '", 2);
4218 q = *args;
4219 while ((p = strchr (q, '\'')))
4221 obstack_grow (&collect_obstack, q, p - q);
4222 obstack_grow (&collect_obstack, "'\\''", 4);
4223 q = ++p;
4225 obstack_grow (&collect_obstack, q, strlen (q));
4226 obstack_grow (&collect_obstack, "'", 1);
4229 obstack_grow (&collect_obstack, "\0", 1);
4230 xputenv (XOBFINISH (&collect_obstack, char *));
4233 /* Process a spec string, accumulating and running commands. */
4235 /* These variables describe the input file name.
4236 input_file_number is the index on outfiles of this file,
4237 so that the output file name can be stored for later use by %o.
4238 input_basename is the start of the part of the input file
4239 sans all directory names, and basename_length is the number
4240 of characters starting there excluding the suffix .c or whatever. */
4242 static const char *gcc_input_filename;
4243 static int input_file_number;
4244 size_t input_filename_length;
4245 static int basename_length;
4246 static int suffixed_basename_length;
4247 static const char *input_basename;
4248 static const char *input_suffix;
4249 #ifndef HOST_LACKS_INODE_NUMBERS
4250 static struct stat input_stat;
4251 #endif
4252 static int input_stat_set;
4254 /* The compiler used to process the current input file. */
4255 static struct compiler *input_file_compiler;
4257 /* These are variables used within do_spec and do_spec_1. */
4259 /* Nonzero if an arg has been started and not yet terminated
4260 (with space, tab or newline). */
4261 static int arg_going;
4263 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4264 is a temporary file name. */
4265 static int delete_this_arg;
4267 /* Nonzero means %w has been seen; the next arg to be terminated
4268 is the output file name of this compilation. */
4269 static int this_is_output_file;
4271 /* Nonzero means %s has been seen; the next arg to be terminated
4272 is the name of a library file and we should try the standard
4273 search dirs for it. */
4274 static int this_is_library_file;
4276 /* Nonzero means %T has been seen; the next arg to be terminated
4277 is the name of a linker script and we should try all of the
4278 standard search dirs for it. If it is found insert a --script
4279 command line switch and then substitute the full path in place,
4280 otherwise generate an error message. */
4281 static int this_is_linker_script;
4283 /* Nonzero means that the input of this command is coming from a pipe. */
4284 static int input_from_pipe;
4286 /* Nonnull means substitute this for any suffix when outputting a switches
4287 arguments. */
4288 static const char *suffix_subst;
4290 /* If there is an argument being accumulated, terminate it and store it. */
4292 static void
4293 end_going_arg (void)
4295 if (arg_going)
4297 const char *string;
4299 obstack_1grow (&obstack, 0);
4300 string = XOBFINISH (&obstack, const char *);
4301 if (this_is_library_file)
4302 string = find_file (string);
4303 if (this_is_linker_script)
4305 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4307 if (full_script_path == NULL)
4309 error ("unable to locate default linker script %qs in the library search paths", string);
4310 /* Script was not found on search path. */
4311 return;
4313 store_arg ("--script", false, false);
4314 string = full_script_path;
4316 store_arg (string, delete_this_arg, this_is_output_file);
4317 if (this_is_output_file)
4318 outfiles[input_file_number] = string;
4319 arg_going = 0;
4324 /* Parse the WRAPPER string which is a comma separated list of the command line
4325 and insert them into the beginning of argbuf. */
4327 static void
4328 insert_wrapper (const char *wrapper)
4330 int n = 0;
4331 int i;
4332 char *buf = xstrdup (wrapper);
4333 char *p = buf;
4334 unsigned int old_length = argbuf.length ();
4338 n++;
4339 while (*p == ',')
4340 p++;
4342 while ((p = strchr (p, ',')) != NULL);
4344 argbuf.safe_grow (old_length + n);
4345 memmove (argbuf.address () + n,
4346 argbuf.address (),
4347 old_length * sizeof (const_char_p));
4349 i = 0;
4350 p = buf;
4353 while (*p == ',')
4355 *p = 0;
4356 p++;
4358 argbuf[i] = p;
4359 i++;
4361 while ((p = strchr (p, ',')) != NULL);
4362 gcc_assert (i == n);
4365 /* Process the spec SPEC and run the commands specified therein.
4366 Returns 0 if the spec is successfully processed; -1 if failed. */
4369 do_spec (const char *spec)
4371 int value;
4373 value = do_spec_2 (spec);
4375 /* Force out any unfinished command.
4376 If -pipe, this forces out the last command if it ended in `|'. */
4377 if (value == 0)
4379 if (argbuf.length () > 0
4380 && !strcmp (argbuf.last (), "|"))
4381 argbuf.pop ();
4383 set_collect_gcc_options ();
4385 if (argbuf.length () > 0)
4386 value = execute ();
4389 return value;
4392 static int
4393 do_spec_2 (const char *spec)
4395 int result;
4397 clear_args ();
4398 arg_going = 0;
4399 delete_this_arg = 0;
4400 this_is_output_file = 0;
4401 this_is_library_file = 0;
4402 this_is_linker_script = 0;
4403 input_from_pipe = 0;
4404 suffix_subst = NULL;
4406 result = do_spec_1 (spec, 0, NULL);
4408 end_going_arg ();
4410 return result;
4414 /* Process the given spec string and add any new options to the end
4415 of the switches/n_switches array. */
4417 static void
4418 do_option_spec (const char *name, const char *spec)
4420 unsigned int i, value_count, value_len;
4421 const char *p, *q, *value;
4422 char *tmp_spec, *tmp_spec_p;
4424 if (configure_default_options[0].name == NULL)
4425 return;
4427 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4428 if (strcmp (configure_default_options[i].name, name) == 0)
4429 break;
4430 if (i == ARRAY_SIZE (configure_default_options))
4431 return;
4433 value = configure_default_options[i].value;
4434 value_len = strlen (value);
4436 /* Compute the size of the final spec. */
4437 value_count = 0;
4438 p = spec;
4439 while ((p = strstr (p, "%(VALUE)")) != NULL)
4441 p ++;
4442 value_count ++;
4445 /* Replace each %(VALUE) by the specified value. */
4446 tmp_spec = (char *) alloca (strlen (spec) + 1
4447 + value_count * (value_len - strlen ("%(VALUE)")));
4448 tmp_spec_p = tmp_spec;
4449 q = spec;
4450 while ((p = strstr (q, "%(VALUE)")) != NULL)
4452 memcpy (tmp_spec_p, q, p - q);
4453 tmp_spec_p = tmp_spec_p + (p - q);
4454 memcpy (tmp_spec_p, value, value_len);
4455 tmp_spec_p += value_len;
4456 q = p + strlen ("%(VALUE)");
4458 strcpy (tmp_spec_p, q);
4460 do_self_spec (tmp_spec);
4463 /* Process the given spec string and add any new options to the end
4464 of the switches/n_switches array. */
4466 static void
4467 do_self_spec (const char *spec)
4469 int i;
4471 do_spec_2 (spec);
4472 do_spec_1 (" ", 0, NULL);
4474 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4475 do_self_specs adds the replacements to switches array, so it shouldn't
4476 be processed afterwards. */
4477 for (i = 0; i < n_switches; i++)
4478 if ((switches[i].live_cond & SWITCH_IGNORE))
4479 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4481 if (argbuf.length () > 0)
4483 const char **argbuf_copy;
4484 struct cl_decoded_option *decoded_options;
4485 struct cl_option_handlers handlers;
4486 unsigned int decoded_options_count;
4487 unsigned int j;
4489 /* Create a copy of argbuf with a dummy argv[0] entry for
4490 decode_cmdline_options_to_array. */
4491 argbuf_copy = XNEWVEC (const char *,
4492 argbuf.length () + 1);
4493 argbuf_copy[0] = "";
4494 memcpy (argbuf_copy + 1, argbuf.address (),
4495 argbuf.length () * sizeof (const char *));
4497 decode_cmdline_options_to_array (argbuf.length () + 1,
4498 argbuf_copy,
4499 CL_DRIVER, &decoded_options,
4500 &decoded_options_count);
4501 free (argbuf_copy);
4503 set_option_handlers (&handlers);
4505 for (j = 1; j < decoded_options_count; j++)
4507 switch (decoded_options[j].opt_index)
4509 case OPT_SPECIAL_input_file:
4510 /* Specs should only generate options, not input
4511 files. */
4512 if (strcmp (decoded_options[j].arg, "-") != 0)
4513 fatal_error ("switch %qs does not start with %<-%>",
4514 decoded_options[j].arg);
4515 else
4516 fatal_error ("spec-generated switch is just %<-%>");
4517 break;
4519 case OPT_fcompare_debug_second:
4520 case OPT_fcompare_debug:
4521 case OPT_fcompare_debug_:
4522 case OPT_o:
4523 /* Avoid duplicate processing of some options from
4524 compare-debug specs; just save them here. */
4525 save_switch (decoded_options[j].canonical_option[0],
4526 (decoded_options[j].canonical_option_num_elements
4527 - 1),
4528 &decoded_options[j].canonical_option[1], false, true);
4529 break;
4531 default:
4532 read_cmdline_option (&global_options, &global_options_set,
4533 decoded_options + j, UNKNOWN_LOCATION,
4534 CL_DRIVER, &handlers, global_dc);
4535 break;
4539 alloc_switch ();
4540 switches[n_switches].part1 = 0;
4544 /* Callback for processing %D and %I specs. */
4546 struct spec_path_info {
4547 const char *option;
4548 const char *append;
4549 size_t append_len;
4550 bool omit_relative;
4551 bool separate_options;
4554 static void *
4555 spec_path (char *path, void *data)
4557 struct spec_path_info *info = (struct spec_path_info *) data;
4558 size_t len = 0;
4559 char save = 0;
4561 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4562 return NULL;
4564 if (info->append_len != 0)
4566 len = strlen (path);
4567 memcpy (path + len, info->append, info->append_len + 1);
4570 if (!is_directory (path, true))
4571 return NULL;
4573 do_spec_1 (info->option, 1, NULL);
4574 if (info->separate_options)
4575 do_spec_1 (" ", 0, NULL);
4577 if (info->append_len == 0)
4579 len = strlen (path);
4580 save = path[len - 1];
4581 if (IS_DIR_SEPARATOR (path[len - 1]))
4582 path[len - 1] = '\0';
4585 do_spec_1 (path, 1, NULL);
4586 do_spec_1 (" ", 0, NULL);
4588 /* Must not damage the original path. */
4589 if (info->append_len == 0)
4590 path[len - 1] = save;
4592 return NULL;
4595 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
4596 argument list. */
4598 static void
4599 create_at_file (char **argv)
4601 char *temp_file = make_temp_file ("");
4602 char *at_argument = concat ("@", temp_file, NULL);
4603 FILE *f = fopen (temp_file, "w");
4604 int status;
4606 if (f == NULL)
4607 fatal_error ("could not open temporary response file %s",
4608 temp_file);
4610 status = writeargv (argv, f);
4612 if (status)
4613 fatal_error ("could not write to temporary response file %s",
4614 temp_file);
4616 status = fclose (f);
4618 if (EOF == status)
4619 fatal_error ("could not close temporary response file %s",
4620 temp_file);
4622 store_arg (at_argument, 0, 0);
4624 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
4627 /* True if we should compile INFILE. */
4629 static bool
4630 compile_input_file_p (struct infile *infile)
4632 if ((!infile->language) || (infile->language[0] != '*'))
4633 if (infile->incompiler == input_file_compiler)
4634 return true;
4635 return false;
4638 /* Process each member of VEC as a spec. */
4640 static void
4641 do_specs_vec (vec<char_p> vec)
4643 unsigned ix;
4644 char *opt;
4646 FOR_EACH_VEC_ELT (vec, ix, opt)
4648 do_spec_1 (opt, 1, NULL);
4649 /* Make each accumulated option a separate argument. */
4650 do_spec_1 (" ", 0, NULL);
4654 /* Process the sub-spec SPEC as a portion of a larger spec.
4655 This is like processing a whole spec except that we do
4656 not initialize at the beginning and we do not supply a
4657 newline by default at the end.
4658 INSWITCH nonzero means don't process %-sequences in SPEC;
4659 in this case, % is treated as an ordinary character.
4660 This is used while substituting switches.
4661 INSWITCH nonzero also causes SPC not to terminate an argument.
4663 Value is zero unless a line was finished
4664 and the command on that line reported an error. */
4666 static int
4667 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4669 const char *p = spec;
4670 int c;
4671 int i;
4672 int value;
4674 /* If it's an empty string argument to a switch, keep it as is. */
4675 if (inswitch && !*p)
4676 arg_going = 1;
4678 while ((c = *p++))
4679 /* If substituting a switch, treat all chars like letters.
4680 Otherwise, NL, SPC, TAB and % are special. */
4681 switch (inswitch ? 'a' : c)
4683 case '\n':
4684 end_going_arg ();
4686 if (argbuf.length () > 0
4687 && !strcmp (argbuf.last (), "|"))
4689 /* A `|' before the newline means use a pipe here,
4690 but only if -pipe was specified.
4691 Otherwise, execute now and don't pass the `|' as an arg. */
4692 if (use_pipes)
4694 input_from_pipe = 1;
4695 break;
4697 else
4698 argbuf.pop ();
4701 set_collect_gcc_options ();
4703 if (argbuf.length () > 0)
4705 value = execute ();
4706 if (value)
4707 return value;
4709 /* Reinitialize for a new command, and for a new argument. */
4710 clear_args ();
4711 arg_going = 0;
4712 delete_this_arg = 0;
4713 this_is_output_file = 0;
4714 this_is_library_file = 0;
4715 this_is_linker_script = 0;
4716 input_from_pipe = 0;
4717 break;
4719 case '|':
4720 end_going_arg ();
4722 /* Use pipe */
4723 obstack_1grow (&obstack, c);
4724 arg_going = 1;
4725 break;
4727 case '\t':
4728 case ' ':
4729 end_going_arg ();
4731 /* Reinitialize for a new argument. */
4732 delete_this_arg = 0;
4733 this_is_output_file = 0;
4734 this_is_library_file = 0;
4735 this_is_linker_script = 0;
4736 break;
4738 case '%':
4739 switch (c = *p++)
4741 case 0:
4742 fatal_error ("spec %qs invalid", spec);
4744 case 'b':
4745 if (save_temps_length)
4746 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4747 else
4748 obstack_grow (&obstack, input_basename, basename_length);
4749 if (compare_debug < 0)
4750 obstack_grow (&obstack, ".gk", 3);
4751 arg_going = 1;
4752 break;
4754 case 'B':
4755 if (save_temps_length)
4756 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4757 else
4758 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4759 if (compare_debug < 0)
4760 obstack_grow (&obstack, ".gk", 3);
4761 arg_going = 1;
4762 break;
4764 case 'd':
4765 delete_this_arg = 2;
4766 break;
4768 /* Dump out the directories specified with LIBRARY_PATH,
4769 followed by the absolute directories
4770 that we search for startfiles. */
4771 case 'D':
4773 struct spec_path_info info;
4775 info.option = "-L";
4776 info.append_len = 0;
4777 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4778 /* Used on systems which record the specified -L dirs
4779 and use them to search for dynamic linking.
4780 Relative directories always come from -B,
4781 and it is better not to use them for searching
4782 at run time. In particular, stage1 loses. */
4783 info.omit_relative = true;
4784 #else
4785 info.omit_relative = false;
4786 #endif
4787 info.separate_options = false;
4789 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
4791 break;
4793 case 'e':
4794 /* %efoo means report an error with `foo' as error message
4795 and don't execute any more commands for this file. */
4797 const char *q = p;
4798 char *buf;
4799 while (*p != 0 && *p != '\n')
4800 p++;
4801 buf = (char *) alloca (p - q + 1);
4802 strncpy (buf, q, p - q);
4803 buf[p - q] = 0;
4804 error ("%s", _(buf));
4805 return -1;
4807 break;
4808 case 'n':
4809 /* %nfoo means report a notice with `foo' on stderr. */
4811 const char *q = p;
4812 char *buf;
4813 while (*p != 0 && *p != '\n')
4814 p++;
4815 buf = (char *) alloca (p - q + 1);
4816 strncpy (buf, q, p - q);
4817 buf[p - q] = 0;
4818 inform (0, "%s", _(buf));
4819 if (*p)
4820 p++;
4822 break;
4824 case 'j':
4826 struct stat st;
4828 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4829 defined, and it is not a directory, and it is
4830 writable, use it. Otherwise, treat this like any
4831 other temporary file. */
4833 if ((!save_temps_flag)
4834 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4835 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4837 obstack_grow (&obstack, HOST_BIT_BUCKET,
4838 strlen (HOST_BIT_BUCKET));
4839 delete_this_arg = 0;
4840 arg_going = 1;
4841 break;
4844 goto create_temp_file;
4845 case '|':
4846 if (use_pipes)
4848 obstack_1grow (&obstack, '-');
4849 delete_this_arg = 0;
4850 arg_going = 1;
4852 /* consume suffix */
4853 while (*p == '.' || ISALNUM ((unsigned char) *p))
4854 p++;
4855 if (p[0] == '%' && p[1] == 'O')
4856 p += 2;
4858 break;
4860 goto create_temp_file;
4861 case 'm':
4862 if (use_pipes)
4864 /* consume suffix */
4865 while (*p == '.' || ISALNUM ((unsigned char) *p))
4866 p++;
4867 if (p[0] == '%' && p[1] == 'O')
4868 p += 2;
4870 break;
4872 goto create_temp_file;
4873 case 'g':
4874 case 'u':
4875 case 'U':
4876 create_temp_file:
4878 struct temp_name *t;
4879 int suffix_length;
4880 const char *suffix = p;
4881 char *saved_suffix = NULL;
4883 while (*p == '.' || ISALNUM ((unsigned char) *p))
4884 p++;
4885 suffix_length = p - suffix;
4886 if (p[0] == '%' && p[1] == 'O')
4888 p += 2;
4889 /* We don't support extra suffix characters after %O. */
4890 if (*p == '.' || ISALNUM ((unsigned char) *p))
4891 fatal_error ("spec %qs has invalid %<%%0%c%>", spec, *p);
4892 if (suffix_length == 0)
4893 suffix = TARGET_OBJECT_SUFFIX;
4894 else
4896 saved_suffix
4897 = XNEWVEC (char, suffix_length
4898 + strlen (TARGET_OBJECT_SUFFIX));
4899 strncpy (saved_suffix, suffix, suffix_length);
4900 strcpy (saved_suffix + suffix_length,
4901 TARGET_OBJECT_SUFFIX);
4903 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4906 if (compare_debug < 0)
4908 suffix = concat (".gk", suffix, NULL);
4909 suffix_length += 3;
4912 /* If -save-temps=obj and -o were specified, use that for the
4913 temp file. */
4914 if (save_temps_length)
4916 char *tmp;
4917 temp_filename_length
4918 = save_temps_length + suffix_length + 1;
4919 tmp = (char *) alloca (temp_filename_length);
4920 memcpy (tmp, save_temps_prefix, save_temps_length);
4921 memcpy (tmp + save_temps_length, suffix, suffix_length);
4922 tmp[save_temps_length + suffix_length] = '\0';
4923 temp_filename = save_string (tmp, save_temps_length
4924 + suffix_length);
4925 obstack_grow (&obstack, temp_filename,
4926 temp_filename_length);
4927 arg_going = 1;
4928 delete_this_arg = 0;
4929 break;
4932 /* If the gcc_input_filename has the same suffix specified
4933 for the %g, %u, or %U, and -save-temps is specified,
4934 we could end up using that file as an intermediate
4935 thus clobbering the user's source file (.e.g.,
4936 gcc -save-temps foo.s would clobber foo.s with the
4937 output of cpp0). So check for this condition and
4938 generate a temp file as the intermediate. */
4940 if (save_temps_flag)
4942 char *tmp;
4943 temp_filename_length = basename_length + suffix_length + 1;
4944 tmp = (char *) alloca (temp_filename_length);
4945 memcpy (tmp, input_basename, basename_length);
4946 memcpy (tmp + basename_length, suffix, suffix_length);
4947 tmp[basename_length + suffix_length] = '\0';
4948 temp_filename = tmp;
4950 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
4952 #ifndef HOST_LACKS_INODE_NUMBERS
4953 struct stat st_temp;
4955 /* Note, set_input() resets input_stat_set to 0. */
4956 if (input_stat_set == 0)
4958 input_stat_set = stat (gcc_input_filename,
4959 &input_stat);
4960 if (input_stat_set >= 0)
4961 input_stat_set = 1;
4964 /* If we have the stat for the gcc_input_filename
4965 and we can do the stat for the temp_filename
4966 then the they could still refer to the same
4967 file if st_dev/st_ino's are the same. */
4968 if (input_stat_set != 1
4969 || stat (temp_filename, &st_temp) < 0
4970 || input_stat.st_dev != st_temp.st_dev
4971 || input_stat.st_ino != st_temp.st_ino)
4972 #else
4973 /* Just compare canonical pathnames. */
4974 char* input_realname = lrealpath (gcc_input_filename);
4975 char* temp_realname = lrealpath (temp_filename);
4976 bool files_differ = filename_cmp (input_realname, temp_realname);
4977 free (input_realname);
4978 free (temp_realname);
4979 if (files_differ)
4980 #endif
4982 temp_filename = save_string (temp_filename,
4983 temp_filename_length + 1);
4984 obstack_grow (&obstack, temp_filename,
4985 temp_filename_length);
4986 arg_going = 1;
4987 delete_this_arg = 0;
4988 break;
4993 /* See if we already have an association of %g/%u/%U and
4994 suffix. */
4995 for (t = temp_names; t; t = t->next)
4996 if (t->length == suffix_length
4997 && strncmp (t->suffix, suffix, suffix_length) == 0
4998 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4999 break;
5001 /* Make a new association if needed. %u and %j
5002 require one. */
5003 if (t == 0 || c == 'u' || c == 'j')
5005 if (t == 0)
5007 t = XNEW (struct temp_name);
5008 t->next = temp_names;
5009 temp_names = t;
5011 t->length = suffix_length;
5012 if (saved_suffix)
5014 t->suffix = saved_suffix;
5015 saved_suffix = NULL;
5017 else
5018 t->suffix = save_string (suffix, suffix_length);
5019 t->unique = (c == 'u' || c == 'U' || c == 'j');
5020 temp_filename = make_temp_file (t->suffix);
5021 temp_filename_length = strlen (temp_filename);
5022 t->filename = temp_filename;
5023 t->filename_length = temp_filename_length;
5026 free (saved_suffix);
5028 obstack_grow (&obstack, t->filename, t->filename_length);
5029 delete_this_arg = 1;
5031 arg_going = 1;
5032 break;
5034 case 'i':
5035 if (combine_inputs)
5037 if (at_file_supplied)
5039 /* We are going to expand `%i' to `@FILE', where FILE
5040 is a newly-created temporary filename. The filenames
5041 that would usually be expanded in place of %o will be
5042 written to the temporary file. */
5043 char **argv;
5044 int n_files = 0;
5045 int j;
5047 for (i = 0; i < n_infiles; i++)
5048 if (compile_input_file_p (&infiles[i]))
5049 n_files++;
5051 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5053 /* Copy the strings over. */
5054 for (i = 0, j = 0; i < n_infiles; i++)
5055 if (compile_input_file_p (&infiles[i]))
5057 argv[j] = CONST_CAST (char *, infiles[i].name);
5058 infiles[i].compiled = true;
5059 j++;
5061 argv[j] = NULL;
5063 create_at_file (argv);
5065 else
5066 for (i = 0; (int) i < n_infiles; i++)
5067 if (compile_input_file_p (&infiles[i]))
5069 store_arg (infiles[i].name, 0, 0);
5070 infiles[i].compiled = true;
5073 else
5075 obstack_grow (&obstack, gcc_input_filename,
5076 input_filename_length);
5077 arg_going = 1;
5079 break;
5081 case 'I':
5083 struct spec_path_info info;
5085 if (multilib_dir)
5087 do_spec_1 ("-imultilib", 1, NULL);
5088 /* Make this a separate argument. */
5089 do_spec_1 (" ", 0, NULL);
5090 do_spec_1 (multilib_dir, 1, NULL);
5091 do_spec_1 (" ", 0, NULL);
5094 if (multiarch_dir)
5096 do_spec_1 ("-imultiarch", 1, NULL);
5097 /* Make this a separate argument. */
5098 do_spec_1 (" ", 0, NULL);
5099 do_spec_1 (multiarch_dir, 1, NULL);
5100 do_spec_1 (" ", 0, NULL);
5103 if (gcc_exec_prefix)
5105 do_spec_1 ("-iprefix", 1, NULL);
5106 /* Make this a separate argument. */
5107 do_spec_1 (" ", 0, NULL);
5108 do_spec_1 (gcc_exec_prefix, 1, NULL);
5109 do_spec_1 (" ", 0, NULL);
5112 if (target_system_root_changed ||
5113 (target_system_root && target_sysroot_hdrs_suffix))
5115 do_spec_1 ("-isysroot", 1, NULL);
5116 /* Make this a separate argument. */
5117 do_spec_1 (" ", 0, NULL);
5118 do_spec_1 (target_system_root, 1, NULL);
5119 if (target_sysroot_hdrs_suffix)
5120 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
5121 do_spec_1 (" ", 0, NULL);
5124 info.option = "-isystem";
5125 info.append = "include";
5126 info.append_len = strlen (info.append);
5127 info.omit_relative = false;
5128 info.separate_options = true;
5130 for_each_path (&include_prefixes, false, info.append_len,
5131 spec_path, &info);
5133 info.append = "include-fixed";
5134 if (*sysroot_hdrs_suffix_spec)
5135 info.append = concat (info.append, dir_separator_str,
5136 multilib_dir, NULL);
5137 info.append_len = strlen (info.append);
5138 for_each_path (&include_prefixes, false, info.append_len,
5139 spec_path, &info);
5141 break;
5143 case 'o':
5145 int max = n_infiles;
5146 max += lang_specific_extra_outfiles;
5148 if (HAVE_GNU_LD && at_file_supplied)
5150 /* We are going to expand `%o' to `@FILE', where FILE
5151 is a newly-created temporary filename. The filenames
5152 that would usually be expanded in place of %o will be
5153 written to the temporary file. */
5155 char **argv;
5156 int n_files, j;
5158 /* Convert OUTFILES into a form suitable for writeargv. */
5160 /* Determine how many are non-NULL. */
5161 for (n_files = 0, i = 0; i < max; i++)
5162 n_files += outfiles[i] != NULL;
5164 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5166 /* Copy the strings over. */
5167 for (i = 0, j = 0; i < max; i++)
5168 if (outfiles[i])
5170 argv[j] = CONST_CAST (char *, outfiles[i]);
5171 j++;
5173 argv[j] = NULL;
5175 create_at_file (argv);
5177 else
5178 for (i = 0; i < max; i++)
5179 if (outfiles[i])
5180 store_arg (outfiles[i], 0, 0);
5181 break;
5184 case 'O':
5185 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5186 arg_going = 1;
5187 break;
5189 case 's':
5190 this_is_library_file = 1;
5191 break;
5193 case 'T':
5194 this_is_linker_script = 1;
5195 break;
5197 case 'V':
5198 outfiles[input_file_number] = NULL;
5199 break;
5201 case 'w':
5202 this_is_output_file = 1;
5203 break;
5205 case 'W':
5207 unsigned int cur_index = argbuf.length ();
5208 /* Handle the {...} following the %W. */
5209 if (*p != '{')
5210 fatal_error ("spec %qs has invalid %<%%W%c%>", spec, *p);
5211 p = handle_braces (p + 1);
5212 if (p == 0)
5213 return -1;
5214 end_going_arg ();
5215 /* If any args were output, mark the last one for deletion
5216 on failure. */
5217 if (argbuf.length () != cur_index)
5218 record_temp_file (argbuf.last (), 0, 1);
5219 break;
5222 /* %x{OPTION} records OPTION for %X to output. */
5223 case 'x':
5225 const char *p1 = p;
5226 char *string;
5227 char *opt;
5228 unsigned ix;
5230 /* Skip past the option value and make a copy. */
5231 if (*p != '{')
5232 fatal_error ("spec %qs has invalid %<%%x%c%>", spec, *p);
5233 while (*p++ != '}')
5235 string = save_string (p1 + 1, p - p1 - 2);
5237 /* See if we already recorded this option. */
5238 FOR_EACH_VEC_ELT (linker_options, ix, opt)
5239 if (! strcmp (string, opt))
5241 free (string);
5242 return 0;
5245 /* This option is new; add it. */
5246 add_linker_option (string, strlen (string));
5247 free (string);
5249 break;
5251 /* Dump out the options accumulated previously using %x. */
5252 case 'X':
5253 do_specs_vec (linker_options);
5254 break;
5256 /* Dump out the options accumulated previously using -Wa,. */
5257 case 'Y':
5258 do_specs_vec (assembler_options);
5259 break;
5261 /* Dump out the options accumulated previously using -Wp,. */
5262 case 'Z':
5263 do_specs_vec (preprocessor_options);
5264 break;
5266 /* Here are digits and numbers that just process
5267 a certain constant string as a spec. */
5269 case '1':
5270 value = do_spec_1 (cc1_spec, 0, NULL);
5271 if (value != 0)
5272 return value;
5273 break;
5275 case '2':
5276 value = do_spec_1 (cc1plus_spec, 0, NULL);
5277 if (value != 0)
5278 return value;
5279 break;
5281 case 'a':
5282 value = do_spec_1 (asm_spec, 0, NULL);
5283 if (value != 0)
5284 return value;
5285 break;
5287 case 'A':
5288 value = do_spec_1 (asm_final_spec, 0, NULL);
5289 if (value != 0)
5290 return value;
5291 break;
5293 case 'C':
5295 const char *const spec
5296 = (input_file_compiler->cpp_spec
5297 ? input_file_compiler->cpp_spec
5298 : cpp_spec);
5299 value = do_spec_1 (spec, 0, NULL);
5300 if (value != 0)
5301 return value;
5303 break;
5305 case 'E':
5306 value = do_spec_1 (endfile_spec, 0, NULL);
5307 if (value != 0)
5308 return value;
5309 break;
5311 case 'l':
5312 value = do_spec_1 (link_spec, 0, NULL);
5313 if (value != 0)
5314 return value;
5315 break;
5317 case 'L':
5318 value = do_spec_1 (lib_spec, 0, NULL);
5319 if (value != 0)
5320 return value;
5321 break;
5323 case 'M':
5324 if (multilib_os_dir == NULL)
5325 obstack_1grow (&obstack, '.');
5326 else
5327 obstack_grow (&obstack, multilib_os_dir,
5328 strlen (multilib_os_dir));
5329 break;
5331 case 'G':
5332 value = do_spec_1 (libgcc_spec, 0, NULL);
5333 if (value != 0)
5334 return value;
5335 break;
5337 case 'R':
5338 /* We assume there is a directory
5339 separator at the end of this string. */
5340 if (target_system_root)
5342 obstack_grow (&obstack, target_system_root,
5343 strlen (target_system_root));
5344 if (target_sysroot_suffix)
5345 obstack_grow (&obstack, target_sysroot_suffix,
5346 strlen (target_sysroot_suffix));
5348 break;
5350 case 'S':
5351 value = do_spec_1 (startfile_spec, 0, NULL);
5352 if (value != 0)
5353 return value;
5354 break;
5356 /* Here we define characters other than letters and digits. */
5358 case '{':
5359 p = handle_braces (p);
5360 if (p == 0)
5361 return -1;
5362 break;
5364 case ':':
5365 p = handle_spec_function (p, NULL);
5366 if (p == 0)
5367 return -1;
5368 break;
5370 case '%':
5371 obstack_1grow (&obstack, '%');
5372 break;
5374 case '.':
5376 unsigned len = 0;
5378 while (p[len] && p[len] != ' ' && p[len] != '%')
5379 len++;
5380 suffix_subst = save_string (p - 1, len + 1);
5381 p += len;
5383 break;
5385 /* Henceforth ignore the option(s) matching the pattern
5386 after the %<. */
5387 case '<':
5388 case '>':
5390 unsigned len = 0;
5391 int have_wildcard = 0;
5392 int i;
5393 int switch_option;
5395 if (c == '>')
5396 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5397 else
5398 switch_option = SWITCH_IGNORE;
5400 while (p[len] && p[len] != ' ' && p[len] != '\t')
5401 len++;
5403 if (p[len-1] == '*')
5404 have_wildcard = 1;
5406 for (i = 0; i < n_switches; i++)
5407 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5408 && (have_wildcard || switches[i].part1[len] == '\0'))
5410 switches[i].live_cond |= switch_option;
5411 /* User switch be validated from validate_all_switches.
5412 when the definition is seen from the spec file.
5413 If not defined anywhere, will be rejected. */
5414 if (switches[i].known)
5415 switches[i].validated = true;
5418 p += len;
5420 break;
5422 case '*':
5423 if (soft_matched_part)
5425 if (soft_matched_part[0])
5426 do_spec_1 (soft_matched_part, 1, NULL);
5427 /* Only insert a space after the substitution if it is at the
5428 end of the current sequence. So if:
5430 "%{foo=*:bar%*}%{foo=*:one%*two}"
5432 matches -foo=hello then it will produce:
5434 barhello onehellotwo
5436 if (*p == 0 || *p == '}')
5437 do_spec_1 (" ", 0, NULL);
5439 else
5440 /* Catch the case where a spec string contains something like
5441 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5442 hand side of the :. */
5443 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5444 break;
5446 /* Process a string found as the value of a spec given by name.
5447 This feature allows individual machine descriptions
5448 to add and use their own specs. */
5449 case '(':
5451 const char *name = p;
5452 struct spec_list *sl;
5453 int len;
5455 /* The string after the S/P is the name of a spec that is to be
5456 processed. */
5457 while (*p && *p != ')')
5458 p++;
5460 /* See if it's in the list. */
5461 for (len = p - name, sl = specs; sl; sl = sl->next)
5462 if (sl->name_len == len && !strncmp (sl->name, name, len))
5464 name = *(sl->ptr_spec);
5465 #ifdef DEBUG_SPECS
5466 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5467 sl->name, name);
5468 #endif
5469 break;
5472 if (sl)
5474 value = do_spec_1 (name, 0, NULL);
5475 if (value != 0)
5476 return value;
5479 /* Discard the closing paren. */
5480 if (*p)
5481 p++;
5483 break;
5485 default:
5486 error ("spec failure: unrecognized spec option %qc", c);
5487 break;
5489 break;
5491 case '\\':
5492 /* Backslash: treat next character as ordinary. */
5493 c = *p++;
5495 /* Fall through. */
5496 default:
5497 /* Ordinary character: put it into the current argument. */
5498 obstack_1grow (&obstack, c);
5499 arg_going = 1;
5502 /* End of string. If we are processing a spec function, we need to
5503 end any pending argument. */
5504 if (processing_spec_function)
5505 end_going_arg ();
5507 return 0;
5510 /* Look up a spec function. */
5512 static const struct spec_function *
5513 lookup_spec_function (const char *name)
5515 const struct spec_function *sf;
5517 for (sf = static_spec_functions; sf->name != NULL; sf++)
5518 if (strcmp (sf->name, name) == 0)
5519 return sf;
5521 return NULL;
5524 /* Evaluate a spec function. */
5526 static const char *
5527 eval_spec_function (const char *func, const char *args)
5529 const struct spec_function *sf;
5530 const char *funcval;
5532 /* Saved spec processing context. */
5533 vec<const_char_p> save_argbuf;
5535 int save_arg_going;
5536 int save_delete_this_arg;
5537 int save_this_is_output_file;
5538 int save_this_is_library_file;
5539 int save_input_from_pipe;
5540 int save_this_is_linker_script;
5541 const char *save_suffix_subst;
5543 int save_growing_size;
5544 void *save_growing_value = NULL;
5546 sf = lookup_spec_function (func);
5547 if (sf == NULL)
5548 fatal_error ("unknown spec function %qs", func);
5550 /* Push the spec processing context. */
5551 save_argbuf = argbuf;
5553 save_arg_going = arg_going;
5554 save_delete_this_arg = delete_this_arg;
5555 save_this_is_output_file = this_is_output_file;
5556 save_this_is_library_file = this_is_library_file;
5557 save_this_is_linker_script = this_is_linker_script;
5558 save_input_from_pipe = input_from_pipe;
5559 save_suffix_subst = suffix_subst;
5561 /* If we have some object growing now, finalize it so the args and function
5562 eval proceed from a cleared context. This is needed to prevent the first
5563 constructed arg from mistakenly including the growing value. We'll push
5564 this value back on the obstack once the function evaluation is done, to
5565 restore a consistent processing context for our caller. This is fine as
5566 the address of growing objects isn't guaranteed to remain stable until
5567 they are finalized, and we expect this situation to be rare enough for
5568 the extra copy not to be an issue. */
5569 save_growing_size = obstack_object_size (&obstack);
5570 if (save_growing_size > 0)
5571 save_growing_value = obstack_finish (&obstack);
5573 /* Create a new spec processing context, and build the function
5574 arguments. */
5576 alloc_args ();
5577 if (do_spec_2 (args) < 0)
5578 fatal_error ("error in args to spec function %qs", func);
5580 /* argbuf_index is an index for the next argument to be inserted, and
5581 so contains the count of the args already inserted. */
5583 funcval = (*sf->func) (argbuf.length (),
5584 argbuf.address ());
5586 /* Pop the spec processing context. */
5587 argbuf.release ();
5588 argbuf = save_argbuf;
5590 arg_going = save_arg_going;
5591 delete_this_arg = save_delete_this_arg;
5592 this_is_output_file = save_this_is_output_file;
5593 this_is_library_file = save_this_is_library_file;
5594 this_is_linker_script = save_this_is_linker_script;
5595 input_from_pipe = save_input_from_pipe;
5596 suffix_subst = save_suffix_subst;
5598 if (save_growing_size > 0)
5599 obstack_grow (&obstack, save_growing_value, save_growing_size);
5601 return funcval;
5604 /* Handle a spec function call of the form:
5606 %:function(args)
5608 ARGS is processed as a spec in a separate context and split into an
5609 argument vector in the normal fashion. The function returns a string
5610 containing a spec which we then process in the caller's context, or
5611 NULL if no processing is required.
5613 If RETVAL_NONNULL is not NULL, then store a bool whether function
5614 returned non-NULL. */
5616 static const char *
5617 handle_spec_function (const char *p, bool *retval_nonnull)
5619 char *func, *args;
5620 const char *endp, *funcval;
5621 int count;
5623 processing_spec_function++;
5625 /* Get the function name. */
5626 for (endp = p; *endp != '\0'; endp++)
5628 if (*endp == '(') /* ) */
5629 break;
5630 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5631 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5632 fatal_error ("malformed spec function name");
5634 if (*endp != '(') /* ) */
5635 fatal_error ("no arguments for spec function");
5636 func = save_string (p, endp - p);
5637 p = ++endp;
5639 /* Get the arguments. */
5640 for (count = 0; *endp != '\0'; endp++)
5642 /* ( */
5643 if (*endp == ')')
5645 if (count == 0)
5646 break;
5647 count--;
5649 else if (*endp == '(') /* ) */
5650 count++;
5652 /* ( */
5653 if (*endp != ')')
5654 fatal_error ("malformed spec function arguments");
5655 args = save_string (p, endp - p);
5656 p = ++endp;
5658 /* p now points to just past the end of the spec function expression. */
5660 funcval = eval_spec_function (func, args);
5661 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5662 p = NULL;
5663 if (retval_nonnull)
5664 *retval_nonnull = funcval != NULL;
5666 free (func);
5667 free (args);
5669 processing_spec_function--;
5671 return p;
5674 /* Inline subroutine of handle_braces. Returns true if the current
5675 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5676 static inline bool
5677 input_suffix_matches (const char *atom, const char *end_atom)
5679 return (input_suffix
5680 && !strncmp (input_suffix, atom, end_atom - atom)
5681 && input_suffix[end_atom - atom] == '\0');
5684 /* Subroutine of handle_braces. Returns true if the current
5685 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
5686 static bool
5687 input_spec_matches (const char *atom, const char *end_atom)
5689 return (input_file_compiler
5690 && input_file_compiler->suffix
5691 && input_file_compiler->suffix[0] != '\0'
5692 && !strncmp (input_file_compiler->suffix + 1, atom,
5693 end_atom - atom)
5694 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
5697 /* Subroutine of handle_braces. Returns true if a switch
5698 matching the atom bracketed by ATOM and END_ATOM appeared on the
5699 command line. */
5700 static bool
5701 switch_matches (const char *atom, const char *end_atom, int starred)
5703 int i;
5704 int len = end_atom - atom;
5705 int plen = starred ? len : -1;
5707 for (i = 0; i < n_switches; i++)
5708 if (!strncmp (switches[i].part1, atom, len)
5709 && (starred || switches[i].part1[len] == '\0')
5710 && check_live_switch (i, plen))
5711 return true;
5713 /* Check if a switch with separated form matching the atom.
5714 We check -D and -U switches. */
5715 else if (switches[i].args != 0)
5717 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
5718 && *switches[i].part1 == atom[0])
5720 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
5721 && (starred || (switches[i].part1[1] == '\0'
5722 && switches[i].args[0][len - 1] == '\0'))
5723 && check_live_switch (i, (starred ? 1 : -1)))
5724 return true;
5728 return false;
5731 /* Inline subroutine of handle_braces. Mark all of the switches which
5732 match ATOM (extends to END_ATOM; STARRED indicates whether there
5733 was a star after the atom) for later processing. */
5734 static inline void
5735 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5737 int i;
5738 int len = end_atom - atom;
5739 int plen = starred ? len : -1;
5741 for (i = 0; i < n_switches; i++)
5742 if (!strncmp (switches[i].part1, atom, len)
5743 && (starred || switches[i].part1[len] == '\0')
5744 && check_live_switch (i, plen))
5745 switches[i].ordering = 1;
5748 /* Inline subroutine of handle_braces. Process all the currently
5749 marked switches through give_switch, and clear the marks. */
5750 static inline void
5751 process_marked_switches (void)
5753 int i;
5755 for (i = 0; i < n_switches; i++)
5756 if (switches[i].ordering == 1)
5758 switches[i].ordering = 0;
5759 give_switch (i, 0);
5763 /* Handle a %{ ... } construct. P points just inside the leading {.
5764 Returns a pointer one past the end of the brace block, or 0
5765 if we call do_spec_1 and that returns -1. */
5767 static const char *
5768 handle_braces (const char *p)
5770 const char *atom, *end_atom;
5771 const char *d_atom = NULL, *d_end_atom = NULL;
5772 const char *orig = p;
5774 bool a_is_suffix;
5775 bool a_is_spectype;
5776 bool a_is_starred;
5777 bool a_is_negated;
5778 bool a_matched;
5780 bool a_must_be_last = false;
5781 bool ordered_set = false;
5782 bool disjunct_set = false;
5783 bool disj_matched = false;
5784 bool disj_starred = true;
5785 bool n_way_choice = false;
5786 bool n_way_matched = false;
5788 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5792 if (a_must_be_last)
5793 goto invalid;
5795 /* Scan one "atom" (S in the description above of %{}, possibly
5796 with '!', '.', '@', ',', or '*' modifiers). */
5797 a_matched = false;
5798 a_is_suffix = false;
5799 a_is_starred = false;
5800 a_is_negated = false;
5801 a_is_spectype = false;
5803 SKIP_WHITE ();
5804 if (*p == '!')
5805 p++, a_is_negated = true;
5807 SKIP_WHITE ();
5808 if (*p == '%' && p[1] == ':')
5810 atom = NULL;
5811 end_atom = NULL;
5812 p = handle_spec_function (p + 2, &a_matched);
5814 else
5816 if (*p == '.')
5817 p++, a_is_suffix = true;
5818 else if (*p == ',')
5819 p++, a_is_spectype = true;
5821 atom = p;
5822 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
5823 || *p == ',' || *p == '.' || *p == '@')
5824 p++;
5825 end_atom = p;
5827 if (*p == '*')
5828 p++, a_is_starred = 1;
5831 SKIP_WHITE ();
5832 switch (*p)
5834 case '&': case '}':
5835 /* Substitute the switch(es) indicated by the current atom. */
5836 ordered_set = true;
5837 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5838 || a_is_spectype || atom == end_atom)
5839 goto invalid;
5841 mark_matching_switches (atom, end_atom, a_is_starred);
5843 if (*p == '}')
5844 process_marked_switches ();
5845 break;
5847 case '|': case ':':
5848 /* Substitute some text if the current atom appears as a switch
5849 or suffix. */
5850 disjunct_set = true;
5851 if (ordered_set)
5852 goto invalid;
5854 if (atom && atom == end_atom)
5856 if (!n_way_choice || disj_matched || *p == '|'
5857 || a_is_negated || a_is_suffix || a_is_spectype
5858 || a_is_starred)
5859 goto invalid;
5861 /* An empty term may appear as the last choice of an
5862 N-way choice set; it means "otherwise". */
5863 a_must_be_last = true;
5864 disj_matched = !n_way_matched;
5865 disj_starred = false;
5867 else
5869 if ((a_is_suffix || a_is_spectype) && a_is_starred)
5870 goto invalid;
5872 if (!a_is_starred)
5873 disj_starred = false;
5875 /* Don't bother testing this atom if we already have a
5876 match. */
5877 if (!disj_matched && !n_way_matched)
5879 if (atom == NULL)
5880 /* a_matched is already set by handle_spec_function. */;
5881 else if (a_is_suffix)
5882 a_matched = input_suffix_matches (atom, end_atom);
5883 else if (a_is_spectype)
5884 a_matched = input_spec_matches (atom, end_atom);
5885 else
5886 a_matched = switch_matches (atom, end_atom, a_is_starred);
5888 if (a_matched != a_is_negated)
5890 disj_matched = true;
5891 d_atom = atom;
5892 d_end_atom = end_atom;
5897 if (*p == ':')
5899 /* Found the body, that is, the text to substitute if the
5900 current disjunction matches. */
5901 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5902 disj_matched && !n_way_matched);
5903 if (p == 0)
5904 return 0;
5906 /* If we have an N-way choice, reset state for the next
5907 disjunction. */
5908 if (*p == ';')
5910 n_way_choice = true;
5911 n_way_matched |= disj_matched;
5912 disj_matched = false;
5913 disj_starred = true;
5914 d_atom = d_end_atom = NULL;
5917 break;
5919 default:
5920 goto invalid;
5923 while (*p++ != '}');
5925 return p;
5927 invalid:
5928 fatal_error ("braced spec %qs is invalid at %qc", orig, *p);
5930 #undef SKIP_WHITE
5933 /* Subroutine of handle_braces. Scan and process a brace substitution body
5934 (X in the description of %{} syntax). P points one past the colon;
5935 ATOM and END_ATOM bracket the first atom which was found to be true
5936 (present) in the current disjunction; STARRED indicates whether all
5937 the atoms in the current disjunction were starred (for syntax validation);
5938 MATCHED indicates whether the disjunction matched or not, and therefore
5939 whether or not the body is to be processed through do_spec_1 or just
5940 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5941 returns -1. */
5943 static const char *
5944 process_brace_body (const char *p, const char *atom, const char *end_atom,
5945 int starred, int matched)
5947 const char *body, *end_body;
5948 unsigned int nesting_level;
5949 bool have_subst = false;
5951 /* Locate the closing } or ;, honoring nested braces.
5952 Trim trailing whitespace. */
5953 body = p;
5954 nesting_level = 1;
5955 for (;;)
5957 if (*p == '{')
5958 nesting_level++;
5959 else if (*p == '}')
5961 if (!--nesting_level)
5962 break;
5964 else if (*p == ';' && nesting_level == 1)
5965 break;
5966 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5967 have_subst = true;
5968 else if (*p == '\0')
5969 goto invalid;
5970 p++;
5973 end_body = p;
5974 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5975 end_body--;
5977 if (have_subst && !starred)
5978 goto invalid;
5980 if (matched)
5982 /* Copy the substitution body to permanent storage and execute it.
5983 If have_subst is false, this is a simple matter of running the
5984 body through do_spec_1... */
5985 char *string = save_string (body, end_body - body);
5986 if (!have_subst)
5988 if (do_spec_1 (string, 0, NULL) < 0)
5989 return 0;
5991 else
5993 /* ... but if have_subst is true, we have to process the
5994 body once for each matching switch, with %* set to the
5995 variant part of the switch. */
5996 unsigned int hard_match_len = end_atom - atom;
5997 int i;
5999 for (i = 0; i < n_switches; i++)
6000 if (!strncmp (switches[i].part1, atom, hard_match_len)
6001 && check_live_switch (i, hard_match_len))
6003 if (do_spec_1 (string, 0,
6004 &switches[i].part1[hard_match_len]) < 0)
6005 return 0;
6006 /* Pass any arguments this switch has. */
6007 give_switch (i, 1);
6008 suffix_subst = NULL;
6013 return p;
6015 invalid:
6016 fatal_error ("braced spec body %qs is invalid", body);
6019 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
6020 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
6021 spec, or -1 if either exact match or %* is used.
6023 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
6024 whose value does not begin with "no-" is obsoleted by the same value
6025 with the "no-", similarly for a switch with the "no-" prefix. */
6027 static int
6028 check_live_switch (int switchnum, int prefix_length)
6030 const char *name = switches[switchnum].part1;
6031 int i;
6033 /* If we already processed this switch and determined if it was
6034 live or not, return our past determination. */
6035 if (switches[switchnum].live_cond != 0)
6036 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
6037 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
6038 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
6039 == 0);
6041 /* In the common case of {<at-most-one-letter>*}, a negating
6042 switch would always match, so ignore that case. We will just
6043 send the conflicting switches to the compiler phase. */
6044 if (prefix_length >= 0 && prefix_length <= 1)
6045 return 1;
6047 /* Now search for duplicate in a manner that depends on the name. */
6048 switch (*name)
6050 case 'O':
6051 for (i = switchnum + 1; i < n_switches; i++)
6052 if (switches[i].part1[0] == 'O')
6054 switches[switchnum].validated = true;
6055 switches[switchnum].live_cond = SWITCH_FALSE;
6056 return 0;
6058 break;
6060 case 'W': case 'f': case 'm': case 'g':
6061 if (! strncmp (name + 1, "no-", 3))
6063 /* We have Xno-YYY, search for XYYY. */
6064 for (i = switchnum + 1; i < n_switches; i++)
6065 if (switches[i].part1[0] == name[0]
6066 && ! strcmp (&switches[i].part1[1], &name[4]))
6068 /* --specs are validated with the validate_switches mechanism. */
6069 if (switches[switchnum].known)
6070 switches[switchnum].validated = true;
6071 switches[switchnum].live_cond = SWITCH_FALSE;
6072 return 0;
6075 else
6077 /* We have XYYY, search for Xno-YYY. */
6078 for (i = switchnum + 1; i < n_switches; i++)
6079 if (switches[i].part1[0] == name[0]
6080 && switches[i].part1[1] == 'n'
6081 && switches[i].part1[2] == 'o'
6082 && switches[i].part1[3] == '-'
6083 && !strcmp (&switches[i].part1[4], &name[1]))
6085 /* --specs are validated with the validate_switches mechanism. */
6086 if (switches[switchnum].known)
6087 switches[switchnum].validated = true;
6088 switches[switchnum].live_cond = SWITCH_FALSE;
6089 return 0;
6092 break;
6095 /* Otherwise the switch is live. */
6096 switches[switchnum].live_cond |= SWITCH_LIVE;
6097 return 1;
6100 /* Pass a switch to the current accumulating command
6101 in the same form that we received it.
6102 SWITCHNUM identifies the switch; it is an index into
6103 the vector of switches gcc received, which is `switches'.
6104 This cannot fail since it never finishes a command line.
6106 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
6108 static void
6109 give_switch (int switchnum, int omit_first_word)
6111 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
6112 return;
6114 if (!omit_first_word)
6116 do_spec_1 ("-", 0, NULL);
6117 do_spec_1 (switches[switchnum].part1, 1, NULL);
6120 if (switches[switchnum].args != 0)
6122 const char **p;
6123 for (p = switches[switchnum].args; *p; p++)
6125 const char *arg = *p;
6127 do_spec_1 (" ", 0, NULL);
6128 if (suffix_subst)
6130 unsigned length = strlen (arg);
6131 int dot = 0;
6133 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
6134 if (arg[length] == '.')
6136 (CONST_CAST (char *, arg))[length] = 0;
6137 dot = 1;
6138 break;
6140 do_spec_1 (arg, 1, NULL);
6141 if (dot)
6142 (CONST_CAST (char *, arg))[length] = '.';
6143 do_spec_1 (suffix_subst, 1, NULL);
6145 else
6146 do_spec_1 (arg, 1, NULL);
6150 do_spec_1 (" ", 0, NULL);
6151 switches[switchnum].validated = true;
6154 /* Search for a file named NAME trying various prefixes including the
6155 user's -B prefix and some standard ones.
6156 Return the absolute file name found. If nothing is found, return NAME. */
6158 static const char *
6159 find_file (const char *name)
6161 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
6162 return newname ? newname : name;
6165 /* Determine whether a directory exists. If LINKER, return 0 for
6166 certain fixed names not needed by the linker. */
6168 static int
6169 is_directory (const char *path1, bool linker)
6171 int len1;
6172 char *path;
6173 char *cp;
6174 struct stat st;
6176 /* Ensure the string ends with "/.". The resulting path will be a
6177 directory even if the given path is a symbolic link. */
6178 len1 = strlen (path1);
6179 path = (char *) alloca (3 + len1);
6180 memcpy (path, path1, len1);
6181 cp = path + len1;
6182 if (!IS_DIR_SEPARATOR (cp[-1]))
6183 *cp++ = DIR_SEPARATOR;
6184 *cp++ = '.';
6185 *cp = '\0';
6187 /* Exclude directories that the linker is known to search. */
6188 if (linker
6189 && IS_DIR_SEPARATOR (path[0])
6190 && ((cp - path == 6
6191 && filename_ncmp (path + 1, "lib", 3) == 0)
6192 || (cp - path == 10
6193 && filename_ncmp (path + 1, "usr", 3) == 0
6194 && IS_DIR_SEPARATOR (path[4])
6195 && filename_ncmp (path + 5, "lib", 3) == 0)))
6196 return 0;
6198 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
6201 /* Set up the various global variables to indicate that we're processing
6202 the input file named FILENAME. */
6204 void
6205 set_input (const char *filename)
6207 const char *p;
6209 gcc_input_filename = filename;
6210 input_filename_length = strlen (gcc_input_filename);
6211 input_basename = lbasename (gcc_input_filename);
6213 /* Find a suffix starting with the last period,
6214 and set basename_length to exclude that suffix. */
6215 basename_length = strlen (input_basename);
6216 suffixed_basename_length = basename_length;
6217 p = input_basename + basename_length;
6218 while (p != input_basename && *p != '.')
6219 --p;
6220 if (*p == '.' && p != input_basename)
6222 basename_length = p - input_basename;
6223 input_suffix = p + 1;
6225 else
6226 input_suffix = "";
6228 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6229 we will need to do a stat on the gcc_input_filename. The
6230 INPUT_STAT_SET signals that the stat is needed. */
6231 input_stat_set = 0;
6234 /* On fatal signals, delete all the temporary files. */
6236 static void
6237 fatal_signal (int signum)
6239 signal (signum, SIG_DFL);
6240 delete_failure_queue ();
6241 delete_temp_files ();
6242 /* Get the same signal again, this time not handled,
6243 so its normal effect occurs. */
6244 kill (getpid (), signum);
6247 /* Compare the contents of the two files named CMPFILE[0] and
6248 CMPFILE[1]. Return zero if they're identical, nonzero
6249 otherwise. */
6251 static int
6252 compare_files (char *cmpfile[])
6254 int ret = 0;
6255 FILE *temp[2] = { NULL, NULL };
6256 int i;
6258 #if HAVE_MMAP_FILE
6260 size_t length[2];
6261 void *map[2] = { NULL, NULL };
6263 for (i = 0; i < 2; i++)
6265 struct stat st;
6267 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
6269 error ("%s: could not determine length of compare-debug file %s",
6270 gcc_input_filename, cmpfile[i]);
6271 ret = 1;
6272 break;
6275 length[i] = st.st_size;
6278 if (!ret && length[0] != length[1])
6280 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
6281 ret = 1;
6284 if (!ret)
6285 for (i = 0; i < 2; i++)
6287 int fd = open (cmpfile[i], O_RDONLY);
6288 if (fd < 0)
6290 error ("%s: could not open compare-debug file %s",
6291 gcc_input_filename, cmpfile[i]);
6292 ret = 1;
6293 break;
6296 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
6297 close (fd);
6299 if (map[i] == (void *) MAP_FAILED)
6301 ret = -1;
6302 break;
6306 if (!ret)
6308 if (memcmp (map[0], map[1], length[0]) != 0)
6310 error ("%s: -fcompare-debug failure", gcc_input_filename);
6311 ret = 1;
6315 for (i = 0; i < 2; i++)
6316 if (map[i])
6317 munmap ((caddr_t) map[i], length[i]);
6319 if (ret >= 0)
6320 return ret;
6322 ret = 0;
6324 #endif
6326 for (i = 0; i < 2; i++)
6328 temp[i] = fopen (cmpfile[i], "r");
6329 if (!temp[i])
6331 error ("%s: could not open compare-debug file %s",
6332 gcc_input_filename, cmpfile[i]);
6333 ret = 1;
6334 break;
6338 if (!ret && temp[0] && temp[1])
6339 for (;;)
6341 int c0, c1;
6342 c0 = fgetc (temp[0]);
6343 c1 = fgetc (temp[1]);
6345 if (c0 != c1)
6347 error ("%s: -fcompare-debug failure",
6348 gcc_input_filename);
6349 ret = 1;
6350 break;
6353 if (c0 == EOF)
6354 break;
6357 for (i = 1; i >= 0; i--)
6359 if (temp[i])
6360 fclose (temp[i]);
6363 return ret;
6366 extern int main (int, char **);
6369 main (int argc, char **argv)
6371 size_t i;
6372 int value;
6373 int linker_was_run = 0;
6374 int lang_n_infiles = 0;
6375 int num_linker_inputs = 0;
6376 char *explicit_link_files;
6377 char *specs_file;
6378 char *lto_wrapper_file;
6379 const char *p;
6380 struct user_specs *uptr;
6381 char **old_argv = argv;
6382 struct cl_decoded_option *decoded_options;
6383 unsigned int decoded_options_count;
6385 p = argv[0] + strlen (argv[0]);
6386 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
6387 --p;
6388 progname = p;
6390 xmalloc_set_program_name (progname);
6392 expandargv (&argc, &argv);
6394 /* Determine if any expansions were made. */
6395 if (argv != old_argv)
6396 at_file_supplied = true;
6398 /* Register the language-independent parameters. */
6399 global_init_params ();
6400 finish_params ();
6402 init_options_struct (&global_options, &global_options_set);
6404 decode_cmdline_options_to_array (argc, CONST_CAST2 (const char **, char **,
6405 argv),
6406 CL_DRIVER,
6407 &decoded_options, &decoded_options_count);
6409 /* Unlock the stdio streams. */
6410 unlock_std_streams ();
6412 gcc_init_libintl ();
6414 diagnostic_initialize (global_dc, 0);
6416 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6417 /* Perform host dependent initialization when needed. */
6418 GCC_DRIVER_HOST_INITIALIZATION;
6419 #endif
6421 if (atexit (delete_temp_files) != 0)
6422 fatal_error ("atexit failed");
6424 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6425 signal (SIGINT, fatal_signal);
6426 #ifdef SIGHUP
6427 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6428 signal (SIGHUP, fatal_signal);
6429 #endif
6430 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6431 signal (SIGTERM, fatal_signal);
6432 #ifdef SIGPIPE
6433 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6434 signal (SIGPIPE, fatal_signal);
6435 #endif
6436 #ifdef SIGCHLD
6437 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6438 receive the signal. A different setting is inheritable */
6439 signal (SIGCHLD, SIG_DFL);
6440 #endif
6442 /* Parsing and gimplification sometimes need quite large stack.
6443 Increase stack size limits if possible. */
6444 stack_limit_increase (64 * 1024 * 1024);
6446 /* Allocate the argument vector. */
6447 alloc_args ();
6449 obstack_init (&obstack);
6451 /* Build multilib_select, et. al from the separate lines that make up each
6452 multilib selection. */
6454 const char *const *q = multilib_raw;
6455 int need_space;
6457 obstack_init (&multilib_obstack);
6458 while ((p = *q++) != (char *) 0)
6459 obstack_grow (&multilib_obstack, p, strlen (p));
6461 obstack_1grow (&multilib_obstack, 0);
6462 multilib_select = XOBFINISH (&multilib_obstack, const char *);
6464 q = multilib_matches_raw;
6465 while ((p = *q++) != (char *) 0)
6466 obstack_grow (&multilib_obstack, p, strlen (p));
6468 obstack_1grow (&multilib_obstack, 0);
6469 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
6471 q = multilib_exclusions_raw;
6472 while ((p = *q++) != (char *) 0)
6473 obstack_grow (&multilib_obstack, p, strlen (p));
6475 obstack_1grow (&multilib_obstack, 0);
6476 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
6478 q = multilib_reuse_raw;
6479 while ((p = *q++) != (char *) 0)
6480 obstack_grow (&multilib_obstack, p, strlen (p));
6482 obstack_1grow (&multilib_obstack, 0);
6483 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
6485 need_space = FALSE;
6486 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6488 if (need_space)
6489 obstack_1grow (&multilib_obstack, ' ');
6490 obstack_grow (&multilib_obstack,
6491 multilib_defaults_raw[i],
6492 strlen (multilib_defaults_raw[i]));
6493 need_space = TRUE;
6496 obstack_1grow (&multilib_obstack, 0);
6497 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
6500 #ifdef INIT_ENVIRONMENT
6501 /* Set up any other necessary machine specific environment variables. */
6502 xputenv (INIT_ENVIRONMENT);
6503 #endif
6505 /* Make a table of what switches there are (switches, n_switches).
6506 Make a table of specified input files (infiles, n_infiles).
6507 Decode switches that are handled locally. */
6509 process_command (decoded_options_count, decoded_options);
6511 /* Initialize the vector of specs to just the default.
6512 This means one element containing 0s, as a terminator. */
6514 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
6515 memcpy (compilers, default_compilers, sizeof default_compilers);
6516 n_compilers = n_default_compilers;
6518 /* Read specs from a file if there is one. */
6520 machine_suffix = concat (spec_machine, dir_separator_str,
6521 spec_version, dir_separator_str, NULL);
6522 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6524 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
6525 /* Read the specs file unless it is a default one. */
6526 if (specs_file != 0 && strcmp (specs_file, "specs"))
6527 read_specs (specs_file, true, false);
6528 else
6529 init_spec ();
6531 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6532 for any override of as, ld and libraries. */
6533 specs_file = (char *) alloca (strlen (standard_exec_prefix)
6534 + strlen (just_machine_suffix) + sizeof ("specs"));
6536 strcpy (specs_file, standard_exec_prefix);
6537 strcat (specs_file, just_machine_suffix);
6538 strcat (specs_file, "specs");
6539 if (access (specs_file, R_OK) == 0)
6540 read_specs (specs_file, true, false);
6542 /* Process any configure-time defaults specified for the command line
6543 options, via OPTION_DEFAULT_SPECS. */
6544 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6545 do_option_spec (option_default_specs[i].name,
6546 option_default_specs[i].spec);
6548 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6549 of the command line. */
6551 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6552 do_self_spec (driver_self_specs[i]);
6554 /* If not cross-compiling, look for executables in the standard
6555 places. */
6556 if (*cross_compile == '0')
6558 if (*md_exec_prefix)
6560 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6561 PREFIX_PRIORITY_LAST, 0, 0);
6565 /* Process sysroot_suffix_spec. */
6566 if (*sysroot_suffix_spec != 0
6567 && !no_sysroot_suffix
6568 && do_spec_2 (sysroot_suffix_spec) == 0)
6570 if (argbuf.length () > 1)
6571 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
6572 else if (argbuf.length () == 1)
6573 target_sysroot_suffix = xstrdup (argbuf.last ());
6576 #ifdef HAVE_LD_SYSROOT
6577 /* Pass the --sysroot option to the linker, if it supports that. If
6578 there is a sysroot_suffix_spec, it has already been processed by
6579 this point, so target_system_root really is the system root we
6580 should be using. */
6581 if (target_system_root)
6583 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
6584 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
6585 set_spec ("link", XOBFINISH (&obstack, const char *), false);
6587 #endif
6589 /* Process sysroot_hdrs_suffix_spec. */
6590 if (*sysroot_hdrs_suffix_spec != 0
6591 && !no_sysroot_suffix
6592 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6594 if (argbuf.length () > 1)
6595 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
6596 else if (argbuf.length () == 1)
6597 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
6600 /* Look for startfiles in the standard places. */
6601 if (*startfile_prefix_spec != 0
6602 && do_spec_2 (startfile_prefix_spec) == 0
6603 && do_spec_1 (" ", 0, NULL) == 0)
6605 const char *arg;
6606 int ndx;
6607 FOR_EACH_VEC_ELT (argbuf, ndx, arg)
6608 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
6609 PREFIX_PRIORITY_LAST, 0, 1);
6611 /* We should eventually get rid of all these and stick to
6612 startfile_prefix_spec exclusively. */
6613 else if (*cross_compile == '0' || target_system_root)
6615 if (*md_startfile_prefix)
6616 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6617 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6619 if (*md_startfile_prefix_1)
6620 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6621 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6623 /* If standard_startfile_prefix is relative, base it on
6624 standard_exec_prefix. This lets us move the installed tree
6625 as a unit. If GCC_EXEC_PREFIX is defined, base
6626 standard_startfile_prefix on that as well.
6628 If the prefix is relative, only search it for native compilers;
6629 otherwise we will search a directory containing host libraries. */
6630 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6631 add_sysrooted_prefix (&startfile_prefixes,
6632 standard_startfile_prefix, "BINUTILS",
6633 PREFIX_PRIORITY_LAST, 0, 1);
6634 else if (*cross_compile == '0')
6636 add_prefix (&startfile_prefixes,
6637 concat (gcc_exec_prefix
6638 ? gcc_exec_prefix : standard_exec_prefix,
6639 machine_suffix,
6640 standard_startfile_prefix, NULL),
6641 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6644 /* Sysrooted prefixes are relocated because target_system_root is
6645 also relocated by gcc_exec_prefix. */
6646 if (*standard_startfile_prefix_1)
6647 add_sysrooted_prefix (&startfile_prefixes,
6648 standard_startfile_prefix_1, "BINUTILS",
6649 PREFIX_PRIORITY_LAST, 0, 1);
6650 if (*standard_startfile_prefix_2)
6651 add_sysrooted_prefix (&startfile_prefixes,
6652 standard_startfile_prefix_2, "BINUTILS",
6653 PREFIX_PRIORITY_LAST, 0, 1);
6656 /* Process any user specified specs in the order given on the command
6657 line. */
6658 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6660 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6661 R_OK, true);
6662 read_specs (filename ? filename : uptr->filename, false, true);
6665 /* Process any user self specs. */
6667 struct spec_list *sl;
6668 for (sl = specs; sl; sl = sl->next)
6669 if (sl->name_len == sizeof "self_spec" - 1
6670 && !strcmp (sl->name, "self_spec"))
6671 do_self_spec (*sl->ptr_spec);
6674 if (compare_debug)
6676 enum save_temps save;
6678 if (!compare_debug_second)
6680 n_switches_debug_check[1] = n_switches;
6681 n_switches_alloc_debug_check[1] = n_switches_alloc;
6682 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
6683 n_switches_alloc);
6685 do_self_spec ("%:compare-debug-self-opt()");
6686 n_switches_debug_check[0] = n_switches;
6687 n_switches_alloc_debug_check[0] = n_switches_alloc;
6688 switches_debug_check[0] = switches;
6690 n_switches = n_switches_debug_check[1];
6691 n_switches_alloc = n_switches_alloc_debug_check[1];
6692 switches = switches_debug_check[1];
6695 /* Avoid crash when computing %j in this early. */
6696 save = save_temps_flag;
6697 save_temps_flag = SAVE_TEMPS_NONE;
6699 compare_debug = -compare_debug;
6700 do_self_spec ("%:compare-debug-self-opt()");
6702 save_temps_flag = save;
6704 if (!compare_debug_second)
6706 n_switches_debug_check[1] = n_switches;
6707 n_switches_alloc_debug_check[1] = n_switches_alloc;
6708 switches_debug_check[1] = switches;
6709 compare_debug = -compare_debug;
6710 n_switches = n_switches_debug_check[0];
6711 n_switches_alloc = n_switches_debug_check[0];
6712 switches = switches_debug_check[0];
6717 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6718 if (gcc_exec_prefix)
6719 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6720 spec_version, dir_separator_str, NULL);
6722 /* Now we have the specs.
6723 Set the `valid' bits for switches that match anything in any spec. */
6725 validate_all_switches ();
6727 /* Now that we have the switches and the specs, set
6728 the subdirectory based on the options. */
6729 set_multilib_dir ();
6731 /* Set up to remember the pathname of gcc and any options
6732 needed for collect. We use argv[0] instead of progname because
6733 we need the complete pathname. */
6734 obstack_init (&collect_obstack);
6735 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
6736 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
6737 xputenv (XOBFINISH (&collect_obstack, char *));
6739 /* Set up to remember the pathname of the lto wrapper. */
6741 if (have_c)
6742 lto_wrapper_file = NULL;
6743 else
6744 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
6745 X_OK, false);
6746 if (lto_wrapper_file)
6748 lto_wrapper_file = convert_white_space (lto_wrapper_file);
6749 lto_wrapper_spec = lto_wrapper_file;
6750 obstack_init (&collect_obstack);
6751 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
6752 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
6753 obstack_grow (&collect_obstack, lto_wrapper_spec,
6754 strlen (lto_wrapper_spec) + 1);
6755 xputenv (XOBFINISH (&collect_obstack, char *));
6758 /* Reject switches that no pass was interested in. */
6760 for (i = 0; (int) i < n_switches; i++)
6761 if (! switches[i].validated)
6762 error ("unrecognized command line option %<-%s%>", switches[i].part1);
6764 /* Obey some of the options. */
6766 if (print_search_dirs)
6768 printf (_("install: %s%s\n"),
6769 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
6770 gcc_exec_prefix ? "" : machine_suffix);
6771 printf (_("programs: %s\n"),
6772 build_search_list (&exec_prefixes, "", false, false));
6773 printf (_("libraries: %s\n"),
6774 build_search_list (&startfile_prefixes, "", false, true));
6775 return (0);
6778 if (print_file_name)
6780 printf ("%s\n", find_file (print_file_name));
6781 return (0);
6784 if (print_prog_name)
6786 if (use_ld != NULL && ! strcmp (print_prog_name, "ld"))
6788 /* Append USE_LD to to the default linker. */
6789 #ifdef DEFAULT_LINKER
6790 char *ld;
6791 # ifdef HAVE_HOST_EXECUTABLE_SUFFIX
6792 int len = (sizeof (DEFAULT_LINKER)
6793 - sizeof (HOST_EXECUTABLE_SUFFIX));
6794 ld = NULL;
6795 if (len > 0)
6797 char *default_linker = xstrdup (DEFAULT_LINKER);
6798 /* Strip HOST_EXECUTABLE_SUFFIX if DEFAULT_LINKER contains
6799 HOST_EXECUTABLE_SUFFIX. */
6800 if (! strcmp (&default_linker[len], HOST_EXECUTABLE_SUFFIX))
6802 default_linker[len] = '\0';
6803 ld = concat (default_linker, use_ld,
6804 HOST_EXECUTABLE_SUFFIX, NULL);
6807 if (ld == NULL)
6808 # endif
6809 ld = concat (DEFAULT_LINKER, use_ld, NULL);
6810 if (access (ld, X_OK) == 0)
6812 printf ("%s\n", ld);
6813 return (0);
6815 #endif
6816 print_prog_name = concat (print_prog_name, use_ld, NULL);
6818 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6819 printf ("%s\n", (newname ? newname : print_prog_name));
6820 return (0);
6823 if (print_multi_lib)
6825 print_multilib_info ();
6826 return (0);
6829 if (print_multi_directory)
6831 if (multilib_dir == NULL)
6832 printf (".\n");
6833 else
6834 printf ("%s\n", multilib_dir);
6835 return (0);
6838 if (print_multiarch)
6840 if (multiarch_dir == NULL)
6841 printf ("\n");
6842 else
6843 printf ("%s\n", multiarch_dir);
6844 return (0);
6847 if (print_sysroot)
6849 if (target_system_root)
6851 if (target_sysroot_suffix)
6852 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
6853 else
6854 printf ("%s\n", target_system_root);
6856 return (0);
6859 if (print_multi_os_directory)
6861 if (multilib_os_dir == NULL)
6862 printf (".\n");
6863 else
6864 printf ("%s\n", multilib_os_dir);
6865 return (0);
6868 if (print_sysroot_headers_suffix)
6870 if (*sysroot_hdrs_suffix_spec)
6872 printf("%s\n", (target_sysroot_hdrs_suffix
6873 ? target_sysroot_hdrs_suffix
6874 : ""));
6875 return (0);
6877 else
6878 /* The error status indicates that only one set of fixed
6879 headers should be built. */
6880 fatal_error ("not configured with sysroot headers suffix");
6883 if (print_help_list)
6885 display_help ();
6887 if (! verbose_flag)
6889 printf (_("\nFor bug reporting instructions, please see:\n"));
6890 printf ("%s.\n", bug_report_url);
6892 return (0);
6895 /* We do not exit here. Instead we have created a fake input file
6896 called 'help-dummy' which needs to be compiled, and we pass this
6897 on the various sub-processes, along with the --help switch.
6898 Ensure their output appears after ours. */
6899 fputc ('\n', stdout);
6900 fflush (stdout);
6903 if (print_version)
6905 printf (_("%s %s%s\n"), progname, pkgversion_string,
6906 version_string);
6907 printf ("Copyright %s 2014 Free Software Foundation, Inc.\n",
6908 _("(C)"));
6909 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
6910 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
6911 stdout);
6912 if (! verbose_flag)
6913 return 0;
6915 /* We do not exit here. We use the same mechanism of --help to print
6916 the version of the sub-processes. */
6917 fputc ('\n', stdout);
6918 fflush (stdout);
6921 if (verbose_flag)
6923 int n;
6924 const char *thrmod;
6926 fnotice (stderr, "Target: %s\n", spec_machine);
6927 fnotice (stderr, "Configured with: %s\n", configuration_arguments);
6929 #ifdef THREAD_MODEL_SPEC
6930 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6931 but there's no point in doing all this processing just to get
6932 thread_model back. */
6933 obstack_init (&obstack);
6934 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6935 obstack_1grow (&obstack, '\0');
6936 thrmod = XOBFINISH (&obstack, const char *);
6937 #else
6938 thrmod = thread_model;
6939 #endif
6941 fnotice (stderr, "Thread model: %s\n", thrmod);
6943 /* compiler_version is truncated at the first space when initialized
6944 from version string, so truncate version_string at the first space
6945 before comparing. */
6946 for (n = 0; version_string[n]; n++)
6947 if (version_string[n] == ' ')
6948 break;
6950 if (! strncmp (version_string, compiler_version, n)
6951 && compiler_version[n] == 0)
6952 fnotice (stderr, "gcc version %s %s\n", version_string,
6953 pkgversion_string);
6954 else
6955 fnotice (stderr, "gcc driver version %s %sexecuting gcc version %s\n",
6956 version_string, pkgversion_string, compiler_version);
6958 if (n_infiles == 0)
6959 return (0);
6962 if (n_infiles == added_libraries)
6963 fatal_error ("no input files");
6965 if (seen_error ())
6966 goto out;
6968 /* Make a place to record the compiler output file names
6969 that correspond to the input files. */
6971 i = n_infiles;
6972 i += lang_specific_extra_outfiles;
6973 outfiles = XCNEWVEC (const char *, i);
6975 /* Record which files were specified explicitly as link input. */
6977 explicit_link_files = XCNEWVEC (char, n_infiles);
6979 combine_inputs = have_o || flag_wpa;
6981 for (i = 0; (int) i < n_infiles; i++)
6983 const char *name = infiles[i].name;
6984 struct compiler *compiler = lookup_compiler (name,
6985 strlen (name),
6986 infiles[i].language);
6988 if (compiler && !(compiler->combinable))
6989 combine_inputs = false;
6991 if (lang_n_infiles > 0 && compiler != input_file_compiler
6992 && infiles[i].language && infiles[i].language[0] != '*')
6993 infiles[i].incompiler = compiler;
6994 else if (compiler)
6996 lang_n_infiles++;
6997 input_file_compiler = compiler;
6998 infiles[i].incompiler = compiler;
7000 else
7002 /* Since there is no compiler for this input file, assume it is a
7003 linker file. */
7004 explicit_link_files[i] = 1;
7005 infiles[i].incompiler = NULL;
7007 infiles[i].compiled = false;
7008 infiles[i].preprocessed = false;
7011 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
7012 fatal_error ("cannot specify -o with -c, -S or -E with multiple files");
7014 for (i = 0; (int) i < n_infiles; i++)
7016 int this_file_error = 0;
7018 /* Tell do_spec what to substitute for %i. */
7020 input_file_number = i;
7021 set_input (infiles[i].name);
7023 if (infiles[i].compiled)
7024 continue;
7026 /* Use the same thing in %o, unless cp->spec says otherwise. */
7028 outfiles[i] = gcc_input_filename;
7030 /* Figure out which compiler from the file's suffix. */
7032 input_file_compiler
7033 = lookup_compiler (infiles[i].name, input_filename_length,
7034 infiles[i].language);
7036 if (input_file_compiler)
7038 /* Ok, we found an applicable compiler. Run its spec. */
7040 if (input_file_compiler->spec[0] == '#')
7042 error ("%s: %s compiler not installed on this system",
7043 gcc_input_filename, &input_file_compiler->spec[1]);
7044 this_file_error = 1;
7046 else
7048 if (compare_debug)
7050 free (debug_check_temp_file[0]);
7051 debug_check_temp_file[0] = NULL;
7053 free (debug_check_temp_file[1]);
7054 debug_check_temp_file[1] = NULL;
7057 value = do_spec (input_file_compiler->spec);
7058 infiles[i].compiled = true;
7059 if (value < 0)
7060 this_file_error = 1;
7061 else if (compare_debug && debug_check_temp_file[0])
7063 if (verbose_flag)
7064 inform (0, "recompiling with -fcompare-debug");
7066 compare_debug = -compare_debug;
7067 n_switches = n_switches_debug_check[1];
7068 n_switches_alloc = n_switches_alloc_debug_check[1];
7069 switches = switches_debug_check[1];
7071 value = do_spec (input_file_compiler->spec);
7073 compare_debug = -compare_debug;
7074 n_switches = n_switches_debug_check[0];
7075 n_switches_alloc = n_switches_alloc_debug_check[0];
7076 switches = switches_debug_check[0];
7078 if (value < 0)
7080 error ("during -fcompare-debug recompilation");
7081 this_file_error = 1;
7084 gcc_assert (debug_check_temp_file[1]
7085 && filename_cmp (debug_check_temp_file[0],
7086 debug_check_temp_file[1]));
7088 if (verbose_flag)
7089 inform (0, "comparing final insns dumps");
7091 if (compare_files (debug_check_temp_file))
7092 this_file_error = 1;
7095 if (compare_debug)
7097 free (debug_check_temp_file[0]);
7098 debug_check_temp_file[0] = NULL;
7100 free (debug_check_temp_file[1]);
7101 debug_check_temp_file[1] = NULL;
7106 /* If this file's name does not contain a recognized suffix,
7107 record it as explicit linker input. */
7109 else
7110 explicit_link_files[i] = 1;
7112 /* Clear the delete-on-failure queue, deleting the files in it
7113 if this compilation failed. */
7115 if (this_file_error)
7117 delete_failure_queue ();
7118 errorcount++;
7120 /* If this compilation succeeded, don't delete those files later. */
7121 clear_failure_queue ();
7124 /* Reset the input file name to the first compile/object file name, for use
7125 with %b in LINK_SPEC. We use the first input file that we can find
7126 a compiler to compile it instead of using infiles.language since for
7127 languages other than C we use aliases that we then lookup later. */
7128 if (n_infiles > 0)
7130 int i;
7132 for (i = 0; i < n_infiles ; i++)
7133 if (infiles[i].incompiler
7134 || (infiles[i].language && infiles[i].language[0] != '*'))
7136 set_input (infiles[i].name);
7137 break;
7141 if (!seen_error ())
7143 /* Make sure INPUT_FILE_NUMBER points to first available open
7144 slot. */
7145 input_file_number = n_infiles;
7146 if (lang_specific_pre_link ())
7147 errorcount++;
7150 /* Determine if there are any linker input files. */
7151 num_linker_inputs = 0;
7152 for (i = 0; (int) i < n_infiles; i++)
7153 if (explicit_link_files[i] || outfiles[i] != NULL)
7154 num_linker_inputs++;
7156 /* Run ld to link all the compiler output files. */
7158 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
7160 int tmp = execution_count;
7162 if (! have_c)
7164 #if HAVE_LTO_PLUGIN > 0
7165 #if HAVE_LTO_PLUGIN == 2
7166 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
7167 #else
7168 const char *fuse_linker_plugin = "fuse-linker-plugin";
7169 #endif
7170 #endif
7172 /* We'll use ld if we can't find collect2. */
7173 if (! strcmp (linker_name_spec, "collect2"))
7175 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
7176 if (s == NULL)
7177 linker_name_spec = "ld";
7180 #if HAVE_LTO_PLUGIN > 0
7181 #if HAVE_LTO_PLUGIN == 2
7182 if (!switch_matches (fno_use_linker_plugin,
7183 fno_use_linker_plugin
7184 + strlen (fno_use_linker_plugin), 0))
7185 #else
7186 if (switch_matches (fuse_linker_plugin,
7187 fuse_linker_plugin
7188 + strlen (fuse_linker_plugin), 0))
7189 #endif
7191 char *temp_spec = find_a_file (&exec_prefixes,
7192 LTOPLUGINSONAME, R_OK,
7193 false);
7194 if (!temp_spec)
7195 fatal_error ("-fuse-linker-plugin, but %s not found",
7196 LTOPLUGINSONAME);
7197 linker_plugin_file_spec = convert_white_space (temp_spec);
7199 #endif
7200 lto_gcc_spec = argv[0];
7203 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
7204 for collect. */
7205 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
7206 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
7208 if (print_subprocess_help == 1)
7210 printf (_("\nLinker options\n==============\n\n"));
7211 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
7212 " to the linker.\n\n"));
7213 fflush (stdout);
7215 value = do_spec (link_command_spec);
7216 if (value < 0)
7217 errorcount = 1;
7218 linker_was_run = (tmp != execution_count);
7221 /* If options said don't run linker,
7222 complain about input files to be given to the linker. */
7224 if (! linker_was_run && !seen_error ())
7225 for (i = 0; (int) i < n_infiles; i++)
7226 if (explicit_link_files[i]
7227 && !(infiles[i].language && infiles[i].language[0] == '*'))
7228 warning (0, "%s: linker input file unused because linking not done",
7229 outfiles[i]);
7231 /* Delete some or all of the temporary files we made. */
7233 if (seen_error ())
7234 delete_failure_queue ();
7235 delete_temp_files ();
7237 if (print_help_list)
7239 printf (("\nFor bug reporting instructions, please see:\n"));
7240 printf ("%s\n", bug_report_url);
7243 out:
7244 return (signal_count != 0 ? 2
7245 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
7246 : 0);
7249 /* Find the proper compilation spec for the file name NAME,
7250 whose length is LENGTH. LANGUAGE is the specified language,
7251 or 0 if this file is to be passed to the linker. */
7253 static struct compiler *
7254 lookup_compiler (const char *name, size_t length, const char *language)
7256 struct compiler *cp;
7258 /* If this was specified by the user to be a linker input, indicate that. */
7259 if (language != 0 && language[0] == '*')
7260 return 0;
7262 /* Otherwise, look for the language, if one is spec'd. */
7263 if (language != 0)
7265 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7266 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
7267 return cp;
7269 error ("language %s not recognized", language);
7270 return 0;
7273 /* Look for a suffix. */
7274 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7276 if (/* The suffix `-' matches only the file name `-'. */
7277 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7278 || (strlen (cp->suffix) < length
7279 /* See if the suffix matches the end of NAME. */
7280 && !strcmp (cp->suffix,
7281 name + length - strlen (cp->suffix))
7283 break;
7286 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
7287 /* Look again, but case-insensitively this time. */
7288 if (cp < compilers)
7289 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7291 if (/* The suffix `-' matches only the file name `-'. */
7292 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7293 || (strlen (cp->suffix) < length
7294 /* See if the suffix matches the end of NAME. */
7295 && ((!strcmp (cp->suffix,
7296 name + length - strlen (cp->suffix))
7297 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
7298 && !strcasecmp (cp->suffix,
7299 name + length - strlen (cp->suffix)))
7301 break;
7303 #endif
7305 if (cp >= compilers)
7307 if (cp->spec[0] != '@')
7308 /* A non-alias entry: return it. */
7309 return cp;
7311 /* An alias entry maps a suffix to a language.
7312 Search for the language; pass 0 for NAME and LENGTH
7313 to avoid infinite recursion if language not found. */
7314 return lookup_compiler (NULL, 0, cp->spec + 1);
7316 return 0;
7319 static char *
7320 save_string (const char *s, int len)
7322 char *result = XNEWVEC (char, len + 1);
7324 memcpy (result, s, len);
7325 result[len] = 0;
7326 return result;
7329 void
7330 pfatal_with_name (const char *name)
7332 perror_with_name (name);
7333 delete_temp_files ();
7334 exit (1);
7337 static void
7338 perror_with_name (const char *name)
7340 error ("%s: %m", name);
7343 static inline void
7344 validate_switches_from_spec (const char *spec, bool user)
7346 const char *p = spec;
7347 char c;
7348 while ((c = *p++))
7349 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
7350 /* We have a switch spec. */
7351 p = validate_switches (p + 1, user);
7354 static void
7355 validate_all_switches (void)
7357 struct compiler *comp;
7358 struct spec_list *spec;
7360 for (comp = compilers; comp->spec; comp++)
7361 validate_switches_from_spec (comp->spec, false);
7363 /* Look through the linked list of specs read from the specs file. */
7364 for (spec = specs; spec; spec = spec->next)
7365 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
7367 validate_switches_from_spec (link_command_spec, false);
7370 /* Look at the switch-name that comes after START
7371 and mark as valid all supplied switches that match it. */
7373 static const char *
7374 validate_switches (const char *start, bool user_spec)
7376 const char *p = start;
7377 const char *atom;
7378 size_t len;
7379 int i;
7380 bool suffix = false;
7381 bool starred = false;
7383 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
7385 next_member:
7386 SKIP_WHITE ();
7388 if (*p == '!')
7389 p++;
7391 SKIP_WHITE ();
7392 if (*p == '.' || *p == ',')
7393 suffix = true, p++;
7395 atom = p;
7396 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
7397 || *p == ',' || *p == '.' || *p == '@')
7398 p++;
7399 len = p - atom;
7401 if (*p == '*')
7402 starred = true, p++;
7404 SKIP_WHITE ();
7406 if (!suffix)
7408 /* Mark all matching switches as valid. */
7409 for (i = 0; i < n_switches; i++)
7410 if (!strncmp (switches[i].part1, atom, len)
7411 && (starred || switches[i].part1[len] == '\0')
7412 && (switches[i].known || user_spec))
7413 switches[i].validated = true;
7416 if (*p) p++;
7417 if (*p && (p[-1] == '|' || p[-1] == '&'))
7418 goto next_member;
7420 if (*p && p[-1] == ':')
7422 while (*p && *p != ';' && *p != '}')
7424 if (*p == '%')
7426 p++;
7427 if (*p == '{' || *p == '<')
7428 p = validate_switches (p+1, user_spec);
7429 else if (p[0] == 'W' && p[1] == '{')
7430 p = validate_switches (p+2, user_spec);
7432 else
7433 p++;
7436 if (*p) p++;
7437 if (*p && p[-1] == ';')
7438 goto next_member;
7441 return p;
7442 #undef SKIP_WHITE
7445 struct mdswitchstr
7447 const char *str;
7448 int len;
7451 static struct mdswitchstr *mdswitches;
7452 static int n_mdswitches;
7454 /* Check whether a particular argument was used. The first time we
7455 canonicalize the switches to keep only the ones we care about. */
7457 static int
7458 used_arg (const char *p, int len)
7460 struct mswitchstr
7462 const char *str;
7463 const char *replace;
7464 int len;
7465 int rep_len;
7468 static struct mswitchstr *mswitches;
7469 static int n_mswitches;
7470 int i, j;
7472 if (!mswitches)
7474 struct mswitchstr *matches;
7475 const char *q;
7476 int cnt = 0;
7478 /* Break multilib_matches into the component strings of string
7479 and replacement string. */
7480 for (q = multilib_matches; *q != '\0'; q++)
7481 if (*q == ';')
7482 cnt++;
7484 matches
7485 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
7486 i = 0;
7487 q = multilib_matches;
7488 while (*q != '\0')
7490 matches[i].str = q;
7491 while (*q != ' ')
7493 if (*q == '\0')
7495 invalid_matches:
7496 fatal_error ("multilib spec %qs is invalid",
7497 multilib_matches);
7499 q++;
7501 matches[i].len = q - matches[i].str;
7503 matches[i].replace = ++q;
7504 while (*q != ';' && *q != '\0')
7506 if (*q == ' ')
7507 goto invalid_matches;
7508 q++;
7510 matches[i].rep_len = q - matches[i].replace;
7511 i++;
7512 if (*q == ';')
7513 q++;
7516 /* Now build a list of the replacement string for switches that we care
7517 about. Make sure we allocate at least one entry. This prevents
7518 xmalloc from calling fatal, and prevents us from re-executing this
7519 block of code. */
7520 mswitches
7521 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
7522 for (i = 0; i < n_switches; i++)
7523 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
7525 int xlen = strlen (switches[i].part1);
7526 for (j = 0; j < cnt; j++)
7527 if (xlen == matches[j].len
7528 && ! strncmp (switches[i].part1, matches[j].str, xlen))
7530 mswitches[n_mswitches].str = matches[j].replace;
7531 mswitches[n_mswitches].len = matches[j].rep_len;
7532 mswitches[n_mswitches].replace = (char *) 0;
7533 mswitches[n_mswitches].rep_len = 0;
7534 n_mswitches++;
7535 break;
7539 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
7540 on the command line nor any options mutually incompatible with
7541 them. */
7542 for (i = 0; i < n_mdswitches; i++)
7544 const char *r;
7546 for (q = multilib_options; *q != '\0'; *q && q++)
7548 while (*q == ' ')
7549 q++;
7551 r = q;
7552 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
7553 || strchr (" /", q[mdswitches[i].len]) == NULL)
7555 while (*q != ' ' && *q != '/' && *q != '\0')
7556 q++;
7557 if (*q != '/')
7558 break;
7559 q++;
7562 if (*q != ' ' && *q != '\0')
7564 while (*r != ' ' && *r != '\0')
7566 q = r;
7567 while (*q != ' ' && *q != '/' && *q != '\0')
7568 q++;
7570 if (used_arg (r, q - r))
7571 break;
7573 if (*q != '/')
7575 mswitches[n_mswitches].str = mdswitches[i].str;
7576 mswitches[n_mswitches].len = mdswitches[i].len;
7577 mswitches[n_mswitches].replace = (char *) 0;
7578 mswitches[n_mswitches].rep_len = 0;
7579 n_mswitches++;
7580 break;
7583 r = q + 1;
7585 break;
7591 for (i = 0; i < n_mswitches; i++)
7592 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7593 return 1;
7595 return 0;
7598 static int
7599 default_arg (const char *p, int len)
7601 int i;
7603 for (i = 0; i < n_mdswitches; i++)
7604 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7605 return 1;
7607 return 0;
7610 /* Work out the subdirectory to use based on the options. The format of
7611 multilib_select is a list of elements. Each element is a subdirectory
7612 name followed by a list of options followed by a semicolon. The format
7613 of multilib_exclusions is the same, but without the preceding
7614 directory. First gcc will check the exclusions, if none of the options
7615 beginning with an exclamation point are present, and all of the other
7616 options are present, then we will ignore this completely. Passing
7617 that, gcc will consider each multilib_select in turn using the same
7618 rules for matching the options. If a match is found, that subdirectory
7619 will be used.
7620 A subdirectory name is optionally followed by a colon and the corresponding
7621 multiarch name. */
7623 static void
7624 set_multilib_dir (void)
7626 const char *p;
7627 unsigned int this_path_len;
7628 const char *this_path, *this_arg;
7629 const char *start, *end;
7630 int not_arg;
7631 int ok, ndfltok, first;
7633 n_mdswitches = 0;
7634 start = multilib_defaults;
7635 while (*start == ' ' || *start == '\t')
7636 start++;
7637 while (*start != '\0')
7639 n_mdswitches++;
7640 while (*start != ' ' && *start != '\t' && *start != '\0')
7641 start++;
7642 while (*start == ' ' || *start == '\t')
7643 start++;
7646 if (n_mdswitches)
7648 int i = 0;
7650 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
7651 for (start = multilib_defaults; *start != '\0'; start = end + 1)
7653 while (*start == ' ' || *start == '\t')
7654 start++;
7656 if (*start == '\0')
7657 break;
7659 for (end = start + 1;
7660 *end != ' ' && *end != '\t' && *end != '\0'; end++)
7663 obstack_grow (&multilib_obstack, start, end - start);
7664 obstack_1grow (&multilib_obstack, 0);
7665 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
7666 mdswitches[i++].len = end - start;
7668 if (*end == '\0')
7669 break;
7673 p = multilib_exclusions;
7674 while (*p != '\0')
7676 /* Ignore newlines. */
7677 if (*p == '\n')
7679 ++p;
7680 continue;
7683 /* Check the arguments. */
7684 ok = 1;
7685 while (*p != ';')
7687 if (*p == '\0')
7689 invalid_exclusions:
7690 fatal_error ("multilib exclusions %qs is invalid",
7691 multilib_exclusions);
7694 if (! ok)
7696 ++p;
7697 continue;
7700 this_arg = p;
7701 while (*p != ' ' && *p != ';')
7703 if (*p == '\0')
7704 goto invalid_exclusions;
7705 ++p;
7708 if (*this_arg != '!')
7709 not_arg = 0;
7710 else
7712 not_arg = 1;
7713 ++this_arg;
7716 ok = used_arg (this_arg, p - this_arg);
7717 if (not_arg)
7718 ok = ! ok;
7720 if (*p == ' ')
7721 ++p;
7724 if (ok)
7725 return;
7727 ++p;
7730 first = 1;
7731 p = multilib_select;
7733 /* Append multilib reuse rules if any. With those rules, we can reuse
7734 one multilib for certain different options sets. */
7735 if (strlen (multilib_reuse) > 0)
7736 p = concat (p, multilib_reuse, NULL);
7738 while (*p != '\0')
7740 /* Ignore newlines. */
7741 if (*p == '\n')
7743 ++p;
7744 continue;
7747 /* Get the initial path. */
7748 this_path = p;
7749 while (*p != ' ')
7751 if (*p == '\0')
7753 invalid_select:
7754 fatal_error ("multilib select %qs %qs is invalid",
7755 multilib_select, multilib_reuse);
7757 ++p;
7759 this_path_len = p - this_path;
7761 /* Check the arguments. */
7762 ok = 1;
7763 ndfltok = 1;
7764 ++p;
7765 while (*p != ';')
7767 if (*p == '\0')
7768 goto invalid_select;
7770 if (! ok)
7772 ++p;
7773 continue;
7776 this_arg = p;
7777 while (*p != ' ' && *p != ';')
7779 if (*p == '\0')
7780 goto invalid_select;
7781 ++p;
7784 if (*this_arg != '!')
7785 not_arg = 0;
7786 else
7788 not_arg = 1;
7789 ++this_arg;
7792 /* If this is a default argument, we can just ignore it.
7793 This is true even if this_arg begins with '!'. Beginning
7794 with '!' does not mean that this argument is necessarily
7795 inappropriate for this library: it merely means that
7796 there is a more specific library which uses this
7797 argument. If this argument is a default, we need not
7798 consider that more specific library. */
7799 ok = used_arg (this_arg, p - this_arg);
7800 if (not_arg)
7801 ok = ! ok;
7803 if (! ok)
7804 ndfltok = 0;
7806 if (default_arg (this_arg, p - this_arg))
7807 ok = 1;
7809 if (*p == ' ')
7810 ++p;
7813 if (ok && first)
7815 if (this_path_len != 1
7816 || this_path[0] != '.')
7818 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
7819 char *q;
7821 strncpy (new_multilib_dir, this_path, this_path_len);
7822 new_multilib_dir[this_path_len] = '\0';
7823 q = strchr (new_multilib_dir, ':');
7824 if (q != NULL)
7825 *q = '\0';
7826 multilib_dir = new_multilib_dir;
7828 first = 0;
7831 if (ndfltok)
7833 const char *q = this_path, *end = this_path + this_path_len;
7835 while (q < end && *q != ':')
7836 q++;
7837 if (q < end)
7839 const char *q2 = q + 1, *ml_end = end;
7840 char *new_multilib_os_dir;
7842 while (q2 < end && *q2 != ':')
7843 q2++;
7844 if (*q2 == ':')
7845 ml_end = q2;
7846 if (ml_end - q == 1)
7847 multilib_os_dir = xstrdup (".");
7848 else
7850 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
7851 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
7852 new_multilib_os_dir[ml_end - q - 1] = '\0';
7853 multilib_os_dir = new_multilib_os_dir;
7856 if (q2 < end && *q2 == ':')
7858 char *new_multiarch_dir = XNEWVEC (char, end - q2);
7859 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
7860 new_multiarch_dir[end - q2 - 1] = '\0';
7861 multiarch_dir = new_multiarch_dir;
7863 break;
7867 ++p;
7870 if (multilib_dir == NULL && multilib_os_dir != NULL
7871 && strcmp (multilib_os_dir, ".") == 0)
7873 free (CONST_CAST (char *, multilib_os_dir));
7874 multilib_os_dir = NULL;
7876 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7877 multilib_os_dir = multilib_dir;
7880 /* Print out the multiple library subdirectory selection
7881 information. This prints out a series of lines. Each line looks
7882 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7883 required. Only the desired options are printed out, the negative
7884 matches. The options are print without a leading dash. There are
7885 no spaces to make it easy to use the information in the shell.
7886 Each subdirectory is printed only once. This assumes the ordering
7887 generated by the genmultilib script. Also, we leave out ones that match
7888 the exclusions. */
7890 static void
7891 print_multilib_info (void)
7893 const char *p = multilib_select;
7894 const char *last_path = 0, *this_path;
7895 int skip;
7896 unsigned int last_path_len = 0;
7898 while (*p != '\0')
7900 skip = 0;
7901 /* Ignore newlines. */
7902 if (*p == '\n')
7904 ++p;
7905 continue;
7908 /* Get the initial path. */
7909 this_path = p;
7910 while (*p != ' ')
7912 if (*p == '\0')
7914 invalid_select:
7915 fatal_error ("multilib select %qs is invalid", multilib_select);
7918 ++p;
7921 /* When --disable-multilib was used but target defines
7922 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
7923 with .:: for multiarch configurations) are there just to find
7924 multilib_os_dir, so skip them from output. */
7925 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
7926 skip = 1;
7928 /* Check for matches with the multilib_exclusions. We don't bother
7929 with the '!' in either list. If any of the exclusion rules match
7930 all of its options with the select rule, we skip it. */
7932 const char *e = multilib_exclusions;
7933 const char *this_arg;
7935 while (*e != '\0')
7937 int m = 1;
7938 /* Ignore newlines. */
7939 if (*e == '\n')
7941 ++e;
7942 continue;
7945 /* Check the arguments. */
7946 while (*e != ';')
7948 const char *q;
7949 int mp = 0;
7951 if (*e == '\0')
7953 invalid_exclusion:
7954 fatal_error ("multilib exclusion %qs is invalid",
7955 multilib_exclusions);
7958 if (! m)
7960 ++e;
7961 continue;
7964 this_arg = e;
7966 while (*e != ' ' && *e != ';')
7968 if (*e == '\0')
7969 goto invalid_exclusion;
7970 ++e;
7973 q = p + 1;
7974 while (*q != ';')
7976 const char *arg;
7977 int len = e - this_arg;
7979 if (*q == '\0')
7980 goto invalid_select;
7982 arg = q;
7984 while (*q != ' ' && *q != ';')
7986 if (*q == '\0')
7987 goto invalid_select;
7988 ++q;
7991 if (! strncmp (arg, this_arg,
7992 (len < q - arg) ? q - arg : len)
7993 || default_arg (this_arg, e - this_arg))
7995 mp = 1;
7996 break;
7999 if (*q == ' ')
8000 ++q;
8003 if (! mp)
8004 m = 0;
8006 if (*e == ' ')
8007 ++e;
8010 if (m)
8012 skip = 1;
8013 break;
8016 if (*e != '\0')
8017 ++e;
8021 if (! skip)
8023 /* If this is a duplicate, skip it. */
8024 skip = (last_path != 0
8025 && (unsigned int) (p - this_path) == last_path_len
8026 && ! filename_ncmp (last_path, this_path, last_path_len));
8028 last_path = this_path;
8029 last_path_len = p - this_path;
8032 /* If this directory requires any default arguments, we can skip
8033 it. We will already have printed a directory identical to
8034 this one which does not require that default argument. */
8035 if (! skip)
8037 const char *q;
8039 q = p + 1;
8040 while (*q != ';')
8042 const char *arg;
8044 if (*q == '\0')
8045 goto invalid_select;
8047 if (*q == '!')
8048 arg = NULL;
8049 else
8050 arg = q;
8052 while (*q != ' ' && *q != ';')
8054 if (*q == '\0')
8055 goto invalid_select;
8056 ++q;
8059 if (arg != NULL
8060 && default_arg (arg, q - arg))
8062 skip = 1;
8063 break;
8066 if (*q == ' ')
8067 ++q;
8071 if (! skip)
8073 const char *p1;
8075 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
8076 putchar (*p1);
8077 putchar (';');
8080 ++p;
8081 while (*p != ';')
8083 int use_arg;
8085 if (*p == '\0')
8086 goto invalid_select;
8088 if (skip)
8090 ++p;
8091 continue;
8094 use_arg = *p != '!';
8096 if (use_arg)
8097 putchar ('@');
8099 while (*p != ' ' && *p != ';')
8101 if (*p == '\0')
8102 goto invalid_select;
8103 if (use_arg)
8104 putchar (*p);
8105 ++p;
8108 if (*p == ' ')
8109 ++p;
8112 if (! skip)
8114 /* If there are extra options, print them now. */
8115 if (multilib_extra && *multilib_extra)
8117 int print_at = TRUE;
8118 const char *q;
8120 for (q = multilib_extra; *q != '\0'; q++)
8122 if (*q == ' ')
8123 print_at = TRUE;
8124 else
8126 if (print_at)
8127 putchar ('@');
8128 putchar (*q);
8129 print_at = FALSE;
8134 putchar ('\n');
8137 ++p;
8141 /* getenv built-in spec function.
8143 Returns the value of the environment variable given by its first
8144 argument, concatenated with the second argument. If the
8145 environment variable is not defined, a fatal error is issued. */
8147 static const char *
8148 getenv_spec_function (int argc, const char **argv)
8150 char *value;
8151 char *result;
8152 char *ptr;
8153 size_t len;
8155 if (argc != 2)
8156 return NULL;
8158 value = getenv (argv[0]);
8159 if (!value)
8160 fatal_error ("environment variable %qs not defined", argv[0]);
8162 /* We have to escape every character of the environment variable so
8163 they are not interpreted as active spec characters. A
8164 particularly painful case is when we are reading a variable
8165 holding a windows path complete with \ separators. */
8166 len = strlen (value) * 2 + strlen (argv[1]) + 1;
8167 result = XNEWVAR (char, len);
8168 for (ptr = result; *value; ptr += 2)
8170 ptr[0] = '\\';
8171 ptr[1] = *value++;
8174 strcpy (ptr, argv[1]);
8176 return result;
8179 /* if-exists built-in spec function.
8181 Checks to see if the file specified by the absolute pathname in
8182 ARGS exists. Returns that pathname if found.
8184 The usual use for this function is to check for a library file
8185 (whose name has been expanded with %s). */
8187 static const char *
8188 if_exists_spec_function (int argc, const char **argv)
8190 /* Must have only one argument. */
8191 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8192 return argv[0];
8194 return NULL;
8197 /* if-exists-else built-in spec function.
8199 This is like if-exists, but takes an additional argument which
8200 is returned if the first argument does not exist. */
8202 static const char *
8203 if_exists_else_spec_function (int argc, const char **argv)
8205 /* Must have exactly two arguments. */
8206 if (argc != 2)
8207 return NULL;
8209 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8210 return argv[0];
8212 return argv[1];
8215 /* sanitize built-in spec function.
8217 This returns non-NULL, if sanitizing address, thread or
8218 any of the undefined behavior sanitizers. */
8220 static const char *
8221 sanitize_spec_function (int argc, const char **argv)
8223 if (argc != 1)
8224 return NULL;
8226 if (strcmp (argv[0], "address") == 0)
8227 return (flag_sanitize & SANITIZE_ADDRESS) ? "" : NULL;
8228 if (strcmp (argv[0], "thread") == 0)
8229 return (flag_sanitize & SANITIZE_THREAD) ? "" : NULL;
8230 if (strcmp (argv[0], "undefined") == 0)
8231 return ((flag_sanitize & (SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT))
8232 && !flag_sanitize_undefined_trap_on_error) ? "" : NULL;
8233 if (strcmp (argv[0], "leak") == 0)
8234 return ((flag_sanitize
8235 & (SANITIZE_ADDRESS | SANITIZE_LEAK | SANITIZE_THREAD))
8236 == SANITIZE_LEAK) ? "" : NULL;
8237 return NULL;
8240 /* replace-outfile built-in spec function.
8242 This looks for the first argument in the outfiles array's name and
8243 replaces it with the second argument. */
8245 static const char *
8246 replace_outfile_spec_function (int argc, const char **argv)
8248 int i;
8249 /* Must have exactly two arguments. */
8250 if (argc != 2)
8251 abort ();
8253 for (i = 0; i < n_infiles; i++)
8255 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8256 outfiles[i] = xstrdup (argv[1]);
8258 return NULL;
8261 /* remove-outfile built-in spec function.
8263 * This looks for the first argument in the outfiles array's name and
8264 * removes it. */
8266 static const char *
8267 remove_outfile_spec_function (int argc, const char **argv)
8269 int i;
8270 /* Must have exactly one argument. */
8271 if (argc != 1)
8272 abort ();
8274 for (i = 0; i < n_infiles; i++)
8276 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8277 outfiles[i] = NULL;
8279 return NULL;
8282 /* Given two version numbers, compares the two numbers.
8283 A version number must match the regular expression
8284 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
8286 static int
8287 compare_version_strings (const char *v1, const char *v2)
8289 int rresult;
8290 regex_t r;
8292 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
8293 REG_EXTENDED | REG_NOSUB) != 0)
8294 abort ();
8295 rresult = regexec (&r, v1, 0, NULL, 0);
8296 if (rresult == REG_NOMATCH)
8297 fatal_error ("invalid version number %qs", v1);
8298 else if (rresult != 0)
8299 abort ();
8300 rresult = regexec (&r, v2, 0, NULL, 0);
8301 if (rresult == REG_NOMATCH)
8302 fatal_error ("invalid version number %qs", v2);
8303 else if (rresult != 0)
8304 abort ();
8306 return strverscmp (v1, v2);
8310 /* version_compare built-in spec function.
8312 This takes an argument of the following form:
8314 <comparison-op> <arg1> [<arg2>] <switch> <result>
8316 and produces "result" if the comparison evaluates to true,
8317 and nothing if it doesn't.
8319 The supported <comparison-op> values are:
8321 >= true if switch is a later (or same) version than arg1
8322 !> opposite of >=
8323 < true if switch is an earlier version than arg1
8324 !< opposite of <
8325 >< true if switch is arg1 or later, and earlier than arg2
8326 <> true if switch is earlier than arg1 or is arg2 or later
8328 If the switch is not present, the condition is false unless
8329 the first character of the <comparison-op> is '!'.
8331 For example,
8332 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
8333 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
8335 static const char *
8336 version_compare_spec_function (int argc, const char **argv)
8338 int comp1, comp2;
8339 size_t switch_len;
8340 const char *switch_value = NULL;
8341 int nargs = 1, i;
8342 bool result;
8344 if (argc < 3)
8345 fatal_error ("too few arguments to %%:version-compare");
8346 if (argv[0][0] == '\0')
8347 abort ();
8348 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
8349 nargs = 2;
8350 if (argc != nargs + 3)
8351 fatal_error ("too many arguments to %%:version-compare");
8353 switch_len = strlen (argv[nargs + 1]);
8354 for (i = 0; i < n_switches; i++)
8355 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
8356 && check_live_switch (i, switch_len))
8357 switch_value = switches[i].part1 + switch_len;
8359 if (switch_value == NULL)
8360 comp1 = comp2 = -1;
8361 else
8363 comp1 = compare_version_strings (switch_value, argv[1]);
8364 if (nargs == 2)
8365 comp2 = compare_version_strings (switch_value, argv[2]);
8366 else
8367 comp2 = -1; /* This value unused. */
8370 switch (argv[0][0] << 8 | argv[0][1])
8372 case '>' << 8 | '=':
8373 result = comp1 >= 0;
8374 break;
8375 case '!' << 8 | '<':
8376 result = comp1 >= 0 || switch_value == NULL;
8377 break;
8378 case '<' << 8:
8379 result = comp1 < 0;
8380 break;
8381 case '!' << 8 | '>':
8382 result = comp1 < 0 || switch_value == NULL;
8383 break;
8384 case '>' << 8 | '<':
8385 result = comp1 >= 0 && comp2 < 0;
8386 break;
8387 case '<' << 8 | '>':
8388 result = comp1 < 0 || comp2 >= 0;
8389 break;
8391 default:
8392 fatal_error ("unknown operator %qs in %%:version-compare", argv[0]);
8394 if (! result)
8395 return NULL;
8397 return argv[nargs + 2];
8400 /* %:include builtin spec function. This differs from %include in that it
8401 can be nested inside a spec, and thus be conditionalized. It takes
8402 one argument, the filename, and looks for it in the startfile path.
8403 The result is always NULL, i.e. an empty expansion. */
8405 static const char *
8406 include_spec_function (int argc, const char **argv)
8408 char *file;
8410 if (argc != 1)
8411 abort ();
8413 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
8414 read_specs (file ? file : argv[0], false, false);
8416 return NULL;
8419 /* %:find-file spec function. This function replaces its argument by
8420 the file found through find_file, that is the -print-file-name gcc
8421 program option. */
8422 static const char *
8423 find_file_spec_function (int argc, const char **argv)
8425 const char *file;
8427 if (argc != 1)
8428 abort ();
8430 file = find_file (argv[0]);
8431 return file;
8435 /* %:find-plugindir spec function. This function replaces its argument
8436 by the -iplugindir=<dir> option. `dir' is found through find_file, that
8437 is the -print-file-name gcc program option. */
8438 static const char *
8439 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
8441 const char *option;
8443 if (argc != 0)
8444 abort ();
8446 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
8447 return option;
8451 /* %:print-asm-header spec function. Print a banner to say that the
8452 following output is from the assembler. */
8454 static const char *
8455 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
8456 const char **argv ATTRIBUTE_UNUSED)
8458 printf (_("Assembler options\n=================\n\n"));
8459 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
8460 fflush (stdout);
8461 return NULL;
8464 /* Get a random number for -frandom-seed */
8466 static unsigned HOST_WIDE_INT
8467 get_random_number (void)
8469 unsigned HOST_WIDE_INT ret = 0;
8470 int fd;
8472 fd = open ("/dev/urandom", O_RDONLY);
8473 if (fd >= 0)
8475 read (fd, &ret, sizeof (HOST_WIDE_INT));
8476 close (fd);
8477 if (ret)
8478 return ret;
8481 /* Get some more or less random data. */
8482 #ifdef HAVE_GETTIMEOFDAY
8484 struct timeval tv;
8486 gettimeofday (&tv, NULL);
8487 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
8489 #else
8491 time_t now = time (NULL);
8493 if (now != (time_t)-1)
8494 ret = (unsigned) now;
8496 #endif
8498 return ret ^ getpid ();
8501 /* %:compare-debug-dump-opt spec function. Save the last argument,
8502 expected to be the last -fdump-final-insns option, or generate a
8503 temporary. */
8505 static const char *
8506 compare_debug_dump_opt_spec_function (int arg,
8507 const char **argv ATTRIBUTE_UNUSED)
8509 char *ret;
8510 char *name;
8511 int which;
8512 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
8514 if (arg != 0)
8515 fatal_error ("too many arguments to %%:compare-debug-dump-opt");
8517 do_spec_2 ("%{fdump-final-insns=*:%*}");
8518 do_spec_1 (" ", 0, NULL);
8520 if (argbuf.length () > 0
8521 && strcmp (argv[argbuf.length () - 1], "."))
8523 if (!compare_debug)
8524 return NULL;
8526 name = xstrdup (argv[argbuf.length () - 1]);
8527 ret = NULL;
8529 else
8531 const char *ext = NULL;
8533 if (argbuf.length () > 0)
8535 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
8536 ext = ".gkd";
8538 else if (!compare_debug)
8539 return NULL;
8540 else
8541 do_spec_2 ("%g.gkd");
8543 do_spec_1 (" ", 0, NULL);
8545 gcc_assert (argbuf.length () > 0);
8547 name = concat (argbuf.last (), ext, NULL);
8549 ret = concat ("-fdump-final-insns=", name, NULL);
8552 which = compare_debug < 0;
8553 debug_check_temp_file[which] = name;
8555 if (!which)
8557 unsigned HOST_WIDE_INT value = get_random_number ();
8559 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
8562 if (*random_seed)
8564 char *tmp = ret;
8565 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
8566 ret, NULL);
8567 free (tmp);
8570 if (which)
8571 *random_seed = 0;
8573 return ret;
8576 static const char *debug_auxbase_opt;
8578 /* %:compare-debug-self-opt spec function. Expands to the options
8579 that are to be passed in the second compilation of
8580 compare-debug. */
8582 static const char *
8583 compare_debug_self_opt_spec_function (int arg,
8584 const char **argv ATTRIBUTE_UNUSED)
8586 if (arg != 0)
8587 fatal_error ("too many arguments to %%:compare-debug-self-opt");
8589 if (compare_debug >= 0)
8590 return NULL;
8592 do_spec_2 ("%{c|S:%{o*:%*}}");
8593 do_spec_1 (" ", 0, NULL);
8595 if (argbuf.length () > 0)
8596 debug_auxbase_opt = concat ("-auxbase-strip ",
8597 argbuf.last (),
8598 NULL);
8599 else
8600 debug_auxbase_opt = NULL;
8602 return concat ("\
8603 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
8604 %<fdump-final-insns=* -w -S -o %j \
8605 %{!fcompare-debug-second:-fcompare-debug-second} \
8606 ", compare_debug_opt, NULL);
8609 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
8610 options that are to be passed in the second compilation of
8611 compare-debug. It expects, as an argument, the basename of the
8612 current input file name, with the .gk suffix appended to it. */
8614 static const char *
8615 compare_debug_auxbase_opt_spec_function (int arg,
8616 const char **argv)
8618 char *name;
8619 int len;
8621 if (arg == 0)
8622 fatal_error ("too few arguments to %%:compare-debug-auxbase-opt");
8624 if (arg != 1)
8625 fatal_error ("too many arguments to %%:compare-debug-auxbase-opt");
8627 if (compare_debug >= 0)
8628 return NULL;
8630 len = strlen (argv[0]);
8631 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
8632 fatal_error ("argument to %%:compare-debug-auxbase-opt "
8633 "does not end in .gk");
8635 if (debug_auxbase_opt)
8636 return debug_auxbase_opt;
8638 #define OPT "-auxbase "
8640 len -= 3;
8641 name = (char*) xmalloc (sizeof (OPT) + len);
8642 memcpy (name, OPT, sizeof (OPT) - 1);
8643 memcpy (name + sizeof (OPT) - 1, argv[0], len);
8644 name[sizeof (OPT) - 1 + len] = '\0';
8646 #undef OPT
8648 return name;
8651 /* %:pass-through-libs spec function. Finds all -l options and input
8652 file names in the lib spec passed to it, and makes a list of them
8653 prepended with the plugin option to cause them to be passed through
8654 to the final link after all the new object files have been added. */
8656 const char *
8657 pass_through_libs_spec_func (int argc, const char **argv)
8659 char *prepended = xstrdup (" ");
8660 int n;
8661 /* Shlemiel the painter's algorithm. Innately horrible, but at least
8662 we know that there will never be more than a handful of strings to
8663 concat, and it's only once per run, so it's not worth optimising. */
8664 for (n = 0; n < argc; n++)
8666 char *old = prepended;
8667 /* Anything that isn't an option is a full path to an output
8668 file; pass it through if it ends in '.a'. Among options,
8669 pass only -l. */
8670 if (argv[n][0] == '-' && argv[n][1] == 'l')
8672 const char *lopt = argv[n] + 2;
8673 /* Handle both joined and non-joined -l options. If for any
8674 reason there's a trailing -l with no joined or following
8675 arg just discard it. */
8676 if (!*lopt && ++n >= argc)
8677 break;
8678 else if (!*lopt)
8679 lopt = argv[n];
8680 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
8681 lopt, " ", NULL);
8683 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
8685 prepended = concat (prepended, "-plugin-opt=-pass-through=",
8686 argv[n], " ", NULL);
8688 if (prepended != old)
8689 free (old);
8691 return prepended;
8694 /* %:replace-extension spec function. Replaces the extension of the
8695 first argument with the second argument. */
8697 const char *
8698 replace_extension_spec_func (int argc, const char **argv)
8700 char *name;
8701 char *p;
8702 char *result;
8703 int i;
8705 if (argc != 2)
8706 fatal_error ("too few arguments to %%:replace-extension");
8708 name = xstrdup (argv[0]);
8710 for (i = strlen (name) - 1; i >= 0; i--)
8711 if (IS_DIR_SEPARATOR (name[i]))
8712 break;
8714 p = strrchr (name + i + 1, '.');
8715 if (p != NULL)
8716 *p = '\0';
8718 result = concat (name, argv[1], NULL);
8720 free (name);
8721 return result;
8724 /* Insert backslash before spaces in ORIG (usually a file path), to
8725 avoid being broken by spec parser.
8727 This function is needed as do_spec_1 treats white space (' ' and '\t')
8728 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
8729 the file name should be treated as a single argument rather than being
8730 broken into multiple. Solution is to insert '\\' before the space in a
8731 file name.
8733 This function converts and only converts all occurrence of ' '
8734 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
8735 "a b" -> "a\\ b"
8736 "a b" -> "a\\ \\ b"
8737 "a\tb" -> "a\\\tb"
8738 "a\\ b" -> "a\\\\ b"
8740 orig: input null-terminating string that was allocated by xalloc. The
8741 memory it points to might be freed in this function. Behavior undefined
8742 if ORIG wasn't xalloced or was freed already at entry.
8744 Return: ORIG if no conversion needed. Otherwise a newly allocated string
8745 that was converted from ORIG. */
8747 static char *
8748 convert_white_space (char *orig)
8750 int len, number_of_space = 0;
8752 for (len = 0; orig[len]; len++)
8753 if (orig[len] == ' ' || orig[len] == '\t') number_of_space++;
8755 if (number_of_space)
8757 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
8758 int j, k;
8759 for (j = 0, k = 0; j <= len; j++, k++)
8761 if (orig[j] == ' ' || orig[j] == '\t')
8762 new_spec[k++] = '\\';
8763 new_spec[k] = orig[j];
8765 free (orig);
8766 return new_spec;
8768 else
8769 return orig;