Merged revisions 208012,208018-208019,208021,208023-208030,208033,208037,208040-20804...
[official-gcc.git] / main / gcc / gcc.c
blob01739f9dec16ee898c551490e3c47308d9532a4c
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 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
601 included. */
602 #ifndef LIBGCC_SPEC
603 #if defined(REAL_LIBGCC_SPEC)
604 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
605 #elif defined(LINK_LIBGCC_SPECIAL_1)
606 /* Have gcc do the search for libgcc.a. */
607 #define LIBGCC_SPEC "libgcc.a%s"
608 #else
609 #define LIBGCC_SPEC "-lgcc"
610 #endif
611 #endif
613 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
614 #ifndef STARTFILE_SPEC
615 #define STARTFILE_SPEC \
616 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
617 #endif
619 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
620 #ifndef ENDFILE_SPEC
621 #define ENDFILE_SPEC ""
622 #endif
624 #ifndef LINKER_NAME
625 #define LINKER_NAME "collect2"
626 #endif
628 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
629 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
630 #else
631 #define ASM_MAP ""
632 #endif
634 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
635 to the assembler. */
636 #ifndef ASM_DEBUG_SPEC
637 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
638 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
639 # define ASM_DEBUG_SPEC \
640 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
641 ? "%{!g0:%{gdwarf*:--gdwarf2}%{!gdwarf*:%{g*:--gstabs}}}" ASM_MAP \
642 : "%{!g0:%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
643 # else
644 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
645 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gstabs}}" ASM_MAP
646 # endif
647 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
648 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gdwarf2}}" ASM_MAP
649 # endif
650 # endif
651 #endif
652 #ifndef ASM_DEBUG_SPEC
653 # define ASM_DEBUG_SPEC ""
654 #endif
656 /* Here is the spec for running the linker, after compiling all files. */
658 /* This is overridable by the target in case they need to specify the
659 -lgcc and -lc order specially, yet not require them to override all
660 of LINK_COMMAND_SPEC. */
661 #ifndef LINK_GCC_C_SEQUENCE_SPEC
662 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
663 #endif
665 #ifndef LINK_SSP_SPEC
666 #ifdef TARGET_LIBC_PROVIDES_SSP
667 #define LINK_SSP_SPEC "%{fstack-protector:}"
668 #else
669 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-strong|fstack-protector-all:-lssp_nonshared -lssp}"
670 #endif
671 #endif
673 #ifndef LINK_PIE_SPEC
674 #ifdef HAVE_LD_PIE
675 #define LINK_PIE_SPEC "%{pie:-pie} "
676 #else
677 #define LINK_PIE_SPEC "%{pie:} "
678 #endif
679 #endif
681 #ifndef LINK_BUILDID_SPEC
682 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
683 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
684 # endif
685 #endif
687 /* Conditional to test whether the LTO plugin is used or not.
688 FIXME: For slim LTO we will need to enable plugin unconditionally. This
689 still cause problems with PLUGIN_LD != LD and when plugin is built but
690 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
691 plugin only when LTO is enabled. We still honor explicit
692 -fuse-linker-plugin if the linker used understands -plugin. */
694 /* The linker has some plugin support. */
695 #if HAVE_LTO_PLUGIN > 0
696 /* The linker used has full plugin support, use LTO plugin by default. */
697 #if HAVE_LTO_PLUGIN == 2
698 #define PLUGIN_COND "!fno-use-linker-plugin:%{!fno-lto"
699 #define PLUGIN_COND_CLOSE "}"
700 #else
701 /* The linker used has limited plugin support, use LTO plugin with explicit
702 -fuse-linker-plugin. */
703 #define PLUGIN_COND "fuse-linker-plugin"
704 #define PLUGIN_COND_CLOSE ""
705 #endif
706 #define LINK_PLUGIN_SPEC \
707 "%{"PLUGIN_COND": \
708 -plugin %(linker_plugin_file) \
709 -plugin-opt=%(lto_wrapper) \
710 -plugin-opt=-fresolution=%u.res \
711 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
712 }"PLUGIN_COND_CLOSE
713 #else
714 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
715 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
716 %e-fuse-linker-plugin is not supported in this configuration}"
717 #endif
719 /* Linker command line options for -fsanitize= early on the command line. */
720 #ifndef SANITIZER_EARLY_SPEC
721 #define SANITIZER_EARLY_SPEC "\
722 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_EARLY_SPEC "} \
723 %{%:sanitize(thread):" LIBTSAN_EARLY_SPEC "}}}"
724 #endif
726 /* Linker command line options for -fsanitize= late on the command line. */
727 #ifndef SANITIZER_SPEC
728 #define SANITIZER_SPEC "\
729 %{!nostdlib:%{!nodefaultlibs:%{%:sanitize(address):" LIBASAN_SPEC "\
730 %{static:%ecannot specify -static with -fsanitize=address}\
731 %{%:sanitize(thread):%e-fsanitize=address is incompatible with -fsanitize=thread}}\
732 %{%:sanitize(thread):" LIBTSAN_SPEC "\
733 %{!pie:%{!shared:%e-fsanitize=thread linking must be done with -pie or -shared}}}\
734 %{%:sanitize(undefined):" LIBUBSAN_SPEC "}\
735 %{%:sanitize(leak):" LIBLSAN_SPEC "}}}"
736 #endif
738 /* This is the spec to use, once the code for creating the vtable
739 verification runtime library, libvtv.so, has been created. Currently
740 the vtable verification runtime functions are in libstdc++, so we use
741 the spec just below this one. */
742 #ifndef VTABLE_VERIFICATION_SPEC
743 #define VTABLE_VERIFICATION_SPEC "\
744 %{!nostdlib:%{fvtable-verify=std: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}\
745 %{fvtable-verify=preinit: -lvtv -u_vtable_map_vars_start -u_vtable_map_vars_end}}"
746 #endif
748 /* -u* was put back because both BSD and SysV seem to support it. */
749 /* %{static:} simply prevents an error message if the target machine
750 doesn't handle -static. */
751 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
752 scripts which exist in user specified directories, or in standard
753 directories. */
754 /* We pass any -flto flags on to the linker, which is expected
755 to understand them. In practice, this means it had better be collect2. */
756 /* %{e*} includes -export-dynamic; see comment in common.opt. */
757 #ifndef LINK_COMMAND_SPEC
758 #define LINK_COMMAND_SPEC "\
759 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
760 %(linker) " \
761 LINK_PLUGIN_SPEC \
762 "%{flto|flto=*:%<fcompare-debug*} \
763 %{flto} %{flto=*} %l " LINK_PIE_SPEC \
764 "%{fuse-ld=*:-fuse-ld=%*}\
765 %X %{o*} %{e*} %{N} %{n} %{r}\
766 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}} " VTABLE_VERIFICATION_SPEC " \
767 %{static:} %{L*} %(mfwrap) %(link_libgcc) " SANITIZER_EARLY_SPEC " %o\
768 %{fopenmp|ftree-parallelize-loops=*:%:include(libgomp.spec)%(link_gomp)}\
769 %{fcilkplus:%:include(libcilkrts.spec)%(link_cilkrts)}\
770 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
771 %(mflib) " STACK_SPLIT_SPEC "\
772 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
773 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
774 %{!nostdlib:%{!nostartfiles:%E}} %{T*} }}}}}}"
775 #endif
777 #ifndef LINK_LIBGCC_SPEC
778 /* Generate -L options for startfile prefix list. */
779 # define LINK_LIBGCC_SPEC "%D"
780 #endif
782 #ifndef STARTFILE_PREFIX_SPEC
783 # define STARTFILE_PREFIX_SPEC ""
784 #endif
786 #ifndef SYSROOT_SPEC
787 # define SYSROOT_SPEC "--sysroot=%R"
788 #endif
790 #ifndef SYSROOT_SUFFIX_SPEC
791 # define SYSROOT_SUFFIX_SPEC ""
792 #endif
794 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
795 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
796 #endif
798 static const char *asm_debug = ASM_DEBUG_SPEC;
799 static const char *cpp_spec = CPP_SPEC;
800 static const char *cc1_spec = CC1_SPEC;
801 static const char *cc1plus_spec = CC1PLUS_SPEC;
802 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
803 static const char *link_ssp_spec = LINK_SSP_SPEC;
804 static const char *asm_spec = ASM_SPEC;
805 static const char *asm_final_spec = ASM_FINAL_SPEC;
806 static const char *link_spec = LINK_SPEC;
807 static const char *lib_spec = LIB_SPEC;
808 static const char *link_gomp_spec = "";
809 static const char *libgcc_spec = LIBGCC_SPEC;
810 static const char *endfile_spec = ENDFILE_SPEC;
811 static const char *startfile_spec = STARTFILE_SPEC;
812 static const char *linker_name_spec = LINKER_NAME;
813 static const char *linker_plugin_file_spec = "";
814 static const char *lto_wrapper_spec = "";
815 static const char *lto_gcc_spec = "";
816 static const char *link_command_spec = LINK_COMMAND_SPEC;
817 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
818 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
819 static const char *sysroot_spec = SYSROOT_SPEC;
820 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
821 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
822 static const char *self_spec = "";
824 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
825 There should be no need to override these in target dependent files,
826 but we need to copy them to the specs file so that newer versions
827 of the GCC driver can correctly drive older tool chains with the
828 appropriate -B options. */
830 /* When cpplib handles traditional preprocessing, get rid of this, and
831 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
832 that we default the front end language better. */
833 static const char *trad_capable_cpp =
834 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
836 /* We don't wrap .d files in %W{} since a missing .d file, and
837 therefore no dependency entry, confuses make into thinking a .o
838 file that happens to exist is up-to-date. */
839 static const char *cpp_unique_options =
840 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
841 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
842 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
843 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
844 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
845 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
846 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
847 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
848 %{E|M|MM:%W{o*}}";
850 /* This contains cpp options which are common with cc1_options and are passed
851 only when preprocessing only to avoid duplication. We pass the cc1 spec
852 options to the preprocessor so that it the cc1 spec may manipulate
853 options used to set target flags. Those special target flags settings may
854 in turn cause preprocessor symbols to be defined specially. */
855 static const char *cpp_options =
856 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
857 %{f*} %{g*:%{!g0:%{g*} %{!fno-working-directory:-fworking-directory}}} %{O*}\
858 %{undef} %{save-temps*:-fpch-preprocess}";
860 /* This contains cpp options which are not passed when the preprocessor
861 output will be used by another program. */
862 static const char *cpp_debug_options = "%{d*}";
864 /* NB: This is shared amongst all front-ends, except for Ada. */
865 static const char *cc1_options =
866 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
867 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
868 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
869 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
870 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
871 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
872 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
873 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
874 %{-target-help:--target-help}\
875 %{-version:--version}\
876 %{-help=*:--help=%*}\
877 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
878 %{fsyntax-only:-o %j} %{-param*}\
879 %{coverage:-fprofile-arcs -ftest-coverage -fno-early-inlining}";
881 static const char *asm_options =
882 "%{-target-help:%:print-asm-header()} "
883 #if HAVE_GNU_AS
884 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
885 to the assembler equivalents. */
886 "%{v} %{w:-W} %{I*} "
887 #endif
888 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
890 static const char *invoke_as =
891 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
892 "%{!fwpa*:\
893 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
894 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
896 #else
897 "%{!fwpa*:\
898 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
899 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
901 #endif
903 /* Some compilers have limits on line lengths, and the multilib_select
904 and/or multilib_matches strings can be very long, so we build them at
905 run time. */
906 static struct obstack multilib_obstack;
907 static const char *multilib_select;
908 static const char *multilib_matches;
909 static const char *multilib_defaults;
910 static const char *multilib_exclusions;
911 static const char *multilib_reuse;
913 /* Check whether a particular argument is a default argument. */
915 #ifndef MULTILIB_DEFAULTS
916 #define MULTILIB_DEFAULTS { "" }
917 #endif
919 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
921 #ifndef DRIVER_SELF_SPECS
922 #define DRIVER_SELF_SPECS ""
923 #endif
925 /* Linking to libgomp implies pthreads. This is particularly important
926 for targets that use different start files and suchlike. */
927 #ifndef GOMP_SELF_SPECS
928 #define GOMP_SELF_SPECS "%{fopenmp|ftree-parallelize-loops=*: -pthread}"
929 #endif
931 /* Likewise for -fgnu-tm. */
932 #ifndef GTM_SELF_SPECS
933 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
934 #endif
936 /* Likewise for -fcilkplus. */
937 #ifndef CILK_SELF_SPECS
938 #define CILK_SELF_SPECS "%{fcilkplus: -pthread}"
939 #endif
941 static const char *const driver_self_specs[] = {
942 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
943 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS,
944 CILK_SELF_SPECS
947 #ifndef OPTION_DEFAULT_SPECS
948 #define OPTION_DEFAULT_SPECS { "", "" }
949 #endif
951 struct default_spec
953 const char *name;
954 const char *spec;
957 static const struct default_spec
958 option_default_specs[] = { OPTION_DEFAULT_SPECS };
960 struct user_specs
962 struct user_specs *next;
963 const char *filename;
966 static struct user_specs *user_specs_head, *user_specs_tail;
969 /* Record the mapping from file suffixes for compilation specs. */
971 struct compiler
973 const char *suffix; /* Use this compiler for input files
974 whose names end in this suffix. */
976 const char *spec; /* To use this compiler, run this spec. */
978 const char *cpp_spec; /* If non-NULL, substitute this spec
979 for `%C', rather than the usual
980 cpp_spec. */
981 const int combinable; /* If nonzero, compiler can deal with
982 multiple source files at once (IMA). */
983 const int needs_preprocessing; /* If nonzero, source files need to
984 be run through a preprocessor. */
987 /* Pointer to a vector of `struct compiler' that gives the spec for
988 compiling a file, based on its suffix.
989 A file that does not end in any of these suffixes will be passed
990 unchanged to the loader and nothing else will be done to it.
992 An entry containing two 0s is used to terminate the vector.
994 If multiple entries match a file, the last matching one is used. */
996 static struct compiler *compilers;
998 /* Number of entries in `compilers', not counting the null terminator. */
1000 static int n_compilers;
1002 /* The default list of file name suffixes and their compilation specs. */
1004 static const struct compiler default_compilers[] =
1006 /* Add lists of suffixes of known languages here. If those languages
1007 were not present when we built the driver, we will hit these copies
1008 and be given a more meaningful error than "file not used since
1009 linking is not done". */
1010 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
1011 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
1012 {".mii", "#Objective-C++", 0, 0, 0},
1013 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
1014 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
1015 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
1016 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
1017 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
1018 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
1019 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
1020 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
1021 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
1022 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
1023 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
1024 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1025 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1026 {".r", "#Ratfor", 0, 0, 0},
1027 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
1028 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
1029 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
1030 {".go", "#Go", 0, 1, 0},
1031 /* Next come the entries for C. */
1032 {".c", "@c", 0, 0, 1},
1033 {"@c",
1034 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1035 external preprocessor if -save-temps is given. */
1036 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1037 %{!E:%{!M:%{!MM:\
1038 %{traditional:\
1039 %eGNU C no longer supports -traditional without -E}\
1040 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1041 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1042 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1043 %(cc1_options)}\
1044 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1045 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1046 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1047 {"-",
1048 "%{!E:%e-E or -x required when input is from standard input}\
1049 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1050 {".h", "@c-header", 0, 0, 0},
1051 {"@c-header",
1052 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1053 external preprocessor if -save-temps is given. */
1054 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1055 %{!E:%{!M:%{!MM:\
1056 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1057 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1058 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1059 %(cc1_options)\
1060 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1061 %W{o*:--output-pch=%*}}%V}\
1062 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1063 cc1 %(cpp_unique_options) %(cc1_options)\
1064 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1065 %W{o*:--output-pch=%*}}%V}}}}}}", 0, 0, 0},
1066 {".i", "@cpp-output", 0, 0, 0},
1067 {"@cpp-output",
1068 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1069 {".s", "@assembler", 0, 0, 0},
1070 {"@assembler",
1071 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1072 {".sx", "@assembler-with-cpp", 0, 0, 0},
1073 {".S", "@assembler-with-cpp", 0, 0, 0},
1074 {"@assembler-with-cpp",
1075 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1076 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1077 %{E|M|MM:%(cpp_debug_options)}\
1078 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1079 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1080 #else
1081 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1082 %{E|M|MM:%(cpp_debug_options)}\
1083 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1084 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1085 #endif
1086 , 0, 0, 0},
1088 #include "specs.h"
1089 /* Mark end of table. */
1090 {0, 0, 0, 0, 0}
1093 /* Number of elements in default_compilers, not counting the terminator. */
1095 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1097 typedef char *char_p; /* For DEF_VEC_P. */
1099 /* A vector of options to give to the linker.
1100 These options are accumulated by %x,
1101 and substituted into the linker command with %X. */
1102 static vec<char_p> linker_options;
1104 /* A vector of options to give to the assembler.
1105 These options are accumulated by -Wa,
1106 and substituted into the assembler command with %Y. */
1107 static vec<char_p> assembler_options;
1109 /* A vector of options to give to the preprocessor.
1110 These options are accumulated by -Wp,
1111 and substituted into the preprocessor command with %Z. */
1112 static vec<char_p> preprocessor_options;
1114 static char *
1115 skip_whitespace (char *p)
1117 while (1)
1119 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1120 be considered whitespace. */
1121 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1122 return p + 1;
1123 else if (*p == '\n' || *p == ' ' || *p == '\t')
1124 p++;
1125 else if (*p == '#')
1127 while (*p != '\n')
1128 p++;
1129 p++;
1131 else
1132 break;
1135 return p;
1137 /* Structures to keep track of prefixes to try when looking for files. */
1139 struct prefix_list
1141 const char *prefix; /* String to prepend to the path. */
1142 struct prefix_list *next; /* Next in linked list. */
1143 int require_machine_suffix; /* Don't use without machine_suffix. */
1144 /* 2 means try both machine_suffix and just_machine_suffix. */
1145 int priority; /* Sort key - priority within list. */
1146 int os_multilib; /* 1 if OS multilib scheme should be used,
1147 0 for GCC multilib scheme. */
1150 struct path_prefix
1152 struct prefix_list *plist; /* List of prefixes to try */
1153 int max_len; /* Max length of a prefix in PLIST */
1154 const char *name; /* Name of this list (used in config stuff) */
1157 /* List of prefixes to try when looking for executables. */
1159 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1161 /* List of prefixes to try when looking for startup (crt0) files. */
1163 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1165 /* List of prefixes to try when looking for include files. */
1167 static struct path_prefix include_prefixes = { 0, 0, "include" };
1169 /* Suffix to attach to directories searched for commands.
1170 This looks like `MACHINE/VERSION/'. */
1172 static const char *machine_suffix = 0;
1174 /* Suffix to attach to directories searched for commands.
1175 This is just `MACHINE/'. */
1177 static const char *just_machine_suffix = 0;
1179 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1181 static const char *gcc_exec_prefix;
1183 /* Adjusted value of standard_libexec_prefix. */
1185 static const char *gcc_libexec_prefix;
1187 /* Default prefixes to attach to command names. */
1189 #ifndef STANDARD_STARTFILE_PREFIX_1
1190 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1191 #endif
1192 #ifndef STANDARD_STARTFILE_PREFIX_2
1193 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1194 #endif
1196 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1197 #undef MD_EXEC_PREFIX
1198 #undef MD_STARTFILE_PREFIX
1199 #undef MD_STARTFILE_PREFIX_1
1200 #endif
1202 /* If no prefixes defined, use the null string, which will disable them. */
1203 #ifndef MD_EXEC_PREFIX
1204 #define MD_EXEC_PREFIX ""
1205 #endif
1206 #ifndef MD_STARTFILE_PREFIX
1207 #define MD_STARTFILE_PREFIX ""
1208 #endif
1209 #ifndef MD_STARTFILE_PREFIX_1
1210 #define MD_STARTFILE_PREFIX_1 ""
1211 #endif
1213 /* These directories are locations set at configure-time based on the
1214 --prefix option provided to configure. Their initializers are
1215 defined in Makefile.in. These paths are not *directly* used when
1216 gcc_exec_prefix is set because, in that case, we know where the
1217 compiler has been installed, and use paths relative to that
1218 location instead. */
1219 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1220 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1221 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1222 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1224 /* For native compilers, these are well-known paths containing
1225 components that may be provided by the system. For cross
1226 compilers, these paths are not used. */
1227 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1228 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1229 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1230 static const char *const standard_startfile_prefix_1
1231 = STANDARD_STARTFILE_PREFIX_1;
1232 static const char *const standard_startfile_prefix_2
1233 = STANDARD_STARTFILE_PREFIX_2;
1235 /* A relative path to be used in finding the location of tools
1236 relative to the driver. */
1237 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1239 /* Subdirectory to use for locating libraries. Set by
1240 set_multilib_dir based on the compilation options. */
1242 static const char *multilib_dir;
1244 /* Subdirectory to use for locating libraries in OS conventions. Set by
1245 set_multilib_dir based on the compilation options. */
1247 static const char *multilib_os_dir;
1249 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1250 set_multilib_dir based on the compilation options. */
1252 static const char *multiarch_dir;
1254 /* Structure to keep track of the specs that have been defined so far.
1255 These are accessed using %(specname) in a compiler or link
1256 spec. */
1258 struct spec_list
1260 /* The following 2 fields must be first */
1261 /* to allow EXTRA_SPECS to be initialized */
1262 const char *name; /* name of the spec. */
1263 const char *ptr; /* available ptr if no static pointer */
1265 /* The following fields are not initialized */
1266 /* by EXTRA_SPECS */
1267 const char **ptr_spec; /* pointer to the spec itself. */
1268 struct spec_list *next; /* Next spec in linked list. */
1269 int name_len; /* length of the name */
1270 bool user_p; /* whether string come from file spec. */
1271 bool alloc_p; /* whether string was allocated */
1274 #define INIT_STATIC_SPEC(NAME,PTR) \
1275 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false }
1277 /* List of statically defined specs. */
1278 static struct spec_list static_specs[] =
1280 INIT_STATIC_SPEC ("asm", &asm_spec),
1281 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1282 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1283 INIT_STATIC_SPEC ("asm_options", &asm_options),
1284 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1285 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1286 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1287 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1288 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1289 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1290 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1291 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1292 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1293 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1294 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1295 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1296 INIT_STATIC_SPEC ("link", &link_spec),
1297 INIT_STATIC_SPEC ("lib", &lib_spec),
1298 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1299 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1300 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1301 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1302 INIT_STATIC_SPEC ("version", &compiler_version),
1303 INIT_STATIC_SPEC ("multilib", &multilib_select),
1304 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1305 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1306 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1307 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1308 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1309 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1310 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1311 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1312 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1313 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1314 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1315 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1316 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1317 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1318 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1319 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1320 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1321 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1322 INIT_STATIC_SPEC ("self_spec", &self_spec),
1325 #ifdef EXTRA_SPECS /* additional specs needed */
1326 /* Structure to keep track of just the first two args of a spec_list.
1327 That is all that the EXTRA_SPECS macro gives us. */
1328 struct spec_list_1
1330 const char *const name;
1331 const char *const ptr;
1334 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1335 static struct spec_list *extra_specs = (struct spec_list *) 0;
1336 #endif
1338 /* List of dynamically allocates specs that have been defined so far. */
1340 static struct spec_list *specs = (struct spec_list *) 0;
1342 /* List of static spec functions. */
1344 static const struct spec_function static_spec_functions[] =
1346 { "getenv", getenv_spec_function },
1347 { "if-exists", if_exists_spec_function },
1348 { "if-exists-else", if_exists_else_spec_function },
1349 { "sanitize", sanitize_spec_function },
1350 { "replace-outfile", replace_outfile_spec_function },
1351 { "remove-outfile", remove_outfile_spec_function },
1352 { "version-compare", version_compare_spec_function },
1353 { "include", include_spec_function },
1354 { "find-file", find_file_spec_function },
1355 { "find-plugindir", find_plugindir_spec_function },
1356 { "print-asm-header", print_asm_header_spec_function },
1357 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1358 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1359 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1360 { "pass-through-libs", pass_through_libs_spec_func },
1361 { "replace-extension", replace_extension_spec_func },
1362 #ifdef EXTRA_SPEC_FUNCTIONS
1363 EXTRA_SPEC_FUNCTIONS
1364 #endif
1365 { 0, 0 }
1368 static int processing_spec_function;
1370 /* Add appropriate libgcc specs to OBSTACK, taking into account
1371 various permutations of -shared-libgcc, -shared, and such. */
1373 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1375 #ifndef USE_LD_AS_NEEDED
1376 #define USE_LD_AS_NEEDED 0
1377 #endif
1379 static void
1380 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1381 const char *static_name, const char *eh_name)
1383 char *buf;
1385 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1386 "%{!static:%{!static-libgcc:"
1387 #if USE_LD_AS_NEEDED
1388 "%{!shared-libgcc:",
1389 static_name, " " LD_AS_NEEDED_OPTION " ",
1390 shared_name, " " LD_NO_AS_NEEDED_OPTION
1392 "%{shared-libgcc:",
1393 shared_name, "%{!shared: ", static_name, "}"
1395 #else
1396 "%{!shared:"
1397 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1398 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1400 #ifdef LINK_EH_SPEC
1401 "%{shared:"
1402 "%{shared-libgcc:", shared_name, "}"
1403 "%{!shared-libgcc:", static_name, "}"
1405 #else
1406 "%{shared:", shared_name, "}"
1407 #endif
1408 #endif
1409 "}}", NULL);
1411 obstack_grow (obstack, buf, strlen (buf));
1412 free (buf);
1414 #endif /* ENABLE_SHARED_LIBGCC */
1416 /* Initialize the specs lookup routines. */
1418 static void
1419 init_spec (void)
1421 struct spec_list *next = (struct spec_list *) 0;
1422 struct spec_list *sl = (struct spec_list *) 0;
1423 int i;
1425 if (specs)
1426 return; /* Already initialized. */
1428 if (verbose_flag)
1429 fnotice (stderr, "Using built-in specs.\n");
1431 #ifdef EXTRA_SPECS
1432 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1434 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1436 sl = &extra_specs[i];
1437 sl->name = extra_specs_1[i].name;
1438 sl->ptr = extra_specs_1[i].ptr;
1439 sl->next = next;
1440 sl->name_len = strlen (sl->name);
1441 sl->ptr_spec = &sl->ptr;
1442 next = sl;
1444 #endif
1446 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1448 sl = &static_specs[i];
1449 sl->next = next;
1450 next = sl;
1453 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1454 /* ??? If neither -shared-libgcc nor --static-libgcc was
1455 seen, then we should be making an educated guess. Some proposed
1456 heuristics for ELF include:
1458 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1459 program will be doing dynamic loading, which will likely
1460 need the shared libgcc.
1462 (2) If "-ldl", then it's also a fair bet that we're doing
1463 dynamic loading.
1465 (3) For each ET_DYN we're linking against (either through -lfoo
1466 or /some/path/foo.so), check to see whether it or one of
1467 its dependencies depends on a shared libgcc.
1469 (4) If "-shared"
1471 If the runtime is fixed to look for program headers instead
1472 of calling __register_frame_info at all, for each object,
1473 use the shared libgcc if any EH symbol referenced.
1475 If crtstuff is fixed to not invoke __register_frame_info
1476 automatically, for each object, use the shared libgcc if
1477 any non-empty unwind section found.
1479 Doing any of this probably requires invoking an external program to
1480 do the actual object file scanning. */
1482 const char *p = libgcc_spec;
1483 int in_sep = 1;
1485 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1486 when given the proper command line arguments. */
1487 while (*p)
1489 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1491 init_gcc_specs (&obstack,
1492 "-lgcc_s"
1493 #ifdef USE_LIBUNWIND_EXCEPTIONS
1494 " -lunwind"
1495 #endif
1497 "-lgcc",
1498 "-lgcc_eh"
1499 #ifdef USE_LIBUNWIND_EXCEPTIONS
1500 # ifdef HAVE_LD_STATIC_DYNAMIC
1501 " %{!static:" LD_STATIC_OPTION "} -lunwind"
1502 " %{!static:" LD_DYNAMIC_OPTION "}"
1503 # else
1504 " -lunwind"
1505 # endif
1506 #endif
1509 p += 5;
1510 in_sep = 0;
1512 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1514 /* Ug. We don't know shared library extensions. Hope that
1515 systems that use this form don't do shared libraries. */
1516 init_gcc_specs (&obstack,
1517 "-lgcc_s",
1518 "libgcc.a%s",
1519 "libgcc_eh.a%s"
1520 #ifdef USE_LIBUNWIND_EXCEPTIONS
1521 " -lunwind"
1522 #endif
1524 p += 10;
1525 in_sep = 0;
1527 else
1529 obstack_1grow (&obstack, *p);
1530 in_sep = (*p == ' ');
1531 p += 1;
1535 obstack_1grow (&obstack, '\0');
1536 libgcc_spec = XOBFINISH (&obstack, const char *);
1538 #endif
1539 #ifdef USE_AS_TRADITIONAL_FORMAT
1540 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1542 static const char tf[] = "--traditional-format ";
1543 obstack_grow (&obstack, tf, sizeof (tf) - 1);
1544 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1545 asm_spec = XOBFINISH (&obstack, const char *);
1547 #endif
1549 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1550 defined LINKER_HASH_STYLE
1551 # ifdef LINK_BUILDID_SPEC
1552 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1553 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof (LINK_BUILDID_SPEC) - 1);
1554 # endif
1555 # ifdef LINK_EH_SPEC
1556 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1557 obstack_grow (&obstack, LINK_EH_SPEC, sizeof (LINK_EH_SPEC) - 1);
1558 # endif
1559 # ifdef LINKER_HASH_STYLE
1560 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1561 before. */
1563 static const char hash_style[] = "--hash-style=";
1564 obstack_grow (&obstack, hash_style, sizeof (hash_style) - 1);
1565 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof (LINKER_HASH_STYLE) - 1);
1566 obstack_1grow (&obstack, ' ');
1568 # endif
1569 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1570 link_spec = XOBFINISH (&obstack, const char *);
1571 #endif
1573 specs = sl;
1576 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1577 removed; If the spec starts with a + then SPEC is added to the end of the
1578 current spec. */
1580 static void
1581 set_spec (const char *name, const char *spec, bool user_p)
1583 struct spec_list *sl;
1584 const char *old_spec;
1585 int name_len = strlen (name);
1586 int i;
1588 /* If this is the first call, initialize the statically allocated specs. */
1589 if (!specs)
1591 struct spec_list *next = (struct spec_list *) 0;
1592 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1594 sl = &static_specs[i];
1595 sl->next = next;
1596 next = sl;
1598 specs = sl;
1601 /* See if the spec already exists. */
1602 for (sl = specs; sl; sl = sl->next)
1603 if (name_len == sl->name_len && !strcmp (sl->name, name))
1604 break;
1606 if (!sl)
1608 /* Not found - make it. */
1609 sl = XNEW (struct spec_list);
1610 sl->name = xstrdup (name);
1611 sl->name_len = name_len;
1612 sl->ptr_spec = &sl->ptr;
1613 sl->alloc_p = 0;
1614 *(sl->ptr_spec) = "";
1615 sl->next = specs;
1616 specs = sl;
1619 old_spec = *(sl->ptr_spec);
1620 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1621 ? concat (old_spec, spec + 1, NULL)
1622 : xstrdup (spec));
1624 #ifdef DEBUG_SPECS
1625 if (verbose_flag)
1626 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1627 #endif
1629 /* Free the old spec. */
1630 if (old_spec && sl->alloc_p)
1631 free (CONST_CAST (char *, old_spec));
1633 sl->user_p = user_p;
1634 sl->alloc_p = true;
1637 /* Accumulate a command (program name and args), and run it. */
1639 typedef const char *const_char_p; /* For DEF_VEC_P. */
1641 /* Vector of pointers to arguments in the current line of specifications. */
1643 static vec<const_char_p> argbuf;
1645 /* Position in the argbuf vector containing the name of the output file
1646 (the value associated with the "-o" flag). */
1648 static int have_o_argbuf_index = 0;
1650 /* Were the options -c, -S or -E passed. */
1651 static int have_c = 0;
1653 /* Was the option -o passed. */
1654 static int have_o = 0;
1656 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1657 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1658 it here. */
1660 static struct temp_name {
1661 const char *suffix; /* suffix associated with the code. */
1662 int length; /* strlen (suffix). */
1663 int unique; /* Indicates whether %g or %u/%U was used. */
1664 const char *filename; /* associated filename. */
1665 int filename_length; /* strlen (filename). */
1666 struct temp_name *next;
1667 } *temp_names;
1669 /* Number of commands executed so far. */
1671 static int execution_count;
1673 /* Number of commands that exited with a signal. */
1675 static int signal_count;
1677 /* Allocate the argument vector. */
1679 static void
1680 alloc_args (void)
1682 argbuf.create (10);
1685 /* Clear out the vector of arguments (after a command is executed). */
1687 static void
1688 clear_args (void)
1690 argbuf.truncate (0);
1693 /* Add one argument to the vector at the end.
1694 This is done when a space is seen or at the end of the line.
1695 If DELETE_ALWAYS is nonzero, the arg is a filename
1696 and the file should be deleted eventually.
1697 If DELETE_FAILURE is nonzero, the arg is a filename
1698 and the file should be deleted if this compilation fails. */
1700 static void
1701 store_arg (const char *arg, int delete_always, int delete_failure)
1703 argbuf.safe_push (arg);
1705 if (strcmp (arg, "-o") == 0)
1706 have_o_argbuf_index = argbuf.length ();
1707 if (delete_always || delete_failure)
1709 const char *p;
1710 /* If the temporary file we should delete is specified as
1711 part of a joined argument extract the filename. */
1712 if (arg[0] == '-'
1713 && (p = strrchr (arg, '=')))
1714 arg = p + 1;
1715 record_temp_file (arg, delete_always, delete_failure);
1719 /* Load specs from a file name named FILENAME, replacing occurrences of
1720 various different types of line-endings, \r\n, \n\r and just \r, with
1721 a single \n. */
1723 static char *
1724 load_specs (const char *filename)
1726 int desc;
1727 int readlen;
1728 struct stat statbuf;
1729 char *buffer;
1730 char *buffer_p;
1731 char *specs;
1732 char *specs_p;
1734 if (verbose_flag)
1735 fnotice (stderr, "Reading specs from %s\n", filename);
1737 /* Open and stat the file. */
1738 desc = open (filename, O_RDONLY, 0);
1739 if (desc < 0)
1740 pfatal_with_name (filename);
1741 if (stat (filename, &statbuf) < 0)
1742 pfatal_with_name (filename);
1744 /* Read contents of file into BUFFER. */
1745 buffer = XNEWVEC (char, statbuf.st_size + 1);
1746 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1747 if (readlen < 0)
1748 pfatal_with_name (filename);
1749 buffer[readlen] = 0;
1750 close (desc);
1752 specs = XNEWVEC (char, readlen + 1);
1753 specs_p = specs;
1754 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1756 int skip = 0;
1757 char c = *buffer_p;
1758 if (c == '\r')
1760 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1761 skip = 1;
1762 else if (*(buffer_p + 1) == '\n') /* \r\n */
1763 skip = 1;
1764 else /* \r */
1765 c = '\n';
1767 if (! skip)
1768 *specs_p++ = c;
1770 *specs_p = '\0';
1772 free (buffer);
1773 return (specs);
1776 /* Read compilation specs from a file named FILENAME,
1777 replacing the default ones.
1779 A suffix which starts with `*' is a definition for
1780 one of the machine-specific sub-specs. The "suffix" should be
1781 *asm, *cc1, *cpp, *link, *startfile, etc.
1782 The corresponding spec is stored in asm_spec, etc.,
1783 rather than in the `compilers' vector.
1785 Anything invalid in the file is a fatal error. */
1787 static void
1788 read_specs (const char *filename, bool main_p, bool user_p)
1790 char *buffer;
1791 char *p;
1793 buffer = load_specs (filename);
1795 /* Scan BUFFER for specs, putting them in the vector. */
1796 p = buffer;
1797 while (1)
1799 char *suffix;
1800 char *spec;
1801 char *in, *out, *p1, *p2, *p3;
1803 /* Advance P in BUFFER to the next nonblank nocomment line. */
1804 p = skip_whitespace (p);
1805 if (*p == 0)
1806 break;
1808 /* Is this a special command that starts with '%'? */
1809 /* Don't allow this for the main specs file, since it would
1810 encourage people to overwrite it. */
1811 if (*p == '%' && !main_p)
1813 p1 = p;
1814 while (*p && *p != '\n')
1815 p++;
1817 /* Skip '\n'. */
1818 p++;
1820 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1821 && (p1[sizeof "%include" - 1] == ' '
1822 || p1[sizeof "%include" - 1] == '\t'))
1824 char *new_filename;
1826 p1 += sizeof ("%include");
1827 while (*p1 == ' ' || *p1 == '\t')
1828 p1++;
1830 if (*p1++ != '<' || p[-2] != '>')
1831 fatal_error ("specs %%include syntax malformed after "
1832 "%ld characters",
1833 (long) (p1 - buffer + 1));
1835 p[-2] = '\0';
1836 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1837 read_specs (new_filename ? new_filename : p1, false, user_p);
1838 continue;
1840 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1841 && (p1[sizeof "%include_noerr" - 1] == ' '
1842 || p1[sizeof "%include_noerr" - 1] == '\t'))
1844 char *new_filename;
1846 p1 += sizeof "%include_noerr";
1847 while (*p1 == ' ' || *p1 == '\t')
1848 p1++;
1850 if (*p1++ != '<' || p[-2] != '>')
1851 fatal_error ("specs %%include syntax malformed after "
1852 "%ld characters",
1853 (long) (p1 - buffer + 1));
1855 p[-2] = '\0';
1856 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1857 if (new_filename)
1858 read_specs (new_filename, false, user_p);
1859 else if (verbose_flag)
1860 fnotice (stderr, "could not find specs file %s\n", p1);
1861 continue;
1863 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1864 && (p1[sizeof "%rename" - 1] == ' '
1865 || p1[sizeof "%rename" - 1] == '\t'))
1867 int name_len;
1868 struct spec_list *sl;
1869 struct spec_list *newsl;
1871 /* Get original name. */
1872 p1 += sizeof "%rename";
1873 while (*p1 == ' ' || *p1 == '\t')
1874 p1++;
1876 if (! ISALPHA ((unsigned char) *p1))
1877 fatal_error ("specs %%rename syntax malformed after "
1878 "%ld characters",
1879 (long) (p1 - buffer));
1881 p2 = p1;
1882 while (*p2 && !ISSPACE ((unsigned char) *p2))
1883 p2++;
1885 if (*p2 != ' ' && *p2 != '\t')
1886 fatal_error ("specs %%rename syntax malformed after "
1887 "%ld characters",
1888 (long) (p2 - buffer));
1890 name_len = p2 - p1;
1891 *p2++ = '\0';
1892 while (*p2 == ' ' || *p2 == '\t')
1893 p2++;
1895 if (! ISALPHA ((unsigned char) *p2))
1896 fatal_error ("specs %%rename syntax malformed after "
1897 "%ld characters",
1898 (long) (p2 - buffer));
1900 /* Get new spec name. */
1901 p3 = p2;
1902 while (*p3 && !ISSPACE ((unsigned char) *p3))
1903 p3++;
1905 if (p3 != p - 1)
1906 fatal_error ("specs %%rename syntax malformed after "
1907 "%ld characters",
1908 (long) (p3 - buffer));
1909 *p3 = '\0';
1911 for (sl = specs; sl; sl = sl->next)
1912 if (name_len == sl->name_len && !strcmp (sl->name, p1))
1913 break;
1915 if (!sl)
1916 fatal_error ("specs %s spec was not found to be renamed", p1);
1918 if (strcmp (p1, p2) == 0)
1919 continue;
1921 for (newsl = specs; newsl; newsl = newsl->next)
1922 if (strcmp (newsl->name, p2) == 0)
1923 fatal_error ("%s: attempt to rename spec %qs to "
1924 "already defined spec %qs",
1925 filename, p1, p2);
1927 if (verbose_flag)
1929 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
1930 #ifdef DEBUG_SPECS
1931 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
1932 #endif
1935 set_spec (p2, *(sl->ptr_spec), user_p);
1936 if (sl->alloc_p)
1937 free (CONST_CAST (char *, *(sl->ptr_spec)));
1939 *(sl->ptr_spec) = "";
1940 sl->alloc_p = 0;
1941 continue;
1943 else
1944 fatal_error ("specs unknown %% command after %ld characters",
1945 (long) (p1 - buffer));
1948 /* Find the colon that should end the suffix. */
1949 p1 = p;
1950 while (*p1 && *p1 != ':' && *p1 != '\n')
1951 p1++;
1953 /* The colon shouldn't be missing. */
1954 if (*p1 != ':')
1955 fatal_error ("specs file malformed after %ld characters",
1956 (long) (p1 - buffer));
1958 /* Skip back over trailing whitespace. */
1959 p2 = p1;
1960 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
1961 p2--;
1963 /* Copy the suffix to a string. */
1964 suffix = save_string (p, p2 - p);
1965 /* Find the next line. */
1966 p = skip_whitespace (p1 + 1);
1967 if (p[1] == 0)
1968 fatal_error ("specs file malformed after %ld characters",
1969 (long) (p - buffer));
1971 p1 = p;
1972 /* Find next blank line or end of string. */
1973 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
1974 p1++;
1976 /* Specs end at the blank line and do not include the newline. */
1977 spec = save_string (p, p1 - p);
1978 p = p1;
1980 /* Delete backslash-newline sequences from the spec. */
1981 in = spec;
1982 out = spec;
1983 while (*in != 0)
1985 if (in[0] == '\\' && in[1] == '\n')
1986 in += 2;
1987 else if (in[0] == '#')
1988 while (*in && *in != '\n')
1989 in++;
1991 else
1992 *out++ = *in++;
1994 *out = 0;
1996 if (suffix[0] == '*')
1998 if (! strcmp (suffix, "*link_command"))
1999 link_command_spec = spec;
2000 else
2001 set_spec (suffix + 1, spec, user_p);
2003 else
2005 /* Add this pair to the vector. */
2006 compilers
2007 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
2009 compilers[n_compilers].suffix = suffix;
2010 compilers[n_compilers].spec = spec;
2011 n_compilers++;
2012 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2015 if (*suffix == 0)
2016 link_command_spec = spec;
2019 if (link_command_spec == 0)
2020 fatal_error ("spec file has no spec for linking");
2023 /* Record the names of temporary files we tell compilers to write,
2024 and delete them at the end of the run. */
2026 /* This is the common prefix we use to make temp file names.
2027 It is chosen once for each run of this program.
2028 It is substituted into a spec by %g or %j.
2029 Thus, all temp file names contain this prefix.
2030 In practice, all temp file names start with this prefix.
2032 This prefix comes from the envvar TMPDIR if it is defined;
2033 otherwise, from the P_tmpdir macro if that is defined;
2034 otherwise, in /usr/tmp or /tmp;
2035 or finally the current directory if all else fails. */
2037 static const char *temp_filename;
2039 /* Length of the prefix. */
2041 static int temp_filename_length;
2043 /* Define the list of temporary files to delete. */
2045 struct temp_file
2047 const char *name;
2048 struct temp_file *next;
2051 /* Queue of files to delete on success or failure of compilation. */
2052 static struct temp_file *always_delete_queue;
2053 /* Queue of files to delete on failure of compilation. */
2054 static struct temp_file *failure_delete_queue;
2056 /* Record FILENAME as a file to be deleted automatically.
2057 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2058 otherwise delete it in any case.
2059 FAIL_DELETE nonzero means delete it if a compilation step fails;
2060 otherwise delete it in any case. */
2062 void
2063 record_temp_file (const char *filename, int always_delete, int fail_delete)
2065 char *const name = xstrdup (filename);
2067 if (always_delete)
2069 struct temp_file *temp;
2070 for (temp = always_delete_queue; temp; temp = temp->next)
2071 if (! filename_cmp (name, temp->name))
2072 goto already1;
2074 temp = XNEW (struct temp_file);
2075 temp->next = always_delete_queue;
2076 temp->name = name;
2077 always_delete_queue = temp;
2079 already1:;
2082 if (fail_delete)
2084 struct temp_file *temp;
2085 for (temp = failure_delete_queue; temp; temp = temp->next)
2086 if (! filename_cmp (name, temp->name))
2088 free (name);
2089 goto already2;
2092 temp = XNEW (struct temp_file);
2093 temp->next = failure_delete_queue;
2094 temp->name = name;
2095 failure_delete_queue = temp;
2097 already2:;
2101 /* Delete all the temporary files whose names we previously recorded. */
2103 #ifndef DELETE_IF_ORDINARY
2104 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2105 do \
2107 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2108 if (unlink (NAME) < 0) \
2109 if (VERBOSE_FLAG) \
2110 perror_with_name (NAME); \
2111 } while (0)
2112 #endif
2114 static void
2115 delete_if_ordinary (const char *name)
2117 struct stat st;
2118 #ifdef DEBUG
2119 int i, c;
2121 printf ("Delete %s? (y or n) ", name);
2122 fflush (stdout);
2123 i = getchar ();
2124 if (i != '\n')
2125 while ((c = getchar ()) != '\n' && c != EOF)
2128 if (i == 'y' || i == 'Y')
2129 #endif /* DEBUG */
2130 DELETE_IF_ORDINARY (name, st, verbose_flag);
2133 static void
2134 delete_temp_files (void)
2136 struct temp_file *temp;
2138 for (temp = always_delete_queue; temp; temp = temp->next)
2139 delete_if_ordinary (temp->name);
2140 always_delete_queue = 0;
2143 /* Delete all the files to be deleted on error. */
2145 static void
2146 delete_failure_queue (void)
2148 struct temp_file *temp;
2150 for (temp = failure_delete_queue; temp; temp = temp->next)
2151 delete_if_ordinary (temp->name);
2154 static void
2155 clear_failure_queue (void)
2157 failure_delete_queue = 0;
2160 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2161 returns non-NULL.
2162 If DO_MULTI is true iterate over the paths twice, first with multilib
2163 suffix then without, otherwise iterate over the paths once without
2164 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2165 to avoid visiting the same path twice, but we could do better. For
2166 instance, /usr/lib/../lib is considered different from /usr/lib.
2167 At least EXTRA_SPACE chars past the end of the path passed to
2168 CALLBACK are available for use by the callback.
2169 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2171 Returns the value returned by CALLBACK. */
2173 static void *
2174 for_each_path (const struct path_prefix *paths,
2175 bool do_multi,
2176 size_t extra_space,
2177 void *(*callback) (char *, void *),
2178 void *callback_info)
2180 struct prefix_list *pl;
2181 const char *multi_dir = NULL;
2182 const char *multi_os_dir = NULL;
2183 const char *multiarch_suffix = NULL;
2184 const char *multi_suffix;
2185 const char *just_multi_suffix;
2186 char *path = NULL;
2187 void *ret = NULL;
2188 bool skip_multi_dir = false;
2189 bool skip_multi_os_dir = false;
2191 multi_suffix = machine_suffix;
2192 just_multi_suffix = just_machine_suffix;
2193 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2195 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2196 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2197 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2199 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2200 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2201 if (multiarch_dir)
2202 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2204 while (1)
2206 size_t multi_dir_len = 0;
2207 size_t multi_os_dir_len = 0;
2208 size_t multiarch_len = 0;
2209 size_t suffix_len;
2210 size_t just_suffix_len;
2211 size_t len;
2213 if (multi_dir)
2214 multi_dir_len = strlen (multi_dir);
2215 if (multi_os_dir)
2216 multi_os_dir_len = strlen (multi_os_dir);
2217 if (multiarch_suffix)
2218 multiarch_len = strlen (multiarch_suffix);
2219 suffix_len = strlen (multi_suffix);
2220 just_suffix_len = strlen (just_multi_suffix);
2222 if (path == NULL)
2224 len = paths->max_len + extra_space + 1;
2225 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2226 path = XNEWVEC (char, len);
2229 for (pl = paths->plist; pl != 0; pl = pl->next)
2231 len = strlen (pl->prefix);
2232 memcpy (path, pl->prefix, len);
2234 /* Look first in MACHINE/VERSION subdirectory. */
2235 if (!skip_multi_dir)
2237 memcpy (path + len, multi_suffix, suffix_len + 1);
2238 ret = callback (path, callback_info);
2239 if (ret)
2240 break;
2243 /* Some paths are tried with just the machine (ie. target)
2244 subdir. This is used for finding as, ld, etc. */
2245 if (!skip_multi_dir
2246 && pl->require_machine_suffix == 2)
2248 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2249 ret = callback (path, callback_info);
2250 if (ret)
2251 break;
2254 /* Now try the multiarch path. */
2255 if (!skip_multi_dir
2256 && !pl->require_machine_suffix && multiarch_dir)
2258 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2259 ret = callback (path, callback_info);
2260 if (ret)
2261 break;
2264 /* Now try the base path. */
2265 if (!pl->require_machine_suffix
2266 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2268 const char *this_multi;
2269 size_t this_multi_len;
2271 if (pl->os_multilib)
2273 this_multi = multi_os_dir;
2274 this_multi_len = multi_os_dir_len;
2276 else
2278 this_multi = multi_dir;
2279 this_multi_len = multi_dir_len;
2282 if (this_multi_len)
2283 memcpy (path + len, this_multi, this_multi_len + 1);
2284 else
2285 path[len] = '\0';
2287 ret = callback (path, callback_info);
2288 if (ret)
2289 break;
2292 if (pl)
2293 break;
2295 if (multi_dir == NULL && multi_os_dir == NULL)
2296 break;
2298 /* Run through the paths again, this time without multilibs.
2299 Don't repeat any we have already seen. */
2300 if (multi_dir)
2302 free (CONST_CAST (char *, multi_dir));
2303 multi_dir = NULL;
2304 free (CONST_CAST (char *, multi_suffix));
2305 multi_suffix = machine_suffix;
2306 free (CONST_CAST (char *, just_multi_suffix));
2307 just_multi_suffix = just_machine_suffix;
2309 else
2310 skip_multi_dir = true;
2311 if (multi_os_dir)
2313 free (CONST_CAST (char *, multi_os_dir));
2314 multi_os_dir = NULL;
2316 else
2317 skip_multi_os_dir = true;
2320 if (multi_dir)
2322 free (CONST_CAST (char *, multi_dir));
2323 free (CONST_CAST (char *, multi_suffix));
2324 free (CONST_CAST (char *, just_multi_suffix));
2326 if (multi_os_dir)
2327 free (CONST_CAST (char *, multi_os_dir));
2328 if (ret != path)
2329 free (path);
2330 return ret;
2333 /* Callback for build_search_list. Adds path to obstack being built. */
2335 struct add_to_obstack_info {
2336 struct obstack *ob;
2337 bool check_dir;
2338 bool first_time;
2341 static void *
2342 add_to_obstack (char *path, void *data)
2344 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2346 if (info->check_dir && !is_directory (path, false))
2347 return NULL;
2349 if (!info->first_time)
2350 obstack_1grow (info->ob, PATH_SEPARATOR);
2352 obstack_grow (info->ob, path, strlen (path));
2354 info->first_time = false;
2355 return NULL;
2358 /* Add or change the value of an environment variable, outputting the
2359 change to standard error if in verbose mode. */
2360 static void
2361 xputenv (const char *string)
2363 if (verbose_flag)
2364 fnotice (stderr, "%s\n", string);
2365 putenv (CONST_CAST (char *, string));
2368 /* Build a list of search directories from PATHS.
2369 PREFIX is a string to prepend to the list.
2370 If CHECK_DIR_P is true we ensure the directory exists.
2371 If DO_MULTI is true, multilib paths are output first, then
2372 non-multilib paths.
2373 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2374 It is also used by the --print-search-dirs flag. */
2376 static char *
2377 build_search_list (const struct path_prefix *paths, const char *prefix,
2378 bool check_dir, bool do_multi)
2380 struct add_to_obstack_info info;
2382 info.ob = &collect_obstack;
2383 info.check_dir = check_dir;
2384 info.first_time = true;
2386 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2387 obstack_1grow (&collect_obstack, '=');
2389 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2391 obstack_1grow (&collect_obstack, '\0');
2392 return XOBFINISH (&collect_obstack, char *);
2395 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2396 for collect. */
2398 static void
2399 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2400 bool do_multi)
2402 xputenv (build_search_list (paths, env_var, true, do_multi));
2405 /* Check whether NAME can be accessed in MODE. This is like access,
2406 except that it never considers directories to be executable. */
2408 static int
2409 access_check (const char *name, int mode)
2411 if (mode == X_OK)
2413 struct stat st;
2415 if (stat (name, &st) < 0
2416 || S_ISDIR (st.st_mode))
2417 return -1;
2420 return access (name, mode);
2423 /* Callback for find_a_file. Appends the file name to the directory
2424 path. If the resulting file exists in the right mode, return the
2425 full pathname to the file. */
2427 struct file_at_path_info {
2428 const char *name;
2429 const char *suffix;
2430 int name_len;
2431 int suffix_len;
2432 int mode;
2435 static void *
2436 file_at_path (char *path, void *data)
2438 struct file_at_path_info *info = (struct file_at_path_info *) data;
2439 size_t len = strlen (path);
2441 memcpy (path + len, info->name, info->name_len);
2442 len += info->name_len;
2444 /* Some systems have a suffix for executable files.
2445 So try appending that first. */
2446 if (info->suffix_len)
2448 memcpy (path + len, info->suffix, info->suffix_len + 1);
2449 if (access_check (path, info->mode) == 0)
2450 return path;
2453 path[len] = '\0';
2454 if (access_check (path, info->mode) == 0)
2455 return path;
2457 return NULL;
2460 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2461 access to check permissions. If DO_MULTI is true, search multilib
2462 paths then non-multilib paths, otherwise do not search multilib paths.
2463 Return 0 if not found, otherwise return its name, allocated with malloc. */
2465 static char *
2466 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2467 bool do_multi)
2469 struct file_at_path_info info;
2471 #ifdef DEFAULT_ASSEMBLER
2472 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2473 return xstrdup (DEFAULT_ASSEMBLER);
2474 #endif
2476 #ifdef DEFAULT_LINKER
2477 if (! strcmp (name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2478 return xstrdup (DEFAULT_LINKER);
2479 #endif
2481 /* Determine the filename to execute (special case for absolute paths). */
2483 if (IS_ABSOLUTE_PATH (name))
2485 if (access (name, mode) == 0)
2486 return xstrdup (name);
2488 return NULL;
2491 info.name = name;
2492 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2493 info.name_len = strlen (info.name);
2494 info.suffix_len = strlen (info.suffix);
2495 info.mode = mode;
2497 return (char*) for_each_path (pprefix, do_multi,
2498 info.name_len + info.suffix_len,
2499 file_at_path, &info);
2502 /* Ranking of prefixes in the sort list. -B prefixes are put before
2503 all others. */
2505 enum path_prefix_priority
2507 PREFIX_PRIORITY_B_OPT,
2508 PREFIX_PRIORITY_LAST
2511 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2512 order according to PRIORITY. Within each PRIORITY, new entries are
2513 appended.
2515 If WARN is nonzero, we will warn if no file is found
2516 through this prefix. WARN should point to an int
2517 which will be set to 1 if this entry is used.
2519 COMPONENT is the value to be passed to update_path.
2521 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2522 the complete value of machine_suffix.
2523 2 means try both machine_suffix and just_machine_suffix. */
2525 static void
2526 add_prefix (struct path_prefix *pprefix, const char *prefix,
2527 const char *component, /* enum prefix_priority */ int priority,
2528 int require_machine_suffix, int os_multilib)
2530 struct prefix_list *pl, **prev;
2531 int len;
2533 for (prev = &pprefix->plist;
2534 (*prev) != NULL && (*prev)->priority <= priority;
2535 prev = &(*prev)->next)
2538 /* Keep track of the longest prefix. */
2540 prefix = update_path (prefix, component);
2541 len = strlen (prefix);
2542 if (len > pprefix->max_len)
2543 pprefix->max_len = len;
2545 pl = XNEW (struct prefix_list);
2546 pl->prefix = prefix;
2547 pl->require_machine_suffix = require_machine_suffix;
2548 pl->priority = priority;
2549 pl->os_multilib = os_multilib;
2551 /* Insert after PREV. */
2552 pl->next = (*prev);
2553 (*prev) = pl;
2556 /* Same as add_prefix, but prepending target_system_root to prefix. */
2557 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2558 static void
2559 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2560 const char *component,
2561 /* enum prefix_priority */ int priority,
2562 int require_machine_suffix, int os_multilib)
2564 if (!IS_ABSOLUTE_PATH (prefix))
2565 fatal_error ("system path %qs is not absolute", prefix);
2567 if (target_system_root)
2569 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2570 size_t sysroot_len = strlen (target_system_root);
2572 if (sysroot_len > 0
2573 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2574 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2576 if (target_sysroot_suffix)
2577 prefix = concat (sysroot_no_trailing_dir_separator,
2578 target_sysroot_suffix, prefix, NULL);
2579 else
2580 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2582 free (sysroot_no_trailing_dir_separator);
2584 /* We have to override this because GCC's notion of sysroot
2585 moves along with GCC. */
2586 component = "GCC";
2589 add_prefix (pprefix, prefix, component, priority,
2590 require_machine_suffix, os_multilib);
2593 /* Execute the command specified by the arguments on the current line of spec.
2594 When using pipes, this includes several piped-together commands
2595 with `|' between them.
2597 Return 0 if successful, -1 if failed. */
2599 static int
2600 execute (void)
2602 int i;
2603 int n_commands; /* # of command. */
2604 char *string;
2605 struct pex_obj *pex;
2606 struct command
2608 const char *prog; /* program name. */
2609 const char **argv; /* vector of args. */
2611 const char *arg;
2613 struct command *commands; /* each command buffer with above info. */
2615 gcc_assert (!processing_spec_function);
2617 if (wrapper_string)
2619 string = find_a_file (&exec_prefixes,
2620 argbuf[0], X_OK, false);
2621 if (string)
2622 argbuf[0] = string;
2623 insert_wrapper (wrapper_string);
2626 /* Count # of piped commands. */
2627 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2628 if (strcmp (arg, "|") == 0)
2629 n_commands++;
2631 /* Get storage for each command. */
2632 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2634 /* Split argbuf into its separate piped processes,
2635 and record info about each one.
2636 Also search for the programs that are to be run. */
2638 argbuf.safe_push (0);
2640 commands[0].prog = argbuf[0]; /* first command. */
2641 commands[0].argv = argbuf.address ();
2643 if (!wrapper_string)
2645 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2646 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2649 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2650 if (arg && strcmp (arg, "|") == 0)
2651 { /* each command. */
2652 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2653 fatal_error ("-pipe not supported");
2654 #endif
2655 argbuf[i] = 0; /* Termination of
2656 command args. */
2657 commands[n_commands].prog = argbuf[i + 1];
2658 commands[n_commands].argv
2659 = &(argbuf.address ())[i + 1];
2660 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2661 X_OK, false);
2662 if (string)
2663 commands[n_commands].argv[0] = string;
2664 n_commands++;
2667 /* If -v, print what we are about to do, and maybe query. */
2669 if (verbose_flag)
2671 /* For help listings, put a blank line between sub-processes. */
2672 if (print_help_list)
2673 fputc ('\n', stderr);
2675 /* Print each piped command as a separate line. */
2676 for (i = 0; i < n_commands; i++)
2678 const char *const *j;
2680 if (verbose_only_flag)
2682 for (j = commands[i].argv; *j; j++)
2684 const char *p;
2685 for (p = *j; *p; ++p)
2686 if (!ISALNUM ((unsigned char) *p)
2687 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2688 break;
2689 if (*p || !*j)
2691 fprintf (stderr, " \"");
2692 for (p = *j; *p; ++p)
2694 if (*p == '"' || *p == '\\' || *p == '$')
2695 fputc ('\\', stderr);
2696 fputc (*p, stderr);
2698 fputc ('"', stderr);
2700 /* If it's empty, print "". */
2701 else if (!**j)
2702 fprintf (stderr, " \"\"");
2703 else
2704 fprintf (stderr, " %s", *j);
2707 else
2708 for (j = commands[i].argv; *j; j++)
2709 /* If it's empty, print "". */
2710 if (!**j)
2711 fprintf (stderr, " \"\"");
2712 else
2713 fprintf (stderr, " %s", *j);
2715 /* Print a pipe symbol after all but the last command. */
2716 if (i + 1 != n_commands)
2717 fprintf (stderr, " |");
2718 fprintf (stderr, "\n");
2720 fflush (stderr);
2721 if (verbose_only_flag != 0)
2723 /* verbose_only_flag should act as if the spec was
2724 executed, so increment execution_count before
2725 returning. This prevents spurious warnings about
2726 unused linker input files, etc. */
2727 execution_count++;
2728 return 0;
2730 #ifdef DEBUG
2731 fnotice (stderr, "\nGo ahead? (y or n) ");
2732 fflush (stderr);
2733 i = getchar ();
2734 if (i != '\n')
2735 while (getchar () != '\n')
2738 if (i != 'y' && i != 'Y')
2739 return 0;
2740 #endif /* DEBUG */
2743 #ifdef ENABLE_VALGRIND_CHECKING
2744 /* Run the each command through valgrind. To simplify prepending the
2745 path to valgrind and the option "-q" (for quiet operation unless
2746 something triggers), we allocate a separate argv array. */
2748 for (i = 0; i < n_commands; i++)
2750 const char **argv;
2751 int argc;
2752 int j;
2754 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2757 argv = XALLOCAVEC (const char *, argc + 3);
2759 argv[0] = VALGRIND_PATH;
2760 argv[1] = "-q";
2761 for (j = 2; j < argc + 2; j++)
2762 argv[j] = commands[i].argv[j - 2];
2763 argv[j] = NULL;
2765 commands[i].argv = argv;
2766 commands[i].prog = argv[0];
2768 #endif
2770 /* Run each piped subprocess. */
2772 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
2773 ? PEX_RECORD_TIMES : 0),
2774 progname, temp_filename);
2775 if (pex == NULL)
2776 fatal_error ("pex_init failed: %m");
2778 for (i = 0; i < n_commands; i++)
2780 const char *errmsg;
2781 int err;
2782 const char *string = commands[i].argv[0];
2784 errmsg = pex_run (pex,
2785 ((i + 1 == n_commands ? PEX_LAST : 0)
2786 | (string == commands[i].prog ? PEX_SEARCH : 0)),
2787 string, CONST_CAST (char **, commands[i].argv),
2788 NULL, NULL, &err);
2789 if (errmsg != NULL)
2791 if (err == 0)
2792 fatal_error (errmsg);
2793 else
2795 errno = err;
2796 pfatal_with_name (errmsg);
2800 if (string != commands[i].prog)
2801 free (CONST_CAST (char *, string));
2804 execution_count++;
2806 /* Wait for all the subprocesses to finish. */
2809 int *statuses;
2810 struct pex_time *times = NULL;
2811 int ret_code = 0;
2813 statuses = (int *) alloca (n_commands * sizeof (int));
2814 if (!pex_get_status (pex, n_commands, statuses))
2815 fatal_error ("failed to get exit status: %m");
2817 if (report_times || report_times_to_file)
2819 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
2820 if (!pex_get_times (pex, n_commands, times))
2821 fatal_error ("failed to get process times: %m");
2824 pex_free (pex);
2826 for (i = 0; i < n_commands; ++i)
2828 int status = statuses[i];
2830 if (WIFSIGNALED (status))
2832 #ifdef SIGPIPE
2833 /* SIGPIPE is a special case. It happens in -pipe mode
2834 when the compiler dies before the preprocessor is done,
2835 or the assembler dies before the compiler is done.
2836 There's generally been an error already, and this is
2837 just fallout. So don't generate another error unless
2838 we would otherwise have succeeded. */
2839 if (WTERMSIG (status) == SIGPIPE
2840 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2842 signal_count++;
2843 ret_code = -1;
2845 else
2846 #endif
2847 internal_error ("%s (program %s)",
2848 strsignal (WTERMSIG (status)), commands[i].prog);
2850 else if (WIFEXITED (status)
2851 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2853 if (WEXITSTATUS (status) > greatest_status)
2854 greatest_status = WEXITSTATUS (status);
2855 ret_code = -1;
2858 if (report_times || report_times_to_file)
2860 struct pex_time *pt = &times[i];
2861 double ut, st;
2863 ut = ((double) pt->user_seconds
2864 + (double) pt->user_microseconds / 1.0e6);
2865 st = ((double) pt->system_seconds
2866 + (double) pt->system_microseconds / 1.0e6);
2868 if (ut + st != 0)
2870 if (report_times)
2871 fnotice (stderr, "# %s %.2f %.2f\n",
2872 commands[i].prog, ut, st);
2874 if (report_times_to_file)
2876 int c = 0;
2877 const char *const *j;
2879 fprintf (report_times_to_file, "%g %g", ut, st);
2881 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
2883 const char *p;
2884 for (p = *j; *p; ++p)
2885 if (*p == '"' || *p == '\\' || *p == '$'
2886 || ISSPACE (*p))
2887 break;
2889 if (*p)
2891 fprintf (report_times_to_file, " \"");
2892 for (p = *j; *p; ++p)
2894 if (*p == '"' || *p == '\\' || *p == '$')
2895 fputc ('\\', report_times_to_file);
2896 fputc (*p, report_times_to_file);
2898 fputc ('"', report_times_to_file);
2900 else
2901 fprintf (report_times_to_file, " %s", *j);
2904 fputc ('\n', report_times_to_file);
2910 return ret_code;
2914 /* Find all the switches given to us
2915 and make a vector describing them.
2916 The elements of the vector are strings, one per switch given.
2917 If a switch uses following arguments, then the `part1' field
2918 is the switch itself and the `args' field
2919 is a null-terminated vector containing the following arguments.
2920 Bits in the `live_cond' field are:
2921 SWITCH_LIVE to indicate this switch is true in a conditional spec.
2922 SWITCH_FALSE to indicate this switch is overridden by a later switch.
2923 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
2924 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored
2925 in all do_spec calls afterwards. Used for %<S from self specs.
2926 The `validated' field is nonzero if any spec has looked at this switch;
2927 if it remains zero at the end of the run, it must be meaningless. */
2929 #define SWITCH_LIVE (1 << 0)
2930 #define SWITCH_FALSE (1 << 1)
2931 #define SWITCH_IGNORE (1 << 2)
2932 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
2933 #define SWITCH_KEEP_FOR_GCC (1 << 4)
2935 struct switchstr
2937 const char *part1;
2938 const char **args;
2939 unsigned int live_cond;
2940 bool known;
2941 bool validated;
2942 bool ordering;
2945 static struct switchstr *switches;
2947 static int n_switches;
2949 static int n_switches_alloc;
2951 /* Set to zero if -fcompare-debug is disabled, positive if it's
2952 enabled and we're running the first compilation, negative if it's
2953 enabled and we're running the second compilation. For most of the
2954 time, it's in the range -1..1, but it can be temporarily set to 2
2955 or 3 to indicate that the -fcompare-debug flags didn't come from
2956 the command-line, but rather from the GCC_COMPARE_DEBUG environment
2957 variable, until a synthesized -fcompare-debug flag is added to the
2958 command line. */
2959 int compare_debug;
2961 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
2962 int compare_debug_second;
2964 /* Set to the flags that should be passed to the second compilation in
2965 a -fcompare-debug compilation. */
2966 const char *compare_debug_opt;
2968 static struct switchstr *switches_debug_check[2];
2970 static int n_switches_debug_check[2];
2972 static int n_switches_alloc_debug_check[2];
2974 static char *debug_check_temp_file[2];
2976 /* Language is one of three things:
2978 1) The name of a real programming language.
2979 2) NULL, indicating that no one has figured out
2980 what it is yet.
2981 3) '*', indicating that the file should be passed
2982 to the linker. */
2983 struct infile
2985 const char *name;
2986 const char *language;
2987 struct compiler *incompiler;
2988 bool compiled;
2989 bool preprocessed;
2992 /* Also a vector of input files specified. */
2994 static struct infile *infiles;
2996 int n_infiles;
2998 static int n_infiles_alloc;
3000 /* True if multiple input files are being compiled to a single
3001 assembly file. */
3003 static bool combine_inputs;
3005 /* This counts the number of libraries added by lang_specific_driver, so that
3006 we can tell if there were any user supplied any files or libraries. */
3008 static int added_libraries;
3010 /* And a vector of corresponding output files is made up later. */
3012 const char **outfiles;
3014 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3016 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3017 is true if we should look for an executable suffix. DO_OBJ
3018 is true if we should look for an object suffix. */
3020 static const char *
3021 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3022 int do_obj ATTRIBUTE_UNUSED)
3024 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3025 int i;
3026 #endif
3027 int len;
3029 if (name == NULL)
3030 return NULL;
3032 len = strlen (name);
3034 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3035 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3036 if (do_obj && len > 2
3037 && name[len - 2] == '.'
3038 && name[len - 1] == 'o')
3040 obstack_grow (&obstack, name, len - 2);
3041 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3042 name = XOBFINISH (&obstack, const char *);
3044 #endif
3046 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3047 /* If there is no filetype, make it the executable suffix (which includes
3048 the "."). But don't get confused if we have just "-o". */
3049 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3050 return name;
3052 for (i = len - 1; i >= 0; i--)
3053 if (IS_DIR_SEPARATOR (name[i]))
3054 break;
3056 for (i++; i < len; i++)
3057 if (name[i] == '.')
3058 return name;
3060 obstack_grow (&obstack, name, len);
3061 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3062 strlen (TARGET_EXECUTABLE_SUFFIX));
3063 name = XOBFINISH (&obstack, const char *);
3064 #endif
3066 return name;
3068 #endif
3070 /* Display the command line switches accepted by gcc. */
3071 static void
3072 display_help (void)
3074 printf (_("Usage: %s [options] file...\n"), progname);
3075 fputs (_("Options:\n"), stdout);
3077 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3078 fputs (_(" --help Display this information\n"), stdout);
3079 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3080 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...]\n"), stdout);
3081 fputs (_(" Display specific types of command line options\n"), stdout);
3082 if (! verbose_flag)
3083 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3084 fputs (_(" --version Display compiler version information\n"), stdout);
3085 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3086 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3087 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3088 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3089 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3090 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3091 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3092 fputs (_("\
3093 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3094 a component in the library path\n"), stdout);
3095 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3096 fputs (_("\
3097 -print-multi-lib Display the mapping between command line options and\n\
3098 multiple library search directories\n"), stdout);
3099 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3100 fputs (_(" -print-sysroot Display the target libraries directory\n"), stdout);
3101 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
3102 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3103 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3104 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3105 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3106 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3107 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3108 fputs (_(" -Xclang-only=<arg> Ignore <arg>\n"), stdout);
3109 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3110 fputs (_(" -save-temps=<arg> Do not delete intermediate files\n"), stdout);
3111 fputs (_("\
3112 -[no-]canonical-prefixes Specify the path canonicalization for relative\n\
3113 prefixes to other gcc components\n"), stdout);
3114 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3115 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3116 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3117 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3118 fputs (_("\
3119 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3120 and libraries\n"), stdout);
3121 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3122 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3123 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3124 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3125 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3126 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3127 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3128 fputs (_(" -pie Create a position independent executable\n"), stdout);
3129 fputs (_(" -shared Create a shared library\n"), stdout);
3130 fputs (_("\
3131 -x <language> Specify the language of the following input files\n\
3132 Permissible languages include: c c++ assembler none\n\
3133 'none' means revert to the default behavior of\n\
3134 guessing the language based on the file's extension\n\
3135 "), stdout);
3137 printf (_("\
3138 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3139 passed on to the various sub-processes invoked by %s. In order to pass\n\
3140 other options on to these processes the -W<letter> options must be used.\n\
3141 "), progname);
3143 /* The rest of the options are displayed by invocations of the various
3144 sub-processes. */
3147 static void
3148 add_preprocessor_option (const char *option, int len)
3150 preprocessor_options.safe_push (save_string (option, len));
3153 static void
3154 add_assembler_option (const char *option, int len)
3156 assembler_options.safe_push (save_string (option, len));
3159 static void
3160 add_linker_option (const char *option, int len)
3162 linker_options.safe_push (save_string (option, len));
3165 /* Allocate space for an input file in infiles. */
3167 static void
3168 alloc_infile (void)
3170 if (n_infiles_alloc == 0)
3172 n_infiles_alloc = 16;
3173 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3175 else if (n_infiles_alloc == n_infiles)
3177 n_infiles_alloc *= 2;
3178 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3182 /* Store an input file with the given NAME and LANGUAGE in
3183 infiles. */
3185 static void
3186 add_infile (const char *name, const char *language)
3188 alloc_infile ();
3189 infiles[n_infiles].name = name;
3190 infiles[n_infiles++].language = language;
3193 /* Allocate space for a switch in switches. */
3195 static void
3196 alloc_switch (void)
3198 if (n_switches_alloc == 0)
3200 n_switches_alloc = 16;
3201 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3203 else if (n_switches_alloc == n_switches)
3205 n_switches_alloc *= 2;
3206 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3210 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3211 as validated if VALIDATED and KNOWN if it is an internal switch. */
3213 static void
3214 save_switch (const char *opt, size_t n_args, const char *const *args,
3215 bool validated, bool known)
3217 alloc_switch ();
3218 switches[n_switches].part1 = opt + 1;
3219 if (n_args == 0)
3220 switches[n_switches].args = 0;
3221 else
3223 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3224 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3225 switches[n_switches].args[n_args] = NULL;
3228 switches[n_switches].live_cond = 0;
3229 switches[n_switches].validated = validated;
3230 switches[n_switches].known = known;
3231 switches[n_switches].ordering = 0;
3232 n_switches++;
3235 /* Handle an option DECODED that is unknown to the option-processing
3236 machinery. */
3238 static bool
3239 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3241 const char *opt = decoded->arg;
3242 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3243 && !(decoded->errors & CL_ERR_NEGATIVE))
3245 /* Leave unknown -Wno-* options for the compiler proper, to be
3246 diagnosed only if there are warnings. */
3247 save_switch (decoded->canonical_option[0],
3248 decoded->canonical_option_num_elements - 1,
3249 &decoded->canonical_option[1], false, true);
3250 return false;
3252 if (decoded->opt_index == OPT_SPECIAL_unknown)
3254 /* Give it a chance to define it a a spec file. */
3255 save_switch (decoded->canonical_option[0],
3256 decoded->canonical_option_num_elements - 1,
3257 &decoded->canonical_option[1], false, false);
3258 return false;
3260 else
3261 return true;
3264 /* Handle an option DECODED that is not marked as CL_DRIVER.
3265 LANG_MASK will always be CL_DRIVER. */
3267 static void
3268 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3269 unsigned int lang_mask ATTRIBUTE_UNUSED)
3271 /* At this point, non-driver options are accepted (and expected to
3272 be passed down by specs) unless marked to be rejected by the
3273 driver. Options to be rejected by the driver but accepted by the
3274 compilers proper are treated just like completely unknown
3275 options. */
3276 const struct cl_option *option = &cl_options[decoded->opt_index];
3278 if (option->cl_reject_driver)
3279 error ("unrecognized command line option %qs",
3280 decoded->orig_option_with_args_text);
3281 else
3282 save_switch (decoded->canonical_option[0],
3283 decoded->canonical_option_num_elements - 1,
3284 &decoded->canonical_option[1], false, true);
3287 static const char *spec_lang = 0;
3288 static int last_language_n_infiles;
3290 /* Handle a driver option; arguments and return value as for
3291 handle_option. */
3293 static bool
3294 driver_handle_option (struct gcc_options *opts,
3295 struct gcc_options *opts_set,
3296 const struct cl_decoded_option *decoded,
3297 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3298 location_t loc,
3299 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3300 diagnostic_context *dc)
3302 size_t opt_index = decoded->opt_index;
3303 const char *arg = decoded->arg;
3304 const char *compare_debug_replacement_opt;
3305 int value = decoded->value;
3306 bool validated = false;
3307 bool do_save = true;
3309 gcc_assert (opts == &global_options);
3310 gcc_assert (opts_set == &global_options_set);
3311 gcc_assert (kind == DK_UNSPECIFIED);
3312 gcc_assert (loc == UNKNOWN_LOCATION);
3313 gcc_assert (dc == global_dc);
3315 switch (opt_index)
3317 case OPT_dumpspecs:
3319 struct spec_list *sl;
3320 init_spec ();
3321 for (sl = specs; sl; sl = sl->next)
3322 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3323 if (link_command_spec)
3324 printf ("*link_command:\n%s\n\n", link_command_spec);
3325 exit (0);
3328 case OPT_dumpversion:
3329 printf ("%s\n", spec_version);
3330 exit (0);
3332 case OPT_dumpmachine:
3333 printf ("%s\n", spec_machine);
3334 exit (0);
3336 case OPT__version:
3337 print_version = 1;
3339 /* CPP driver cannot obtain switch from cc1_options. */
3340 if (is_cpp_driver)
3341 add_preprocessor_option ("--version", strlen ("--version"));
3342 add_assembler_option ("--version", strlen ("--version"));
3343 add_linker_option ("--version", strlen ("--version"));
3344 break;
3346 case OPT__help:
3347 print_help_list = 1;
3349 /* CPP driver cannot obtain switch from cc1_options. */
3350 if (is_cpp_driver)
3351 add_preprocessor_option ("--help", 6);
3352 add_assembler_option ("--help", 6);
3353 add_linker_option ("--help", 6);
3354 break;
3356 case OPT__help_:
3357 print_subprocess_help = 2;
3358 break;
3360 case OPT__target_help:
3361 print_subprocess_help = 1;
3363 /* CPP driver cannot obtain switch from cc1_options. */
3364 if (is_cpp_driver)
3365 add_preprocessor_option ("--target-help", 13);
3366 add_assembler_option ("--target-help", 13);
3367 add_linker_option ("--target-help", 13);
3368 break;
3370 case OPT__no_sysroot_suffix:
3371 case OPT_pass_exit_codes:
3372 case OPT_print_search_dirs:
3373 case OPT_print_file_name_:
3374 case OPT_print_prog_name_:
3375 case OPT_print_multi_lib:
3376 case OPT_print_multi_directory:
3377 case OPT_print_sysroot:
3378 case OPT_print_multi_os_directory:
3379 case OPT_print_multiarch:
3380 case OPT_print_sysroot_headers_suffix:
3381 case OPT_time:
3382 case OPT_wrapper:
3383 /* These options set the variables specified in common.opt
3384 automatically, and do not need to be saved for spec
3385 processing. */
3386 do_save = false;
3387 break;
3389 case OPT_print_libgcc_file_name:
3390 print_file_name = "libgcc.a";
3391 do_save = false;
3392 break;
3394 case OPT_fuse_ld_bfd:
3395 use_ld = ".bfd";
3396 break;
3398 case OPT_fuse_ld_gold:
3399 use_ld = ".gold";
3400 break;
3402 case OPT_fcompare_debug_second:
3403 compare_debug_second = 1;
3404 break;
3406 case OPT_fcompare_debug:
3407 switch (value)
3409 case 0:
3410 compare_debug_replacement_opt = "-fcompare-debug=";
3411 arg = "";
3412 goto compare_debug_with_arg;
3414 case 1:
3415 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3416 arg = "-gtoggle";
3417 goto compare_debug_with_arg;
3419 default:
3420 gcc_unreachable ();
3422 break;
3424 case OPT_fcompare_debug_:
3425 compare_debug_replacement_opt = decoded->canonical_option[0];
3426 compare_debug_with_arg:
3427 gcc_assert (decoded->canonical_option_num_elements == 1);
3428 gcc_assert (arg != NULL);
3429 if (*arg)
3430 compare_debug = 1;
3431 else
3432 compare_debug = -1;
3433 if (compare_debug < 0)
3434 compare_debug_opt = NULL;
3435 else
3436 compare_debug_opt = arg;
3437 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3438 return true;
3440 case OPT_Wa_:
3442 int prev, j;
3443 /* Pass the rest of this option to the assembler. */
3445 /* Split the argument at commas. */
3446 prev = 0;
3447 for (j = 0; arg[j]; j++)
3448 if (arg[j] == ',')
3450 add_assembler_option (arg + prev, j - prev);
3451 prev = j + 1;
3454 /* Record the part after the last comma. */
3455 add_assembler_option (arg + prev, j - prev);
3457 do_save = false;
3458 break;
3460 case OPT_Wp_:
3462 int prev, j;
3463 /* Pass the rest of this option to the preprocessor. */
3465 /* Split the argument at commas. */
3466 prev = 0;
3467 for (j = 0; arg[j]; j++)
3468 if (arg[j] == ',')
3470 add_preprocessor_option (arg + prev, j - prev);
3471 prev = j + 1;
3474 /* Record the part after the last comma. */
3475 add_preprocessor_option (arg + prev, j - prev);
3477 do_save = false;
3478 break;
3480 case OPT_Wl_:
3482 int prev, j;
3483 /* Split the argument at commas. */
3484 prev = 0;
3485 for (j = 0; arg[j]; j++)
3486 if (arg[j] == ',')
3488 add_infile (save_string (arg + prev, j - prev), "*");
3489 prev = j + 1;
3491 /* Record the part after the last comma. */
3492 add_infile (arg + prev, "*");
3494 do_save = false;
3495 break;
3497 case OPT_Xlinker:
3498 add_infile (arg, "*");
3499 do_save = false;
3500 break;
3502 case OPT_Xpreprocessor:
3503 add_preprocessor_option (arg, strlen (arg));
3504 do_save = false;
3505 break;
3507 case OPT_Xassembler:
3508 add_assembler_option (arg, strlen (arg));
3509 do_save = false;
3510 break;
3512 case OPT_l:
3513 /* POSIX allows separation of -l and the lib arg; canonicalize
3514 by concatenating -l with its arg */
3515 add_infile (concat ("-l", arg, NULL), "*");
3516 do_save = false;
3517 break;
3519 case OPT_L:
3520 /* Similarly, canonicalize -L for linkers that may not accept
3521 separate arguments. */
3522 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
3523 return true;
3525 case OPT_F:
3526 /* Likewise -F. */
3527 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
3528 return true;
3530 case OPT_save_temps:
3531 save_temps_flag = SAVE_TEMPS_CWD;
3532 validated = true;
3533 break;
3535 case OPT_save_temps_:
3536 if (strcmp (arg, "cwd") == 0)
3537 save_temps_flag = SAVE_TEMPS_CWD;
3538 else if (strcmp (arg, "obj") == 0
3539 || strcmp (arg, "object") == 0)
3540 save_temps_flag = SAVE_TEMPS_OBJ;
3541 else
3542 fatal_error ("%qs is an unknown -save-temps option",
3543 decoded->orig_option_with_args_text);
3544 break;
3546 case OPT_canonical_prefixes:
3547 case OPT_no_canonical_prefixes:
3548 /* Already handled as a special case, so ignored here. */
3549 do_save = false;
3550 break;
3552 case OPT_pipe:
3553 validated = true;
3554 /* These options set the variables specified in common.opt
3555 automatically, but do need to be saved for spec
3556 processing. */
3557 break;
3559 case OPT_specs_:
3561 struct user_specs *user = XNEW (struct user_specs);
3563 user->next = (struct user_specs *) 0;
3564 user->filename = arg;
3565 if (user_specs_tail)
3566 user_specs_tail->next = user;
3567 else
3568 user_specs_head = user;
3569 user_specs_tail = user;
3571 validated = true;
3572 break;
3574 case OPT__sysroot_:
3575 target_system_root = arg;
3576 target_system_root_changed = 1;
3577 do_save = false;
3578 break;
3580 case OPT_time_:
3581 if (report_times_to_file)
3582 fclose (report_times_to_file);
3583 report_times_to_file = fopen (arg, "a");
3584 do_save = false;
3585 break;
3587 case OPT____:
3588 /* "-###"
3589 This is similar to -v except that there is no execution
3590 of the commands and the echoed arguments are quoted. It
3591 is intended for use in shell scripts to capture the
3592 driver-generated command line. */
3593 verbose_only_flag++;
3594 verbose_flag = 1;
3595 do_save = false;
3596 break;
3598 case OPT_B:
3600 size_t len = strlen (arg);
3602 /* Catch the case where the user has forgotten to append a
3603 directory separator to the path. Note, they may be using
3604 -B to add an executable name prefix, eg "i386-elf-", in
3605 order to distinguish between multiple installations of
3606 GCC in the same directory. Hence we must check to see
3607 if appending a directory separator actually makes a
3608 valid directory name. */
3609 if (!IS_DIR_SEPARATOR (arg[len - 1])
3610 && is_directory (arg, false))
3612 char *tmp = XNEWVEC (char, len + 2);
3613 strcpy (tmp, arg);
3614 tmp[len] = DIR_SEPARATOR;
3615 tmp[++len] = 0;
3616 arg = tmp;
3619 add_prefix (&exec_prefixes, arg, NULL,
3620 PREFIX_PRIORITY_B_OPT, 0, 0);
3621 add_prefix (&startfile_prefixes, arg, NULL,
3622 PREFIX_PRIORITY_B_OPT, 0, 0);
3623 add_prefix (&include_prefixes, arg, NULL,
3624 PREFIX_PRIORITY_B_OPT, 0, 0);
3626 validated = true;
3627 break;
3629 case OPT_x:
3630 spec_lang = arg;
3631 if (!strcmp (spec_lang, "none"))
3632 /* Suppress the warning if -xnone comes after the last input
3633 file, because alternate command interfaces like g++ might
3634 find it useful to place -xnone after each input file. */
3635 spec_lang = 0;
3636 else
3637 last_language_n_infiles = n_infiles;
3638 do_save = false;
3639 break;
3641 case OPT_o:
3642 have_o = 1;
3643 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3644 arg = convert_filename (arg, ! have_c, 0);
3645 #endif
3646 /* Save the output name in case -save-temps=obj was used. */
3647 save_temps_prefix = xstrdup (arg);
3648 /* On some systems, ld cannot handle "-o" without a space. So
3649 split the option from its argument. */
3650 save_switch ("-o", 1, &arg, validated, true);
3651 return true;
3653 case OPT_static_libgcc:
3654 case OPT_shared_libgcc:
3655 case OPT_static_libgfortran:
3656 case OPT_static_libstdc__:
3657 /* These are always valid, since gcc.c itself understands the
3658 first two, gfortranspec.c understands -static-libgfortran and
3659 g++spec.c understands -static-libstdc++ */
3660 validated = true;
3661 break;
3663 case OPT_fwpa:
3664 flag_wpa = "";
3665 break;
3667 default:
3668 /* Various driver options need no special processing at this
3669 point, having been handled in a prescan above or being
3670 handled by specs. */
3671 break;
3674 if (do_save)
3675 save_switch (decoded->canonical_option[0],
3676 decoded->canonical_option_num_elements - 1,
3677 &decoded->canonical_option[1], validated, true);
3678 return true;
3681 /* Put the driver's standard set of option handlers in *HANDLERS. */
3683 static void
3684 set_option_handlers (struct cl_option_handlers *handlers)
3686 handlers->unknown_option_callback = driver_unknown_option_callback;
3687 handlers->wrong_lang_callback = driver_wrong_lang_callback;
3688 handlers->num_handlers = 3;
3689 handlers->handlers[0].handler = driver_handle_option;
3690 handlers->handlers[0].mask = CL_DRIVER;
3691 handlers->handlers[1].handler = common_handle_option;
3692 handlers->handlers[1].mask = CL_COMMON;
3693 handlers->handlers[2].handler = target_handle_option;
3694 handlers->handlers[2].mask = CL_TARGET;
3697 /* Create the vector `switches' and its contents.
3698 Store its length in `n_switches'. */
3700 static void
3701 process_command (unsigned int decoded_options_count,
3702 struct cl_decoded_option *decoded_options)
3704 const char *temp;
3705 char *temp1;
3706 char *tooldir_prefix, *tooldir_prefix2;
3707 char *(*get_relative_prefix) (const char *, const char *,
3708 const char *) = NULL;
3709 struct cl_option_handlers handlers;
3710 unsigned int j;
3712 gcc_exec_prefix = getenv ("GCC_EXEC_PREFIX");
3714 n_switches = 0;
3715 n_infiles = 0;
3716 added_libraries = 0;
3718 /* Figure compiler version from version string. */
3720 compiler_version = temp1 = xstrdup (version_string);
3722 for (; *temp1; ++temp1)
3724 if (*temp1 == ' ')
3726 *temp1 = '\0';
3727 break;
3731 /* Handle any -[no-]canonical-prefixes flags early, to assign the function
3732 that builds relative prefixes. This function creates default search
3733 paths that are needed later in normal option handling. */
3735 for (j = 1; j < decoded_options_count; j++)
3737 if (decoded_options[j].opt_index == OPT_canonical_prefixes)
3738 get_relative_prefix = make_relative_prefix;
3739 else if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
3740 get_relative_prefix = make_relative_prefix_ignore_links;
3742 if (! get_relative_prefix)
3744 #ifdef ENABLE_CANONICAL_PREFIXES
3745 get_relative_prefix = make_relative_prefix;
3746 #else
3747 get_relative_prefix = make_relative_prefix_ignore_links;
3748 #endif
3751 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3752 see if we can create it from the pathname specified in
3753 decoded_options[0].arg. */
3755 gcc_libexec_prefix = standard_libexec_prefix;
3756 #ifndef VMS
3757 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3758 if (!gcc_exec_prefix)
3760 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
3761 standard_bindir_prefix,
3762 standard_exec_prefix);
3763 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
3764 standard_bindir_prefix,
3765 standard_libexec_prefix);
3766 if (gcc_exec_prefix)
3767 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3769 else
3771 /* make_relative_prefix requires a program name, but
3772 GCC_EXEC_PREFIX is typically a directory name with a trailing
3773 / (which is ignored by make_relative_prefix), so append a
3774 program name. */
3775 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
3776 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
3777 standard_exec_prefix,
3778 standard_libexec_prefix);
3780 /* The path is unrelocated, so fallback to the original setting. */
3781 if (!gcc_libexec_prefix)
3782 gcc_libexec_prefix = standard_libexec_prefix;
3784 free (tmp_prefix);
3786 #else
3787 #endif
3788 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
3789 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
3790 or an automatically created GCC_EXEC_PREFIX from
3791 decoded_options[0].arg. */
3793 /* Do language-specific adjustment/addition of flags. */
3794 lang_specific_driver (&decoded_options, &decoded_options_count,
3795 &added_libraries);
3797 if (gcc_exec_prefix)
3799 int len = strlen (gcc_exec_prefix);
3801 if (len > (int) sizeof ("/lib/gcc/") - 1
3802 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3804 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3805 if (IS_DIR_SEPARATOR (*temp)
3806 && filename_ncmp (temp + 1, "lib", 3) == 0
3807 && IS_DIR_SEPARATOR (temp[4])
3808 && filename_ncmp (temp + 5, "gcc", 3) == 0)
3809 len -= sizeof ("/lib/gcc/") - 1;
3812 set_std_prefix (gcc_exec_prefix, len);
3813 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3814 PREFIX_PRIORITY_LAST, 0, 0);
3815 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3816 PREFIX_PRIORITY_LAST, 0, 0);
3819 /* COMPILER_PATH and LIBRARY_PATH have values
3820 that are lists of directory names with colons. */
3822 temp = getenv ("COMPILER_PATH");
3823 if (temp)
3825 const char *startp, *endp;
3826 char *nstore = (char *) alloca (strlen (temp) + 3);
3828 startp = endp = temp;
3829 while (1)
3831 if (*endp == PATH_SEPARATOR || *endp == 0)
3833 strncpy (nstore, startp, endp - startp);
3834 if (endp == startp)
3835 strcpy (nstore, concat (".", dir_separator_str, NULL));
3836 else if (!IS_DIR_SEPARATOR (endp[-1]))
3838 nstore[endp - startp] = DIR_SEPARATOR;
3839 nstore[endp - startp + 1] = 0;
3841 else
3842 nstore[endp - startp] = 0;
3843 add_prefix (&exec_prefixes, nstore, 0,
3844 PREFIX_PRIORITY_LAST, 0, 0);
3845 add_prefix (&include_prefixes, nstore, 0,
3846 PREFIX_PRIORITY_LAST, 0, 0);
3847 if (*endp == 0)
3848 break;
3849 endp = startp = endp + 1;
3851 else
3852 endp++;
3856 temp = getenv (LIBRARY_PATH_ENV);
3857 if (temp && *cross_compile == '0')
3859 const char *startp, *endp;
3860 char *nstore = (char *) alloca (strlen (temp) + 3);
3862 startp = endp = temp;
3863 while (1)
3865 if (*endp == PATH_SEPARATOR || *endp == 0)
3867 strncpy (nstore, startp, endp - startp);
3868 if (endp == startp)
3869 strcpy (nstore, concat (".", dir_separator_str, NULL));
3870 else if (!IS_DIR_SEPARATOR (endp[-1]))
3872 nstore[endp - startp] = DIR_SEPARATOR;
3873 nstore[endp - startp + 1] = 0;
3875 else
3876 nstore[endp - startp] = 0;
3877 add_prefix (&startfile_prefixes, nstore, NULL,
3878 PREFIX_PRIORITY_LAST, 0, 1);
3879 if (*endp == 0)
3880 break;
3881 endp = startp = endp + 1;
3883 else
3884 endp++;
3888 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3889 temp = getenv ("LPATH");
3890 if (temp && *cross_compile == '0')
3892 const char *startp, *endp;
3893 char *nstore = (char *) alloca (strlen (temp) + 3);
3895 startp = endp = temp;
3896 while (1)
3898 if (*endp == PATH_SEPARATOR || *endp == 0)
3900 strncpy (nstore, startp, endp - startp);
3901 if (endp == startp)
3902 strcpy (nstore, concat (".", dir_separator_str, NULL));
3903 else if (!IS_DIR_SEPARATOR (endp[-1]))
3905 nstore[endp - startp] = DIR_SEPARATOR;
3906 nstore[endp - startp + 1] = 0;
3908 else
3909 nstore[endp - startp] = 0;
3910 add_prefix (&startfile_prefixes, nstore, NULL,
3911 PREFIX_PRIORITY_LAST, 0, 1);
3912 if (*endp == 0)
3913 break;
3914 endp = startp = endp + 1;
3916 else
3917 endp++;
3921 /* Process the options and store input files and switches in their
3922 vectors. */
3924 last_language_n_infiles = -1;
3926 set_option_handlers (&handlers);
3928 for (j = 1; j < decoded_options_count; j++)
3930 switch (decoded_options[j].opt_index)
3932 case OPT_S:
3933 case OPT_c:
3934 case OPT_E:
3935 have_c = 1;
3936 break;
3938 if (have_c)
3939 break;
3942 for (j = 1; j < decoded_options_count; j++)
3944 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
3946 const char *arg = decoded_options[j].arg;
3947 const char *p = strrchr (arg, '@');
3948 char *fname;
3949 long offset;
3950 int consumed;
3951 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3952 arg = convert_filename (arg, 0, access (arg, F_OK));
3953 #endif
3954 /* For LTO static archive support we handle input file
3955 specifications that are composed of a filename and
3956 an offset like FNAME@OFFSET. */
3957 if (p
3958 && p != arg
3959 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
3960 && strlen (p) == (unsigned int)consumed)
3962 fname = (char *)xmalloc (p - arg + 1);
3963 memcpy (fname, arg, p - arg);
3964 fname[p - arg] = '\0';
3965 /* Only accept non-stdin and existing FNAME parts, otherwise
3966 try with the full name. */
3967 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
3969 free (fname);
3970 fname = xstrdup (arg);
3973 else
3974 fname = xstrdup (arg);
3976 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
3977 perror_with_name (fname);
3978 else
3979 add_infile (arg, spec_lang);
3981 free (fname);
3982 continue;
3985 read_cmdline_option (&global_options, &global_options_set,
3986 decoded_options + j, UNKNOWN_LOCATION,
3987 CL_DRIVER, &handlers, global_dc);
3990 /* If -save-temps=obj and -o name, create the prefix to use for %b.
3991 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
3992 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
3994 save_temps_length = strlen (save_temps_prefix);
3995 temp = strrchr (lbasename (save_temps_prefix), '.');
3996 if (temp)
3998 save_temps_length -= strlen (temp);
3999 save_temps_prefix[save_temps_length] = '\0';
4003 else if (save_temps_prefix != NULL)
4005 free (save_temps_prefix);
4006 save_temps_prefix = NULL;
4009 if (save_temps_flag && use_pipes)
4011 /* -save-temps overrides -pipe, so that temp files are produced */
4012 if (save_temps_flag)
4013 warning (0, "-pipe ignored because -save-temps specified");
4014 use_pipes = 0;
4017 if (!compare_debug)
4019 const char *gcd = getenv ("GCC_COMPARE_DEBUG");
4021 if (gcd && gcd[0] == '-')
4023 compare_debug = 2;
4024 compare_debug_opt = gcd;
4026 else if (gcd && *gcd && strcmp (gcd, "0"))
4028 compare_debug = 3;
4029 compare_debug_opt = "-gtoggle";
4032 else if (compare_debug < 0)
4034 compare_debug = 0;
4035 gcc_assert (!compare_debug_opt);
4038 /* Set up the search paths. We add directories that we expect to
4039 contain GNU Toolchain components before directories specified by
4040 the machine description so that we will find GNU components (like
4041 the GNU assembler) before those of the host system. */
4043 /* If we don't know where the toolchain has been installed, use the
4044 configured-in locations. */
4045 if (!gcc_exec_prefix)
4047 #ifndef OS2
4048 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
4049 PREFIX_PRIORITY_LAST, 1, 0);
4050 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
4051 PREFIX_PRIORITY_LAST, 2, 0);
4052 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
4053 PREFIX_PRIORITY_LAST, 2, 0);
4054 #endif
4055 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
4056 PREFIX_PRIORITY_LAST, 1, 0);
4059 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
4060 tooldir_prefix2 = concat (tooldir_base_prefix, spec_machine,
4061 dir_separator_str, NULL);
4063 /* Look for tools relative to the location from which the driver is
4064 running, or, if that is not available, the configured prefix. */
4065 tooldir_prefix
4066 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4067 spec_machine, dir_separator_str,
4068 spec_version, dir_separator_str, tooldir_prefix2, NULL);
4069 free (tooldir_prefix2);
4071 add_prefix (&exec_prefixes,
4072 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4073 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4074 add_prefix (&startfile_prefixes,
4075 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4076 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4077 free (tooldir_prefix);
4079 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4080 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4081 then consider it to relocate with the rest of the GCC installation
4082 if GCC_EXEC_PREFIX is set.
4083 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4084 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
4086 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
4087 standard_bindir_prefix,
4088 target_system_root);
4089 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4091 target_system_root = tmp_prefix;
4092 target_system_root_changed = 1;
4095 #endif
4097 /* More prefixes are enabled in main, after we read the specs file
4098 and determine whether this is cross-compilation or not. */
4100 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4101 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
4103 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
4104 environment variable. */
4105 if (compare_debug == 2 || compare_debug == 3)
4107 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
4108 save_switch (opt, 0, NULL, false, true);
4109 compare_debug = 1;
4112 /* Ensure we only invoke each subprocess once. */
4113 if (print_subprocess_help || print_help_list || print_version)
4115 n_infiles = 0;
4117 /* Create a dummy input file, so that we can pass
4118 the help option on to the various sub-processes. */
4119 add_infile ("help-dummy", "c");
4122 alloc_switch ();
4123 switches[n_switches].part1 = 0;
4124 alloc_infile ();
4125 infiles[n_infiles].name = 0;
4128 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4129 and place that in the environment. */
4131 static void
4132 set_collect_gcc_options (void)
4134 int i;
4135 int first_time;
4137 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4138 the compiler. */
4139 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4140 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4142 first_time = TRUE;
4143 for (i = 0; (int) i < n_switches; i++)
4145 const char *const *args;
4146 const char *p, *q;
4147 if (!first_time)
4148 obstack_grow (&collect_obstack, " ", 1);
4150 first_time = FALSE;
4152 /* Ignore elided switches. */
4153 if ((switches[i].live_cond
4154 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4155 == SWITCH_IGNORE)
4156 continue;
4158 obstack_grow (&collect_obstack, "'-", 2);
4159 q = switches[i].part1;
4160 while ((p = strchr (q, '\'')))
4162 obstack_grow (&collect_obstack, q, p - q);
4163 obstack_grow (&collect_obstack, "'\\''", 4);
4164 q = ++p;
4166 obstack_grow (&collect_obstack, q, strlen (q));
4167 obstack_grow (&collect_obstack, "'", 1);
4169 for (args = switches[i].args; args && *args; args++)
4171 obstack_grow (&collect_obstack, " '", 2);
4172 q = *args;
4173 while ((p = strchr (q, '\'')))
4175 obstack_grow (&collect_obstack, q, p - q);
4176 obstack_grow (&collect_obstack, "'\\''", 4);
4177 q = ++p;
4179 obstack_grow (&collect_obstack, q, strlen (q));
4180 obstack_grow (&collect_obstack, "'", 1);
4183 obstack_grow (&collect_obstack, "\0", 1);
4184 xputenv (XOBFINISH (&collect_obstack, char *));
4187 /* Process a spec string, accumulating and running commands. */
4189 /* These variables describe the input file name.
4190 input_file_number is the index on outfiles of this file,
4191 so that the output file name can be stored for later use by %o.
4192 input_basename is the start of the part of the input file
4193 sans all directory names, and basename_length is the number
4194 of characters starting there excluding the suffix .c or whatever. */
4196 static const char *gcc_input_filename;
4197 static int input_file_number;
4198 size_t input_filename_length;
4199 static int basename_length;
4200 static int suffixed_basename_length;
4201 static const char *input_basename;
4202 static const char *input_suffix;
4203 #ifndef HOST_LACKS_INODE_NUMBERS
4204 static struct stat input_stat;
4205 #endif
4206 static int input_stat_set;
4208 /* The compiler used to process the current input file. */
4209 static struct compiler *input_file_compiler;
4211 /* These are variables used within do_spec and do_spec_1. */
4213 /* Nonzero if an arg has been started and not yet terminated
4214 (with space, tab or newline). */
4215 static int arg_going;
4217 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4218 is a temporary file name. */
4219 static int delete_this_arg;
4221 /* Nonzero means %w has been seen; the next arg to be terminated
4222 is the output file name of this compilation. */
4223 static int this_is_output_file;
4225 /* Nonzero means %s has been seen; the next arg to be terminated
4226 is the name of a library file and we should try the standard
4227 search dirs for it. */
4228 static int this_is_library_file;
4230 /* Nonzero means %T has been seen; the next arg to be terminated
4231 is the name of a linker script and we should try all of the
4232 standard search dirs for it. If it is found insert a --script
4233 command line switch and then substitute the full path in place,
4234 otherwise generate an error message. */
4235 static int this_is_linker_script;
4237 /* Nonzero means that the input of this command is coming from a pipe. */
4238 static int input_from_pipe;
4240 /* Nonnull means substitute this for any suffix when outputting a switches
4241 arguments. */
4242 static const char *suffix_subst;
4244 /* If there is an argument being accumulated, terminate it and store it. */
4246 static void
4247 end_going_arg (void)
4249 if (arg_going)
4251 const char *string;
4253 obstack_1grow (&obstack, 0);
4254 string = XOBFINISH (&obstack, const char *);
4255 if (this_is_library_file)
4256 string = find_file (string);
4257 if (this_is_linker_script)
4259 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4261 if (full_script_path == NULL)
4263 error ("unable to locate default linker script %qs in the library search paths", string);
4264 /* Script was not found on search path. */
4265 return;
4267 store_arg ("--script", false, false);
4268 string = full_script_path;
4270 store_arg (string, delete_this_arg, this_is_output_file);
4271 if (this_is_output_file)
4272 outfiles[input_file_number] = string;
4273 arg_going = 0;
4278 /* Parse the WRAPPER string which is a comma separated list of the command line
4279 and insert them into the beginning of argbuf. */
4281 static void
4282 insert_wrapper (const char *wrapper)
4284 int n = 0;
4285 int i;
4286 char *buf = xstrdup (wrapper);
4287 char *p = buf;
4288 unsigned int old_length = argbuf.length ();
4292 n++;
4293 while (*p == ',')
4294 p++;
4296 while ((p = strchr (p, ',')) != NULL);
4298 argbuf.safe_grow (old_length + n);
4299 memmove (argbuf.address () + n,
4300 argbuf.address (),
4301 old_length * sizeof (const_char_p));
4303 i = 0;
4304 p = buf;
4307 while (*p == ',')
4309 *p = 0;
4310 p++;
4312 argbuf[i] = p;
4313 i++;
4315 while ((p = strchr (p, ',')) != NULL);
4316 gcc_assert (i == n);
4319 /* Process the spec SPEC and run the commands specified therein.
4320 Returns 0 if the spec is successfully processed; -1 if failed. */
4323 do_spec (const char *spec)
4325 int value;
4327 value = do_spec_2 (spec);
4329 /* Force out any unfinished command.
4330 If -pipe, this forces out the last command if it ended in `|'. */
4331 if (value == 0)
4333 if (argbuf.length () > 0
4334 && !strcmp (argbuf.last (), "|"))
4335 argbuf.pop ();
4337 set_collect_gcc_options ();
4339 if (argbuf.length () > 0)
4340 value = execute ();
4343 return value;
4346 static int
4347 do_spec_2 (const char *spec)
4349 int result;
4351 clear_args ();
4352 arg_going = 0;
4353 delete_this_arg = 0;
4354 this_is_output_file = 0;
4355 this_is_library_file = 0;
4356 this_is_linker_script = 0;
4357 input_from_pipe = 0;
4358 suffix_subst = NULL;
4360 result = do_spec_1 (spec, 0, NULL);
4362 end_going_arg ();
4364 return result;
4368 /* Process the given spec string and add any new options to the end
4369 of the switches/n_switches array. */
4371 static void
4372 do_option_spec (const char *name, const char *spec)
4374 unsigned int i, value_count, value_len;
4375 const char *p, *q, *value;
4376 char *tmp_spec, *tmp_spec_p;
4378 if (configure_default_options[0].name == NULL)
4379 return;
4381 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4382 if (strcmp (configure_default_options[i].name, name) == 0)
4383 break;
4384 if (i == ARRAY_SIZE (configure_default_options))
4385 return;
4387 value = configure_default_options[i].value;
4388 value_len = strlen (value);
4390 /* Compute the size of the final spec. */
4391 value_count = 0;
4392 p = spec;
4393 while ((p = strstr (p, "%(VALUE)")) != NULL)
4395 p ++;
4396 value_count ++;
4399 /* Replace each %(VALUE) by the specified value. */
4400 tmp_spec = (char *) alloca (strlen (spec) + 1
4401 + value_count * (value_len - strlen ("%(VALUE)")));
4402 tmp_spec_p = tmp_spec;
4403 q = spec;
4404 while ((p = strstr (q, "%(VALUE)")) != NULL)
4406 memcpy (tmp_spec_p, q, p - q);
4407 tmp_spec_p = tmp_spec_p + (p - q);
4408 memcpy (tmp_spec_p, value, value_len);
4409 tmp_spec_p += value_len;
4410 q = p + strlen ("%(VALUE)");
4412 strcpy (tmp_spec_p, q);
4414 do_self_spec (tmp_spec);
4417 /* Process the given spec string and add any new options to the end
4418 of the switches/n_switches array. */
4420 static void
4421 do_self_spec (const char *spec)
4423 int i;
4425 do_spec_2 (spec);
4426 do_spec_1 (" ", 0, NULL);
4428 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4429 do_self_specs adds the replacements to switches array, so it shouldn't
4430 be processed afterwards. */
4431 for (i = 0; i < n_switches; i++)
4432 if ((switches[i].live_cond & SWITCH_IGNORE))
4433 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4435 if (argbuf.length () > 0)
4437 const char **argbuf_copy;
4438 struct cl_decoded_option *decoded_options;
4439 struct cl_option_handlers handlers;
4440 unsigned int decoded_options_count;
4441 unsigned int j;
4443 /* Create a copy of argbuf with a dummy argv[0] entry for
4444 decode_cmdline_options_to_array. */
4445 argbuf_copy = XNEWVEC (const char *,
4446 argbuf.length () + 1);
4447 argbuf_copy[0] = "";
4448 memcpy (argbuf_copy + 1, argbuf.address (),
4449 argbuf.length () * sizeof (const char *));
4451 decode_cmdline_options_to_array (argbuf.length () + 1,
4452 argbuf_copy,
4453 CL_DRIVER, &decoded_options,
4454 &decoded_options_count);
4455 free (argbuf_copy);
4457 set_option_handlers (&handlers);
4459 for (j = 1; j < decoded_options_count; j++)
4461 switch (decoded_options[j].opt_index)
4463 case OPT_SPECIAL_input_file:
4464 /* Specs should only generate options, not input
4465 files. */
4466 if (strcmp (decoded_options[j].arg, "-") != 0)
4467 fatal_error ("switch %qs does not start with %<-%>",
4468 decoded_options[j].arg);
4469 else
4470 fatal_error ("spec-generated switch is just %<-%>");
4471 break;
4473 case OPT_fcompare_debug_second:
4474 case OPT_fcompare_debug:
4475 case OPT_fcompare_debug_:
4476 case OPT_o:
4477 /* Avoid duplicate processing of some options from
4478 compare-debug specs; just save them here. */
4479 save_switch (decoded_options[j].canonical_option[0],
4480 (decoded_options[j].canonical_option_num_elements
4481 - 1),
4482 &decoded_options[j].canonical_option[1], false, true);
4483 break;
4485 default:
4486 read_cmdline_option (&global_options, &global_options_set,
4487 decoded_options + j, UNKNOWN_LOCATION,
4488 CL_DRIVER, &handlers, global_dc);
4489 break;
4493 alloc_switch ();
4494 switches[n_switches].part1 = 0;
4498 /* Callback for processing %D and %I specs. */
4500 struct spec_path_info {
4501 const char *option;
4502 const char *append;
4503 size_t append_len;
4504 bool omit_relative;
4505 bool separate_options;
4508 static void *
4509 spec_path (char *path, void *data)
4511 struct spec_path_info *info = (struct spec_path_info *) data;
4512 size_t len = 0;
4513 char save = 0;
4515 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4516 return NULL;
4518 if (info->append_len != 0)
4520 len = strlen (path);
4521 memcpy (path + len, info->append, info->append_len + 1);
4524 if (!is_directory (path, true))
4525 return NULL;
4527 do_spec_1 (info->option, 1, NULL);
4528 if (info->separate_options)
4529 do_spec_1 (" ", 0, NULL);
4531 if (info->append_len == 0)
4533 len = strlen (path);
4534 save = path[len - 1];
4535 if (IS_DIR_SEPARATOR (path[len - 1]))
4536 path[len - 1] = '\0';
4539 do_spec_1 (path, 1, NULL);
4540 do_spec_1 (" ", 0, NULL);
4542 /* Must not damage the original path. */
4543 if (info->append_len == 0)
4544 path[len - 1] = save;
4546 return NULL;
4549 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
4550 argument list. */
4552 static void
4553 create_at_file (char **argv)
4555 char *temp_file = make_temp_file ("");
4556 char *at_argument = concat ("@", temp_file, NULL);
4557 FILE *f = fopen (temp_file, "w");
4558 int status;
4560 if (f == NULL)
4561 fatal_error ("could not open temporary response file %s",
4562 temp_file);
4564 status = writeargv (argv, f);
4566 if (status)
4567 fatal_error ("could not write to temporary response file %s",
4568 temp_file);
4570 status = fclose (f);
4572 if (EOF == status)
4573 fatal_error ("could not close temporary response file %s",
4574 temp_file);
4576 store_arg (at_argument, 0, 0);
4578 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
4581 /* True if we should compile INFILE. */
4583 static bool
4584 compile_input_file_p (struct infile *infile)
4586 if ((!infile->language) || (infile->language[0] != '*'))
4587 if (infile->incompiler == input_file_compiler)
4588 return true;
4589 return false;
4592 /* Process each member of VEC as a spec. */
4594 static void
4595 do_specs_vec (vec<char_p> vec)
4597 unsigned ix;
4598 char *opt;
4600 FOR_EACH_VEC_ELT (vec, ix, opt)
4602 do_spec_1 (opt, 1, NULL);
4603 /* Make each accumulated option a separate argument. */
4604 do_spec_1 (" ", 0, NULL);
4608 /* Process the sub-spec SPEC as a portion of a larger spec.
4609 This is like processing a whole spec except that we do
4610 not initialize at the beginning and we do not supply a
4611 newline by default at the end.
4612 INSWITCH nonzero means don't process %-sequences in SPEC;
4613 in this case, % is treated as an ordinary character.
4614 This is used while substituting switches.
4615 INSWITCH nonzero also causes SPC not to terminate an argument.
4617 Value is zero unless a line was finished
4618 and the command on that line reported an error. */
4620 static int
4621 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4623 const char *p = spec;
4624 int c;
4625 int i;
4626 int value;
4628 /* If it's an empty string argument to a switch, keep it as is. */
4629 if (inswitch && !*p)
4630 arg_going = 1;
4632 while ((c = *p++))
4633 /* If substituting a switch, treat all chars like letters.
4634 Otherwise, NL, SPC, TAB and % are special. */
4635 switch (inswitch ? 'a' : c)
4637 case '\n':
4638 end_going_arg ();
4640 if (argbuf.length () > 0
4641 && !strcmp (argbuf.last (), "|"))
4643 /* A `|' before the newline means use a pipe here,
4644 but only if -pipe was specified.
4645 Otherwise, execute now and don't pass the `|' as an arg. */
4646 if (use_pipes)
4648 input_from_pipe = 1;
4649 break;
4651 else
4652 argbuf.pop ();
4655 set_collect_gcc_options ();
4657 if (argbuf.length () > 0)
4659 value = execute ();
4660 if (value)
4661 return value;
4663 /* Reinitialize for a new command, and for a new argument. */
4664 clear_args ();
4665 arg_going = 0;
4666 delete_this_arg = 0;
4667 this_is_output_file = 0;
4668 this_is_library_file = 0;
4669 this_is_linker_script = 0;
4670 input_from_pipe = 0;
4671 break;
4673 case '|':
4674 end_going_arg ();
4676 /* Use pipe */
4677 obstack_1grow (&obstack, c);
4678 arg_going = 1;
4679 break;
4681 case '\t':
4682 case ' ':
4683 end_going_arg ();
4685 /* Reinitialize for a new argument. */
4686 delete_this_arg = 0;
4687 this_is_output_file = 0;
4688 this_is_library_file = 0;
4689 this_is_linker_script = 0;
4690 break;
4692 case '%':
4693 switch (c = *p++)
4695 case 0:
4696 fatal_error ("spec %qs invalid", spec);
4698 case 'b':
4699 if (save_temps_length)
4700 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4701 else
4702 obstack_grow (&obstack, input_basename, basename_length);
4703 if (compare_debug < 0)
4704 obstack_grow (&obstack, ".gk", 3);
4705 arg_going = 1;
4706 break;
4708 case 'B':
4709 if (save_temps_length)
4710 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4711 else
4712 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4713 if (compare_debug < 0)
4714 obstack_grow (&obstack, ".gk", 3);
4715 arg_going = 1;
4716 break;
4718 case 'd':
4719 delete_this_arg = 2;
4720 break;
4722 /* Dump out the directories specified with LIBRARY_PATH,
4723 followed by the absolute directories
4724 that we search for startfiles. */
4725 case 'D':
4727 struct spec_path_info info;
4729 info.option = "-L";
4730 info.append_len = 0;
4731 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4732 /* Used on systems which record the specified -L dirs
4733 and use them to search for dynamic linking.
4734 Relative directories always come from -B,
4735 and it is better not to use them for searching
4736 at run time. In particular, stage1 loses. */
4737 info.omit_relative = true;
4738 #else
4739 info.omit_relative = false;
4740 #endif
4741 info.separate_options = false;
4743 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
4745 break;
4747 case 'e':
4748 /* %efoo means report an error with `foo' as error message
4749 and don't execute any more commands for this file. */
4751 const char *q = p;
4752 char *buf;
4753 while (*p != 0 && *p != '\n')
4754 p++;
4755 buf = (char *) alloca (p - q + 1);
4756 strncpy (buf, q, p - q);
4757 buf[p - q] = 0;
4758 error ("%s", _(buf));
4759 return -1;
4761 break;
4762 case 'n':
4763 /* %nfoo means report a notice with `foo' on stderr. */
4765 const char *q = p;
4766 char *buf;
4767 while (*p != 0 && *p != '\n')
4768 p++;
4769 buf = (char *) alloca (p - q + 1);
4770 strncpy (buf, q, p - q);
4771 buf[p - q] = 0;
4772 inform (0, "%s", _(buf));
4773 if (*p)
4774 p++;
4776 break;
4778 case 'j':
4780 struct stat st;
4782 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4783 defined, and it is not a directory, and it is
4784 writable, use it. Otherwise, treat this like any
4785 other temporary file. */
4787 if ((!save_temps_flag)
4788 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4789 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4791 obstack_grow (&obstack, HOST_BIT_BUCKET,
4792 strlen (HOST_BIT_BUCKET));
4793 delete_this_arg = 0;
4794 arg_going = 1;
4795 break;
4798 goto create_temp_file;
4799 case '|':
4800 if (use_pipes)
4802 obstack_1grow (&obstack, '-');
4803 delete_this_arg = 0;
4804 arg_going = 1;
4806 /* consume suffix */
4807 while (*p == '.' || ISALNUM ((unsigned char) *p))
4808 p++;
4809 if (p[0] == '%' && p[1] == 'O')
4810 p += 2;
4812 break;
4814 goto create_temp_file;
4815 case 'm':
4816 if (use_pipes)
4818 /* consume suffix */
4819 while (*p == '.' || ISALNUM ((unsigned char) *p))
4820 p++;
4821 if (p[0] == '%' && p[1] == 'O')
4822 p += 2;
4824 break;
4826 goto create_temp_file;
4827 case 'g':
4828 case 'u':
4829 case 'U':
4830 create_temp_file:
4832 struct temp_name *t;
4833 int suffix_length;
4834 const char *suffix = p;
4835 char *saved_suffix = NULL;
4837 while (*p == '.' || ISALNUM ((unsigned char) *p))
4838 p++;
4839 suffix_length = p - suffix;
4840 if (p[0] == '%' && p[1] == 'O')
4842 p += 2;
4843 /* We don't support extra suffix characters after %O. */
4844 if (*p == '.' || ISALNUM ((unsigned char) *p))
4845 fatal_error ("spec %qs has invalid %<%%0%c%>", spec, *p);
4846 if (suffix_length == 0)
4847 suffix = TARGET_OBJECT_SUFFIX;
4848 else
4850 saved_suffix
4851 = XNEWVEC (char, suffix_length
4852 + strlen (TARGET_OBJECT_SUFFIX));
4853 strncpy (saved_suffix, suffix, suffix_length);
4854 strcpy (saved_suffix + suffix_length,
4855 TARGET_OBJECT_SUFFIX);
4857 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4860 if (compare_debug < 0)
4862 suffix = concat (".gk", suffix, NULL);
4863 suffix_length += 3;
4866 /* If -save-temps=obj and -o were specified, use that for the
4867 temp file. */
4868 if (save_temps_length)
4870 char *tmp;
4871 temp_filename_length
4872 = save_temps_length + suffix_length + 1;
4873 tmp = (char *) alloca (temp_filename_length);
4874 memcpy (tmp, save_temps_prefix, save_temps_length);
4875 memcpy (tmp + save_temps_length, suffix, suffix_length);
4876 tmp[save_temps_length + suffix_length] = '\0';
4877 temp_filename = save_string (tmp, save_temps_length
4878 + suffix_length);
4879 obstack_grow (&obstack, temp_filename,
4880 temp_filename_length);
4881 arg_going = 1;
4882 delete_this_arg = 0;
4883 break;
4886 /* If the gcc_input_filename has the same suffix specified
4887 for the %g, %u, or %U, and -save-temps is specified,
4888 we could end up using that file as an intermediate
4889 thus clobbering the user's source file (.e.g.,
4890 gcc -save-temps foo.s would clobber foo.s with the
4891 output of cpp0). So check for this condition and
4892 generate a temp file as the intermediate. */
4894 if (save_temps_flag)
4896 char *tmp;
4897 temp_filename_length = basename_length + suffix_length + 1;
4898 tmp = (char *) alloca (temp_filename_length);
4899 memcpy (tmp, input_basename, basename_length);
4900 memcpy (tmp + basename_length, suffix, suffix_length);
4901 tmp[basename_length + suffix_length] = '\0';
4902 temp_filename = tmp;
4904 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
4906 #ifndef HOST_LACKS_INODE_NUMBERS
4907 struct stat st_temp;
4909 /* Note, set_input() resets input_stat_set to 0. */
4910 if (input_stat_set == 0)
4912 input_stat_set = stat (gcc_input_filename,
4913 &input_stat);
4914 if (input_stat_set >= 0)
4915 input_stat_set = 1;
4918 /* If we have the stat for the gcc_input_filename
4919 and we can do the stat for the temp_filename
4920 then the they could still refer to the same
4921 file if st_dev/st_ino's are the same. */
4922 if (input_stat_set != 1
4923 || stat (temp_filename, &st_temp) < 0
4924 || input_stat.st_dev != st_temp.st_dev
4925 || input_stat.st_ino != st_temp.st_ino)
4926 #else
4927 /* Just compare canonical pathnames. */
4928 char* input_realname = lrealpath (gcc_input_filename);
4929 char* temp_realname = lrealpath (temp_filename);
4930 bool files_differ = filename_cmp (input_realname, temp_realname);
4931 free (input_realname);
4932 free (temp_realname);
4933 if (files_differ)
4934 #endif
4936 temp_filename = save_string (temp_filename,
4937 temp_filename_length + 1);
4938 obstack_grow (&obstack, temp_filename,
4939 temp_filename_length);
4940 arg_going = 1;
4941 delete_this_arg = 0;
4942 break;
4947 /* See if we already have an association of %g/%u/%U and
4948 suffix. */
4949 for (t = temp_names; t; t = t->next)
4950 if (t->length == suffix_length
4951 && strncmp (t->suffix, suffix, suffix_length) == 0
4952 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4953 break;
4955 /* Make a new association if needed. %u and %j
4956 require one. */
4957 if (t == 0 || c == 'u' || c == 'j')
4959 if (t == 0)
4961 t = XNEW (struct temp_name);
4962 t->next = temp_names;
4963 temp_names = t;
4965 t->length = suffix_length;
4966 if (saved_suffix)
4968 t->suffix = saved_suffix;
4969 saved_suffix = NULL;
4971 else
4972 t->suffix = save_string (suffix, suffix_length);
4973 t->unique = (c == 'u' || c == 'U' || c == 'j');
4974 temp_filename = make_temp_file (t->suffix);
4975 temp_filename_length = strlen (temp_filename);
4976 t->filename = temp_filename;
4977 t->filename_length = temp_filename_length;
4980 free (saved_suffix);
4982 obstack_grow (&obstack, t->filename, t->filename_length);
4983 delete_this_arg = 1;
4985 arg_going = 1;
4986 break;
4988 case 'i':
4989 if (combine_inputs)
4991 if (at_file_supplied)
4993 /* We are going to expand `%i' to `@FILE', where FILE
4994 is a newly-created temporary filename. The filenames
4995 that would usually be expanded in place of %o will be
4996 written to the temporary file. */
4997 char **argv;
4998 int n_files = 0;
4999 int j;
5001 for (i = 0; i < n_infiles; i++)
5002 if (compile_input_file_p (&infiles[i]))
5003 n_files++;
5005 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5007 /* Copy the strings over. */
5008 for (i = 0, j = 0; i < n_infiles; i++)
5009 if (compile_input_file_p (&infiles[i]))
5011 argv[j] = CONST_CAST (char *, infiles[i].name);
5012 infiles[i].compiled = true;
5013 j++;
5015 argv[j] = NULL;
5017 create_at_file (argv);
5019 else
5020 for (i = 0; (int) i < n_infiles; i++)
5021 if (compile_input_file_p (&infiles[i]))
5023 store_arg (infiles[i].name, 0, 0);
5024 infiles[i].compiled = true;
5027 else
5029 obstack_grow (&obstack, gcc_input_filename,
5030 input_filename_length);
5031 arg_going = 1;
5033 break;
5035 case 'I':
5037 struct spec_path_info info;
5039 if (multilib_dir)
5041 do_spec_1 ("-imultilib", 1, NULL);
5042 /* Make this a separate argument. */
5043 do_spec_1 (" ", 0, NULL);
5044 do_spec_1 (multilib_dir, 1, NULL);
5045 do_spec_1 (" ", 0, NULL);
5048 if (multiarch_dir)
5050 do_spec_1 ("-imultiarch", 1, NULL);
5051 /* Make this a separate argument. */
5052 do_spec_1 (" ", 0, NULL);
5053 do_spec_1 (multiarch_dir, 1, NULL);
5054 do_spec_1 (" ", 0, NULL);
5057 if (gcc_exec_prefix)
5059 do_spec_1 ("-iprefix", 1, NULL);
5060 /* Make this a separate argument. */
5061 do_spec_1 (" ", 0, NULL);
5062 do_spec_1 (gcc_exec_prefix, 1, NULL);
5063 do_spec_1 (" ", 0, NULL);
5066 if (target_system_root_changed ||
5067 (target_system_root && target_sysroot_hdrs_suffix))
5069 do_spec_1 ("-isysroot", 1, NULL);
5070 /* Make this a separate argument. */
5071 do_spec_1 (" ", 0, NULL);
5072 do_spec_1 (target_system_root, 1, NULL);
5073 if (target_sysroot_hdrs_suffix)
5074 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
5075 do_spec_1 (" ", 0, NULL);
5078 info.option = "-isystem";
5079 info.append = "include";
5080 info.append_len = strlen (info.append);
5081 info.omit_relative = false;
5082 info.separate_options = true;
5084 for_each_path (&include_prefixes, false, info.append_len,
5085 spec_path, &info);
5087 info.append = "include-fixed";
5088 if (*sysroot_hdrs_suffix_spec)
5089 info.append = concat (info.append, dir_separator_str,
5090 multilib_dir, NULL);
5091 info.append_len = strlen (info.append);
5092 for_each_path (&include_prefixes, false, info.append_len,
5093 spec_path, &info);
5095 break;
5097 case 'o':
5099 int max = n_infiles;
5100 max += lang_specific_extra_outfiles;
5102 if (HAVE_GNU_LD && at_file_supplied)
5104 /* We are going to expand `%o' to `@FILE', where FILE
5105 is a newly-created temporary filename. The filenames
5106 that would usually be expanded in place of %o will be
5107 written to the temporary file. */
5109 char **argv;
5110 int n_files, j;
5112 /* Convert OUTFILES into a form suitable for writeargv. */
5114 /* Determine how many are non-NULL. */
5115 for (n_files = 0, i = 0; i < max; i++)
5116 n_files += outfiles[i] != NULL;
5118 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5120 /* Copy the strings over. */
5121 for (i = 0, j = 0; i < max; i++)
5122 if (outfiles[i])
5124 argv[j] = CONST_CAST (char *, outfiles[i]);
5125 j++;
5127 argv[j] = NULL;
5129 create_at_file (argv);
5131 else
5132 for (i = 0; i < max; i++)
5133 if (outfiles[i])
5134 store_arg (outfiles[i], 0, 0);
5135 break;
5138 case 'O':
5139 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5140 arg_going = 1;
5141 break;
5143 case 's':
5144 this_is_library_file = 1;
5145 break;
5147 case 'T':
5148 this_is_linker_script = 1;
5149 break;
5151 case 'V':
5152 outfiles[input_file_number] = NULL;
5153 break;
5155 case 'w':
5156 this_is_output_file = 1;
5157 break;
5159 case 'W':
5161 unsigned int cur_index = argbuf.length ();
5162 /* Handle the {...} following the %W. */
5163 if (*p != '{')
5164 fatal_error ("spec %qs has invalid %<%%W%c%>", spec, *p);
5165 p = handle_braces (p + 1);
5166 if (p == 0)
5167 return -1;
5168 end_going_arg ();
5169 /* If any args were output, mark the last one for deletion
5170 on failure. */
5171 if (argbuf.length () != cur_index)
5172 record_temp_file (argbuf.last (), 0, 1);
5173 break;
5176 /* %x{OPTION} records OPTION for %X to output. */
5177 case 'x':
5179 const char *p1 = p;
5180 char *string;
5181 char *opt;
5182 unsigned ix;
5184 /* Skip past the option value and make a copy. */
5185 if (*p != '{')
5186 fatal_error ("spec %qs has invalid %<%%x%c%>", spec, *p);
5187 while (*p++ != '}')
5189 string = save_string (p1 + 1, p - p1 - 2);
5191 /* See if we already recorded this option. */
5192 FOR_EACH_VEC_ELT (linker_options, ix, opt)
5193 if (! strcmp (string, opt))
5195 free (string);
5196 return 0;
5199 /* This option is new; add it. */
5200 add_linker_option (string, strlen (string));
5201 free (string);
5203 break;
5205 /* Dump out the options accumulated previously using %x. */
5206 case 'X':
5207 do_specs_vec (linker_options);
5208 break;
5210 /* Dump out the options accumulated previously using -Wa,. */
5211 case 'Y':
5212 do_specs_vec (assembler_options);
5213 break;
5215 /* Dump out the options accumulated previously using -Wp,. */
5216 case 'Z':
5217 do_specs_vec (preprocessor_options);
5218 break;
5220 /* Here are digits and numbers that just process
5221 a certain constant string as a spec. */
5223 case '1':
5224 value = do_spec_1 (cc1_spec, 0, NULL);
5225 if (value != 0)
5226 return value;
5227 break;
5229 case '2':
5230 value = do_spec_1 (cc1plus_spec, 0, NULL);
5231 if (value != 0)
5232 return value;
5233 break;
5235 case 'a':
5236 value = do_spec_1 (asm_spec, 0, NULL);
5237 if (value != 0)
5238 return value;
5239 break;
5241 case 'A':
5242 value = do_spec_1 (asm_final_spec, 0, NULL);
5243 if (value != 0)
5244 return value;
5245 break;
5247 case 'C':
5249 const char *const spec
5250 = (input_file_compiler->cpp_spec
5251 ? input_file_compiler->cpp_spec
5252 : cpp_spec);
5253 value = do_spec_1 (spec, 0, NULL);
5254 if (value != 0)
5255 return value;
5257 break;
5259 case 'E':
5260 value = do_spec_1 (endfile_spec, 0, NULL);
5261 if (value != 0)
5262 return value;
5263 break;
5265 case 'l':
5266 value = do_spec_1 (link_spec, 0, NULL);
5267 if (value != 0)
5268 return value;
5269 break;
5271 case 'L':
5272 value = do_spec_1 (lib_spec, 0, NULL);
5273 if (value != 0)
5274 return value;
5275 break;
5277 case 'M':
5278 if (multilib_os_dir == NULL)
5279 obstack_1grow (&obstack, '.');
5280 else
5281 obstack_grow (&obstack, multilib_os_dir,
5282 strlen (multilib_os_dir));
5283 break;
5285 case 'G':
5286 value = do_spec_1 (libgcc_spec, 0, NULL);
5287 if (value != 0)
5288 return value;
5289 break;
5291 case 'R':
5292 /* We assume there is a directory
5293 separator at the end of this string. */
5294 if (target_system_root)
5296 obstack_grow (&obstack, target_system_root,
5297 strlen (target_system_root));
5298 if (target_sysroot_suffix)
5299 obstack_grow (&obstack, target_sysroot_suffix,
5300 strlen (target_sysroot_suffix));
5302 break;
5304 case 'S':
5305 value = do_spec_1 (startfile_spec, 0, NULL);
5306 if (value != 0)
5307 return value;
5308 break;
5310 /* Here we define characters other than letters and digits. */
5312 case '{':
5313 p = handle_braces (p);
5314 if (p == 0)
5315 return -1;
5316 break;
5318 case ':':
5319 p = handle_spec_function (p, NULL);
5320 if (p == 0)
5321 return -1;
5322 break;
5324 case '%':
5325 obstack_1grow (&obstack, '%');
5326 break;
5328 case '.':
5330 unsigned len = 0;
5332 while (p[len] && p[len] != ' ' && p[len] != '%')
5333 len++;
5334 suffix_subst = save_string (p - 1, len + 1);
5335 p += len;
5337 break;
5339 /* Henceforth ignore the option(s) matching the pattern
5340 after the %<. */
5341 case '<':
5342 case '>':
5344 unsigned len = 0;
5345 int have_wildcard = 0;
5346 int i;
5347 int switch_option;
5349 if (c == '>')
5350 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5351 else
5352 switch_option = SWITCH_IGNORE;
5354 while (p[len] && p[len] != ' ' && p[len] != '\t')
5355 len++;
5357 if (p[len-1] == '*')
5358 have_wildcard = 1;
5360 for (i = 0; i < n_switches; i++)
5361 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5362 && (have_wildcard || switches[i].part1[len] == '\0'))
5364 switches[i].live_cond |= switch_option;
5365 /* User switch be validated from validate_all_switches.
5366 when the definition is seen from the spec file.
5367 If not defined anywhere, will be rejected. */
5368 if (switches[i].known)
5369 switches[i].validated = true;
5372 p += len;
5374 break;
5376 case '*':
5377 if (soft_matched_part)
5379 if (soft_matched_part[0])
5380 do_spec_1 (soft_matched_part, 1, NULL);
5381 /* Only insert a space after the substitution if it is at the
5382 end of the current sequence. So if:
5384 "%{foo=*:bar%*}%{foo=*:one%*two}"
5386 matches -foo=hello then it will produce:
5388 barhello onehellotwo
5390 if (*p == 0 || *p == '}')
5391 do_spec_1 (" ", 0, NULL);
5393 else
5394 /* Catch the case where a spec string contains something like
5395 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5396 hand side of the :. */
5397 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5398 break;
5400 /* Process a string found as the value of a spec given by name.
5401 This feature allows individual machine descriptions
5402 to add and use their own specs. */
5403 case '(':
5405 const char *name = p;
5406 struct spec_list *sl;
5407 int len;
5409 /* The string after the S/P is the name of a spec that is to be
5410 processed. */
5411 while (*p && *p != ')')
5412 p++;
5414 /* See if it's in the list. */
5415 for (len = p - name, sl = specs; sl; sl = sl->next)
5416 if (sl->name_len == len && !strncmp (sl->name, name, len))
5418 name = *(sl->ptr_spec);
5419 #ifdef DEBUG_SPECS
5420 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5421 sl->name, name);
5422 #endif
5423 break;
5426 if (sl)
5428 value = do_spec_1 (name, 0, NULL);
5429 if (value != 0)
5430 return value;
5433 /* Discard the closing paren. */
5434 if (*p)
5435 p++;
5437 break;
5439 default:
5440 error ("spec failure: unrecognized spec option %qc", c);
5441 break;
5443 break;
5445 case '\\':
5446 /* Backslash: treat next character as ordinary. */
5447 c = *p++;
5449 /* Fall through. */
5450 default:
5451 /* Ordinary character: put it into the current argument. */
5452 obstack_1grow (&obstack, c);
5453 arg_going = 1;
5456 /* End of string. If we are processing a spec function, we need to
5457 end any pending argument. */
5458 if (processing_spec_function)
5459 end_going_arg ();
5461 return 0;
5464 /* Look up a spec function. */
5466 static const struct spec_function *
5467 lookup_spec_function (const char *name)
5469 const struct spec_function *sf;
5471 for (sf = static_spec_functions; sf->name != NULL; sf++)
5472 if (strcmp (sf->name, name) == 0)
5473 return sf;
5475 return NULL;
5478 /* Evaluate a spec function. */
5480 static const char *
5481 eval_spec_function (const char *func, const char *args)
5483 const struct spec_function *sf;
5484 const char *funcval;
5486 /* Saved spec processing context. */
5487 vec<const_char_p> save_argbuf;
5489 int save_arg_going;
5490 int save_delete_this_arg;
5491 int save_this_is_output_file;
5492 int save_this_is_library_file;
5493 int save_input_from_pipe;
5494 int save_this_is_linker_script;
5495 const char *save_suffix_subst;
5497 int save_growing_size;
5498 void *save_growing_value = NULL;
5500 sf = lookup_spec_function (func);
5501 if (sf == NULL)
5502 fatal_error ("unknown spec function %qs", func);
5504 /* Push the spec processing context. */
5505 save_argbuf = argbuf;
5507 save_arg_going = arg_going;
5508 save_delete_this_arg = delete_this_arg;
5509 save_this_is_output_file = this_is_output_file;
5510 save_this_is_library_file = this_is_library_file;
5511 save_this_is_linker_script = this_is_linker_script;
5512 save_input_from_pipe = input_from_pipe;
5513 save_suffix_subst = suffix_subst;
5515 /* If we have some object growing now, finalize it so the args and function
5516 eval proceed from a cleared context. This is needed to prevent the first
5517 constructed arg from mistakenly including the growing value. We'll push
5518 this value back on the obstack once the function evaluation is done, to
5519 restore a consistent processing context for our caller. This is fine as
5520 the address of growing objects isn't guaranteed to remain stable until
5521 they are finalized, and we expect this situation to be rare enough for
5522 the extra copy not to be an issue. */
5523 save_growing_size = obstack_object_size (&obstack);
5524 if (save_growing_size > 0)
5525 save_growing_value = obstack_finish (&obstack);
5527 /* Create a new spec processing context, and build the function
5528 arguments. */
5530 alloc_args ();
5531 if (do_spec_2 (args) < 0)
5532 fatal_error ("error in args to spec function %qs", func);
5534 /* argbuf_index is an index for the next argument to be inserted, and
5535 so contains the count of the args already inserted. */
5537 funcval = (*sf->func) (argbuf.length (),
5538 argbuf.address ());
5540 /* Pop the spec processing context. */
5541 argbuf.release ();
5542 argbuf = save_argbuf;
5544 arg_going = save_arg_going;
5545 delete_this_arg = save_delete_this_arg;
5546 this_is_output_file = save_this_is_output_file;
5547 this_is_library_file = save_this_is_library_file;
5548 this_is_linker_script = save_this_is_linker_script;
5549 input_from_pipe = save_input_from_pipe;
5550 suffix_subst = save_suffix_subst;
5552 if (save_growing_size > 0)
5553 obstack_grow (&obstack, save_growing_value, save_growing_size);
5555 return funcval;
5558 /* Handle a spec function call of the form:
5560 %:function(args)
5562 ARGS is processed as a spec in a separate context and split into an
5563 argument vector in the normal fashion. The function returns a string
5564 containing a spec which we then process in the caller's context, or
5565 NULL if no processing is required.
5567 If RETVAL_NONNULL is not NULL, then store a bool whether function
5568 returned non-NULL. */
5570 static const char *
5571 handle_spec_function (const char *p, bool *retval_nonnull)
5573 char *func, *args;
5574 const char *endp, *funcval;
5575 int count;
5577 processing_spec_function++;
5579 /* Get the function name. */
5580 for (endp = p; *endp != '\0'; endp++)
5582 if (*endp == '(') /* ) */
5583 break;
5584 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5585 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5586 fatal_error ("malformed spec function name");
5588 if (*endp != '(') /* ) */
5589 fatal_error ("no arguments for spec function");
5590 func = save_string (p, endp - p);
5591 p = ++endp;
5593 /* Get the arguments. */
5594 for (count = 0; *endp != '\0'; endp++)
5596 /* ( */
5597 if (*endp == ')')
5599 if (count == 0)
5600 break;
5601 count--;
5603 else if (*endp == '(') /* ) */
5604 count++;
5606 /* ( */
5607 if (*endp != ')')
5608 fatal_error ("malformed spec function arguments");
5609 args = save_string (p, endp - p);
5610 p = ++endp;
5612 /* p now points to just past the end of the spec function expression. */
5614 funcval = eval_spec_function (func, args);
5615 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5616 p = NULL;
5617 if (retval_nonnull)
5618 *retval_nonnull = funcval != NULL;
5620 free (func);
5621 free (args);
5623 processing_spec_function--;
5625 return p;
5628 /* Inline subroutine of handle_braces. Returns true if the current
5629 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5630 static inline bool
5631 input_suffix_matches (const char *atom, const char *end_atom)
5633 return (input_suffix
5634 && !strncmp (input_suffix, atom, end_atom - atom)
5635 && input_suffix[end_atom - atom] == '\0');
5638 /* Subroutine of handle_braces. Returns true if the current
5639 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
5640 static bool
5641 input_spec_matches (const char *atom, const char *end_atom)
5643 return (input_file_compiler
5644 && input_file_compiler->suffix
5645 && input_file_compiler->suffix[0] != '\0'
5646 && !strncmp (input_file_compiler->suffix + 1, atom,
5647 end_atom - atom)
5648 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
5651 /* Subroutine of handle_braces. Returns true if a switch
5652 matching the atom bracketed by ATOM and END_ATOM appeared on the
5653 command line. */
5654 static bool
5655 switch_matches (const char *atom, const char *end_atom, int starred)
5657 int i;
5658 int len = end_atom - atom;
5659 int plen = starred ? len : -1;
5661 for (i = 0; i < n_switches; i++)
5662 if (!strncmp (switches[i].part1, atom, len)
5663 && (starred || switches[i].part1[len] == '\0')
5664 && check_live_switch (i, plen))
5665 return true;
5667 /* Check if a switch with separated form matching the atom.
5668 We check -D and -U switches. */
5669 else if (switches[i].args != 0)
5671 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
5672 && *switches[i].part1 == atom[0])
5674 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
5675 && (starred || (switches[i].part1[1] == '\0'
5676 && switches[i].args[0][len - 1] == '\0'))
5677 && check_live_switch (i, (starred ? 1 : -1)))
5678 return true;
5682 return false;
5685 /* Inline subroutine of handle_braces. Mark all of the switches which
5686 match ATOM (extends to END_ATOM; STARRED indicates whether there
5687 was a star after the atom) for later processing. */
5688 static inline void
5689 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5691 int i;
5692 int len = end_atom - atom;
5693 int plen = starred ? len : -1;
5695 for (i = 0; i < n_switches; i++)
5696 if (!strncmp (switches[i].part1, atom, len)
5697 && (starred || switches[i].part1[len] == '\0')
5698 && check_live_switch (i, plen))
5699 switches[i].ordering = 1;
5702 /* Inline subroutine of handle_braces. Process all the currently
5703 marked switches through give_switch, and clear the marks. */
5704 static inline void
5705 process_marked_switches (void)
5707 int i;
5709 for (i = 0; i < n_switches; i++)
5710 if (switches[i].ordering == 1)
5712 switches[i].ordering = 0;
5713 give_switch (i, 0);
5717 /* Handle a %{ ... } construct. P points just inside the leading {.
5718 Returns a pointer one past the end of the brace block, or 0
5719 if we call do_spec_1 and that returns -1. */
5721 static const char *
5722 handle_braces (const char *p)
5724 const char *atom, *end_atom;
5725 const char *d_atom = NULL, *d_end_atom = NULL;
5726 const char *orig = p;
5728 bool a_is_suffix;
5729 bool a_is_spectype;
5730 bool a_is_starred;
5731 bool a_is_negated;
5732 bool a_matched;
5734 bool a_must_be_last = false;
5735 bool ordered_set = false;
5736 bool disjunct_set = false;
5737 bool disj_matched = false;
5738 bool disj_starred = true;
5739 bool n_way_choice = false;
5740 bool n_way_matched = false;
5742 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5746 if (a_must_be_last)
5747 goto invalid;
5749 /* Scan one "atom" (S in the description above of %{}, possibly
5750 with '!', '.', '@', ',', or '*' modifiers). */
5751 a_matched = false;
5752 a_is_suffix = false;
5753 a_is_starred = false;
5754 a_is_negated = false;
5755 a_is_spectype = false;
5757 SKIP_WHITE ();
5758 if (*p == '!')
5759 p++, a_is_negated = true;
5761 SKIP_WHITE ();
5762 if (*p == '%' && p[1] == ':')
5764 atom = NULL;
5765 end_atom = NULL;
5766 p = handle_spec_function (p + 2, &a_matched);
5768 else
5770 if (*p == '.')
5771 p++, a_is_suffix = true;
5772 else if (*p == ',')
5773 p++, a_is_spectype = true;
5775 atom = p;
5776 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
5777 || *p == ',' || *p == '.' || *p == '@')
5778 p++;
5779 end_atom = p;
5781 if (*p == '*')
5782 p++, a_is_starred = 1;
5785 SKIP_WHITE ();
5786 switch (*p)
5788 case '&': case '}':
5789 /* Substitute the switch(es) indicated by the current atom. */
5790 ordered_set = true;
5791 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5792 || a_is_spectype || atom == end_atom)
5793 goto invalid;
5795 mark_matching_switches (atom, end_atom, a_is_starred);
5797 if (*p == '}')
5798 process_marked_switches ();
5799 break;
5801 case '|': case ':':
5802 /* Substitute some text if the current atom appears as a switch
5803 or suffix. */
5804 disjunct_set = true;
5805 if (ordered_set)
5806 goto invalid;
5808 if (atom && atom == end_atom)
5810 if (!n_way_choice || disj_matched || *p == '|'
5811 || a_is_negated || a_is_suffix || a_is_spectype
5812 || a_is_starred)
5813 goto invalid;
5815 /* An empty term may appear as the last choice of an
5816 N-way choice set; it means "otherwise". */
5817 a_must_be_last = true;
5818 disj_matched = !n_way_matched;
5819 disj_starred = false;
5821 else
5823 if ((a_is_suffix || a_is_spectype) && a_is_starred)
5824 goto invalid;
5826 if (!a_is_starred)
5827 disj_starred = false;
5829 /* Don't bother testing this atom if we already have a
5830 match. */
5831 if (!disj_matched && !n_way_matched)
5833 if (atom == NULL)
5834 /* a_matched is already set by handle_spec_function. */;
5835 else if (a_is_suffix)
5836 a_matched = input_suffix_matches (atom, end_atom);
5837 else if (a_is_spectype)
5838 a_matched = input_spec_matches (atom, end_atom);
5839 else
5840 a_matched = switch_matches (atom, end_atom, a_is_starred);
5842 if (a_matched != a_is_negated)
5844 disj_matched = true;
5845 d_atom = atom;
5846 d_end_atom = end_atom;
5851 if (*p == ':')
5853 /* Found the body, that is, the text to substitute if the
5854 current disjunction matches. */
5855 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5856 disj_matched && !n_way_matched);
5857 if (p == 0)
5858 return 0;
5860 /* If we have an N-way choice, reset state for the next
5861 disjunction. */
5862 if (*p == ';')
5864 n_way_choice = true;
5865 n_way_matched |= disj_matched;
5866 disj_matched = false;
5867 disj_starred = true;
5868 d_atom = d_end_atom = NULL;
5871 break;
5873 default:
5874 goto invalid;
5877 while (*p++ != '}');
5879 return p;
5881 invalid:
5882 fatal_error ("braced spec %qs is invalid at %qc", orig, *p);
5884 #undef SKIP_WHITE
5887 /* Subroutine of handle_braces. Scan and process a brace substitution body
5888 (X in the description of %{} syntax). P points one past the colon;
5889 ATOM and END_ATOM bracket the first atom which was found to be true
5890 (present) in the current disjunction; STARRED indicates whether all
5891 the atoms in the current disjunction were starred (for syntax validation);
5892 MATCHED indicates whether the disjunction matched or not, and therefore
5893 whether or not the body is to be processed through do_spec_1 or just
5894 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5895 returns -1. */
5897 static const char *
5898 process_brace_body (const char *p, const char *atom, const char *end_atom,
5899 int starred, int matched)
5901 const char *body, *end_body;
5902 unsigned int nesting_level;
5903 bool have_subst = false;
5905 /* Locate the closing } or ;, honoring nested braces.
5906 Trim trailing whitespace. */
5907 body = p;
5908 nesting_level = 1;
5909 for (;;)
5911 if (*p == '{')
5912 nesting_level++;
5913 else if (*p == '}')
5915 if (!--nesting_level)
5916 break;
5918 else if (*p == ';' && nesting_level == 1)
5919 break;
5920 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5921 have_subst = true;
5922 else if (*p == '\0')
5923 goto invalid;
5924 p++;
5927 end_body = p;
5928 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5929 end_body--;
5931 if (have_subst && !starred)
5932 goto invalid;
5934 if (matched)
5936 /* Copy the substitution body to permanent storage and execute it.
5937 If have_subst is false, this is a simple matter of running the
5938 body through do_spec_1... */
5939 char *string = save_string (body, end_body - body);
5940 if (!have_subst)
5942 if (do_spec_1 (string, 0, NULL) < 0)
5943 return 0;
5945 else
5947 /* ... but if have_subst is true, we have to process the
5948 body once for each matching switch, with %* set to the
5949 variant part of the switch. */
5950 unsigned int hard_match_len = end_atom - atom;
5951 int i;
5953 for (i = 0; i < n_switches; i++)
5954 if (!strncmp (switches[i].part1, atom, hard_match_len)
5955 && check_live_switch (i, hard_match_len))
5957 if (do_spec_1 (string, 0,
5958 &switches[i].part1[hard_match_len]) < 0)
5959 return 0;
5960 /* Pass any arguments this switch has. */
5961 give_switch (i, 1);
5962 suffix_subst = NULL;
5967 return p;
5969 invalid:
5970 fatal_error ("braced spec body %qs is invalid", body);
5973 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5974 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5975 spec, or -1 if either exact match or %* is used.
5977 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
5978 whose value does not begin with "no-" is obsoleted by the same value
5979 with the "no-", similarly for a switch with the "no-" prefix. */
5981 static int
5982 check_live_switch (int switchnum, int prefix_length)
5984 const char *name = switches[switchnum].part1;
5985 int i;
5987 /* If we already processed this switch and determined if it was
5988 live or not, return our past determination. */
5989 if (switches[switchnum].live_cond != 0)
5990 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
5991 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
5992 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
5993 == 0);
5995 /* In the common case of {<at-most-one-letter>*}, a negating
5996 switch would always match, so ignore that case. We will just
5997 send the conflicting switches to the compiler phase. */
5998 if (prefix_length >= 0 && prefix_length <= 1)
5999 return 1;
6001 /* Now search for duplicate in a manner that depends on the name. */
6002 switch (*name)
6004 case 'O':
6005 for (i = switchnum + 1; i < n_switches; i++)
6006 if (switches[i].part1[0] == 'O')
6008 switches[switchnum].validated = true;
6009 switches[switchnum].live_cond = SWITCH_FALSE;
6010 return 0;
6012 break;
6014 case 'W': case 'f': case 'm': case 'g':
6015 if (! strncmp (name + 1, "no-", 3))
6017 /* We have Xno-YYY, search for XYYY. */
6018 for (i = switchnum + 1; i < n_switches; i++)
6019 if (switches[i].part1[0] == name[0]
6020 && ! strcmp (&switches[i].part1[1], &name[4]))
6022 /* --specs are validated with the validate_switches mechanism. */
6023 if (switches[switchnum].known)
6024 switches[switchnum].validated = true;
6025 switches[switchnum].live_cond = SWITCH_FALSE;
6026 return 0;
6029 else
6031 /* We have XYYY, search for Xno-YYY. */
6032 for (i = switchnum + 1; i < n_switches; i++)
6033 if (switches[i].part1[0] == name[0]
6034 && switches[i].part1[1] == 'n'
6035 && switches[i].part1[2] == 'o'
6036 && switches[i].part1[3] == '-'
6037 && !strcmp (&switches[i].part1[4], &name[1]))
6039 /* --specs are validated with the validate_switches mechanism. */
6040 if (switches[switchnum].known)
6041 switches[switchnum].validated = true;
6042 switches[switchnum].live_cond = SWITCH_FALSE;
6043 return 0;
6046 break;
6049 /* Otherwise the switch is live. */
6050 switches[switchnum].live_cond |= SWITCH_LIVE;
6051 return 1;
6054 /* Pass a switch to the current accumulating command
6055 in the same form that we received it.
6056 SWITCHNUM identifies the switch; it is an index into
6057 the vector of switches gcc received, which is `switches'.
6058 This cannot fail since it never finishes a command line.
6060 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
6062 static void
6063 give_switch (int switchnum, int omit_first_word)
6065 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
6066 return;
6068 if (!omit_first_word)
6070 do_spec_1 ("-", 0, NULL);
6071 do_spec_1 (switches[switchnum].part1, 1, NULL);
6074 if (switches[switchnum].args != 0)
6076 const char **p;
6077 for (p = switches[switchnum].args; *p; p++)
6079 const char *arg = *p;
6081 do_spec_1 (" ", 0, NULL);
6082 if (suffix_subst)
6084 unsigned length = strlen (arg);
6085 int dot = 0;
6087 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
6088 if (arg[length] == '.')
6090 (CONST_CAST (char *, arg))[length] = 0;
6091 dot = 1;
6092 break;
6094 do_spec_1 (arg, 1, NULL);
6095 if (dot)
6096 (CONST_CAST (char *, arg))[length] = '.';
6097 do_spec_1 (suffix_subst, 1, NULL);
6099 else
6100 do_spec_1 (arg, 1, NULL);
6104 do_spec_1 (" ", 0, NULL);
6105 switches[switchnum].validated = true;
6108 /* Search for a file named NAME trying various prefixes including the
6109 user's -B prefix and some standard ones.
6110 Return the absolute file name found. If nothing is found, return NAME. */
6112 static const char *
6113 find_file (const char *name)
6115 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
6116 return newname ? newname : name;
6119 /* Determine whether a directory exists. If LINKER, return 0 for
6120 certain fixed names not needed by the linker. */
6122 static int
6123 is_directory (const char *path1, bool linker)
6125 int len1;
6126 char *path;
6127 char *cp;
6128 struct stat st;
6130 /* Ensure the string ends with "/.". The resulting path will be a
6131 directory even if the given path is a symbolic link. */
6132 len1 = strlen (path1);
6133 path = (char *) alloca (3 + len1);
6134 memcpy (path, path1, len1);
6135 cp = path + len1;
6136 if (!IS_DIR_SEPARATOR (cp[-1]))
6137 *cp++ = DIR_SEPARATOR;
6138 *cp++ = '.';
6139 *cp = '\0';
6141 /* Exclude directories that the linker is known to search. */
6142 if (linker
6143 && IS_DIR_SEPARATOR (path[0])
6144 && ((cp - path == 6
6145 && filename_ncmp (path + 1, "lib", 3) == 0)
6146 || (cp - path == 10
6147 && filename_ncmp (path + 1, "usr", 3) == 0
6148 && IS_DIR_SEPARATOR (path[4])
6149 && filename_ncmp (path + 5, "lib", 3) == 0)))
6150 return 0;
6152 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
6155 /* Set up the various global variables to indicate that we're processing
6156 the input file named FILENAME. */
6158 void
6159 set_input (const char *filename)
6161 const char *p;
6163 gcc_input_filename = filename;
6164 input_filename_length = strlen (gcc_input_filename);
6165 input_basename = lbasename (gcc_input_filename);
6167 /* Find a suffix starting with the last period,
6168 and set basename_length to exclude that suffix. */
6169 basename_length = strlen (input_basename);
6170 suffixed_basename_length = basename_length;
6171 p = input_basename + basename_length;
6172 while (p != input_basename && *p != '.')
6173 --p;
6174 if (*p == '.' && p != input_basename)
6176 basename_length = p - input_basename;
6177 input_suffix = p + 1;
6179 else
6180 input_suffix = "";
6182 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6183 we will need to do a stat on the gcc_input_filename. The
6184 INPUT_STAT_SET signals that the stat is needed. */
6185 input_stat_set = 0;
6188 /* On fatal signals, delete all the temporary files. */
6190 static void
6191 fatal_signal (int signum)
6193 signal (signum, SIG_DFL);
6194 delete_failure_queue ();
6195 delete_temp_files ();
6196 /* Get the same signal again, this time not handled,
6197 so its normal effect occurs. */
6198 kill (getpid (), signum);
6201 /* Compare the contents of the two files named CMPFILE[0] and
6202 CMPFILE[1]. Return zero if they're identical, nonzero
6203 otherwise. */
6205 static int
6206 compare_files (char *cmpfile[])
6208 int ret = 0;
6209 FILE *temp[2] = { NULL, NULL };
6210 int i;
6212 #if HAVE_MMAP_FILE
6214 size_t length[2];
6215 void *map[2] = { NULL, NULL };
6217 for (i = 0; i < 2; i++)
6219 struct stat st;
6221 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
6223 error ("%s: could not determine length of compare-debug file %s",
6224 gcc_input_filename, cmpfile[i]);
6225 ret = 1;
6226 break;
6229 length[i] = st.st_size;
6232 if (!ret && length[0] != length[1])
6234 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
6235 ret = 1;
6238 if (!ret)
6239 for (i = 0; i < 2; i++)
6241 int fd = open (cmpfile[i], O_RDONLY);
6242 if (fd < 0)
6244 error ("%s: could not open compare-debug file %s",
6245 gcc_input_filename, cmpfile[i]);
6246 ret = 1;
6247 break;
6250 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
6251 close (fd);
6253 if (map[i] == (void *) MAP_FAILED)
6255 ret = -1;
6256 break;
6260 if (!ret)
6262 if (memcmp (map[0], map[1], length[0]) != 0)
6264 error ("%s: -fcompare-debug failure", gcc_input_filename);
6265 ret = 1;
6269 for (i = 0; i < 2; i++)
6270 if (map[i])
6271 munmap ((caddr_t) map[i], length[i]);
6273 if (ret >= 0)
6274 return ret;
6276 ret = 0;
6278 #endif
6280 for (i = 0; i < 2; i++)
6282 temp[i] = fopen (cmpfile[i], "r");
6283 if (!temp[i])
6285 error ("%s: could not open compare-debug file %s",
6286 gcc_input_filename, cmpfile[i]);
6287 ret = 1;
6288 break;
6292 if (!ret && temp[0] && temp[1])
6293 for (;;)
6295 int c0, c1;
6296 c0 = fgetc (temp[0]);
6297 c1 = fgetc (temp[1]);
6299 if (c0 != c1)
6301 error ("%s: -fcompare-debug failure",
6302 gcc_input_filename);
6303 ret = 1;
6304 break;
6307 if (c0 == EOF)
6308 break;
6311 for (i = 1; i >= 0; i--)
6313 if (temp[i])
6314 fclose (temp[i]);
6317 return ret;
6320 extern int main (int, char **);
6323 main (int argc, char **argv)
6325 size_t i;
6326 int value;
6327 int linker_was_run = 0;
6328 int lang_n_infiles = 0;
6329 int num_linker_inputs = 0;
6330 char *explicit_link_files;
6331 char *specs_file;
6332 char *lto_wrapper_file;
6333 const char *p;
6334 struct user_specs *uptr;
6335 char **old_argv = argv;
6336 struct cl_decoded_option *decoded_options;
6337 unsigned int decoded_options_count;
6339 p = argv[0] + strlen (argv[0]);
6340 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
6341 --p;
6342 progname = p;
6344 xmalloc_set_program_name (progname);
6346 expandargv (&argc, &argv);
6348 /* Determine if any expansions were made. */
6349 if (argv != old_argv)
6350 at_file_supplied = true;
6352 /* Register the language-independent parameters. */
6353 global_init_params ();
6354 finish_params ();
6356 init_options_struct (&global_options, &global_options_set);
6358 decode_cmdline_options_to_array (argc, CONST_CAST2 (const char **, char **,
6359 argv),
6360 CL_DRIVER,
6361 &decoded_options, &decoded_options_count);
6363 /* Unlock the stdio streams. */
6364 unlock_std_streams ();
6366 gcc_init_libintl ();
6368 diagnostic_initialize (global_dc, 0);
6370 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6371 /* Perform host dependent initialization when needed. */
6372 GCC_DRIVER_HOST_INITIALIZATION;
6373 #endif
6375 if (atexit (delete_temp_files) != 0)
6376 fatal_error ("atexit failed");
6378 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6379 signal (SIGINT, fatal_signal);
6380 #ifdef SIGHUP
6381 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6382 signal (SIGHUP, fatal_signal);
6383 #endif
6384 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6385 signal (SIGTERM, fatal_signal);
6386 #ifdef SIGPIPE
6387 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6388 signal (SIGPIPE, fatal_signal);
6389 #endif
6390 #ifdef SIGCHLD
6391 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6392 receive the signal. A different setting is inheritable */
6393 signal (SIGCHLD, SIG_DFL);
6394 #endif
6396 /* Parsing and gimplification sometimes need quite large stack.
6397 Increase stack size limits if possible. */
6398 stack_limit_increase (64 * 1024 * 1024);
6400 /* Allocate the argument vector. */
6401 alloc_args ();
6403 obstack_init (&obstack);
6405 /* Build multilib_select, et. al from the separate lines that make up each
6406 multilib selection. */
6408 const char *const *q = multilib_raw;
6409 int need_space;
6411 obstack_init (&multilib_obstack);
6412 while ((p = *q++) != (char *) 0)
6413 obstack_grow (&multilib_obstack, p, strlen (p));
6415 obstack_1grow (&multilib_obstack, 0);
6416 multilib_select = XOBFINISH (&multilib_obstack, const char *);
6418 q = multilib_matches_raw;
6419 while ((p = *q++) != (char *) 0)
6420 obstack_grow (&multilib_obstack, p, strlen (p));
6422 obstack_1grow (&multilib_obstack, 0);
6423 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
6425 q = multilib_exclusions_raw;
6426 while ((p = *q++) != (char *) 0)
6427 obstack_grow (&multilib_obstack, p, strlen (p));
6429 obstack_1grow (&multilib_obstack, 0);
6430 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
6432 q = multilib_reuse_raw;
6433 while ((p = *q++) != (char *) 0)
6434 obstack_grow (&multilib_obstack, p, strlen (p));
6436 obstack_1grow (&multilib_obstack, 0);
6437 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
6439 need_space = FALSE;
6440 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6442 if (need_space)
6443 obstack_1grow (&multilib_obstack, ' ');
6444 obstack_grow (&multilib_obstack,
6445 multilib_defaults_raw[i],
6446 strlen (multilib_defaults_raw[i]));
6447 need_space = TRUE;
6450 obstack_1grow (&multilib_obstack, 0);
6451 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
6454 #ifdef INIT_ENVIRONMENT
6455 /* Set up any other necessary machine specific environment variables. */
6456 xputenv (INIT_ENVIRONMENT);
6457 #endif
6459 /* Make a table of what switches there are (switches, n_switches).
6460 Make a table of specified input files (infiles, n_infiles).
6461 Decode switches that are handled locally. */
6463 process_command (decoded_options_count, decoded_options);
6465 /* Initialize the vector of specs to just the default.
6466 This means one element containing 0s, as a terminator. */
6468 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
6469 memcpy (compilers, default_compilers, sizeof default_compilers);
6470 n_compilers = n_default_compilers;
6472 /* Read specs from a file if there is one. */
6474 machine_suffix = concat (spec_machine, dir_separator_str,
6475 spec_version, dir_separator_str, NULL);
6476 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6478 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
6479 /* Read the specs file unless it is a default one. */
6480 if (specs_file != 0 && strcmp (specs_file, "specs"))
6481 read_specs (specs_file, true, false);
6482 else
6483 init_spec ();
6485 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6486 for any override of as, ld and libraries. */
6487 specs_file = (char *) alloca (strlen (standard_exec_prefix)
6488 + strlen (just_machine_suffix) + sizeof ("specs"));
6490 strcpy (specs_file, standard_exec_prefix);
6491 strcat (specs_file, just_machine_suffix);
6492 strcat (specs_file, "specs");
6493 if (access (specs_file, R_OK) == 0)
6494 read_specs (specs_file, true, false);
6496 /* Process any configure-time defaults specified for the command line
6497 options, via OPTION_DEFAULT_SPECS. */
6498 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6499 do_option_spec (option_default_specs[i].name,
6500 option_default_specs[i].spec);
6502 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6503 of the command line. */
6505 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6506 do_self_spec (driver_self_specs[i]);
6508 /* If not cross-compiling, look for executables in the standard
6509 places. */
6510 if (*cross_compile == '0')
6512 if (*md_exec_prefix)
6514 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6515 PREFIX_PRIORITY_LAST, 0, 0);
6519 /* Process sysroot_suffix_spec. */
6520 if (*sysroot_suffix_spec != 0
6521 && !no_sysroot_suffix
6522 && do_spec_2 (sysroot_suffix_spec) == 0)
6524 if (argbuf.length () > 1)
6525 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
6526 else if (argbuf.length () == 1)
6527 target_sysroot_suffix = xstrdup (argbuf.last ());
6530 #ifdef HAVE_LD_SYSROOT
6531 /* Pass the --sysroot option to the linker, if it supports that. If
6532 there is a sysroot_suffix_spec, it has already been processed by
6533 this point, so target_system_root really is the system root we
6534 should be using. */
6535 if (target_system_root)
6537 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
6538 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
6539 set_spec ("link", XOBFINISH (&obstack, const char *), false);
6541 #endif
6543 /* Process sysroot_hdrs_suffix_spec. */
6544 if (*sysroot_hdrs_suffix_spec != 0
6545 && !no_sysroot_suffix
6546 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6548 if (argbuf.length () > 1)
6549 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
6550 else if (argbuf.length () == 1)
6551 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
6554 /* Look for startfiles in the standard places. */
6555 if (*startfile_prefix_spec != 0
6556 && do_spec_2 (startfile_prefix_spec) == 0
6557 && do_spec_1 (" ", 0, NULL) == 0)
6559 const char *arg;
6560 int ndx;
6561 FOR_EACH_VEC_ELT (argbuf, ndx, arg)
6562 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
6563 PREFIX_PRIORITY_LAST, 0, 1);
6565 /* We should eventually get rid of all these and stick to
6566 startfile_prefix_spec exclusively. */
6567 else if (*cross_compile == '0' || target_system_root)
6569 if (*md_startfile_prefix)
6570 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6571 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6573 if (*md_startfile_prefix_1)
6574 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6575 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6577 /* If standard_startfile_prefix is relative, base it on
6578 standard_exec_prefix. This lets us move the installed tree
6579 as a unit. If GCC_EXEC_PREFIX is defined, base
6580 standard_startfile_prefix on that as well.
6582 If the prefix is relative, only search it for native compilers;
6583 otherwise we will search a directory containing host libraries. */
6584 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6585 add_sysrooted_prefix (&startfile_prefixes,
6586 standard_startfile_prefix, "BINUTILS",
6587 PREFIX_PRIORITY_LAST, 0, 1);
6588 else if (*cross_compile == '0')
6590 add_prefix (&startfile_prefixes,
6591 concat (gcc_exec_prefix
6592 ? gcc_exec_prefix : standard_exec_prefix,
6593 machine_suffix,
6594 standard_startfile_prefix, NULL),
6595 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6598 /* Sysrooted prefixes are relocated because target_system_root is
6599 also relocated by gcc_exec_prefix. */
6600 if (*standard_startfile_prefix_1)
6601 add_sysrooted_prefix (&startfile_prefixes,
6602 standard_startfile_prefix_1, "BINUTILS",
6603 PREFIX_PRIORITY_LAST, 0, 1);
6604 if (*standard_startfile_prefix_2)
6605 add_sysrooted_prefix (&startfile_prefixes,
6606 standard_startfile_prefix_2, "BINUTILS",
6607 PREFIX_PRIORITY_LAST, 0, 1);
6610 /* Process any user specified specs in the order given on the command
6611 line. */
6612 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6614 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6615 R_OK, true);
6616 read_specs (filename ? filename : uptr->filename, false, true);
6619 /* Process any user self specs. */
6621 struct spec_list *sl;
6622 for (sl = specs; sl; sl = sl->next)
6623 if (sl->name_len == sizeof "self_spec" - 1
6624 && !strcmp (sl->name, "self_spec"))
6625 do_self_spec (*sl->ptr_spec);
6628 if (compare_debug)
6630 enum save_temps save;
6632 if (!compare_debug_second)
6634 n_switches_debug_check[1] = n_switches;
6635 n_switches_alloc_debug_check[1] = n_switches_alloc;
6636 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
6637 n_switches_alloc);
6639 do_self_spec ("%:compare-debug-self-opt()");
6640 n_switches_debug_check[0] = n_switches;
6641 n_switches_alloc_debug_check[0] = n_switches_alloc;
6642 switches_debug_check[0] = switches;
6644 n_switches = n_switches_debug_check[1];
6645 n_switches_alloc = n_switches_alloc_debug_check[1];
6646 switches = switches_debug_check[1];
6649 /* Avoid crash when computing %j in this early. */
6650 save = save_temps_flag;
6651 save_temps_flag = SAVE_TEMPS_NONE;
6653 compare_debug = -compare_debug;
6654 do_self_spec ("%:compare-debug-self-opt()");
6656 save_temps_flag = save;
6658 if (!compare_debug_second)
6660 n_switches_debug_check[1] = n_switches;
6661 n_switches_alloc_debug_check[1] = n_switches_alloc;
6662 switches_debug_check[1] = switches;
6663 compare_debug = -compare_debug;
6664 n_switches = n_switches_debug_check[0];
6665 n_switches_alloc = n_switches_debug_check[0];
6666 switches = switches_debug_check[0];
6671 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6672 if (gcc_exec_prefix)
6673 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6674 spec_version, dir_separator_str, NULL);
6676 /* Now we have the specs.
6677 Set the `valid' bits for switches that match anything in any spec. */
6679 validate_all_switches ();
6681 /* Now that we have the switches and the specs, set
6682 the subdirectory based on the options. */
6683 set_multilib_dir ();
6685 /* Set up to remember the pathname of gcc and any options
6686 needed for collect. We use argv[0] instead of progname because
6687 we need the complete pathname. */
6688 obstack_init (&collect_obstack);
6689 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
6690 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
6691 xputenv (XOBFINISH (&collect_obstack, char *));
6693 /* Set up to remember the pathname of the lto wrapper. */
6695 if (have_c)
6696 lto_wrapper_file = NULL;
6697 else
6698 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
6699 X_OK, false);
6700 if (lto_wrapper_file)
6702 lto_wrapper_file = convert_white_space (lto_wrapper_file);
6703 lto_wrapper_spec = lto_wrapper_file;
6704 obstack_init (&collect_obstack);
6705 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
6706 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
6707 obstack_grow (&collect_obstack, lto_wrapper_spec,
6708 strlen (lto_wrapper_spec) + 1);
6709 xputenv (XOBFINISH (&collect_obstack, char *));
6712 /* Reject switches that no pass was interested in. */
6714 for (i = 0; (int) i < n_switches; i++)
6715 if (! switches[i].validated)
6716 error ("unrecognized command line option %<-%s%>", switches[i].part1);
6718 /* Obey some of the options. */
6720 if (print_search_dirs)
6722 printf (_("install: %s%s\n"),
6723 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
6724 gcc_exec_prefix ? "" : machine_suffix);
6725 printf (_("programs: %s\n"),
6726 build_search_list (&exec_prefixes, "", false, false));
6727 printf (_("libraries: %s\n"),
6728 build_search_list (&startfile_prefixes, "", false, true));
6729 return (0);
6732 if (print_file_name)
6734 printf ("%s\n", find_file (print_file_name));
6735 return (0);
6738 if (print_prog_name)
6740 if (use_ld != NULL && ! strcmp (print_prog_name, "ld"))
6742 /* Append USE_LD to to the default linker. */
6743 #ifdef DEFAULT_LINKER
6744 char *ld;
6745 # ifdef HAVE_HOST_EXECUTABLE_SUFFIX
6746 int len = (sizeof (DEFAULT_LINKER)
6747 - sizeof (HOST_EXECUTABLE_SUFFIX));
6748 ld = NULL;
6749 if (len > 0)
6751 char *default_linker = xstrdup (DEFAULT_LINKER);
6752 /* Strip HOST_EXECUTABLE_SUFFIX if DEFAULT_LINKER contains
6753 HOST_EXECUTABLE_SUFFIX. */
6754 if (! strcmp (&default_linker[len], HOST_EXECUTABLE_SUFFIX))
6756 default_linker[len] = '\0';
6757 ld = concat (default_linker, use_ld,
6758 HOST_EXECUTABLE_SUFFIX, NULL);
6761 if (ld == NULL)
6762 # endif
6763 ld = concat (DEFAULT_LINKER, use_ld, NULL);
6764 if (access (ld, X_OK) == 0)
6766 printf ("%s\n", ld);
6767 return (0);
6769 #endif
6770 print_prog_name = concat (print_prog_name, use_ld, NULL);
6772 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6773 printf ("%s\n", (newname ? newname : print_prog_name));
6774 return (0);
6777 if (print_multi_lib)
6779 print_multilib_info ();
6780 return (0);
6783 if (print_multi_directory)
6785 if (multilib_dir == NULL)
6786 printf (".\n");
6787 else
6788 printf ("%s\n", multilib_dir);
6789 return (0);
6792 if (print_multiarch)
6794 if (multiarch_dir == NULL)
6795 printf ("\n");
6796 else
6797 printf ("%s\n", multiarch_dir);
6798 return (0);
6801 if (print_sysroot)
6803 if (target_system_root)
6805 if (target_sysroot_suffix)
6806 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
6807 else
6808 printf ("%s\n", target_system_root);
6810 return (0);
6813 if (print_multi_os_directory)
6815 if (multilib_os_dir == NULL)
6816 printf (".\n");
6817 else
6818 printf ("%s\n", multilib_os_dir);
6819 return (0);
6822 if (print_sysroot_headers_suffix)
6824 if (*sysroot_hdrs_suffix_spec)
6826 printf("%s\n", (target_sysroot_hdrs_suffix
6827 ? target_sysroot_hdrs_suffix
6828 : ""));
6829 return (0);
6831 else
6832 /* The error status indicates that only one set of fixed
6833 headers should be built. */
6834 fatal_error ("not configured with sysroot headers suffix");
6837 if (print_help_list)
6839 display_help ();
6841 if (! verbose_flag)
6843 printf (_("\nFor bug reporting instructions, please see:\n"));
6844 printf ("%s.\n", bug_report_url);
6846 return (0);
6849 /* We do not exit here. Instead we have created a fake input file
6850 called 'help-dummy' which needs to be compiled, and we pass this
6851 on the various sub-processes, along with the --help switch.
6852 Ensure their output appears after ours. */
6853 fputc ('\n', stdout);
6854 fflush (stdout);
6857 if (print_version)
6859 printf (_("%s %s%s\n"), progname, pkgversion_string,
6860 version_string);
6861 printf ("Copyright %s 2014 Free Software Foundation, Inc.\n",
6862 _("(C)"));
6863 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
6864 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
6865 stdout);
6866 if (! verbose_flag)
6867 return 0;
6869 /* We do not exit here. We use the same mechanism of --help to print
6870 the version of the sub-processes. */
6871 fputc ('\n', stdout);
6872 fflush (stdout);
6875 if (verbose_flag)
6877 int n;
6878 const char *thrmod;
6880 fnotice (stderr, "Target: %s\n", spec_machine);
6881 fnotice (stderr, "Configured with: %s\n", configuration_arguments);
6883 #ifdef THREAD_MODEL_SPEC
6884 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6885 but there's no point in doing all this processing just to get
6886 thread_model back. */
6887 obstack_init (&obstack);
6888 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6889 obstack_1grow (&obstack, '\0');
6890 thrmod = XOBFINISH (&obstack, const char *);
6891 #else
6892 thrmod = thread_model;
6893 #endif
6895 fnotice (stderr, "Thread model: %s\n", thrmod);
6897 /* compiler_version is truncated at the first space when initialized
6898 from version string, so truncate version_string at the first space
6899 before comparing. */
6900 for (n = 0; version_string[n]; n++)
6901 if (version_string[n] == ' ')
6902 break;
6904 if (! strncmp (version_string, compiler_version, n)
6905 && compiler_version[n] == 0)
6906 fnotice (stderr, "gcc version %s %s\n", version_string,
6907 pkgversion_string);
6908 else
6909 fnotice (stderr, "gcc driver version %s %sexecuting gcc version %s\n",
6910 version_string, pkgversion_string, compiler_version);
6912 if (n_infiles == 0)
6913 return (0);
6916 if (n_infiles == added_libraries)
6917 fatal_error ("no input files");
6919 if (seen_error ())
6920 goto out;
6922 /* Make a place to record the compiler output file names
6923 that correspond to the input files. */
6925 i = n_infiles;
6926 i += lang_specific_extra_outfiles;
6927 outfiles = XCNEWVEC (const char *, i);
6929 /* Record which files were specified explicitly as link input. */
6931 explicit_link_files = XCNEWVEC (char, n_infiles);
6933 combine_inputs = have_o || flag_wpa;
6935 for (i = 0; (int) i < n_infiles; i++)
6937 const char *name = infiles[i].name;
6938 struct compiler *compiler = lookup_compiler (name,
6939 strlen (name),
6940 infiles[i].language);
6942 if (compiler && !(compiler->combinable))
6943 combine_inputs = false;
6945 if (lang_n_infiles > 0 && compiler != input_file_compiler
6946 && infiles[i].language && infiles[i].language[0] != '*')
6947 infiles[i].incompiler = compiler;
6948 else if (compiler)
6950 lang_n_infiles++;
6951 input_file_compiler = compiler;
6952 infiles[i].incompiler = compiler;
6954 else
6956 /* Since there is no compiler for this input file, assume it is a
6957 linker file. */
6958 explicit_link_files[i] = 1;
6959 infiles[i].incompiler = NULL;
6961 infiles[i].compiled = false;
6962 infiles[i].preprocessed = false;
6965 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
6966 fatal_error ("cannot specify -o with -c, -S or -E with multiple files");
6968 for (i = 0; (int) i < n_infiles; i++)
6970 int this_file_error = 0;
6972 /* Tell do_spec what to substitute for %i. */
6974 input_file_number = i;
6975 set_input (infiles[i].name);
6977 if (infiles[i].compiled)
6978 continue;
6980 /* Use the same thing in %o, unless cp->spec says otherwise. */
6982 outfiles[i] = gcc_input_filename;
6984 /* Figure out which compiler from the file's suffix. */
6986 input_file_compiler
6987 = lookup_compiler (infiles[i].name, input_filename_length,
6988 infiles[i].language);
6990 if (input_file_compiler)
6992 /* Ok, we found an applicable compiler. Run its spec. */
6994 if (input_file_compiler->spec[0] == '#')
6996 error ("%s: %s compiler not installed on this system",
6997 gcc_input_filename, &input_file_compiler->spec[1]);
6998 this_file_error = 1;
7000 else
7002 if (compare_debug)
7004 free (debug_check_temp_file[0]);
7005 debug_check_temp_file[0] = NULL;
7007 free (debug_check_temp_file[1]);
7008 debug_check_temp_file[1] = NULL;
7011 value = do_spec (input_file_compiler->spec);
7012 infiles[i].compiled = true;
7013 if (value < 0)
7014 this_file_error = 1;
7015 else if (compare_debug && debug_check_temp_file[0])
7017 if (verbose_flag)
7018 inform (0, "recompiling with -fcompare-debug");
7020 compare_debug = -compare_debug;
7021 n_switches = n_switches_debug_check[1];
7022 n_switches_alloc = n_switches_alloc_debug_check[1];
7023 switches = switches_debug_check[1];
7025 value = do_spec (input_file_compiler->spec);
7027 compare_debug = -compare_debug;
7028 n_switches = n_switches_debug_check[0];
7029 n_switches_alloc = n_switches_alloc_debug_check[0];
7030 switches = switches_debug_check[0];
7032 if (value < 0)
7034 error ("during -fcompare-debug recompilation");
7035 this_file_error = 1;
7038 gcc_assert (debug_check_temp_file[1]
7039 && filename_cmp (debug_check_temp_file[0],
7040 debug_check_temp_file[1]));
7042 if (verbose_flag)
7043 inform (0, "comparing final insns dumps");
7045 if (compare_files (debug_check_temp_file))
7046 this_file_error = 1;
7049 if (compare_debug)
7051 free (debug_check_temp_file[0]);
7052 debug_check_temp_file[0] = NULL;
7054 free (debug_check_temp_file[1]);
7055 debug_check_temp_file[1] = NULL;
7060 /* If this file's name does not contain a recognized suffix,
7061 record it as explicit linker input. */
7063 else
7064 explicit_link_files[i] = 1;
7066 /* Clear the delete-on-failure queue, deleting the files in it
7067 if this compilation failed. */
7069 if (this_file_error)
7071 delete_failure_queue ();
7072 errorcount++;
7074 /* If this compilation succeeded, don't delete those files later. */
7075 clear_failure_queue ();
7078 /* Reset the input file name to the first compile/object file name, for use
7079 with %b in LINK_SPEC. We use the first input file that we can find
7080 a compiler to compile it instead of using infiles.language since for
7081 languages other than C we use aliases that we then lookup later. */
7082 if (n_infiles > 0)
7084 int i;
7086 for (i = 0; i < n_infiles ; i++)
7087 if (infiles[i].incompiler
7088 || (infiles[i].language && infiles[i].language[0] != '*'))
7090 set_input (infiles[i].name);
7091 break;
7095 if (!seen_error ())
7097 /* Make sure INPUT_FILE_NUMBER points to first available open
7098 slot. */
7099 input_file_number = n_infiles;
7100 if (lang_specific_pre_link ())
7101 errorcount++;
7104 /* Determine if there are any linker input files. */
7105 num_linker_inputs = 0;
7106 for (i = 0; (int) i < n_infiles; i++)
7107 if (explicit_link_files[i] || outfiles[i] != NULL)
7108 num_linker_inputs++;
7110 /* Run ld to link all the compiler output files. */
7112 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
7114 int tmp = execution_count;
7116 if (! have_c)
7118 #if HAVE_LTO_PLUGIN > 0
7119 #if HAVE_LTO_PLUGIN == 2
7120 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
7121 #else
7122 const char *fuse_linker_plugin = "fuse-linker-plugin";
7123 #endif
7124 #endif
7126 /* We'll use ld if we can't find collect2. */
7127 if (! strcmp (linker_name_spec, "collect2"))
7129 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
7130 if (s == NULL)
7131 linker_name_spec = "ld";
7134 #if HAVE_LTO_PLUGIN > 0
7135 #if HAVE_LTO_PLUGIN == 2
7136 if (!switch_matches (fno_use_linker_plugin,
7137 fno_use_linker_plugin
7138 + strlen (fno_use_linker_plugin), 0))
7139 #else
7140 if (switch_matches (fuse_linker_plugin,
7141 fuse_linker_plugin
7142 + strlen (fuse_linker_plugin), 0))
7143 #endif
7145 char *temp_spec = find_a_file (&exec_prefixes,
7146 LTOPLUGINSONAME, R_OK,
7147 false);
7148 if (!temp_spec)
7149 fatal_error ("-fuse-linker-plugin, but %s not found",
7150 LTOPLUGINSONAME);
7151 linker_plugin_file_spec = convert_white_space (temp_spec);
7153 #endif
7154 lto_gcc_spec = argv[0];
7157 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
7158 for collect. */
7159 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
7160 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
7162 if (print_subprocess_help == 1)
7164 printf (_("\nLinker options\n==============\n\n"));
7165 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
7166 " to the linker.\n\n"));
7167 fflush (stdout);
7169 value = do_spec (link_command_spec);
7170 if (value < 0)
7171 errorcount = 1;
7172 linker_was_run = (tmp != execution_count);
7175 /* If options said don't run linker,
7176 complain about input files to be given to the linker. */
7178 if (! linker_was_run && !seen_error ())
7179 for (i = 0; (int) i < n_infiles; i++)
7180 if (explicit_link_files[i]
7181 && !(infiles[i].language && infiles[i].language[0] == '*'))
7182 warning (0, "%s: linker input file unused because linking not done",
7183 outfiles[i]);
7185 /* Delete some or all of the temporary files we made. */
7187 if (seen_error ())
7188 delete_failure_queue ();
7189 delete_temp_files ();
7191 if (print_help_list)
7193 printf (("\nFor bug reporting instructions, please see:\n"));
7194 printf ("%s\n", bug_report_url);
7197 out:
7198 return (signal_count != 0 ? 2
7199 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
7200 : 0);
7203 /* Find the proper compilation spec for the file name NAME,
7204 whose length is LENGTH. LANGUAGE is the specified language,
7205 or 0 if this file is to be passed to the linker. */
7207 static struct compiler *
7208 lookup_compiler (const char *name, size_t length, const char *language)
7210 struct compiler *cp;
7212 /* If this was specified by the user to be a linker input, indicate that. */
7213 if (language != 0 && language[0] == '*')
7214 return 0;
7216 /* Otherwise, look for the language, if one is spec'd. */
7217 if (language != 0)
7219 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7220 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
7221 return cp;
7223 error ("language %s not recognized", language);
7224 return 0;
7227 /* Look for a suffix. */
7228 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7230 if (/* The suffix `-' matches only the file name `-'. */
7231 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7232 || (strlen (cp->suffix) < length
7233 /* See if the suffix matches the end of NAME. */
7234 && !strcmp (cp->suffix,
7235 name + length - strlen (cp->suffix))
7237 break;
7240 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
7241 /* Look again, but case-insensitively this time. */
7242 if (cp < compilers)
7243 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7245 if (/* The suffix `-' matches only the file name `-'. */
7246 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7247 || (strlen (cp->suffix) < length
7248 /* See if the suffix matches the end of NAME. */
7249 && ((!strcmp (cp->suffix,
7250 name + length - strlen (cp->suffix))
7251 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
7252 && !strcasecmp (cp->suffix,
7253 name + length - strlen (cp->suffix)))
7255 break;
7257 #endif
7259 if (cp >= compilers)
7261 if (cp->spec[0] != '@')
7262 /* A non-alias entry: return it. */
7263 return cp;
7265 /* An alias entry maps a suffix to a language.
7266 Search for the language; pass 0 for NAME and LENGTH
7267 to avoid infinite recursion if language not found. */
7268 return lookup_compiler (NULL, 0, cp->spec + 1);
7270 return 0;
7273 static char *
7274 save_string (const char *s, int len)
7276 char *result = XNEWVEC (char, len + 1);
7278 memcpy (result, s, len);
7279 result[len] = 0;
7280 return result;
7283 void
7284 pfatal_with_name (const char *name)
7286 perror_with_name (name);
7287 delete_temp_files ();
7288 exit (1);
7291 static void
7292 perror_with_name (const char *name)
7294 error ("%s: %m", name);
7297 static inline void
7298 validate_switches_from_spec (const char *spec, bool user)
7300 const char *p = spec;
7301 char c;
7302 while ((c = *p++))
7303 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
7304 /* We have a switch spec. */
7305 p = validate_switches (p + 1, user);
7308 static void
7309 validate_all_switches (void)
7311 struct compiler *comp;
7312 struct spec_list *spec;
7314 for (comp = compilers; comp->spec; comp++)
7315 validate_switches_from_spec (comp->spec, false);
7317 /* Look through the linked list of specs read from the specs file. */
7318 for (spec = specs; spec; spec = spec->next)
7319 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
7321 validate_switches_from_spec (link_command_spec, false);
7324 /* Look at the switch-name that comes after START
7325 and mark as valid all supplied switches that match it. */
7327 static const char *
7328 validate_switches (const char *start, bool user_spec)
7330 const char *p = start;
7331 const char *atom;
7332 size_t len;
7333 int i;
7334 bool suffix = false;
7335 bool starred = false;
7337 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
7339 next_member:
7340 SKIP_WHITE ();
7342 if (*p == '!')
7343 p++;
7345 SKIP_WHITE ();
7346 if (*p == '.' || *p == ',')
7347 suffix = true, p++;
7349 atom = p;
7350 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
7351 || *p == ',' || *p == '.' || *p == '@')
7352 p++;
7353 len = p - atom;
7355 if (*p == '*')
7356 starred = true, p++;
7358 SKIP_WHITE ();
7360 if (!suffix)
7362 /* Mark all matching switches as valid. */
7363 for (i = 0; i < n_switches; i++)
7364 if (!strncmp (switches[i].part1, atom, len)
7365 && (starred || switches[i].part1[len] == '\0')
7366 && (switches[i].known || user_spec))
7367 switches[i].validated = true;
7370 if (*p) p++;
7371 if (*p && (p[-1] == '|' || p[-1] == '&'))
7372 goto next_member;
7374 if (*p && p[-1] == ':')
7376 while (*p && *p != ';' && *p != '}')
7378 if (*p == '%')
7380 p++;
7381 if (*p == '{' || *p == '<')
7382 p = validate_switches (p+1, user_spec);
7383 else if (p[0] == 'W' && p[1] == '{')
7384 p = validate_switches (p+2, user_spec);
7386 else
7387 p++;
7390 if (*p) p++;
7391 if (*p && p[-1] == ';')
7392 goto next_member;
7395 return p;
7396 #undef SKIP_WHITE
7399 struct mdswitchstr
7401 const char *str;
7402 int len;
7405 static struct mdswitchstr *mdswitches;
7406 static int n_mdswitches;
7408 /* Check whether a particular argument was used. The first time we
7409 canonicalize the switches to keep only the ones we care about. */
7411 static int
7412 used_arg (const char *p, int len)
7414 struct mswitchstr
7416 const char *str;
7417 const char *replace;
7418 int len;
7419 int rep_len;
7422 static struct mswitchstr *mswitches;
7423 static int n_mswitches;
7424 int i, j;
7426 if (!mswitches)
7428 struct mswitchstr *matches;
7429 const char *q;
7430 int cnt = 0;
7432 /* Break multilib_matches into the component strings of string
7433 and replacement string. */
7434 for (q = multilib_matches; *q != '\0'; q++)
7435 if (*q == ';')
7436 cnt++;
7438 matches
7439 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
7440 i = 0;
7441 q = multilib_matches;
7442 while (*q != '\0')
7444 matches[i].str = q;
7445 while (*q != ' ')
7447 if (*q == '\0')
7449 invalid_matches:
7450 fatal_error ("multilib spec %qs is invalid",
7451 multilib_matches);
7453 q++;
7455 matches[i].len = q - matches[i].str;
7457 matches[i].replace = ++q;
7458 while (*q != ';' && *q != '\0')
7460 if (*q == ' ')
7461 goto invalid_matches;
7462 q++;
7464 matches[i].rep_len = q - matches[i].replace;
7465 i++;
7466 if (*q == ';')
7467 q++;
7470 /* Now build a list of the replacement string for switches that we care
7471 about. Make sure we allocate at least one entry. This prevents
7472 xmalloc from calling fatal, and prevents us from re-executing this
7473 block of code. */
7474 mswitches
7475 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
7476 for (i = 0; i < n_switches; i++)
7477 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
7479 int xlen = strlen (switches[i].part1);
7480 for (j = 0; j < cnt; j++)
7481 if (xlen == matches[j].len
7482 && ! strncmp (switches[i].part1, matches[j].str, xlen))
7484 mswitches[n_mswitches].str = matches[j].replace;
7485 mswitches[n_mswitches].len = matches[j].rep_len;
7486 mswitches[n_mswitches].replace = (char *) 0;
7487 mswitches[n_mswitches].rep_len = 0;
7488 n_mswitches++;
7489 break;
7493 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
7494 on the command line nor any options mutually incompatible with
7495 them. */
7496 for (i = 0; i < n_mdswitches; i++)
7498 const char *r;
7500 for (q = multilib_options; *q != '\0'; q++)
7502 while (*q == ' ')
7503 q++;
7505 r = q;
7506 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
7507 || strchr (" /", q[mdswitches[i].len]) == NULL)
7509 while (*q != ' ' && *q != '/' && *q != '\0')
7510 q++;
7511 if (*q != '/')
7512 break;
7513 q++;
7516 if (*q != ' ' && *q != '\0')
7518 while (*r != ' ' && *r != '\0')
7520 q = r;
7521 while (*q != ' ' && *q != '/' && *q != '\0')
7522 q++;
7524 if (used_arg (r, q - r))
7525 break;
7527 if (*q != '/')
7529 mswitches[n_mswitches].str = mdswitches[i].str;
7530 mswitches[n_mswitches].len = mdswitches[i].len;
7531 mswitches[n_mswitches].replace = (char *) 0;
7532 mswitches[n_mswitches].rep_len = 0;
7533 n_mswitches++;
7534 break;
7537 r = q + 1;
7539 break;
7545 for (i = 0; i < n_mswitches; i++)
7546 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7547 return 1;
7549 return 0;
7552 static int
7553 default_arg (const char *p, int len)
7555 int i;
7557 for (i = 0; i < n_mdswitches; i++)
7558 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7559 return 1;
7561 return 0;
7564 /* Work out the subdirectory to use based on the options. The format of
7565 multilib_select is a list of elements. Each element is a subdirectory
7566 name followed by a list of options followed by a semicolon. The format
7567 of multilib_exclusions is the same, but without the preceding
7568 directory. First gcc will check the exclusions, if none of the options
7569 beginning with an exclamation point are present, and all of the other
7570 options are present, then we will ignore this completely. Passing
7571 that, gcc will consider each multilib_select in turn using the same
7572 rules for matching the options. If a match is found, that subdirectory
7573 will be used.
7574 A subdirectory name is optionally followed by a colon and the corresponding
7575 multiarch name. */
7577 static void
7578 set_multilib_dir (void)
7580 const char *p;
7581 unsigned int this_path_len;
7582 const char *this_path, *this_arg;
7583 const char *start, *end;
7584 int not_arg;
7585 int ok, ndfltok, first;
7587 n_mdswitches = 0;
7588 start = multilib_defaults;
7589 while (*start == ' ' || *start == '\t')
7590 start++;
7591 while (*start != '\0')
7593 n_mdswitches++;
7594 while (*start != ' ' && *start != '\t' && *start != '\0')
7595 start++;
7596 while (*start == ' ' || *start == '\t')
7597 start++;
7600 if (n_mdswitches)
7602 int i = 0;
7604 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
7605 for (start = multilib_defaults; *start != '\0'; start = end + 1)
7607 while (*start == ' ' || *start == '\t')
7608 start++;
7610 if (*start == '\0')
7611 break;
7613 for (end = start + 1;
7614 *end != ' ' && *end != '\t' && *end != '\0'; end++)
7617 obstack_grow (&multilib_obstack, start, end - start);
7618 obstack_1grow (&multilib_obstack, 0);
7619 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
7620 mdswitches[i++].len = end - start;
7622 if (*end == '\0')
7623 break;
7627 p = multilib_exclusions;
7628 while (*p != '\0')
7630 /* Ignore newlines. */
7631 if (*p == '\n')
7633 ++p;
7634 continue;
7637 /* Check the arguments. */
7638 ok = 1;
7639 while (*p != ';')
7641 if (*p == '\0')
7643 invalid_exclusions:
7644 fatal_error ("multilib exclusions %qs is invalid",
7645 multilib_exclusions);
7648 if (! ok)
7650 ++p;
7651 continue;
7654 this_arg = p;
7655 while (*p != ' ' && *p != ';')
7657 if (*p == '\0')
7658 goto invalid_exclusions;
7659 ++p;
7662 if (*this_arg != '!')
7663 not_arg = 0;
7664 else
7666 not_arg = 1;
7667 ++this_arg;
7670 ok = used_arg (this_arg, p - this_arg);
7671 if (not_arg)
7672 ok = ! ok;
7674 if (*p == ' ')
7675 ++p;
7678 if (ok)
7679 return;
7681 ++p;
7684 first = 1;
7685 p = multilib_select;
7687 /* Append multilib reuse rules if any. With those rules, we can reuse
7688 one multilib for certain different options sets. */
7689 if (strlen (multilib_reuse) > 0)
7690 p = concat (p, multilib_reuse, NULL);
7692 while (*p != '\0')
7694 /* Ignore newlines. */
7695 if (*p == '\n')
7697 ++p;
7698 continue;
7701 /* Get the initial path. */
7702 this_path = p;
7703 while (*p != ' ')
7705 if (*p == '\0')
7707 invalid_select:
7708 fatal_error ("multilib select %qs %qs is invalid",
7709 multilib_select, multilib_reuse);
7711 ++p;
7713 this_path_len = p - this_path;
7715 /* Check the arguments. */
7716 ok = 1;
7717 ndfltok = 1;
7718 ++p;
7719 while (*p != ';')
7721 if (*p == '\0')
7722 goto invalid_select;
7724 if (! ok)
7726 ++p;
7727 continue;
7730 this_arg = p;
7731 while (*p != ' ' && *p != ';')
7733 if (*p == '\0')
7734 goto invalid_select;
7735 ++p;
7738 if (*this_arg != '!')
7739 not_arg = 0;
7740 else
7742 not_arg = 1;
7743 ++this_arg;
7746 /* If this is a default argument, we can just ignore it.
7747 This is true even if this_arg begins with '!'. Beginning
7748 with '!' does not mean that this argument is necessarily
7749 inappropriate for this library: it merely means that
7750 there is a more specific library which uses this
7751 argument. If this argument is a default, we need not
7752 consider that more specific library. */
7753 ok = used_arg (this_arg, p - this_arg);
7754 if (not_arg)
7755 ok = ! ok;
7757 if (! ok)
7758 ndfltok = 0;
7760 if (default_arg (this_arg, p - this_arg))
7761 ok = 1;
7763 if (*p == ' ')
7764 ++p;
7767 if (ok && first)
7769 if (this_path_len != 1
7770 || this_path[0] != '.')
7772 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
7773 char *q;
7775 strncpy (new_multilib_dir, this_path, this_path_len);
7776 new_multilib_dir[this_path_len] = '\0';
7777 q = strchr (new_multilib_dir, ':');
7778 if (q != NULL)
7779 *q = '\0';
7780 multilib_dir = new_multilib_dir;
7782 first = 0;
7785 if (ndfltok)
7787 const char *q = this_path, *end = this_path + this_path_len;
7789 while (q < end && *q != ':')
7790 q++;
7791 if (q < end)
7793 const char *q2 = q + 1, *ml_end = end;
7794 char *new_multilib_os_dir;
7796 while (q2 < end && *q2 != ':')
7797 q2++;
7798 if (*q2 == ':')
7799 ml_end = q2;
7800 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
7801 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
7802 new_multilib_os_dir[ml_end - q - 1] = '\0';
7803 multilib_os_dir = *new_multilib_os_dir ? new_multilib_os_dir : ".";
7805 if (q2 < end && *q2 == ':')
7807 char *new_multiarch_dir = XNEWVEC (char, end - q2);
7808 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
7809 new_multiarch_dir[end - q2 - 1] = '\0';
7810 multiarch_dir = new_multiarch_dir;
7812 break;
7816 ++p;
7819 if (multilib_dir == NULL && multilib_os_dir != NULL
7820 && strcmp (multilib_os_dir, ".") == 0)
7822 free (CONST_CAST (char *, multilib_os_dir));
7823 multilib_os_dir = NULL;
7825 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7826 multilib_os_dir = multilib_dir;
7829 /* Print out the multiple library subdirectory selection
7830 information. This prints out a series of lines. Each line looks
7831 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7832 required. Only the desired options are printed out, the negative
7833 matches. The options are print without a leading dash. There are
7834 no spaces to make it easy to use the information in the shell.
7835 Each subdirectory is printed only once. This assumes the ordering
7836 generated by the genmultilib script. Also, we leave out ones that match
7837 the exclusions. */
7839 static void
7840 print_multilib_info (void)
7842 const char *p = multilib_select;
7843 const char *last_path = 0, *this_path;
7844 int skip;
7845 unsigned int last_path_len = 0;
7847 while (*p != '\0')
7849 skip = 0;
7850 /* Ignore newlines. */
7851 if (*p == '\n')
7853 ++p;
7854 continue;
7857 /* Get the initial path. */
7858 this_path = p;
7859 while (*p != ' ')
7861 if (*p == '\0')
7863 invalid_select:
7864 fatal_error ("multilib select %qs is invalid", multilib_select);
7867 ++p;
7870 /* When --disable-multilib was used but target defines
7871 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
7872 with .:: for multiarch configurations) are there just to find
7873 multilib_os_dir, so skip them from output. */
7874 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
7875 skip = 1;
7877 /* Check for matches with the multilib_exclusions. We don't bother
7878 with the '!' in either list. If any of the exclusion rules match
7879 all of its options with the select rule, we skip it. */
7881 const char *e = multilib_exclusions;
7882 const char *this_arg;
7884 while (*e != '\0')
7886 int m = 1;
7887 /* Ignore newlines. */
7888 if (*e == '\n')
7890 ++e;
7891 continue;
7894 /* Check the arguments. */
7895 while (*e != ';')
7897 const char *q;
7898 int mp = 0;
7900 if (*e == '\0')
7902 invalid_exclusion:
7903 fatal_error ("multilib exclusion %qs is invalid",
7904 multilib_exclusions);
7907 if (! m)
7909 ++e;
7910 continue;
7913 this_arg = e;
7915 while (*e != ' ' && *e != ';')
7917 if (*e == '\0')
7918 goto invalid_exclusion;
7919 ++e;
7922 q = p + 1;
7923 while (*q != ';')
7925 const char *arg;
7926 int len = e - this_arg;
7928 if (*q == '\0')
7929 goto invalid_select;
7931 arg = q;
7933 while (*q != ' ' && *q != ';')
7935 if (*q == '\0')
7936 goto invalid_select;
7937 ++q;
7940 if (! strncmp (arg, this_arg,
7941 (len < q - arg) ? q - arg : len)
7942 || default_arg (this_arg, e - this_arg))
7944 mp = 1;
7945 break;
7948 if (*q == ' ')
7949 ++q;
7952 if (! mp)
7953 m = 0;
7955 if (*e == ' ')
7956 ++e;
7959 if (m)
7961 skip = 1;
7962 break;
7965 if (*e != '\0')
7966 ++e;
7970 if (! skip)
7972 /* If this is a duplicate, skip it. */
7973 skip = (last_path != 0
7974 && (unsigned int) (p - this_path) == last_path_len
7975 && ! filename_ncmp (last_path, this_path, last_path_len));
7977 last_path = this_path;
7978 last_path_len = p - this_path;
7981 /* If this directory requires any default arguments, we can skip
7982 it. We will already have printed a directory identical to
7983 this one which does not require that default argument. */
7984 if (! skip)
7986 const char *q;
7988 q = p + 1;
7989 while (*q != ';')
7991 const char *arg;
7993 if (*q == '\0')
7994 goto invalid_select;
7996 if (*q == '!')
7997 arg = NULL;
7998 else
7999 arg = q;
8001 while (*q != ' ' && *q != ';')
8003 if (*q == '\0')
8004 goto invalid_select;
8005 ++q;
8008 if (arg != NULL
8009 && default_arg (arg, q - arg))
8011 skip = 1;
8012 break;
8015 if (*q == ' ')
8016 ++q;
8020 if (! skip)
8022 const char *p1;
8024 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
8025 putchar (*p1);
8026 putchar (';');
8029 ++p;
8030 while (*p != ';')
8032 int use_arg;
8034 if (*p == '\0')
8035 goto invalid_select;
8037 if (skip)
8039 ++p;
8040 continue;
8043 use_arg = *p != '!';
8045 if (use_arg)
8046 putchar ('@');
8048 while (*p != ' ' && *p != ';')
8050 if (*p == '\0')
8051 goto invalid_select;
8052 if (use_arg)
8053 putchar (*p);
8054 ++p;
8057 if (*p == ' ')
8058 ++p;
8061 if (! skip)
8063 /* If there are extra options, print them now. */
8064 if (multilib_extra && *multilib_extra)
8066 int print_at = TRUE;
8067 const char *q;
8069 for (q = multilib_extra; *q != '\0'; q++)
8071 if (*q == ' ')
8072 print_at = TRUE;
8073 else
8075 if (print_at)
8076 putchar ('@');
8077 putchar (*q);
8078 print_at = FALSE;
8083 putchar ('\n');
8086 ++p;
8090 /* getenv built-in spec function.
8092 Returns the value of the environment variable given by its first
8093 argument, concatenated with the second argument. If the
8094 environment variable is not defined, a fatal error is issued. */
8096 static const char *
8097 getenv_spec_function (int argc, const char **argv)
8099 char *value;
8100 char *result;
8101 char *ptr;
8102 size_t len;
8104 if (argc != 2)
8105 return NULL;
8107 value = getenv (argv[0]);
8108 if (!value)
8109 fatal_error ("environment variable %qs not defined", argv[0]);
8111 /* We have to escape every character of the environment variable so
8112 they are not interpreted as active spec characters. A
8113 particularly painful case is when we are reading a variable
8114 holding a windows path complete with \ separators. */
8115 len = strlen (value) * 2 + strlen (argv[1]) + 1;
8116 result = XNEWVAR (char, len);
8117 for (ptr = result; *value; ptr += 2)
8119 ptr[0] = '\\';
8120 ptr[1] = *value++;
8123 strcpy (ptr, argv[1]);
8125 return result;
8128 /* if-exists built-in spec function.
8130 Checks to see if the file specified by the absolute pathname in
8131 ARGS exists. Returns that pathname if found.
8133 The usual use for this function is to check for a library file
8134 (whose name has been expanded with %s). */
8136 static const char *
8137 if_exists_spec_function (int argc, const char **argv)
8139 /* Must have only one argument. */
8140 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8141 return argv[0];
8143 return NULL;
8146 /* if-exists-else built-in spec function.
8148 This is like if-exists, but takes an additional argument which
8149 is returned if the first argument does not exist. */
8151 static const char *
8152 if_exists_else_spec_function (int argc, const char **argv)
8154 /* Must have exactly two arguments. */
8155 if (argc != 2)
8156 return NULL;
8158 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8159 return argv[0];
8161 return argv[1];
8164 /* sanitize built-in spec function.
8166 This returns non-NULL, if sanitizing address, thread or
8167 any of the undefined behavior sanitizers. */
8169 static const char *
8170 sanitize_spec_function (int argc, const char **argv)
8172 if (argc != 1)
8173 return NULL;
8175 if (strcmp (argv[0], "address") == 0)
8176 return (flag_sanitize & SANITIZE_ADDRESS) ? "" : NULL;
8177 if (strcmp (argv[0], "thread") == 0)
8178 return (flag_sanitize & SANITIZE_THREAD) ? "" : NULL;
8179 if (strcmp (argv[0], "undefined") == 0)
8180 return (flag_sanitize & SANITIZE_UNDEFINED) ? "" : NULL;
8181 if (strcmp (argv[0], "leak") == 0)
8182 return ((flag_sanitize
8183 & (SANITIZE_ADDRESS | SANITIZE_LEAK | SANITIZE_THREAD))
8184 == SANITIZE_LEAK) ? "" : NULL;
8185 return NULL;
8188 /* replace-outfile built-in spec function.
8190 This looks for the first argument in the outfiles array's name and
8191 replaces it with the second argument. */
8193 static const char *
8194 replace_outfile_spec_function (int argc, const char **argv)
8196 int i;
8197 /* Must have exactly two arguments. */
8198 if (argc != 2)
8199 abort ();
8201 for (i = 0; i < n_infiles; i++)
8203 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8204 outfiles[i] = xstrdup (argv[1]);
8206 return NULL;
8209 /* remove-outfile built-in spec function.
8211 * This looks for the first argument in the outfiles array's name and
8212 * removes it. */
8214 static const char *
8215 remove_outfile_spec_function (int argc, const char **argv)
8217 int i;
8218 /* Must have exactly one argument. */
8219 if (argc != 1)
8220 abort ();
8222 for (i = 0; i < n_infiles; i++)
8224 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8225 outfiles[i] = NULL;
8227 return NULL;
8230 /* Given two version numbers, compares the two numbers.
8231 A version number must match the regular expression
8232 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
8234 static int
8235 compare_version_strings (const char *v1, const char *v2)
8237 int rresult;
8238 regex_t r;
8240 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
8241 REG_EXTENDED | REG_NOSUB) != 0)
8242 abort ();
8243 rresult = regexec (&r, v1, 0, NULL, 0);
8244 if (rresult == REG_NOMATCH)
8245 fatal_error ("invalid version number %qs", v1);
8246 else if (rresult != 0)
8247 abort ();
8248 rresult = regexec (&r, v2, 0, NULL, 0);
8249 if (rresult == REG_NOMATCH)
8250 fatal_error ("invalid version number %qs", v2);
8251 else if (rresult != 0)
8252 abort ();
8254 return strverscmp (v1, v2);
8258 /* version_compare built-in spec function.
8260 This takes an argument of the following form:
8262 <comparison-op> <arg1> [<arg2>] <switch> <result>
8264 and produces "result" if the comparison evaluates to true,
8265 and nothing if it doesn't.
8267 The supported <comparison-op> values are:
8269 >= true if switch is a later (or same) version than arg1
8270 !> opposite of >=
8271 < true if switch is an earlier version than arg1
8272 !< opposite of <
8273 >< true if switch is arg1 or later, and earlier than arg2
8274 <> true if switch is earlier than arg1 or is arg2 or later
8276 If the switch is not present, the condition is false unless
8277 the first character of the <comparison-op> is '!'.
8279 For example,
8280 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
8281 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
8283 static const char *
8284 version_compare_spec_function (int argc, const char **argv)
8286 int comp1, comp2;
8287 size_t switch_len;
8288 const char *switch_value = NULL;
8289 int nargs = 1, i;
8290 bool result;
8292 if (argc < 3)
8293 fatal_error ("too few arguments to %%:version-compare");
8294 if (argv[0][0] == '\0')
8295 abort ();
8296 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
8297 nargs = 2;
8298 if (argc != nargs + 3)
8299 fatal_error ("too many arguments to %%:version-compare");
8301 switch_len = strlen (argv[nargs + 1]);
8302 for (i = 0; i < n_switches; i++)
8303 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
8304 && check_live_switch (i, switch_len))
8305 switch_value = switches[i].part1 + switch_len;
8307 if (switch_value == NULL)
8308 comp1 = comp2 = -1;
8309 else
8311 comp1 = compare_version_strings (switch_value, argv[1]);
8312 if (nargs == 2)
8313 comp2 = compare_version_strings (switch_value, argv[2]);
8314 else
8315 comp2 = -1; /* This value unused. */
8318 switch (argv[0][0] << 8 | argv[0][1])
8320 case '>' << 8 | '=':
8321 result = comp1 >= 0;
8322 break;
8323 case '!' << 8 | '<':
8324 result = comp1 >= 0 || switch_value == NULL;
8325 break;
8326 case '<' << 8:
8327 result = comp1 < 0;
8328 break;
8329 case '!' << 8 | '>':
8330 result = comp1 < 0 || switch_value == NULL;
8331 break;
8332 case '>' << 8 | '<':
8333 result = comp1 >= 0 && comp2 < 0;
8334 break;
8335 case '<' << 8 | '>':
8336 result = comp1 < 0 || comp2 >= 0;
8337 break;
8339 default:
8340 fatal_error ("unknown operator %qs in %%:version-compare", argv[0]);
8342 if (! result)
8343 return NULL;
8345 return argv[nargs + 2];
8348 /* %:include builtin spec function. This differs from %include in that it
8349 can be nested inside a spec, and thus be conditionalized. It takes
8350 one argument, the filename, and looks for it in the startfile path.
8351 The result is always NULL, i.e. an empty expansion. */
8353 static const char *
8354 include_spec_function (int argc, const char **argv)
8356 char *file;
8358 if (argc != 1)
8359 abort ();
8361 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
8362 read_specs (file ? file : argv[0], false, false);
8364 return NULL;
8367 /* %:find-file spec function. This function replaces its argument by
8368 the file found through find_file, that is the -print-file-name gcc
8369 program option. */
8370 static const char *
8371 find_file_spec_function (int argc, const char **argv)
8373 const char *file;
8375 if (argc != 1)
8376 abort ();
8378 file = find_file (argv[0]);
8379 return file;
8383 /* %:find-plugindir spec function. This function replaces its argument
8384 by the -iplugindir=<dir> option. `dir' is found through find_file, that
8385 is the -print-file-name gcc program option. */
8386 static const char *
8387 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
8389 const char *option;
8391 if (argc != 0)
8392 abort ();
8394 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
8395 return option;
8399 /* %:print-asm-header spec function. Print a banner to say that the
8400 following output is from the assembler. */
8402 static const char *
8403 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
8404 const char **argv ATTRIBUTE_UNUSED)
8406 printf (_("Assembler options\n=================\n\n"));
8407 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
8408 fflush (stdout);
8409 return NULL;
8412 /* Get a random number for -frandom-seed */
8414 static unsigned HOST_WIDE_INT
8415 get_random_number (void)
8417 unsigned HOST_WIDE_INT ret = 0;
8418 int fd;
8420 fd = open ("/dev/urandom", O_RDONLY);
8421 if (fd >= 0)
8423 read (fd, &ret, sizeof (HOST_WIDE_INT));
8424 close (fd);
8425 if (ret)
8426 return ret;
8429 /* Get some more or less random data. */
8430 #ifdef HAVE_GETTIMEOFDAY
8432 struct timeval tv;
8434 gettimeofday (&tv, NULL);
8435 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
8437 #else
8439 time_t now = time (NULL);
8441 if (now != (time_t)-1)
8442 ret = (unsigned) now;
8444 #endif
8446 return ret ^ getpid ();
8449 /* %:compare-debug-dump-opt spec function. Save the last argument,
8450 expected to be the last -fdump-final-insns option, or generate a
8451 temporary. */
8453 static const char *
8454 compare_debug_dump_opt_spec_function (int arg,
8455 const char **argv ATTRIBUTE_UNUSED)
8457 char *ret;
8458 char *name;
8459 int which;
8460 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
8462 if (arg != 0)
8463 fatal_error ("too many arguments to %%:compare-debug-dump-opt");
8465 do_spec_2 ("%{fdump-final-insns=*:%*}");
8466 do_spec_1 (" ", 0, NULL);
8468 if (argbuf.length () > 0
8469 && strcmp (argv[argbuf.length () - 1], "."))
8471 if (!compare_debug)
8472 return NULL;
8474 name = xstrdup (argv[argbuf.length () - 1]);
8475 ret = NULL;
8477 else
8479 const char *ext = NULL;
8481 if (argbuf.length () > 0)
8483 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
8484 ext = ".gkd";
8486 else if (!compare_debug)
8487 return NULL;
8488 else
8489 do_spec_2 ("%g.gkd");
8491 do_spec_1 (" ", 0, NULL);
8493 gcc_assert (argbuf.length () > 0);
8495 name = concat (argbuf.last (), ext, NULL);
8497 ret = concat ("-fdump-final-insns=", name, NULL);
8500 which = compare_debug < 0;
8501 debug_check_temp_file[which] = name;
8503 if (!which)
8505 unsigned HOST_WIDE_INT value = get_random_number ();
8507 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
8510 if (*random_seed)
8512 char *tmp = ret;
8513 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
8514 ret, NULL);
8515 free (tmp);
8518 if (which)
8519 *random_seed = 0;
8521 return ret;
8524 static const char *debug_auxbase_opt;
8526 /* %:compare-debug-self-opt spec function. Expands to the options
8527 that are to be passed in the second compilation of
8528 compare-debug. */
8530 static const char *
8531 compare_debug_self_opt_spec_function (int arg,
8532 const char **argv ATTRIBUTE_UNUSED)
8534 if (arg != 0)
8535 fatal_error ("too many arguments to %%:compare-debug-self-opt");
8537 if (compare_debug >= 0)
8538 return NULL;
8540 do_spec_2 ("%{c|S:%{o*:%*}}");
8541 do_spec_1 (" ", 0, NULL);
8543 if (argbuf.length () > 0)
8544 debug_auxbase_opt = concat ("-auxbase-strip ",
8545 argbuf.last (),
8546 NULL);
8547 else
8548 debug_auxbase_opt = NULL;
8550 return concat ("\
8551 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
8552 %<fdump-final-insns=* -w -S -o %j \
8553 %{!fcompare-debug-second:-fcompare-debug-second} \
8554 ", compare_debug_opt, NULL);
8557 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
8558 options that are to be passed in the second compilation of
8559 compare-debug. It expects, as an argument, the basename of the
8560 current input file name, with the .gk suffix appended to it. */
8562 static const char *
8563 compare_debug_auxbase_opt_spec_function (int arg,
8564 const char **argv)
8566 char *name;
8567 int len;
8569 if (arg == 0)
8570 fatal_error ("too few arguments to %%:compare-debug-auxbase-opt");
8572 if (arg != 1)
8573 fatal_error ("too many arguments to %%:compare-debug-auxbase-opt");
8575 if (compare_debug >= 0)
8576 return NULL;
8578 len = strlen (argv[0]);
8579 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
8580 fatal_error ("argument to %%:compare-debug-auxbase-opt "
8581 "does not end in .gk");
8583 if (debug_auxbase_opt)
8584 return debug_auxbase_opt;
8586 #define OPT "-auxbase "
8588 len -= 3;
8589 name = (char*) xmalloc (sizeof (OPT) + len);
8590 memcpy (name, OPT, sizeof (OPT) - 1);
8591 memcpy (name + sizeof (OPT) - 1, argv[0], len);
8592 name[sizeof (OPT) - 1 + len] = '\0';
8594 #undef OPT
8596 return name;
8599 /* %:pass-through-libs spec function. Finds all -l options and input
8600 file names in the lib spec passed to it, and makes a list of them
8601 prepended with the plugin option to cause them to be passed through
8602 to the final link after all the new object files have been added. */
8604 const char *
8605 pass_through_libs_spec_func (int argc, const char **argv)
8607 char *prepended = xstrdup (" ");
8608 int n;
8609 /* Shlemiel the painter's algorithm. Innately horrible, but at least
8610 we know that there will never be more than a handful of strings to
8611 concat, and it's only once per run, so it's not worth optimising. */
8612 for (n = 0; n < argc; n++)
8614 char *old = prepended;
8615 /* Anything that isn't an option is a full path to an output
8616 file; pass it through if it ends in '.a'. Among options,
8617 pass only -l. */
8618 if (argv[n][0] == '-' && argv[n][1] == 'l')
8620 const char *lopt = argv[n] + 2;
8621 /* Handle both joined and non-joined -l options. If for any
8622 reason there's a trailing -l with no joined or following
8623 arg just discard it. */
8624 if (!*lopt && ++n >= argc)
8625 break;
8626 else if (!*lopt)
8627 lopt = argv[n];
8628 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
8629 lopt, " ", NULL);
8631 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
8633 prepended = concat (prepended, "-plugin-opt=-pass-through=",
8634 argv[n], " ", NULL);
8636 if (prepended != old)
8637 free (old);
8639 return prepended;
8642 /* %:replace-extension spec function. Replaces the extension of the
8643 first argument with the second argument. */
8645 const char *
8646 replace_extension_spec_func (int argc, const char **argv)
8648 char *name;
8649 char *p;
8650 char *result;
8651 int i;
8653 if (argc != 2)
8654 fatal_error ("too few arguments to %%:replace-extension");
8656 name = xstrdup (argv[0]);
8658 for (i = strlen (name) - 1; i >= 0; i--)
8659 if (IS_DIR_SEPARATOR (name[i]))
8660 break;
8662 p = strrchr (name + i + 1, '.');
8663 if (p != NULL)
8664 *p = '\0';
8666 result = concat (name, argv[1], NULL);
8668 free (name);
8669 return result;
8672 /* Insert backslash before spaces in ORIG (usually a file path), to
8673 avoid being broken by spec parser.
8675 This function is needed as do_spec_1 treats white space (' ' and '\t')
8676 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
8677 the file name should be treated as a single argument rather than being
8678 broken into multiple. Solution is to insert '\\' before the space in a
8679 file name.
8681 This function converts and only converts all occurrence of ' '
8682 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
8683 "a b" -> "a\\ b"
8684 "a b" -> "a\\ \\ b"
8685 "a\tb" -> "a\\\tb"
8686 "a\\ b" -> "a\\\\ b"
8688 orig: input null-terminating string that was allocated by xalloc. The
8689 memory it points to might be freed in this function. Behavior undefined
8690 if ORIG wasn't xalloced or was freed already at entry.
8692 Return: ORIG if no conversion needed. Otherwise a newly allocated string
8693 that was converted from ORIG. */
8695 static char *
8696 convert_white_space (char *orig)
8698 int len, number_of_space = 0;
8700 for (len = 0; orig[len]; len++)
8701 if (orig[len] == ' ' || orig[len] == '\t') number_of_space++;
8703 if (number_of_space)
8705 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
8706 int j, k;
8707 for (j = 0, k = 0; j <= len; j++, k++)
8709 if (orig[j] == ' ' || orig[j] == '\t')
8710 new_spec[k++] = '\\';
8711 new_spec[k] = orig[j];
8713 free (orig);
8714 return new_spec;
8716 else
8717 return orig;