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