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