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