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