libunwind cleanup
[official-gcc.git] / gcc / gcc.c
blob7b9ea63e97127f48256777993af8993c20269cce
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 Free Software Foundation, Inc.
5 This file is part of GCC.
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.
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.
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.
22 This paragraph is here to try to keep Sun CC from dying.
23 The number of chars here seems crucial!!!! */
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.
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". */
35 /* A Short Introduction to Adding a Command-Line Option.
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.
41 In the following, consider adding the command-line argument
42 `--bar'.
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.
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 `-'.
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'.
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'.
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.
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(). */
73 #include "config.h"
74 #include "system.h"
75 #include "coretypes.h"
76 #include "tm.h"
77 #include <signal.h>
78 #if ! defined( SIGCHLD ) && defined( SIGCLD )
79 # define SIGCHLD SIGCLD
80 #endif
81 #include "obstack.h"
82 #include "intl.h"
83 #include "prefix.h"
84 #include "gcc.h"
85 #include "flags.h"
87 #ifdef HAVE_SYS_RESOURCE_H
88 #include <sys/resource.h>
89 #endif
90 #if defined (HAVE_DECL_GETRUSAGE) && !HAVE_DECL_GETRUSAGE
91 extern int getrusage (int, struct rusage *);
92 #endif
94 /* By default there is no special suffix for target executables. */
95 /* FIXME: when autoconf is fixed, remove the host check - dj */
96 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
97 #define HAVE_TARGET_EXECUTABLE_SUFFIX
98 #endif
100 /* By default there is no special suffix for host executables. */
101 #ifdef HOST_EXECUTABLE_SUFFIX
102 #define HAVE_HOST_EXECUTABLE_SUFFIX
103 #else
104 #define HOST_EXECUTABLE_SUFFIX ""
105 #endif
107 /* By default, the suffix for target object files is ".o". */
108 #ifdef TARGET_OBJECT_SUFFIX
109 #define HAVE_TARGET_OBJECT_SUFFIX
110 #else
111 #define TARGET_OBJECT_SUFFIX ".o"
112 #endif
114 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
116 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
117 #ifndef LIBRARY_PATH_ENV
118 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
119 #endif
121 #ifndef HAVE_KILL
122 #define kill(p,s) raise(s)
123 #endif
125 /* If a stage of compilation returns an exit status >= 1,
126 compilation of that file ceases. */
128 #define MIN_FATAL_STATUS 1
130 /* Flag set by cppspec.c to 1. */
131 int is_cpp_driver;
133 /* Flag saying to pass the greatest exit code returned by a sub-process
134 to the calling program. */
135 static int pass_exit_codes;
137 /* Definition of string containing the arguments given to configure. */
138 #include "configargs.h"
140 /* Flag saying to print the directories gcc will search through looking for
141 programs, libraries, etc. */
143 static int print_search_dirs;
145 /* Flag saying to print the full filename of this file
146 as found through our usual search mechanism. */
148 static const char *print_file_name = NULL;
150 /* As print_file_name, but search for executable file. */
152 static const char *print_prog_name = NULL;
154 /* Flag saying to print the relative path we'd use to
155 find libgcc.a given the current compiler flags. */
157 static int print_multi_directory;
159 /* Flag saying to print the relative path we'd use to
160 find OS libraries given the current compiler flags. */
162 static int print_multi_os_directory;
164 /* Flag saying to print the list of subdirectories and
165 compiler flags used to select them in a standard form. */
167 static int print_multi_lib;
169 /* Flag saying to print the command line options understood by gcc and its
170 sub-processes. */
172 static int print_help_list;
174 /* Flag indicating whether we should print the command and arguments */
176 static int verbose_flag;
178 /* Flag indicating whether we should ONLY print the command and
179 arguments (like verbose_flag) without executing the command.
180 Displayed arguments are quoted so that the generated command
181 line is suitable for execution. This is intended for use in
182 shell scripts to capture the driver-generated command line. */
183 static int verbose_only_flag;
185 /* Flag indicating to print target specific command line options. */
187 static int target_help_flag;
189 /* Flag indicating whether we should report subprocess execution times
190 (if this is supported by the system - see pexecute.c). */
192 static int report_times;
194 /* Nonzero means place this string before uses of /, so that include
195 and library files can be found in an alternate location. */
197 #ifdef TARGET_SYSTEM_ROOT
198 static const char *target_system_root = TARGET_SYSTEM_ROOT;
199 #else
200 static const char *target_system_root = 0;
201 #endif
203 /* Nonzero means pass the updated target_system_root to the compiler. */
205 static int target_system_root_changed;
207 /* Nonzero means append this string to target_system_root. */
209 static const char *target_sysroot_suffix = 0;
211 /* Nonzero means append this string to target_system_root for headers. */
213 static const char *target_sysroot_hdrs_suffix = 0;
215 /* Nonzero means write "temp" files in source directory
216 and use the source file's name in them, and don't delete them. */
218 static int save_temps_flag;
220 /* Nonzero means use pipes to communicate between subprocesses.
221 Overridden by either of the above two flags. */
223 static int use_pipes;
225 /* The compiler version. */
227 static const char *compiler_version;
229 /* The target version specified with -V */
231 static const char *const spec_version = DEFAULT_TARGET_VERSION;
233 /* The target machine specified with -b. */
235 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
237 /* Nonzero if cross-compiling.
238 When -b is used, the value comes from the `specs' file. */
240 #ifdef CROSS_COMPILE
241 static const char *cross_compile = "1";
242 #else
243 static const char *cross_compile = "0";
244 #endif
246 #ifdef MODIFY_TARGET_NAME
248 /* Information on how to alter the target name based on a command-line
249 switch. The only case we support now is simply appending or deleting a
250 string to or from the end of the first part of the configuration name. */
252 static const struct modify_target
254 const char *const sw;
255 const enum add_del {ADD, DELETE} add_del;
256 const char *const str;
258 modify_target[] = MODIFY_TARGET_NAME;
259 #endif
261 /* The number of errors that have occurred; the link phase will not be
262 run if this is nonzero. */
263 static int error_count = 0;
265 /* Greatest exit code of sub-processes that has been encountered up to
266 now. */
267 static int greatest_status = 1;
269 /* This is the obstack which we use to allocate many strings. */
271 static struct obstack obstack;
273 /* This is the obstack to build an environment variable to pass to
274 collect2 that describes all of the relevant switches of what to
275 pass the compiler in building the list of pointers to constructors
276 and destructors. */
278 static struct obstack collect_obstack;
280 /* These structs are used to collect resource usage information for
281 subprocesses. */
282 #ifdef HAVE_GETRUSAGE
283 static struct rusage rus, prus;
284 #endif
286 /* Forward declaration for prototypes. */
287 struct path_prefix;
289 static void init_spec (void);
290 static void store_arg (const char *, int, int);
291 static char *load_specs (const char *);
292 static void read_specs (const char *, int);
293 static void set_spec (const char *, const char *);
294 static struct compiler *lookup_compiler (const char *, size_t, const char *);
295 static char *build_search_list (struct path_prefix *, const char *, int);
296 static void putenv_from_prefixes (struct path_prefix *, const char *);
297 static int access_check (const char *, int);
298 static char *find_a_file (struct path_prefix *, const char *, int, int);
299 static void add_prefix (struct path_prefix *, const char *, const char *,
300 int, int, int *, int);
301 static void add_sysrooted_prefix (struct path_prefix *, const char *,
302 const char *, int, int, int *, int);
303 static void translate_options (int *, const char *const **);
304 static char *skip_whitespace (char *);
305 static void delete_if_ordinary (const char *);
306 static void delete_temp_files (void);
307 static void delete_failure_queue (void);
308 static void clear_failure_queue (void);
309 static int check_live_switch (int, int);
310 static const char *handle_braces (const char *);
311 static inline bool input_suffix_matches (const char *, const char *);
312 static inline bool switch_matches (const char *, const char *, int);
313 static inline void mark_matching_switches (const char *, const char *, int);
314 static inline void process_marked_switches (void);
315 static const char *process_brace_body (const char *, const char *, const char *, int, int);
316 static const struct spec_function *lookup_spec_function (const char *);
317 static const char *eval_spec_function (const char *, const char *);
318 static const char *handle_spec_function (const char *);
319 static char *save_string (const char *, int);
320 static void set_collect_gcc_options (void);
321 static int do_spec_1 (const char *, int, const char *);
322 static int do_spec_2 (const char *);
323 static void do_option_spec (const char *, const char *);
324 static void do_self_spec (const char *);
325 static const char *find_file (const char *);
326 static int is_directory (const char *, const char *, int);
327 static const char *validate_switches (const char *);
328 static void validate_all_switches (void);
329 static inline void validate_switches_from_spec (const char *);
330 static void give_switch (int, int);
331 static int used_arg (const char *, int);
332 static int default_arg (const char *, int);
333 static void set_multilib_dir (void);
334 static void print_multilib_info (void);
335 static void perror_with_name (const char *);
336 static void pfatal_pexecute (const char *, const char *) ATTRIBUTE_NORETURN;
337 static void notice (const char *, ...) ATTRIBUTE_PRINTF_1;
338 static void display_help (void);
339 static void add_preprocessor_option (const char *, int);
340 static void add_assembler_option (const char *, int);
341 static void add_linker_option (const char *, int);
342 static void process_command (int, const char *const *);
343 static int execute (void);
344 static void alloc_args (void);
345 static void clear_args (void);
346 static void fatal_error (int);
347 #ifdef ENABLE_SHARED_LIBGCC
348 static void init_gcc_specs (struct obstack *, const char *, const char *,
349 const char *);
350 #endif
351 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
352 static const char *convert_filename (const char *, int, int);
353 #endif
355 static const char *if_exists_spec_function (int, const char **);
356 static const char *if_exists_else_spec_function (int, const char **);
358 /* The Specs Language
360 Specs are strings containing lines, each of which (if not blank)
361 is made up of a program name, and arguments separated by spaces.
362 The program name must be exact and start from root, since no path
363 is searched and it is unreliable to depend on the current working directory.
364 Redirection of input or output is not supported; the subprograms must
365 accept filenames saying what files to read and write.
367 In addition, the specs can contain %-sequences to substitute variable text
368 or for conditional text. Here is a table of all defined %-sequences.
369 Note that spaces are not generated automatically around the results of
370 expanding these sequences; therefore, you can concatenate them together
371 or with constant text in a single argument.
373 %% substitute one % into the program name or argument.
374 %i substitute the name of the input file being processed.
375 %b substitute the basename of the input file being processed.
376 This is the substring up to (and not including) the last period
377 and not including the directory.
378 %B same as %b, but include the file suffix (text after the last period).
379 %gSUFFIX
380 substitute a file name that has suffix SUFFIX and is chosen
381 once per compilation, and mark the argument a la %d. To reduce
382 exposure to denial-of-service attacks, the file name is now
383 chosen in a way that is hard to predict even when previously
384 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
385 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
386 the regexp "[.A-Za-z]*%O"; "%O" is treated exactly as if it
387 had been pre-processed. Previously, %g was simply substituted
388 with a file name chosen once per compilation, without regard
389 to any appended suffix (which was therefore treated just like
390 ordinary text), making such attacks more likely to succeed.
391 %|SUFFIX
392 like %g, but if -pipe is in effect, expands simply to "-".
393 %mSUFFIX
394 like %g, but if -pipe is in effect, expands to nothing. (We have both
395 %| and %m to accommodate differences between system assemblers; see
396 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
397 %uSUFFIX
398 like %g, but generates a new temporary file name even if %uSUFFIX
399 was already seen.
400 %USUFFIX
401 substitutes the last file name generated with %uSUFFIX, generating a
402 new one if there is no such last file name. In the absence of any
403 %uSUFFIX, this is just like %gSUFFIX, except they don't share
404 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
405 would involve the generation of two distinct file names, one
406 for each `%g.s' and another for each `%U.s'. Previously, %U was
407 simply substituted with a file name chosen for the previous %u,
408 without regard to any appended suffix.
409 %jSUFFIX
410 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
411 writable, and if save-temps is off; otherwise, substitute the name
412 of a temporary file, just like %u. This temporary file is not
413 meant for communication between processes, but rather as a junk
414 disposal mechanism.
415 %.SUFFIX
416 substitutes .SUFFIX for the suffixes of a matched switch's args when
417 it is subsequently output with %*. SUFFIX is terminated by the next
418 space or %.
419 %d marks the argument containing or following the %d as a
420 temporary file name, so that that file will be deleted if CC exits
421 successfully. Unlike %g, this contributes no text to the argument.
422 %w marks the argument containing or following the %w as the
423 "output file" of this compilation. This puts the argument
424 into the sequence of arguments that %o will substitute later.
425 %V indicates that this compilation produces no "output file".
426 %W{...}
427 like %{...} but mark last argument supplied within
428 as a file to be deleted on failure.
429 %o substitutes the names of all the output files, with spaces
430 automatically placed around them. You should write spaces
431 around the %o as well or the results are undefined.
432 %o is for use in the specs for running the linker.
433 Input files whose names have no recognized suffix are not compiled
434 at all, but they are included among the output files, so they will
435 be linked.
436 %O substitutes the suffix for object files. Note that this is
437 handled specially when it immediately follows %g, %u, or %U
438 (with or without a suffix argument) because of the need for
439 those to form complete file names. The handling is such that
440 %O is treated exactly as if it had already been substituted,
441 except that %g, %u, and %U do not currently support additional
442 SUFFIX characters following %O as they would following, for
443 example, `.o'.
444 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
445 (made from TARGET_SYSTEM_ROOT), and -isystem (made from COMPILER_PATH
446 and -B options) as necessary.
447 %s current argument is the name of a library or startup file of some sort.
448 Search for that file in a standard list of directories
449 and substitute the full name found.
450 %eSTR Print STR as an error message. STR is terminated by a newline.
451 Use this when inconsistent options are detected.
452 %nSTR Print STR as a notice. STR is terminated by a newline.
453 %x{OPTION} Accumulate an option for %X.
454 %X Output the accumulated linker options specified by compilations.
455 %Y Output the accumulated assembler options specified by compilations.
456 %Z Output the accumulated preprocessor options specified by compilations.
457 %a process ASM_SPEC as a spec.
458 This allows config.h to specify part of the spec for running as.
459 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
460 used here. This can be used to run a post-processor after the
461 assembler has done its job.
462 %D Dump out a -L option for each directory in startfile_prefixes.
463 If multilib_dir is set, extra entries are generated with it affixed.
464 %l process LINK_SPEC as a spec.
465 %L process LIB_SPEC as a spec.
466 %G process LIBGCC_SPEC as a spec.
467 %M output multilib_dir with directory separators replaced with "_";
468 if multilib_dir is not set or is ".", output "".
469 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
470 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
471 %C process CPP_SPEC as a spec.
472 %1 process CC1_SPEC as a spec.
473 %2 process CC1PLUS_SPEC as a spec.
474 %* substitute the variable part of a matched option. (See below.)
475 Note that each comma in the substituted string is replaced by
476 a single space.
477 %<S remove all occurrences of -S from the command line.
478 Note - this command is position dependent. % commands in the
479 spec string before this one will see -S, % commands in the
480 spec string after this one will not.
481 %<S* remove all occurrences of all switches beginning with -S from the
482 command line.
483 %:function(args)
484 Call the named function FUNCTION, passing it ARGS. ARGS is
485 first processed as a nested spec string, then split into an
486 argument vector in the usual fashion. The function returns
487 a string which is processed as if it had appeared literally
488 as part of the current spec.
489 %{S} substitutes the -S switch, if that switch was given to CC.
490 If that switch was not specified, this substitutes nothing.
491 Here S is a metasyntactic variable.
492 %{S*} substitutes all the switches specified to CC whose names start
493 with -S. This is used for -o, -I, etc; switches that take
494 arguments. CC considers `-o foo' as being one switch whose
495 name starts with `o'. %{o*} would substitute this text,
496 including the space; thus, two arguments would be generated.
497 %{S*&T*} likewise, but preserve order of S and T options (the order
498 of S and T in the spec is not significant). Can be any number
499 of ampersand-separated variables; for each the wild card is
500 optional. Useful for CPP as %{D*&U*&A*}.
502 %{S:X} substitutes X, if the -S switch was given to CC.
503 %{!S:X} substitutes X, if the -S switch was NOT given to CC.
504 %{S*:X} substitutes X if one or more switches whose names start
505 with -S was given to CC. Normally X is substituted only
506 once, no matter how many such switches appeared. However,
507 if %* appears somewhere in X, then X will be substituted
508 once for each matching switch, with the %* replaced by the
509 part of that switch that matched the '*'.
510 %{.S:X} substitutes X, if processing a file with suffix S.
511 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
513 %{S|T:X} substitutes X if either -S or -T was given to CC. This may be
514 combined with !, ., and * as above binding stronger than the OR.
515 If %* appears in X, all of the alternatives must be starred, and
516 only the first matching alternative is substituted.
517 %{S:X; if S was given to CC, substitutes X;
518 T:Y; else if T was given to CC, substitutes Y;
519 :D} else substitutes D. There can be as many clauses as you need.
520 This may be combined with ., !, |, and * as above.
522 %(Spec) processes a specification defined in a specs file as *Spec:
523 %[Spec] as above, but put __ around -D arguments
525 The conditional text X in a %{S:X} or similar construct may contain
526 other nested % constructs or spaces, or even newlines. They are
527 processed as usual, as described above. Trailing white space in X is
528 ignored. White space may also appear anywhere on the left side of the
529 colon in these constructs, except between . or * and the corresponding
530 word.
532 The -O, -f, -m, and -W switches are handled specifically in these
533 constructs. If another value of -O or the negated form of a -f, -m, or
534 -W switch is found later in the command line, the earlier switch
535 value is ignored, except with {S*} where S is just one letter; this
536 passes all matching options.
538 The character | at the beginning of the predicate text is used to indicate
539 that a command should be piped to the following command, but only if -pipe
540 is specified.
542 Note that it is built into CC which switches take arguments and which
543 do not. You might think it would be useful to generalize this to
544 allow each compiler's spec to say which switches take arguments. But
545 this cannot be done in a consistent fashion. CC cannot even decide
546 which input files have been specified without knowing which switches
547 take arguments, and it must know which input files to compile in order
548 to tell which compilers to run.
550 CC also knows implicitly that arguments starting in `-l' are to be
551 treated as compiler output files, and passed to the linker in their
552 proper position among the other output files. */
554 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
556 /* config.h can define ASM_SPEC to provide extra args to the assembler
557 or extra switch-translations. */
558 #ifndef ASM_SPEC
559 #define ASM_SPEC ""
560 #endif
562 /* config.h can define ASM_FINAL_SPEC to run a post processor after
563 the assembler has run. */
564 #ifndef ASM_FINAL_SPEC
565 #define ASM_FINAL_SPEC ""
566 #endif
568 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
569 or extra switch-translations. */
570 #ifndef CPP_SPEC
571 #define CPP_SPEC ""
572 #endif
574 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
575 or extra switch-translations. */
576 #ifndef CC1_SPEC
577 #define CC1_SPEC ""
578 #endif
580 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
581 or extra switch-translations. */
582 #ifndef CC1PLUS_SPEC
583 #define CC1PLUS_SPEC ""
584 #endif
586 /* config.h can define LINK_SPEC to provide extra args to the linker
587 or extra switch-translations. */
588 #ifndef LINK_SPEC
589 #define LINK_SPEC ""
590 #endif
592 /* config.h can define LIB_SPEC to override the default libraries. */
593 #ifndef LIB_SPEC
594 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
595 #endif
597 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
598 included. */
599 #ifndef LIBGCC_SPEC
600 #if defined(LINK_LIBGCC_SPECIAL) || defined(LINK_LIBGCC_SPECIAL_1)
601 /* Have gcc do the search for libgcc.a. */
602 #define LIBGCC_SPEC "libgcc.a%s"
603 #else
604 #define LIBGCC_SPEC "-lgcc"
605 #endif
606 #endif
608 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
609 #ifndef STARTFILE_SPEC
610 #define STARTFILE_SPEC \
611 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
612 #endif
614 /* config.h can define SWITCHES_NEED_SPACES to control which options
615 require spaces between the option and the argument. */
616 #ifndef SWITCHES_NEED_SPACES
617 #define SWITCHES_NEED_SPACES ""
618 #endif
620 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
621 #ifndef ENDFILE_SPEC
622 #define ENDFILE_SPEC ""
623 #endif
625 #ifndef LINKER_NAME
626 #define LINKER_NAME "collect2"
627 #endif
629 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
630 to the assembler. */
631 #ifndef ASM_DEBUG_SPEC
632 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
633 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
634 # define ASM_DEBUG_SPEC \
635 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
636 ? "%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}" \
637 : "%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}")
638 # else
639 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
640 # define ASM_DEBUG_SPEC "%{g*:--gstabs}"
641 # endif
642 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
643 # define ASM_DEBUG_SPEC "%{g*:--gdwarf2}"
644 # endif
645 # endif
646 #endif
647 #ifndef ASM_DEBUG_SPEC
648 # define ASM_DEBUG_SPEC ""
649 #endif
651 /* Here is the spec for running the linker, after compiling all files. */
653 /* This is overridable by the target in case they need to specify the
654 -lgcc and -lc order specially, yet not require them to override all
655 of LINK_COMMAND_SPEC. */
656 #ifndef LINK_GCC_C_SEQUENCE_SPEC
657 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
658 #endif
660 #ifndef LINK_PIE_SPEC
661 #ifdef HAVE_LD_PIE
662 #define LINK_PIE_SPEC "%{pie:-pie} "
663 #else
664 #define LINK_PIE_SPEC "%{pie:} "
665 #endif
666 #endif
668 /* -u* was put back because both BSD and SysV seem to support it. */
669 /* %{static:} simply prevents an error message if the target machine
670 doesn't handle -static. */
671 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
672 scripts which exist in user specified directories, or in standard
673 directories. */
674 #ifndef LINK_COMMAND_SPEC
675 #define LINK_COMMAND_SPEC "\
676 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
677 %(linker) %l " LINK_PIE_SPEC "%X %{o*} %{A} %{d} %{e*} %{m} %{N} %{n} %{r}\
678 %{s} %{t} %{u*} %{x} %{z} %{Z} %{!A:%{!nostdlib:%{!nostartfiles:%S}}}\
679 %{static:} %{L*} %(link_libgcc) %o %{fprofile-arcs:-lgcov}\
680 %{!nostdlib:%{!nodefaultlibs:%(link_gcc_c_sequence)}}\
681 %{!A:%{!nostdlib:%{!nostartfiles:%E}}} %{T*} }}}}}}"
682 #endif
684 #ifndef LINK_LIBGCC_SPEC
685 # ifdef LINK_LIBGCC_SPECIAL
686 /* Don't generate -L options for startfile prefix list. */
687 # define LINK_LIBGCC_SPEC ""
688 # else
689 /* Do generate them. */
690 # define LINK_LIBGCC_SPEC "%D"
691 # endif
692 #endif
694 #ifndef STARTFILE_PREFIX_SPEC
695 # define STARTFILE_PREFIX_SPEC ""
696 #endif
698 #ifndef SYSROOT_SUFFIX_SPEC
699 # define SYSROOT_SUFFIX_SPEC ""
700 #endif
702 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
703 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
704 #endif
706 static const char *asm_debug;
707 static const char *cpp_spec = CPP_SPEC;
708 static const char *cc1_spec = CC1_SPEC;
709 static const char *cc1plus_spec = CC1PLUS_SPEC;
710 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
711 static const char *asm_spec = ASM_SPEC;
712 static const char *asm_final_spec = ASM_FINAL_SPEC;
713 static const char *link_spec = LINK_SPEC;
714 static const char *lib_spec = LIB_SPEC;
715 static const char *libgcc_spec = LIBGCC_SPEC;
716 static const char *endfile_spec = ENDFILE_SPEC;
717 static const char *startfile_spec = STARTFILE_SPEC;
718 static const char *switches_need_spaces = SWITCHES_NEED_SPACES;
719 static const char *linker_name_spec = LINKER_NAME;
720 static const char *link_command_spec = LINK_COMMAND_SPEC;
721 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
722 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
723 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
724 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
726 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
727 There should be no need to override these in target dependent files,
728 but we need to copy them to the specs file so that newer versions
729 of the GCC driver can correctly drive older tool chains with the
730 appropriate -B options. */
732 /* When cpplib handles traditional preprocessing, get rid of this, and
733 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
734 that we default the front end language better. */
735 static const char *trad_capable_cpp =
736 "cc1 -E %{traditional|ftraditional|traditional-cpp:-traditional-cpp}";
738 /* We don't wrap .d files in %W{} since a missing .d file, and
739 therefore no dependency entry, confuses make into thinking a .o
740 file that happens to exist is up-to-date. */
741 static const char *cpp_unique_options =
742 "%{C|CC:%{!E:%eGCC does not support -C or -CC without -E}}\
743 %{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*} %{P} %I\
744 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
745 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
746 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
747 %{!E:%{!M:%{!MM:%{MD|MMD:%{o*:-MQ %*}}}}}\
748 %{trigraphs} %{remap} %{g3:-dD} %{H} %C %{D*&U*&A*} %{i*} %Z %i\
749 %{E|M|MM:%W{o*}}";
751 /* This contains cpp options which are common with cc1_options and are passed
752 only when preprocessing only to avoid duplication. We pass the cc1 spec
753 options to the preprocessor so that it the cc1 spec may manipulate
754 options used to set target flags. Those special target flags settings may
755 in turn cause preprocessor symbols to be defined specially. */
756 static const char *cpp_options =
757 "%(cpp_unique_options) %1 %{m*} %{std*} %{ansi} %{W*&pedantic*} %{w} %{f*}\
758 %{g*:%{!g0:%{!fno-working-directory:-fworking-directory}}} %{O*} %{undef}";
760 /* This contains cpp options which are not passed when the preprocessor
761 output will be used by another program. */
762 static const char *cpp_debug_options = "%{d*}";
764 /* NB: This is shared amongst all front-ends. */
765 static const char *cc1_options =
766 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
767 %1 %{!Q:-quiet} -dumpbase %B %{d*} %{m*} %{a*}\
768 -auxbase%{c|S:%{o*:-strip %*}%{!o*: %b}}%{!c:%{!S: %b}}\
769 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*} %{ansi}\
770 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
771 %{Qn:-fno-ident} %{--help:--help}\
772 %{--target-help:--target-help}\
773 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
774 %{fsyntax-only:-o %j} %{-param*}";
776 static const char *asm_options =
777 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
779 static const char *invoke_as =
780 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
781 "%{!S:-o %|.s |\n as %(asm_options) %|.s %A }";
782 #else
783 "%{!S:-o %|.s |\n as %(asm_options) %m.s %A }";
784 #endif
786 /* Some compilers have limits on line lengths, and the multilib_select
787 and/or multilib_matches strings can be very long, so we build them at
788 run time. */
789 static struct obstack multilib_obstack;
790 static const char *multilib_select;
791 static const char *multilib_matches;
792 static const char *multilib_defaults;
793 static const char *multilib_exclusions;
794 #include "multilib.h"
796 /* Check whether a particular argument is a default argument. */
798 #ifndef MULTILIB_DEFAULTS
799 #define MULTILIB_DEFAULTS { "" }
800 #endif
802 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
804 #ifndef DRIVER_SELF_SPECS
805 #define DRIVER_SELF_SPECS ""
806 #endif
808 static const char *const driver_self_specs[] = { DRIVER_SELF_SPECS };
810 #ifndef OPTION_DEFAULT_SPECS
811 #define OPTION_DEFAULT_SPECS { "", "" }
812 #endif
814 struct default_spec
816 const char *name;
817 const char *spec;
820 static const struct default_spec
821 option_default_specs[] = { OPTION_DEFAULT_SPECS };
823 struct user_specs
825 struct user_specs *next;
826 const char *filename;
829 static struct user_specs *user_specs_head, *user_specs_tail;
831 #ifndef SWITCH_TAKES_ARG
832 #define SWITCH_TAKES_ARG(CHAR) DEFAULT_SWITCH_TAKES_ARG(CHAR)
833 #endif
835 #ifndef WORD_SWITCH_TAKES_ARG
836 #define WORD_SWITCH_TAKES_ARG(STR) DEFAULT_WORD_SWITCH_TAKES_ARG (STR)
837 #endif
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')
844 #ifndef SWITCH_CURTAILS_COMPILATION
845 #define SWITCH_CURTAILS_COMPILATION(CHAR) \
846 DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR)
847 #endif
848 #endif
850 /* Record the mapping from file suffixes for compilation specs. */
852 struct compiler
854 const char *suffix; /* Use this compiler for input files
855 whose names end in this suffix. */
857 const char *spec; /* To use this compiler, run this spec. */
859 const char *cpp_spec; /* If non-NULL, substitute this spec
860 for `%C', rather than the usual
861 cpp_spec. */
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.
869 An entry containing two 0s is used to terminate the vector.
871 If multiple entries match a file, the last matching one is used. */
873 static struct compiler *compilers;
875 /* Number of entries in `compilers', not counting the null terminator. */
877 static int n_compilers;
879 /* The default list of file name suffixes and their compilation specs. */
881 static const struct compiler default_compilers[] =
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},
954 #include "specs.h"
955 /* Mark end of table. */
956 {0, 0, 0}
959 /* Number of elements in default_compilers, not counting the terminator. */
961 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
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;
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;
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;
981 /* Define how to map long options into short ones. */
983 /* This structure describes one mapping. */
984 struct option_map
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;
998 /* This is the table of mappings. Mappings are tried sequentially
999 for each option encountered; the first one that matches, wins. */
1001 static const struct option_map option_map[] =
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"}
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[] =
1092 TARGET_OPTION_TRANSLATE_TABLE,
1093 { 0, 0 }
1095 #endif
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. */
1101 static void
1102 translate_options (int *argcp, const char *const **argvp)
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;
1111 i = 0;
1112 newv[newindex++] = argv[i++];
1114 while (i < argc)
1116 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1117 int tott_idx;
1119 for (tott_idx = 0;
1120 target_option_translations[tott_idx].option_found;
1121 tott_idx++)
1123 if (strcmp (target_option_translations[tott_idx].option_found,
1124 argv[i]) == 0)
1126 int spaces = 1;
1127 const char *sp;
1128 char *np;
1130 for (sp = target_option_translations[tott_idx].replacements;
1131 *sp; sp++)
1133 if (*sp == ' ')
1134 spaces ++;
1137 newvsize += spaces * sizeof (const char *);
1138 newv = xrealloc (newv, newvsize);
1140 sp = target_option_translations[tott_idx].replacements;
1141 np = xstrdup (sp);
1143 while (1)
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;
1157 i ++;
1158 break;
1161 if (target_option_translations[tott_idx].option_found)
1162 continue;
1163 #endif
1165 /* Translate -- options. */
1166 if (argv[i][0] == '-' && argv[i][1] == '-')
1168 size_t j;
1169 /* Find a mapping that applies to this option. */
1170 for (j = 0; j < ARRAY_SIZE (option_map); j++)
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;
1177 if (arginfo == 0)
1178 arginfo = "";
1180 if (!strncmp (argv[i], option_map[j].name, complen))
1182 const char *arg = 0;
1184 if (arglen < optlen)
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))
1191 error ("ambiguous abbreviation %s", argv[i]);
1192 break;
1195 if (k != ARRAY_SIZE (option_map))
1196 break;
1199 if (arglen > optlen)
1201 /* If the option has an argument, accept that. */
1202 if (argv[i][optlen] == '=')
1203 arg = argv[i] + optlen + 1;
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;
1210 /* Otherwise, extra text at end means mismatch.
1211 Try other mappings. */
1212 else
1213 continue;
1216 else if (strchr (arginfo, '*') != 0)
1218 error ("incomplete `%s' option", option_map[j].name);
1219 break;
1222 /* Handle arguments. */
1223 if (strchr (arginfo, 'a') != 0)
1225 if (arg == 0)
1227 if (i + 1 == argc)
1229 error ("missing argument to `%s' option",
1230 option_map[j].name);
1231 break;
1234 arg = argv[++i];
1237 else if (strchr (arginfo, '*') != 0)
1239 else if (strchr (arginfo, 'o') == 0)
1241 if (arg != 0)
1242 error ("extraneous argument to `%s' option",
1243 option_map[j].name);
1244 arg = 0;
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)
1253 newv[newindex++] = option_map[j].equivalent;
1254 newv[newindex++] = arg;
1256 else
1257 newv[newindex++] = option_map[j].equivalent;
1259 break;
1262 i++;
1265 /* Handle old-fashioned options--just copy them through,
1266 with their arguments. */
1267 else if (argv[i][0] == '-')
1269 const char *p = argv[i] + 1;
1270 int c = *p;
1271 int nskip = 1;
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;
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;
1293 while (nskip > 0)
1295 newv[newindex++] = argv[i++];
1296 nskip--;
1299 else
1300 /* Ordinary operands, or +e options. */
1301 newv[newindex++] = argv[i++];
1304 newv[newindex] = 0;
1306 *argvp = newv;
1307 *argcp = newindex;
1310 static char *
1311 skip_whitespace (char *p)
1313 while (1)
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 == '#')
1323 while (*p != '\n')
1324 p++;
1325 p++;
1327 else
1328 break;
1331 return p;
1333 /* Structures to keep track of prefixes to try when looking for files. */
1335 struct prefix_list
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. */
1347 struct path_prefix
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) */
1354 /* List of prefixes to try when looking for executables. */
1356 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1358 /* List of prefixes to try when looking for startup (crt0) files. */
1360 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1362 /* List of prefixes to try when looking for include files. */
1364 static struct path_prefix include_prefixes = { 0, 0, "include" };
1366 /* Suffix to attach to directories searched for commands.
1367 This looks like `MACHINE/VERSION/'. */
1369 static const char *machine_suffix = 0;
1371 /* Suffix to attach to directories searched for commands.
1372 This is just `MACHINE/'. */
1374 static const char *just_machine_suffix = 0;
1376 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1378 static const char *gcc_exec_prefix;
1380 /* Adjusted value of standard_libexec_prefix. */
1382 static const char *gcc_libexec_prefix;
1384 /* Default prefixes to attach to command names. */
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
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
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;
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/";
1414 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1415 static const char *tooldir_prefix;
1417 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1419 static const char *standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1421 /* Subdirectory to use for locating libraries. Set by
1422 set_multilib_dir based on the compilation options. */
1424 static const char *multilib_dir;
1426 /* Subdirectory to use for locating libraries in OS conventions. Set by
1427 set_multilib_dir based on the compilation options. */
1429 static const char *multilib_os_dir;
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. */
1435 struct spec_list
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 */
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 */
1450 #define INIT_STATIC_SPEC(NAME,PTR) \
1451 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, 0 }
1453 /* List of statically defined specs. */
1454 static struct spec_list static_specs[] =
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),
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
1499 const char *const name;
1500 const char *const ptr;
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
1507 /* List of dynamically allocates specs that have been defined so far. */
1509 static struct spec_list *specs = (struct spec_list *) 0;
1511 /* List of static spec functions. */
1513 static const struct spec_function static_spec_functions[] =
1515 { "if-exists", if_exists_spec_function },
1516 { "if-exists-else", if_exists_else_spec_function },
1517 { 0, 0 }
1520 static int processing_spec_function;
1522 /* Add appropriate libgcc specs to OBSTACK, taking into account
1523 various permutations of -shared-libgcc, -shared, and such. */
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)
1530 char *buf;
1532 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name,
1533 "}%{!static:%{!static-libgcc:",
1534 "%{!shared:%{!shared-libgcc:", static_name, " ",
1535 eh_name, "}%{shared-libgcc:", shared_name, " ",
1536 static_name, "}}%{shared:",
1537 #ifdef LINK_EH_SPEC
1538 "%{shared-libgcc:", shared_name,
1539 "}%{!shared-libgcc:", static_name, "}",
1540 #else
1541 shared_name,
1542 #endif
1543 "}}}", NULL);
1545 obstack_grow (obstack, buf, strlen (buf));
1546 free (buf);
1548 #endif /* ENABLE_SHARED_LIBGCC */
1550 /* Initialize the specs lookup routines. */
1552 static void
1553 init_spec (void)
1555 struct spec_list *next = (struct spec_list *) 0;
1556 struct spec_list *sl = (struct spec_list *) 0;
1557 int i;
1559 if (specs)
1560 return; /* Already initialized. */
1562 if (verbose_flag)
1563 notice ("Using built-in specs.\n");
1565 #ifdef EXTRA_SPECS
1566 extra_specs = xcalloc (sizeof (struct spec_list),
1567 ARRAY_SIZE (extra_specs_1));
1569 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1571 sl = &extra_specs[i];
1572 sl->name = extra_specs_1[i].name;
1573 sl->ptr = extra_specs_1[i].ptr;
1574 sl->next = next;
1575 sl->name_len = strlen (sl->name);
1576 sl->ptr_spec = &sl->ptr;
1577 next = sl;
1579 #endif
1581 /* Initialize here, not in definition. The IRIX 6 O32 cc sometimes chokes
1582 on ?: in file-scope variable initializations. */
1583 asm_debug = ASM_DEBUG_SPEC;
1585 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1587 sl = &static_specs[i];
1588 sl->next = next;
1589 next = sl;
1592 #ifdef ENABLE_SHARED_LIBGCC
1593 /* ??? If neither -shared-libgcc nor --static-libgcc was
1594 seen, then we should be making an educated guess. Some proposed
1595 heuristics for ELF include:
1597 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1598 program will be doing dynamic loading, which will likely
1599 need the shared libgcc.
1601 (2) If "-ldl", then it's also a fair bet that we're doing
1602 dynamic loading.
1604 (3) For each ET_DYN we're linking against (either through -lfoo
1605 or /some/path/foo.so), check to see whether it or one of
1606 its dependencies depends on a shared libgcc.
1608 (4) If "-shared"
1610 If the runtime is fixed to look for program headers instead
1611 of calling __register_frame_info at all, for each object,
1612 use the shared libgcc if any EH symbol referenced.
1614 If crtstuff is fixed to not invoke __register_frame_info
1615 automatically, for each object, use the shared libgcc if
1616 any non-empty unwind section found.
1618 Doing any of this probably requires invoking an external program to
1619 do the actual object file scanning. */
1621 const char *p = libgcc_spec;
1622 int in_sep = 1;
1624 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1625 when given the proper command line arguments. */
1626 while (*p)
1628 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1630 init_gcc_specs (&obstack,
1631 #ifdef NO_SHARED_LIBGCC_MULTILIB
1632 "-lgcc_s"
1633 #else
1634 "-lgcc_s%M"
1635 #endif
1637 "-lgcc",
1638 "-lgcc_eh"
1639 #ifdef USE_LIBUNWIND_EXCEPTIONS
1640 " -lunwind"
1641 #endif
1644 p += 5;
1645 in_sep = 0;
1647 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1649 /* Ug. We don't know shared library extensions. Hope that
1650 systems that use this form don't do shared libraries. */
1651 init_gcc_specs (&obstack,
1652 #ifdef NO_SHARED_LIBGCC_MULTILIB
1653 "-lgcc_s"
1654 #else
1655 "-lgcc_s%M"
1656 #endif
1658 "libgcc.a%s",
1659 "libgcc_eh.a%s"
1660 #ifdef USE_LIBUNWIND_EXCEPTIONS
1661 " -lunwind"
1662 #endif
1664 p += 10;
1665 in_sep = 0;
1667 else
1669 obstack_1grow (&obstack, *p);
1670 in_sep = (*p == ' ');
1671 p += 1;
1675 obstack_1grow (&obstack, '\0');
1676 libgcc_spec = obstack_finish (&obstack);
1678 #endif
1679 #ifdef USE_AS_TRADITIONAL_FORMAT
1680 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1682 static const char tf[] = "--traditional-format ";
1683 obstack_grow (&obstack, tf, sizeof(tf) - 1);
1684 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1685 asm_spec = obstack_finish (&obstack);
1687 #endif
1688 #ifdef LINK_EH_SPEC
1689 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1690 obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1691 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1692 link_spec = obstack_finish (&obstack);
1693 #endif
1695 specs = sl;
1698 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1699 removed; If the spec starts with a + then SPEC is added to the end of the
1700 current spec. */
1702 static void
1703 set_spec (const char *name, const char *spec)
1705 struct spec_list *sl;
1706 const char *old_spec;
1707 int name_len = strlen (name);
1708 int i;
1710 /* If this is the first call, initialize the statically allocated specs. */
1711 if (!specs)
1713 struct spec_list *next = (struct spec_list *) 0;
1714 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1716 sl = &static_specs[i];
1717 sl->next = next;
1718 next = sl;
1720 specs = sl;
1723 /* See if the spec already exists. */
1724 for (sl = specs; sl; sl = sl->next)
1725 if (name_len == sl->name_len && !strcmp (sl->name, name))
1726 break;
1728 if (!sl)
1730 /* Not found - make it. */
1731 sl = xmalloc (sizeof (struct spec_list));
1732 sl->name = xstrdup (name);
1733 sl->name_len = name_len;
1734 sl->ptr_spec = &sl->ptr;
1735 sl->alloc_p = 0;
1736 *(sl->ptr_spec) = "";
1737 sl->next = specs;
1738 specs = sl;
1741 old_spec = *(sl->ptr_spec);
1742 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1743 ? concat (old_spec, spec + 1, NULL)
1744 : xstrdup (spec));
1746 #ifdef DEBUG_SPECS
1747 if (verbose_flag)
1748 notice ("Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1749 #endif
1751 /* Free the old spec. */
1752 if (old_spec && sl->alloc_p)
1753 free ((void *) old_spec);
1755 sl->alloc_p = 1;
1758 /* Accumulate a command (program name and args), and run it. */
1760 /* Vector of pointers to arguments in the current line of specifications. */
1762 static const char **argbuf;
1764 /* Number of elements allocated in argbuf. */
1766 static int argbuf_length;
1768 /* Number of elements in argbuf currently in use (containing args). */
1770 static int argbuf_index;
1772 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1773 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1774 it here. */
1776 static struct temp_name {
1777 const char *suffix; /* suffix associated with the code. */
1778 int length; /* strlen (suffix). */
1779 int unique; /* Indicates whether %g or %u/%U was used. */
1780 const char *filename; /* associated filename. */
1781 int filename_length; /* strlen (filename). */
1782 struct temp_name *next;
1783 } *temp_names;
1785 /* Number of commands executed so far. */
1787 static int execution_count;
1789 /* Number of commands that exited with a signal. */
1791 static int signal_count;
1793 /* Name with which this program was invoked. */
1795 static const char *programname;
1797 /* Allocate the argument vector. */
1799 static void
1800 alloc_args (void)
1802 argbuf_length = 10;
1803 argbuf = xmalloc (argbuf_length * sizeof (const char *));
1806 /* Clear out the vector of arguments (after a command is executed). */
1808 static void
1809 clear_args (void)
1811 argbuf_index = 0;
1814 /* Add one argument to the vector at the end.
1815 This is done when a space is seen or at the end of the line.
1816 If DELETE_ALWAYS is nonzero, the arg is a filename
1817 and the file should be deleted eventually.
1818 If DELETE_FAILURE is nonzero, the arg is a filename
1819 and the file should be deleted if this compilation fails. */
1821 static void
1822 store_arg (const char *arg, int delete_always, int delete_failure)
1824 if (argbuf_index + 1 == argbuf_length)
1825 argbuf = xrealloc (argbuf, (argbuf_length *= 2) * sizeof (const char *));
1827 argbuf[argbuf_index++] = arg;
1828 argbuf[argbuf_index] = 0;
1830 if (delete_always || delete_failure)
1831 record_temp_file (arg, delete_always, delete_failure);
1834 /* Load specs from a file name named FILENAME, replacing occurrences of
1835 various different types of line-endings, \r\n, \n\r and just \r, with
1836 a single \n. */
1838 static char *
1839 load_specs (const char *filename)
1841 int desc;
1842 int readlen;
1843 struct stat statbuf;
1844 char *buffer;
1845 char *buffer_p;
1846 char *specs;
1847 char *specs_p;
1849 if (verbose_flag)
1850 notice ("Reading specs from %s\n", filename);
1852 /* Open and stat the file. */
1853 desc = open (filename, O_RDONLY, 0);
1854 if (desc < 0)
1855 pfatal_with_name (filename);
1856 if (stat (filename, &statbuf) < 0)
1857 pfatal_with_name (filename);
1859 /* Read contents of file into BUFFER. */
1860 buffer = xmalloc ((unsigned) statbuf.st_size + 1);
1861 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1862 if (readlen < 0)
1863 pfatal_with_name (filename);
1864 buffer[readlen] = 0;
1865 close (desc);
1867 specs = xmalloc (readlen + 1);
1868 specs_p = specs;
1869 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1871 int skip = 0;
1872 char c = *buffer_p;
1873 if (c == '\r')
1875 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1876 skip = 1;
1877 else if (*(buffer_p + 1) == '\n') /* \r\n */
1878 skip = 1;
1879 else /* \r */
1880 c = '\n';
1882 if (! skip)
1883 *specs_p++ = c;
1885 *specs_p = '\0';
1887 free (buffer);
1888 return (specs);
1891 /* Read compilation specs from a file named FILENAME,
1892 replacing the default ones.
1894 A suffix which starts with `*' is a definition for
1895 one of the machine-specific sub-specs. The "suffix" should be
1896 *asm, *cc1, *cpp, *link, *startfile, etc.
1897 The corresponding spec is stored in asm_spec, etc.,
1898 rather than in the `compilers' vector.
1900 Anything invalid in the file is a fatal error. */
1902 static void
1903 read_specs (const char *filename, int main_p)
1905 char *buffer;
1906 char *p;
1908 buffer = load_specs (filename);
1910 /* Scan BUFFER for specs, putting them in the vector. */
1911 p = buffer;
1912 while (1)
1914 char *suffix;
1915 char *spec;
1916 char *in, *out, *p1, *p2, *p3;
1918 /* Advance P in BUFFER to the next nonblank nocomment line. */
1919 p = skip_whitespace (p);
1920 if (*p == 0)
1921 break;
1923 /* Is this a special command that starts with '%'? */
1924 /* Don't allow this for the main specs file, since it would
1925 encourage people to overwrite it. */
1926 if (*p == '%' && !main_p)
1928 p1 = p;
1929 while (*p && *p != '\n')
1930 p++;
1932 /* Skip '\n'. */
1933 p++;
1935 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1936 && (p1[sizeof "%include" - 1] == ' '
1937 || p1[sizeof "%include" - 1] == '\t'))
1939 char *new_filename;
1941 p1 += sizeof ("%include");
1942 while (*p1 == ' ' || *p1 == '\t')
1943 p1++;
1945 if (*p1++ != '<' || p[-2] != '>')
1946 fatal ("specs %%include syntax malformed after %ld characters",
1947 (long) (p1 - buffer + 1));
1949 p[-2] = '\0';
1950 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, 0);
1951 read_specs (new_filename ? new_filename : p1, FALSE);
1952 continue;
1954 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1955 && (p1[sizeof "%include_noerr" - 1] == ' '
1956 || p1[sizeof "%include_noerr" - 1] == '\t'))
1958 char *new_filename;
1960 p1 += sizeof "%include_noerr";
1961 while (*p1 == ' ' || *p1 == '\t')
1962 p1++;
1964 if (*p1++ != '<' || p[-2] != '>')
1965 fatal ("specs %%include syntax malformed after %ld characters",
1966 (long) (p1 - buffer + 1));
1968 p[-2] = '\0';
1969 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, 0);
1970 if (new_filename)
1971 read_specs (new_filename, FALSE);
1972 else if (verbose_flag)
1973 notice ("could not find specs file %s\n", p1);
1974 continue;
1976 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1977 && (p1[sizeof "%rename" - 1] == ' '
1978 || p1[sizeof "%rename" - 1] == '\t'))
1980 int name_len;
1981 struct spec_list *sl;
1982 struct spec_list *newsl;
1984 /* Get original name. */
1985 p1 += sizeof "%rename";
1986 while (*p1 == ' ' || *p1 == '\t')
1987 p1++;
1989 if (! ISALPHA ((unsigned char) *p1))
1990 fatal ("specs %%rename syntax malformed after %ld characters",
1991 (long) (p1 - buffer));
1993 p2 = p1;
1994 while (*p2 && !ISSPACE ((unsigned char) *p2))
1995 p2++;
1997 if (*p2 != ' ' && *p2 != '\t')
1998 fatal ("specs %%rename syntax malformed after %ld characters",
1999 (long) (p2 - buffer));
2001 name_len = p2 - p1;
2002 *p2++ = '\0';
2003 while (*p2 == ' ' || *p2 == '\t')
2004 p2++;
2006 if (! ISALPHA ((unsigned char) *p2))
2007 fatal ("specs %%rename syntax malformed after %ld characters",
2008 (long) (p2 - buffer));
2010 /* Get new spec name. */
2011 p3 = p2;
2012 while (*p3 && !ISSPACE ((unsigned char) *p3))
2013 p3++;
2015 if (p3 != p - 1)
2016 fatal ("specs %%rename syntax malformed after %ld characters",
2017 (long) (p3 - buffer));
2018 *p3 = '\0';
2020 for (sl = specs; sl; sl = sl->next)
2021 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2022 break;
2024 if (!sl)
2025 fatal ("specs %s spec was not found to be renamed", p1);
2027 if (strcmp (p1, p2) == 0)
2028 continue;
2030 for (newsl = specs; newsl; newsl = newsl->next)
2031 if (strcmp (newsl->name, p2) == 0)
2032 fatal ("%s: attempt to rename spec '%s' to already defined spec '%s'",
2033 filename, p1, p2);
2035 if (verbose_flag)
2037 notice ("rename spec %s to %s\n", p1, p2);
2038 #ifdef DEBUG_SPECS
2039 notice ("spec is '%s'\n\n", *(sl->ptr_spec));
2040 #endif
2043 set_spec (p2, *(sl->ptr_spec));
2044 if (sl->alloc_p)
2045 free ((void *) *(sl->ptr_spec));
2047 *(sl->ptr_spec) = "";
2048 sl->alloc_p = 0;
2049 continue;
2051 else
2052 fatal ("specs unknown %% command after %ld characters",
2053 (long) (p1 - buffer));
2056 /* Find the colon that should end the suffix. */
2057 p1 = p;
2058 while (*p1 && *p1 != ':' && *p1 != '\n')
2059 p1++;
2061 /* The colon shouldn't be missing. */
2062 if (*p1 != ':')
2063 fatal ("specs file malformed after %ld characters",
2064 (long) (p1 - buffer));
2066 /* Skip back over trailing whitespace. */
2067 p2 = p1;
2068 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2069 p2--;
2071 /* Copy the suffix to a string. */
2072 suffix = save_string (p, p2 - p);
2073 /* Find the next line. */
2074 p = skip_whitespace (p1 + 1);
2075 if (p[1] == 0)
2076 fatal ("specs file malformed after %ld characters",
2077 (long) (p - buffer));
2079 p1 = p;
2080 /* Find next blank line or end of string. */
2081 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2082 p1++;
2084 /* Specs end at the blank line and do not include the newline. */
2085 spec = save_string (p, p1 - p);
2086 p = p1;
2088 /* Delete backslash-newline sequences from the spec. */
2089 in = spec;
2090 out = spec;
2091 while (*in != 0)
2093 if (in[0] == '\\' && in[1] == '\n')
2094 in += 2;
2095 else if (in[0] == '#')
2096 while (*in && *in != '\n')
2097 in++;
2099 else
2100 *out++ = *in++;
2102 *out = 0;
2104 if (suffix[0] == '*')
2106 if (! strcmp (suffix, "*link_command"))
2107 link_command_spec = spec;
2108 else
2109 set_spec (suffix + 1, spec);
2111 else
2113 /* Add this pair to the vector. */
2114 compilers
2115 = xrealloc (compilers,
2116 (n_compilers + 2) * sizeof (struct compiler));
2118 compilers[n_compilers].suffix = suffix;
2119 compilers[n_compilers].spec = spec;
2120 n_compilers++;
2121 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2124 if (*suffix == 0)
2125 link_command_spec = spec;
2128 if (link_command_spec == 0)
2129 fatal ("spec file has no spec for linking");
2132 /* Record the names of temporary files we tell compilers to write,
2133 and delete them at the end of the run. */
2135 /* This is the common prefix we use to make temp file names.
2136 It is chosen once for each run of this program.
2137 It is substituted into a spec by %g or %j.
2138 Thus, all temp file names contain this prefix.
2139 In practice, all temp file names start with this prefix.
2141 This prefix comes from the envvar TMPDIR if it is defined;
2142 otherwise, from the P_tmpdir macro if that is defined;
2143 otherwise, in /usr/tmp or /tmp;
2144 or finally the current directory if all else fails. */
2146 static const char *temp_filename;
2148 /* Length of the prefix. */
2150 static int temp_filename_length;
2152 /* Define the list of temporary files to delete. */
2154 struct temp_file
2156 const char *name;
2157 struct temp_file *next;
2160 /* Queue of files to delete on success or failure of compilation. */
2161 static struct temp_file *always_delete_queue;
2162 /* Queue of files to delete on failure of compilation. */
2163 static struct temp_file *failure_delete_queue;
2165 /* Record FILENAME as a file to be deleted automatically.
2166 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2167 otherwise delete it in any case.
2168 FAIL_DELETE nonzero means delete it if a compilation step fails;
2169 otherwise delete it in any case. */
2171 void
2172 record_temp_file (const char *filename, int always_delete, int fail_delete)
2174 char *const name = xstrdup (filename);
2176 if (always_delete)
2178 struct temp_file *temp;
2179 for (temp = always_delete_queue; temp; temp = temp->next)
2180 if (! strcmp (name, temp->name))
2181 goto already1;
2183 temp = xmalloc (sizeof (struct temp_file));
2184 temp->next = always_delete_queue;
2185 temp->name = name;
2186 always_delete_queue = temp;
2188 already1:;
2191 if (fail_delete)
2193 struct temp_file *temp;
2194 for (temp = failure_delete_queue; temp; temp = temp->next)
2195 if (! strcmp (name, temp->name))
2196 goto already2;
2198 temp = xmalloc (sizeof (struct temp_file));
2199 temp->next = failure_delete_queue;
2200 temp->name = name;
2201 failure_delete_queue = temp;
2203 already2:;
2207 /* Delete all the temporary files whose names we previously recorded. */
2209 static void
2210 delete_if_ordinary (const char *name)
2212 struct stat st;
2213 #ifdef DEBUG
2214 int i, c;
2216 printf ("Delete %s? (y or n) ", name);
2217 fflush (stdout);
2218 i = getchar ();
2219 if (i != '\n')
2220 while ((c = getchar ()) != '\n' && c != EOF)
2223 if (i == 'y' || i == 'Y')
2224 #endif /* DEBUG */
2225 if (stat (name, &st) >= 0 && S_ISREG (st.st_mode))
2226 if (unlink (name) < 0)
2227 if (verbose_flag)
2228 perror_with_name (name);
2231 static void
2232 delete_temp_files (void)
2234 struct temp_file *temp;
2236 for (temp = always_delete_queue; temp; temp = temp->next)
2237 delete_if_ordinary (temp->name);
2238 always_delete_queue = 0;
2241 /* Delete all the files to be deleted on error. */
2243 static void
2244 delete_failure_queue (void)
2246 struct temp_file *temp;
2248 for (temp = failure_delete_queue; temp; temp = temp->next)
2249 delete_if_ordinary (temp->name);
2252 static void
2253 clear_failure_queue (void)
2255 failure_delete_queue = 0;
2258 /* Build a list of search directories from PATHS.
2259 PREFIX is a string to prepend to the list.
2260 If CHECK_DIR_P is nonzero we ensure the directory exists.
2261 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2262 It is also used by the --print-search-dirs flag. */
2264 static char *
2265 build_search_list (struct path_prefix *paths, const char *prefix,
2266 int check_dir_p)
2268 int suffix_len = (machine_suffix) ? strlen (machine_suffix) : 0;
2269 int just_suffix_len
2270 = (just_machine_suffix) ? strlen (just_machine_suffix) : 0;
2271 int first_time = TRUE;
2272 struct prefix_list *pprefix;
2274 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2275 obstack_1grow (&collect_obstack, '=');
2277 for (pprefix = paths->plist; pprefix != 0; pprefix = pprefix->next)
2279 int len = strlen (pprefix->prefix);
2281 if (machine_suffix
2282 && (! check_dir_p
2283 || is_directory (pprefix->prefix, machine_suffix, 0)))
2285 if (!first_time)
2286 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2288 first_time = FALSE;
2289 obstack_grow (&collect_obstack, pprefix->prefix, len);
2290 obstack_grow (&collect_obstack, machine_suffix, suffix_len);
2293 if (just_machine_suffix
2294 && pprefix->require_machine_suffix == 2
2295 && (! check_dir_p
2296 || is_directory (pprefix->prefix, just_machine_suffix, 0)))
2298 if (! first_time)
2299 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2301 first_time = FALSE;
2302 obstack_grow (&collect_obstack, pprefix->prefix, len);
2303 obstack_grow (&collect_obstack, just_machine_suffix,
2304 just_suffix_len);
2307 if (! pprefix->require_machine_suffix)
2309 if (! first_time)
2310 obstack_1grow (&collect_obstack, PATH_SEPARATOR);
2312 first_time = FALSE;
2313 obstack_grow (&collect_obstack, pprefix->prefix, len);
2317 obstack_1grow (&collect_obstack, '\0');
2318 return obstack_finish (&collect_obstack);
2321 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2322 for collect. */
2324 static void
2325 putenv_from_prefixes (struct path_prefix *paths, const char *env_var)
2327 putenv (build_search_list (paths, env_var, 1));
2330 /* Check whether NAME can be accessed in MODE. This is like access,
2331 except that it never considers directories to be executable. */
2333 static int
2334 access_check (const char *name, int mode)
2336 if (mode == X_OK)
2338 struct stat st;
2340 if (stat (name, &st) < 0
2341 || S_ISDIR (st.st_mode))
2342 return -1;
2345 return access (name, mode);
2348 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2349 access to check permissions.
2350 Return 0 if not found, otherwise return its name, allocated with malloc. */
2352 static char *
2353 find_a_file (struct path_prefix *pprefix, const char *name, int mode,
2354 int multilib)
2356 char *temp;
2357 const char *const file_suffix =
2358 ((mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "");
2359 struct prefix_list *pl;
2360 int len = pprefix->max_len + strlen (name) + strlen (file_suffix) + 1;
2361 const char *multilib_name, *multilib_os_name;
2363 #ifdef DEFAULT_ASSEMBLER
2364 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2365 return xstrdup (DEFAULT_ASSEMBLER);
2366 #endif
2368 #ifdef DEFAULT_LINKER
2369 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2370 return xstrdup (DEFAULT_LINKER);
2371 #endif
2373 if (machine_suffix)
2374 len += strlen (machine_suffix);
2376 multilib_name = name;
2377 multilib_os_name = name;
2378 if (multilib && multilib_os_dir)
2380 int len1 = multilib_dir ? strlen (multilib_dir) + 1 : 0;
2381 int len2 = strlen (multilib_os_dir) + 1;
2383 len += len1 > len2 ? len1 : len2;
2384 if (multilib_dir)
2385 multilib_name = ACONCAT ((multilib_dir, dir_separator_str, name,
2386 NULL));
2387 if (strcmp (multilib_os_dir, ".") != 0)
2388 multilib_os_name = ACONCAT ((multilib_os_dir, dir_separator_str, name,
2389 NULL));
2392 temp = xmalloc (len);
2394 /* Determine the filename to execute (special case for absolute paths). */
2396 if (IS_ABSOLUTE_PATH (name))
2398 if (access (name, mode) == 0)
2400 strcpy (temp, name);
2401 return temp;
2404 else
2405 for (pl = pprefix->plist; pl; pl = pl->next)
2407 const char *this_name
2408 = pl->os_multilib ? multilib_os_name : multilib_name;
2410 if (machine_suffix)
2412 /* Some systems have a suffix for executable files.
2413 So try appending that first. */
2414 if (file_suffix[0] != 0)
2416 strcpy (temp, pl->prefix);
2417 strcat (temp, machine_suffix);
2418 strcat (temp, multilib_name);
2419 strcat (temp, file_suffix);
2420 if (access_check (temp, mode) == 0)
2422 if (pl->used_flag_ptr != 0)
2423 *pl->used_flag_ptr = 1;
2424 return temp;
2428 /* Now try just the multilib_name. */
2429 strcpy (temp, pl->prefix);
2430 strcat (temp, machine_suffix);
2431 strcat (temp, multilib_name);
2432 if (access_check (temp, mode) == 0)
2434 if (pl->used_flag_ptr != 0)
2435 *pl->used_flag_ptr = 1;
2436 return temp;
2440 /* Certain prefixes are tried with just the machine type,
2441 not the version. This is used for finding as, ld, etc. */
2442 if (just_machine_suffix && pl->require_machine_suffix == 2)
2444 /* Some systems have a suffix for executable files.
2445 So try appending that first. */
2446 if (file_suffix[0] != 0)
2448 strcpy (temp, pl->prefix);
2449 strcat (temp, just_machine_suffix);
2450 strcat (temp, multilib_name);
2451 strcat (temp, file_suffix);
2452 if (access_check (temp, mode) == 0)
2454 if (pl->used_flag_ptr != 0)
2455 *pl->used_flag_ptr = 1;
2456 return temp;
2460 strcpy (temp, pl->prefix);
2461 strcat (temp, just_machine_suffix);
2462 strcat (temp, multilib_name);
2463 if (access_check (temp, mode) == 0)
2465 if (pl->used_flag_ptr != 0)
2466 *pl->used_flag_ptr = 1;
2467 return temp;
2471 /* Certain prefixes can't be used without the machine suffix
2472 when the machine or version is explicitly specified. */
2473 if (! pl->require_machine_suffix)
2475 /* Some systems have a suffix for executable files.
2476 So try appending that first. */
2477 if (file_suffix[0] != 0)
2479 strcpy (temp, pl->prefix);
2480 strcat (temp, this_name);
2481 strcat (temp, file_suffix);
2482 if (access_check (temp, mode) == 0)
2484 if (pl->used_flag_ptr != 0)
2485 *pl->used_flag_ptr = 1;
2486 return temp;
2490 strcpy (temp, pl->prefix);
2491 strcat (temp, this_name);
2492 if (access_check (temp, mode) == 0)
2494 if (pl->used_flag_ptr != 0)
2495 *pl->used_flag_ptr = 1;
2496 return temp;
2501 free (temp);
2502 return 0;
2505 /* Ranking of prefixes in the sort list. -B prefixes are put before
2506 all others. */
2508 enum path_prefix_priority
2510 PREFIX_PRIORITY_B_OPT,
2511 PREFIX_PRIORITY_LAST
2514 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2515 order according to PRIORITY. Within each PRIORITY, new entries are
2516 appended.
2518 If WARN is nonzero, we will warn if no file is found
2519 through this prefix. WARN should point to an int
2520 which will be set to 1 if this entry is used.
2522 COMPONENT is the value to be passed to update_path.
2524 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2525 the complete value of machine_suffix.
2526 2 means try both machine_suffix and just_machine_suffix. */
2528 static void
2529 add_prefix (struct path_prefix *pprefix, const char *prefix,
2530 const char *component, /* enum prefix_priority */ int priority,
2531 int require_machine_suffix, int *warn, int os_multilib)
2533 struct prefix_list *pl, **prev;
2534 int len;
2536 for (prev = &pprefix->plist;
2537 (*prev) != NULL && (*prev)->priority <= priority;
2538 prev = &(*prev)->next)
2541 /* Keep track of the longest prefix. */
2543 prefix = update_path (prefix, component);
2544 len = strlen (prefix);
2545 if (len > pprefix->max_len)
2546 pprefix->max_len = len;
2548 pl = xmalloc (sizeof (struct prefix_list));
2549 pl->prefix = prefix;
2550 pl->require_machine_suffix = require_machine_suffix;
2551 pl->used_flag_ptr = warn;
2552 pl->priority = priority;
2553 pl->os_multilib = os_multilib;
2554 if (warn)
2555 *warn = 0;
2557 /* Insert after PREV. */
2558 pl->next = (*prev);
2559 (*prev) = pl;
2562 /* Same as add_prefix, but prepending target_system_root to prefix. */
2563 static void
2564 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2565 const char *component,
2566 /* enum prefix_priority */ int priority,
2567 int require_machine_suffix, int *warn, int os_multilib)
2569 if (!IS_ABSOLUTE_PATH (prefix))
2570 abort ();
2572 if (target_system_root)
2574 if (target_sysroot_suffix)
2575 prefix = concat (target_sysroot_suffix, prefix, NULL);
2576 prefix = concat (target_system_root, prefix, NULL);
2578 /* We have to override this because GCC's notion of sysroot
2579 moves along with GCC. */
2580 component = "GCC";
2583 add_prefix (pprefix, prefix, component, priority,
2584 require_machine_suffix, warn, os_multilib);
2587 /* Execute the command specified by the arguments on the current line of spec.
2588 When using pipes, this includes several piped-together commands
2589 with `|' between them.
2591 Return 0 if successful, -1 if failed. */
2593 static int
2594 execute (void)
2596 int i;
2597 int n_commands; /* # of command. */
2598 char *string;
2599 struct command
2601 const char *prog; /* program name. */
2602 const char **argv; /* vector of args. */
2603 int pid; /* pid of process for this command. */
2606 struct command *commands; /* each command buffer with above info. */
2608 if (processing_spec_function)
2609 abort ();
2611 /* Count # of piped commands. */
2612 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2613 if (strcmp (argbuf[i], "|") == 0)
2614 n_commands++;
2616 /* Get storage for each command. */
2617 commands = alloca (n_commands * sizeof (struct command));
2619 /* Split argbuf into its separate piped processes,
2620 and record info about each one.
2621 Also search for the programs that are to be run. */
2623 commands[0].prog = argbuf[0]; /* first command. */
2624 commands[0].argv = &argbuf[0];
2625 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, 0);
2627 if (string)
2628 commands[0].argv[0] = string;
2630 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2631 if (strcmp (argbuf[i], "|") == 0)
2632 { /* each command. */
2633 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2634 fatal ("-pipe not supported");
2635 #endif
2636 argbuf[i] = 0; /* termination of command args. */
2637 commands[n_commands].prog = argbuf[i + 1];
2638 commands[n_commands].argv = &argbuf[i + 1];
2639 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2640 X_OK, 0);
2641 if (string)
2642 commands[n_commands].argv[0] = string;
2643 n_commands++;
2646 argbuf[argbuf_index] = 0;
2648 /* If -v, print what we are about to do, and maybe query. */
2650 if (verbose_flag)
2652 /* For help listings, put a blank line between sub-processes. */
2653 if (print_help_list)
2654 fputc ('\n', stderr);
2656 /* Print each piped command as a separate line. */
2657 for (i = 0; i < n_commands; i++)
2659 const char *const *j;
2661 if (verbose_only_flag)
2663 for (j = commands[i].argv; *j; j++)
2665 const char *p;
2666 fprintf (stderr, " \"");
2667 for (p = *j; *p; ++p)
2669 if (*p == '"' || *p == '\\' || *p == '$')
2670 fputc ('\\', stderr);
2671 fputc (*p, stderr);
2673 fputc ('"', stderr);
2676 else
2677 for (j = commands[i].argv; *j; j++)
2678 fprintf (stderr, " %s", *j);
2680 /* Print a pipe symbol after all but the last command. */
2681 if (i + 1 != n_commands)
2682 fprintf (stderr, " |");
2683 fprintf (stderr, "\n");
2685 fflush (stderr);
2686 if (verbose_only_flag != 0)
2687 return 0;
2688 #ifdef DEBUG
2689 notice ("\nGo ahead? (y or n) ");
2690 fflush (stderr);
2691 i = getchar ();
2692 if (i != '\n')
2693 while (getchar () != '\n')
2696 if (i != 'y' && i != 'Y')
2697 return 0;
2698 #endif /* DEBUG */
2701 #ifdef ENABLE_VALGRIND_CHECKING
2702 /* Run the each command through valgrind. To simplify prepending the
2703 path to valgrind and the option "-q" (for quiet operation unless
2704 something triggers), we allocate a separate argv array. */
2706 for (i = 0; i < n_commands; i++)
2708 const char **argv;
2709 int argc;
2710 int j;
2712 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2715 argv = alloca ((argc + 3) * sizeof (char *));
2717 argv[0] = VALGRIND_PATH;
2718 argv[1] = "-q";
2719 for (j = 2; j < argc + 2; j++)
2720 argv[j] = commands[i].argv[j - 2];
2721 argv[j] = NULL;
2723 commands[i].argv = argv;
2724 commands[i].prog = argv[0];
2726 #endif
2728 /* Run each piped subprocess. */
2730 for (i = 0; i < n_commands; i++)
2732 char *errmsg_fmt, *errmsg_arg;
2733 const char *string = commands[i].argv[0];
2735 /* For some bizarre reason, the second argument of execvp() is
2736 char *const *, not const char *const *. */
2737 commands[i].pid = pexecute (string, (char *const *) commands[i].argv,
2738 programname, temp_filename,
2739 &errmsg_fmt, &errmsg_arg,
2740 ((i == 0 ? PEXECUTE_FIRST : 0)
2741 | (i + 1 == n_commands ? PEXECUTE_LAST : 0)
2742 | (string == commands[i].prog
2743 ? PEXECUTE_SEARCH : 0)
2744 | (verbose_flag ? PEXECUTE_VERBOSE : 0)));
2746 if (commands[i].pid == -1)
2747 pfatal_pexecute (errmsg_fmt, errmsg_arg);
2749 if (string != commands[i].prog)
2750 free ((void *) string);
2753 execution_count++;
2755 /* Wait for all the subprocesses to finish.
2756 We don't care what order they finish in;
2757 we know that N_COMMANDS waits will get them all.
2758 Ignore subprocesses that we don't know about,
2759 since they can be spawned by the process that exec'ed us. */
2762 int ret_code = 0;
2763 #ifdef HAVE_GETRUSAGE
2764 struct timeval d;
2765 double ut = 0.0, st = 0.0;
2766 #endif
2768 for (i = 0; i < n_commands;)
2770 int j;
2771 int status;
2772 int pid;
2774 pid = pwait (commands[i].pid, &status, 0);
2775 if (pid < 0)
2776 abort ();
2778 #ifdef HAVE_GETRUSAGE
2779 if (report_times)
2781 /* getrusage returns the total resource usage of all children
2782 up to now. Copy the previous values into prus, get the
2783 current statistics, then take the difference. */
2785 prus = rus;
2786 getrusage (RUSAGE_CHILDREN, &rus);
2787 d.tv_sec = rus.ru_utime.tv_sec - prus.ru_utime.tv_sec;
2788 d.tv_usec = rus.ru_utime.tv_usec - prus.ru_utime.tv_usec;
2789 ut = (double) d.tv_sec + (double) d.tv_usec / 1.0e6;
2791 d.tv_sec = rus.ru_stime.tv_sec - prus.ru_stime.tv_sec;
2792 d.tv_usec = rus.ru_stime.tv_usec - prus.ru_stime.tv_usec;
2793 st = (double) d.tv_sec + (double) d.tv_usec / 1.0e6;
2795 #endif
2797 for (j = 0; j < n_commands; j++)
2798 if (commands[j].pid == pid)
2800 i++;
2801 if (WIFSIGNALED (status))
2803 #ifdef SIGPIPE
2804 /* SIGPIPE is a special case. It happens in -pipe mode
2805 when the compiler dies before the preprocessor is
2806 done, or the assembler dies before the compiler is
2807 done. There's generally been an error already, and
2808 this is just fallout. So don't generate another error
2809 unless we would otherwise have succeeded. */
2810 if (WTERMSIG (status) == SIGPIPE
2811 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2813 else
2814 #endif
2815 fatal ("\
2816 Internal error: %s (program %s)\n\
2817 Please submit a full bug report.\n\
2818 See %s for instructions.",
2819 strsignal (WTERMSIG (status)), commands[j].prog,
2820 bug_report_url);
2821 signal_count++;
2822 ret_code = -1;
2824 else if (WIFEXITED (status)
2825 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2827 if (WEXITSTATUS (status) > greatest_status)
2828 greatest_status = WEXITSTATUS (status);
2829 ret_code = -1;
2831 #ifdef HAVE_GETRUSAGE
2832 if (report_times && ut + st != 0)
2833 notice ("# %s %.2f %.2f\n", commands[j].prog, ut, st);
2834 #endif
2835 break;
2838 return ret_code;
2842 /* Find all the switches given to us
2843 and make a vector describing them.
2844 The elements of the vector are strings, one per switch given.
2845 If a switch uses following arguments, then the `part1' field
2846 is the switch itself and the `args' field
2847 is a null-terminated vector containing the following arguments.
2848 The `live_cond' field is:
2849 0 when initialized
2850 1 if the switch is true in a conditional spec,
2851 -1 if false (overridden by a later switch)
2852 -2 if this switch should be ignored (used in %<S)
2853 The `validated' field is nonzero if any spec has looked at this switch;
2854 if it remains zero at the end of the run, it must be meaningless. */
2856 #define SWITCH_OK 0
2857 #define SWITCH_FALSE -1
2858 #define SWITCH_IGNORE -2
2859 #define SWITCH_LIVE 1
2861 struct switchstr
2863 const char *part1;
2864 const char **args;
2865 int live_cond;
2866 unsigned char validated;
2867 unsigned char ordering;
2870 static struct switchstr *switches;
2872 static int n_switches;
2874 struct infile
2876 const char *name;
2877 const char *language;
2880 /* Also a vector of input files specified. */
2882 static struct infile *infiles;
2884 int n_infiles;
2886 /* True if multiple input files are being compiled to a single
2887 assembly file. */
2889 static bool combine_inputs;
2891 /* This counts the number of libraries added by lang_specific_driver, so that
2892 we can tell if there were any user supplied any files or libraries. */
2894 static int added_libraries;
2896 /* And a vector of corresponding output files is made up later. */
2898 const char **outfiles;
2900 /* Used to track if none of the -B paths are used. */
2901 static int warn_B;
2903 /* Gives value to pass as "warn" to add_prefix for standard prefixes. */
2904 static int *warn_std_ptr = 0;
2906 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2908 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
2909 is true if we should look for an executable suffix. DO_OBJ
2910 is true if we should look for an object suffix. */
2912 static const char *
2913 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
2914 int do_obj ATTRIBUTE_UNUSED)
2916 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2917 int i;
2918 #endif
2919 int len;
2921 if (name == NULL)
2922 return NULL;
2924 len = strlen (name);
2926 #ifdef HAVE_TARGET_OBJECT_SUFFIX
2927 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
2928 if (do_obj && len > 2
2929 && name[len - 2] == '.'
2930 && name[len - 1] == 'o')
2932 obstack_grow (&obstack, name, len - 2);
2933 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
2934 name = obstack_finish (&obstack);
2936 #endif
2938 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2939 /* If there is no filetype, make it the executable suffix (which includes
2940 the "."). But don't get confused if we have just "-o". */
2941 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
2942 return name;
2944 for (i = len - 1; i >= 0; i--)
2945 if (IS_DIR_SEPARATOR (name[i]))
2946 break;
2948 for (i++; i < len; i++)
2949 if (name[i] == '.')
2950 return name;
2952 obstack_grow (&obstack, name, len);
2953 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
2954 strlen (TARGET_EXECUTABLE_SUFFIX));
2955 name = obstack_finish (&obstack);
2956 #endif
2958 return name;
2960 #endif
2962 /* Display the command line switches accepted by gcc. */
2963 static void
2964 display_help (void)
2966 printf (_("Usage: %s [options] file...\n"), programname);
2967 fputs (_("Options:\n"), stdout);
2969 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
2970 fputs (_(" --help Display this information\n"), stdout);
2971 fputs (_(" --target-help Display target specific command line options\n"), stdout);
2972 if (! verbose_flag)
2973 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
2974 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
2975 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
2976 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
2977 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
2978 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
2979 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
2980 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
2981 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
2982 fputs (_("\
2983 -print-multi-lib Display the mapping between command line options and\n\
2984 multiple library search directories\n"), stdout);
2985 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
2986 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
2987 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
2988 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
2989 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
2990 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
2991 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
2992 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
2993 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
2994 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
2995 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
2996 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
2997 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
2998 fputs (_(" -b <machine> Run gcc for target <machine>, if installed\n"), stdout);
2999 fputs (_(" -V <version> Run gcc version number <version>, if installed\n"), stdout);
3000 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3001 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3002 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3003 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3004 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3005 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3006 fputs (_("\
3007 -x <language> Specify the language of the following input files\n\
3008 Permissible languages include: c c++ assembler none\n\
3009 'none' means revert to the default behavior of\n\
3010 guessing the language based on the file's extension\n\
3011 "), stdout);
3013 printf (_("\
3014 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3015 passed on to the various sub-processes invoked by %s. In order to pass\n\
3016 other options on to these processes the -W<letter> options must be used.\n\
3017 "), programname);
3019 /* The rest of the options are displayed by invocations of the various
3020 sub-processes. */
3023 static void
3024 add_preprocessor_option (const char *option, int len)
3026 n_preprocessor_options++;
3028 if (! preprocessor_options)
3029 preprocessor_options = xmalloc (n_preprocessor_options * sizeof (char *));
3030 else
3031 preprocessor_options = xrealloc (preprocessor_options,
3032 n_preprocessor_options * sizeof (char *));
3034 preprocessor_options [n_preprocessor_options - 1] =
3035 save_string (option, len);
3038 static void
3039 add_assembler_option (const char *option, int len)
3041 n_assembler_options++;
3043 if (! assembler_options)
3044 assembler_options = xmalloc (n_assembler_options * sizeof (char *));
3045 else
3046 assembler_options = xrealloc (assembler_options,
3047 n_assembler_options * sizeof (char *));
3049 assembler_options [n_assembler_options - 1] = save_string (option, len);
3052 static void
3053 add_linker_option (const char *option, int len)
3055 n_linker_options++;
3057 if (! linker_options)
3058 linker_options = xmalloc (n_linker_options * sizeof (char *));
3059 else
3060 linker_options = xrealloc (linker_options,
3061 n_linker_options * sizeof (char *));
3063 linker_options [n_linker_options - 1] = save_string (option, len);
3066 /* Create the vector `switches' and its contents.
3067 Store its length in `n_switches'. */
3069 static void
3070 process_command (int argc, const char *const *argv)
3072 int i;
3073 const char *temp;
3074 char *temp1;
3075 const char *spec_lang = 0;
3076 int last_language_n_infiles;
3077 int have_c = 0;
3078 int have_o = 0;
3079 int lang_n_infiles = 0;
3080 #ifdef MODIFY_TARGET_NAME
3081 int is_modify_target_name;
3082 int j;
3083 #endif
3085 GET_ENVIRONMENT (gcc_exec_prefix, "GCC_EXEC_PREFIX");
3087 n_switches = 0;
3088 n_infiles = 0;
3089 added_libraries = 0;
3091 /* Figure compiler version from version string. */
3093 compiler_version = temp1 = xstrdup (version_string);
3095 for (; *temp1; ++temp1)
3097 if (*temp1 == ' ')
3099 *temp1 = '\0';
3100 break;
3104 /* If there is a -V or -b option (or both), process it now, before
3105 trying to interpret the rest of the command line. */
3106 if (argc > 1 && argv[1][0] == '-'
3107 && (argv[1][1] == 'V' || argv[1][1] == 'b'))
3109 const char *new_version = DEFAULT_TARGET_VERSION;
3110 const char *new_machine = DEFAULT_TARGET_MACHINE;
3111 const char *progname = argv[0];
3112 char **new_argv;
3113 char *new_argv0;
3114 int baselen;
3116 while (argc > 1 && argv[1][0] == '-'
3117 && (argv[1][1] == 'V' || argv[1][1] == 'b'))
3119 char opt = argv[1][1];
3120 const char *arg;
3121 if (argv[1][2] != '\0')
3123 arg = argv[1] + 2;
3124 argc -= 1;
3125 argv += 1;
3127 else if (argc > 2)
3129 arg = argv[2];
3130 argc -= 2;
3131 argv += 2;
3133 else
3134 fatal ("`-%c' option must have argument", opt);
3135 if (opt == 'V')
3136 new_version = arg;
3137 else
3138 new_machine = arg;
3141 for (baselen = strlen (progname); baselen > 0; baselen--)
3142 if (IS_DIR_SEPARATOR (progname[baselen-1]))
3143 break;
3144 new_argv0 = xmemdup (progname, baselen,
3145 baselen + concat_length (new_version, new_machine,
3146 "-gcc-", NULL) + 1);
3147 strcpy (new_argv0 + baselen, new_machine);
3148 strcat (new_argv0, "-gcc-");
3149 strcat (new_argv0, new_version);
3151 new_argv = xmemdup (argv, (argc + 1) * sizeof (argv[0]),
3152 (argc + 1) * sizeof (argv[0]));
3153 new_argv[0] = new_argv0;
3155 execvp (new_argv0, new_argv);
3156 fatal ("couldn't run `%s': %s", new_argv0, xstrerror (errno));
3159 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3160 see if we can create it from the pathname specified in argv[0]. */
3162 gcc_libexec_prefix = standard_libexec_prefix;
3163 #ifndef VMS
3164 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3165 if (!gcc_exec_prefix)
3167 gcc_exec_prefix = make_relative_prefix (argv[0], standard_bindir_prefix,
3168 standard_exec_prefix);
3169 gcc_libexec_prefix = make_relative_prefix (argv[0],
3170 standard_bindir_prefix,
3171 standard_libexec_prefix);
3172 if (gcc_exec_prefix)
3173 putenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3175 else
3176 gcc_libexec_prefix = make_relative_prefix (gcc_exec_prefix,
3177 standard_exec_prefix,
3178 standard_libexec_prefix);
3179 #else
3180 #endif
3182 if (gcc_exec_prefix)
3184 int len = strlen (gcc_exec_prefix);
3186 if (len > (int) sizeof ("/lib/gcc/") - 1
3187 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3189 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3190 if (IS_DIR_SEPARATOR (*temp)
3191 && strncmp (temp + 1, "lib", 3) == 0
3192 && IS_DIR_SEPARATOR (temp[4])
3193 && strncmp (temp + 5, "gcc", 3) == 0)
3194 len -= sizeof ("/lib/gcc/") - 1;
3197 set_std_prefix (gcc_exec_prefix, len);
3198 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3199 PREFIX_PRIORITY_LAST, 0, NULL, 0);
3200 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3201 PREFIX_PRIORITY_LAST, 0, NULL, 0);
3204 /* COMPILER_PATH and LIBRARY_PATH have values
3205 that are lists of directory names with colons. */
3207 GET_ENVIRONMENT (temp, "COMPILER_PATH");
3208 if (temp)
3210 const char *startp, *endp;
3211 char *nstore = alloca (strlen (temp) + 3);
3213 startp = endp = temp;
3214 while (1)
3216 if (*endp == PATH_SEPARATOR || *endp == 0)
3218 strncpy (nstore, startp, endp - startp);
3219 if (endp == startp)
3220 strcpy (nstore, concat (".", dir_separator_str, NULL));
3221 else if (!IS_DIR_SEPARATOR (endp[-1]))
3223 nstore[endp - startp] = DIR_SEPARATOR;
3224 nstore[endp - startp + 1] = 0;
3226 else
3227 nstore[endp - startp] = 0;
3228 add_prefix (&exec_prefixes, nstore, 0,
3229 PREFIX_PRIORITY_LAST, 0, NULL, 0);
3230 add_prefix (&include_prefixes,
3231 concat (nstore, "include", NULL),
3232 0, PREFIX_PRIORITY_LAST, 0, NULL, 0);
3233 if (*endp == 0)
3234 break;
3235 endp = startp = endp + 1;
3237 else
3238 endp++;
3242 GET_ENVIRONMENT (temp, LIBRARY_PATH_ENV);
3243 if (temp && *cross_compile == '0')
3245 const char *startp, *endp;
3246 char *nstore = alloca (strlen (temp) + 3);
3248 startp = endp = temp;
3249 while (1)
3251 if (*endp == PATH_SEPARATOR || *endp == 0)
3253 strncpy (nstore, startp, endp - startp);
3254 if (endp == startp)
3255 strcpy (nstore, concat (".", dir_separator_str, NULL));
3256 else if (!IS_DIR_SEPARATOR (endp[-1]))
3258 nstore[endp - startp] = DIR_SEPARATOR;
3259 nstore[endp - startp + 1] = 0;
3261 else
3262 nstore[endp - startp] = 0;
3263 add_prefix (&startfile_prefixes, nstore, NULL,
3264 PREFIX_PRIORITY_LAST, 0, NULL, 1);
3265 if (*endp == 0)
3266 break;
3267 endp = startp = endp + 1;
3269 else
3270 endp++;
3274 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3275 GET_ENVIRONMENT (temp, "LPATH");
3276 if (temp && *cross_compile == '0')
3278 const char *startp, *endp;
3279 char *nstore = alloca (strlen (temp) + 3);
3281 startp = endp = temp;
3282 while (1)
3284 if (*endp == PATH_SEPARATOR || *endp == 0)
3286 strncpy (nstore, startp, endp - startp);
3287 if (endp == startp)
3288 strcpy (nstore, concat (".", dir_separator_str, NULL));
3289 else if (!IS_DIR_SEPARATOR (endp[-1]))
3291 nstore[endp - startp] = DIR_SEPARATOR;
3292 nstore[endp - startp + 1] = 0;
3294 else
3295 nstore[endp - startp] = 0;
3296 add_prefix (&startfile_prefixes, nstore, NULL,
3297 PREFIX_PRIORITY_LAST, 0, NULL, 1);
3298 if (*endp == 0)
3299 break;
3300 endp = startp = endp + 1;
3302 else
3303 endp++;
3307 /* Convert new-style -- options to old-style. */
3308 translate_options (&argc, &argv);
3310 /* Do language-specific adjustment/addition of flags. */
3311 lang_specific_driver (&argc, &argv, &added_libraries);
3313 /* Scan argv twice. Here, the first time, just count how many switches
3314 there will be in their vector, and how many input files in theirs.
3315 Here we also parse the switches that cc itself uses (e.g. -v). */
3317 for (i = 1; i < argc; i++)
3319 if (! strcmp (argv[i], "-dumpspecs"))
3321 struct spec_list *sl;
3322 init_spec ();
3323 for (sl = specs; sl; sl = sl->next)
3324 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3325 if (link_command_spec)
3326 printf ("*link_command:\n%s\n\n", link_command_spec);
3327 exit (0);
3329 else if (! strcmp (argv[i], "-dumpversion"))
3331 printf ("%s\n", spec_version);
3332 exit (0);
3334 else if (! strcmp (argv[i], "-dumpmachine"))
3336 printf ("%s\n", spec_machine);
3337 exit (0);
3339 else if (strcmp (argv[i], "-fversion") == 0)
3341 /* translate_options () has turned --version into -fversion. */
3342 printf (_("%s (GCC) %s\n"), programname, version_string);
3343 fputs (_("Copyright (C) 2003 Free Software Foundation, Inc.\n"),
3344 stdout);
3345 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
3346 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
3347 stdout);
3348 exit (0);
3350 else if (strcmp (argv[i], "-fhelp") == 0)
3352 /* translate_options () has turned --help into -fhelp. */
3353 print_help_list = 1;
3355 /* We will be passing a dummy file on to the sub-processes. */
3356 n_infiles++;
3357 n_switches++;
3359 /* CPP driver cannot obtain switch from cc1_options. */
3360 if (is_cpp_driver)
3361 add_preprocessor_option ("--help", 6);
3362 add_assembler_option ("--help", 6);
3363 add_linker_option ("--help", 6);
3365 else if (strcmp (argv[i], "-ftarget-help") == 0)
3367 /* translate_options() has turned --target-help into -ftarget-help. */
3368 target_help_flag = 1;
3370 /* We will be passing a dummy file on to the sub-processes. */
3371 n_infiles++;
3372 n_switches++;
3374 /* CPP driver cannot obtain switch from cc1_options. */
3375 if (is_cpp_driver)
3376 add_preprocessor_option ("--target-help", 13);
3377 add_assembler_option ("--target-help", 13);
3378 add_linker_option ("--target-help", 13);
3380 else if (! strcmp (argv[i], "-pass-exit-codes"))
3382 pass_exit_codes = 1;
3383 n_switches++;
3385 else if (! strcmp (argv[i], "-print-search-dirs"))
3386 print_search_dirs = 1;
3387 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3388 print_file_name = "libgcc.a";
3389 else if (! strncmp (argv[i], "-print-file-name=", 17))
3390 print_file_name = argv[i] + 17;
3391 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3392 print_prog_name = argv[i] + 17;
3393 else if (! strcmp (argv[i], "-print-multi-lib"))
3394 print_multi_lib = 1;
3395 else if (! strcmp (argv[i], "-print-multi-directory"))
3396 print_multi_directory = 1;
3397 else if (! strcmp (argv[i], "-print-multi-os-directory"))
3398 print_multi_os_directory = 1;
3399 else if (! strncmp (argv[i], "-Wa,", 4))
3401 int prev, j;
3402 /* Pass the rest of this option to the assembler. */
3404 /* Split the argument at commas. */
3405 prev = 4;
3406 for (j = 4; argv[i][j]; j++)
3407 if (argv[i][j] == ',')
3409 add_assembler_option (argv[i] + prev, j - prev);
3410 prev = j + 1;
3413 /* Record the part after the last comma. */
3414 add_assembler_option (argv[i] + prev, j - prev);
3416 else if (! strncmp (argv[i], "-Wp,", 4))
3418 int prev, j;
3419 /* Pass the rest of this option to the preprocessor. */
3421 /* Split the argument at commas. */
3422 prev = 4;
3423 for (j = 4; argv[i][j]; j++)
3424 if (argv[i][j] == ',')
3426 add_preprocessor_option (argv[i] + prev, j - prev);
3427 prev = j + 1;
3430 /* Record the part after the last comma. */
3431 add_preprocessor_option (argv[i] + prev, j - prev);
3433 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3434 /* The +e options to the C++ front-end. */
3435 n_switches++;
3436 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3438 int j;
3439 /* Split the argument at commas. */
3440 for (j = 3; argv[i][j]; j++)
3441 n_infiles += (argv[i][j] == ',');
3443 else if (strcmp (argv[i], "-Xlinker") == 0)
3445 if (i + 1 == argc)
3446 fatal ("argument to `-Xlinker' is missing");
3448 n_infiles++;
3449 i++;
3451 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
3453 if (i + 1 == argc)
3454 fatal ("argument to `-Xpreprocessor' is missing");
3456 add_preprocessor_option (argv[i+1], strlen (argv[i+1]));
3458 else if (strcmp (argv[i], "-Xassembler") == 0)
3460 if (i + 1 == argc)
3461 fatal ("argument to `-Xassembler' is missing");
3463 add_assembler_option (argv[i+1], strlen (argv[i+1]));
3465 else if (strcmp (argv[i], "-l") == 0)
3467 if (i + 1 == argc)
3468 fatal ("argument to `-l' is missing");
3470 n_infiles++;
3471 i++;
3473 else if (strncmp (argv[i], "-l", 2) == 0)
3474 n_infiles++;
3475 else if (strcmp (argv[i], "-save-temps") == 0)
3477 save_temps_flag = 1;
3478 n_switches++;
3480 else if (strcmp (argv[i], "-specs") == 0)
3482 struct user_specs *user = xmalloc (sizeof (struct user_specs));
3483 if (++i >= argc)
3484 fatal ("argument to `-specs' is missing");
3486 user->next = (struct user_specs *) 0;
3487 user->filename = argv[i];
3488 if (user_specs_tail)
3489 user_specs_tail->next = user;
3490 else
3491 user_specs_head = user;
3492 user_specs_tail = user;
3494 else if (strncmp (argv[i], "-specs=", 7) == 0)
3496 struct user_specs *user = xmalloc (sizeof (struct user_specs));
3497 if (strlen (argv[i]) == 7)
3498 fatal ("argument to `-specs=' is missing");
3500 user->next = (struct user_specs *) 0;
3501 user->filename = argv[i] + 7;
3502 if (user_specs_tail)
3503 user_specs_tail->next = user;
3504 else
3505 user_specs_head = user;
3506 user_specs_tail = user;
3508 else if (strcmp (argv[i], "-time") == 0)
3509 report_times = 1;
3510 else if (strcmp (argv[i], "-pipe") == 0)
3512 /* -pipe has to go into the switches array as well as
3513 setting a flag. */
3514 use_pipes = 1;
3515 n_switches++;
3517 else if (strcmp (argv[i], "-###") == 0)
3519 /* This is similar to -v except that there is no execution
3520 of the commands and the echoed arguments are quoted. It
3521 is intended for use in shell scripts to capture the
3522 driver-generated command line. */
3523 verbose_only_flag++;
3524 verbose_flag++;
3526 else if (argv[i][0] == '-' && argv[i][1] != 0)
3528 const char *p = &argv[i][1];
3529 int c = *p;
3531 switch (c)
3533 case 'b':
3534 case 'V':
3535 fatal ("`-%c' must come at the start of the command line", c);
3536 break;
3538 case 'B':
3540 const char *value;
3541 int len;
3543 if (p[1] == 0 && i + 1 == argc)
3544 fatal ("argument to `-B' is missing");
3545 if (p[1] == 0)
3546 value = argv[++i];
3547 else
3548 value = p + 1;
3550 len = strlen (value);
3552 /* Catch the case where the user has forgotten to append a
3553 directory separator to the path. Note, they may be using
3554 -B to add an executable name prefix, eg "i386-elf-", in
3555 order to distinguish between multiple installations of
3556 GCC in the same directory. Hence we must check to see
3557 if appending a directory separator actually makes a
3558 valid directory name. */
3559 if (! IS_DIR_SEPARATOR (value [len - 1])
3560 && is_directory (value, "", 0))
3562 char *tmp = xmalloc (len + 2);
3563 strcpy (tmp, value);
3564 tmp[len] = DIR_SEPARATOR;
3565 tmp[++ len] = 0;
3566 value = tmp;
3569 /* As a kludge, if the arg is "[foo/]stageN/", just
3570 add "[foo/]include" to the include prefix. */
3571 if ((len == 7
3572 || (len > 7
3573 && (IS_DIR_SEPARATOR (value[len - 8]))))
3574 && strncmp (value + len - 7, "stage", 5) == 0
3575 && ISDIGIT (value[len - 2])
3576 && (IS_DIR_SEPARATOR (value[len - 1])))
3578 if (len == 7)
3579 add_prefix (&include_prefixes, "include", NULL,
3580 PREFIX_PRIORITY_B_OPT, 0, NULL, 0);
3581 else
3583 char * string = xmalloc (len + 1);
3585 strncpy (string, value, len - 7);
3586 strcpy (string + len - 7, "include");
3587 add_prefix (&include_prefixes, string, NULL,
3588 PREFIX_PRIORITY_B_OPT, 0, NULL, 0);
3592 add_prefix (&exec_prefixes, value, NULL,
3593 PREFIX_PRIORITY_B_OPT, 0, &warn_B, 0);
3594 add_prefix (&startfile_prefixes, value, NULL,
3595 PREFIX_PRIORITY_B_OPT, 0, &warn_B, 0);
3596 add_prefix (&include_prefixes, concat (value, "include", NULL),
3597 NULL, PREFIX_PRIORITY_B_OPT, 0, NULL, 0);
3598 n_switches++;
3600 break;
3602 case 'v': /* Print our subcommands and print versions. */
3603 n_switches++;
3604 /* If they do anything other than exactly `-v', don't set
3605 verbose_flag; rather, continue on to give the error. */
3606 if (p[1] != 0)
3607 break;
3608 verbose_flag++;
3609 break;
3611 case 'S':
3612 case 'c':
3613 if (p[1] == 0)
3615 have_c = 1;
3616 n_switches++;
3617 break;
3619 goto normal_switch;
3621 case 'o':
3622 have_o = 1;
3623 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3624 if (! have_c)
3626 int skip;
3628 /* Forward scan, just in case -S or -c is specified
3629 after -o. */
3630 int j = i + 1;
3631 if (p[1] == 0)
3632 ++j;
3633 while (j < argc)
3635 if (argv[j][0] == '-')
3637 if (SWITCH_CURTAILS_COMPILATION (argv[j][1])
3638 && argv[j][2] == 0)
3640 have_c = 1;
3641 break;
3643 else if ((skip = SWITCH_TAKES_ARG (argv[j][1])))
3644 j += skip - (argv[j][2] != 0);
3645 else if ((skip = WORD_SWITCH_TAKES_ARG (argv[j] + 1)))
3646 j += skip;
3648 j++;
3651 #endif
3652 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3653 if (p[1] == 0)
3654 argv[i + 1] = convert_filename (argv[i + 1], ! have_c, 0);
3655 else
3656 argv[i] = convert_filename (argv[i], ! have_c, 0);
3657 #endif
3658 goto normal_switch;
3660 default:
3661 normal_switch:
3663 #ifdef MODIFY_TARGET_NAME
3664 is_modify_target_name = 0;
3666 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
3667 if (! strcmp (argv[i], modify_target[j].sw))
3669 char *new_name = xmalloc (strlen (modify_target[j].str)
3670 + strlen (spec_machine));
3671 const char *p, *r;
3672 char *q;
3673 int made_addition = 0;
3675 is_modify_target_name = 1;
3676 for (p = spec_machine, q = new_name; *p != 0; )
3678 if (modify_target[j].add_del == DELETE
3679 && (! strncmp (q, modify_target[j].str,
3680 strlen (modify_target[j].str))))
3681 p += strlen (modify_target[j].str);
3682 else if (modify_target[j].add_del == ADD
3683 && ! made_addition && *p == '-')
3685 for (r = modify_target[j].str; *r != 0; )
3686 *q++ = *r++;
3687 made_addition = 1;
3690 *q++ = *p++;
3693 spec_machine = new_name;
3696 if (is_modify_target_name)
3697 break;
3698 #endif
3700 n_switches++;
3702 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
3703 i += SWITCH_TAKES_ARG (c) - (p[1] != 0);
3704 else if (WORD_SWITCH_TAKES_ARG (p))
3705 i += WORD_SWITCH_TAKES_ARG (p);
3708 else
3710 n_infiles++;
3711 lang_n_infiles++;
3715 combine_inputs = (have_c && have_o && lang_n_infiles > 1);
3717 if ((save_temps_flag || report_times) && use_pipes)
3719 /* -save-temps overrides -pipe, so that temp files are produced */
3720 if (save_temps_flag)
3721 error ("warning: -pipe ignored because -save-temps specified");
3722 /* -time overrides -pipe because we can't get correct stats when
3723 multiple children are running at once. */
3724 else if (report_times)
3725 error ("warning: -pipe ignored because -time specified");
3727 use_pipes = 0;
3730 /* Set up the search paths before we go looking for config files. */
3732 /* These come before the md prefixes so that we will find gcc's subcommands
3733 (such as cpp) rather than those of the host system. */
3734 /* Use 2 as fourth arg meaning try just the machine as a suffix,
3735 as well as trying the machine and the version. */
3736 #ifndef OS2
3737 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
3738 PREFIX_PRIORITY_LAST, 1, warn_std_ptr, 0);
3739 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
3740 PREFIX_PRIORITY_LAST, 2, warn_std_ptr, 0);
3741 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
3742 PREFIX_PRIORITY_LAST, 2, warn_std_ptr, 0);
3743 add_prefix (&exec_prefixes, standard_exec_prefix_1, "BINUTILS",
3744 PREFIX_PRIORITY_LAST, 2, warn_std_ptr, 0);
3745 add_prefix (&exec_prefixes, standard_exec_prefix_2, "BINUTILS",
3746 PREFIX_PRIORITY_LAST, 2, warn_std_ptr, 0);
3747 #endif
3749 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
3750 PREFIX_PRIORITY_LAST, 1, warn_std_ptr, 0);
3751 add_prefix (&startfile_prefixes, standard_exec_prefix_2, "BINUTILS",
3752 PREFIX_PRIORITY_LAST, 1, warn_std_ptr, 0);
3754 tooldir_prefix = concat (tooldir_base_prefix, spec_machine,
3755 dir_separator_str, NULL);
3757 /* If tooldir is relative, base it on exec_prefixes. A relative
3758 tooldir lets us move the installed tree as a unit.
3760 If GCC_EXEC_PREFIX is defined, then we want to add two relative
3761 directories, so that we can search both the user specified directory
3762 and the standard place. */
3764 if (!IS_ABSOLUTE_PATH (tooldir_prefix))
3766 if (gcc_exec_prefix)
3768 char *gcc_exec_tooldir_prefix
3769 = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
3770 spec_version, dir_separator_str, tooldir_prefix, NULL);
3772 add_prefix (&exec_prefixes,
3773 concat (gcc_exec_tooldir_prefix, "bin",
3774 dir_separator_str, NULL),
3775 NULL, PREFIX_PRIORITY_LAST, 0, NULL, 0);
3776 add_prefix (&startfile_prefixes,
3777 concat (gcc_exec_tooldir_prefix, "lib",
3778 dir_separator_str, NULL),
3779 NULL, PREFIX_PRIORITY_LAST, 0, NULL, 1);
3782 tooldir_prefix = concat (standard_exec_prefix, spec_machine,
3783 dir_separator_str, spec_version,
3784 dir_separator_str, tooldir_prefix, NULL);
3787 add_prefix (&exec_prefixes,
3788 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
3789 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL, 0);
3790 add_prefix (&startfile_prefixes,
3791 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
3792 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL, 1);
3794 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
3795 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
3796 then consider it to relocate with the rest of the GCC installation
3797 if GCC_EXEC_PREFIX is set.
3798 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
3799 if (target_system_root && gcc_exec_prefix)
3801 char *tmp_prefix = make_relative_prefix (argv[0],
3802 standard_bindir_prefix,
3803 target_system_root);
3804 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
3806 target_system_root = tmp_prefix;
3807 target_system_root_changed = 1;
3810 #endif
3812 /* More prefixes are enabled in main, after we read the specs file
3813 and determine whether this is cross-compilation or not. */
3815 /* Then create the space for the vectors and scan again. */
3817 switches = xmalloc ((n_switches + 1) * sizeof (struct switchstr));
3818 infiles = xmalloc ((n_infiles + 1) * sizeof (struct infile));
3819 n_switches = 0;
3820 n_infiles = 0;
3821 last_language_n_infiles = -1;
3823 /* This, time, copy the text of each switch and store a pointer
3824 to the copy in the vector of switches.
3825 Store all the infiles in their vector. */
3827 for (i = 1; i < argc; i++)
3829 /* Just skip the switches that were handled by the preceding loop. */
3830 #ifdef MODIFY_TARGET_NAME
3831 is_modify_target_name = 0;
3833 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
3834 if (! strcmp (argv[i], modify_target[j].sw))
3835 is_modify_target_name = 1;
3837 if (is_modify_target_name)
3839 else
3840 #endif
3841 if (! strncmp (argv[i], "-Wa,", 4))
3843 else if (! strncmp (argv[i], "-Wp,", 4))
3845 else if (! strcmp (argv[i], "-pass-exit-codes"))
3847 else if (! strcmp (argv[i], "-print-search-dirs"))
3849 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3851 else if (! strncmp (argv[i], "-print-file-name=", 17))
3853 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3855 else if (! strcmp (argv[i], "-print-multi-lib"))
3857 else if (! strcmp (argv[i], "-print-multi-directory"))
3859 else if (! strcmp (argv[i], "-print-multi-os-directory"))
3861 else if (! strcmp (argv[i], "-ftarget-help"))
3863 else if (! strcmp (argv[i], "-fhelp"))
3865 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3867 /* Compensate for the +e options to the C++ front-end;
3868 they're there simply for cfront call-compatibility. We do
3869 some magic in default_compilers to pass them down properly.
3870 Note we deliberately start at the `+' here, to avoid passing
3871 -e0 or -e1 down into the linker. */
3872 switches[n_switches].part1 = &argv[i][0];
3873 switches[n_switches].args = 0;
3874 switches[n_switches].live_cond = SWITCH_OK;
3875 switches[n_switches].validated = 0;
3876 n_switches++;
3878 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3880 int prev, j;
3881 /* Split the argument at commas. */
3882 prev = 4;
3883 for (j = 4; argv[i][j]; j++)
3884 if (argv[i][j] == ',')
3886 infiles[n_infiles].language = "*";
3887 infiles[n_infiles++].name
3888 = save_string (argv[i] + prev, j - prev);
3889 prev = j + 1;
3891 /* Record the part after the last comma. */
3892 infiles[n_infiles].language = "*";
3893 infiles[n_infiles++].name = argv[i] + prev;
3895 else if (strcmp (argv[i], "-Xlinker") == 0)
3897 infiles[n_infiles].language = "*";
3898 infiles[n_infiles++].name = argv[++i];
3900 else if (strcmp (argv[i], "-Xassembler") == 0)
3902 infiles[n_infiles].language = "*";
3903 infiles[n_infiles++].name = argv[++i];
3905 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
3907 infiles[n_infiles].language = "*";
3908 infiles[n_infiles++].name = argv[++i];
3910 else if (strcmp (argv[i], "-l") == 0)
3911 { /* POSIX allows separation of -l and the lib arg;
3912 canonicalize by concatenating -l with its arg */
3913 infiles[n_infiles].language = "*";
3914 infiles[n_infiles++].name = concat ("-l", argv[++i], NULL);
3916 else if (strncmp (argv[i], "-l", 2) == 0)
3918 infiles[n_infiles].language = "*";
3919 infiles[n_infiles++].name = argv[i];
3921 else if (strcmp (argv[i], "-specs") == 0)
3922 i++;
3923 else if (strncmp (argv[i], "-specs=", 7) == 0)
3925 else if (strcmp (argv[i], "-time") == 0)
3927 else if (strcmp (argv[i], "-###") == 0)
3929 else if (argv[i][0] == '-' && argv[i][1] != 0)
3931 const char *p = &argv[i][1];
3932 int c = *p;
3934 if (c == 'x')
3936 if (p[1] == 0 && i + 1 == argc)
3937 fatal ("argument to `-x' is missing");
3938 if (p[1] == 0)
3939 spec_lang = argv[++i];
3940 else
3941 spec_lang = p + 1;
3942 if (! strcmp (spec_lang, "none"))
3943 /* Suppress the warning if -xnone comes after the last input
3944 file, because alternate command interfaces like g++ might
3945 find it useful to place -xnone after each input file. */
3946 spec_lang = 0;
3947 else
3948 last_language_n_infiles = n_infiles;
3949 continue;
3951 switches[n_switches].part1 = p;
3952 /* Deal with option arguments in separate argv elements. */
3953 if ((SWITCH_TAKES_ARG (c) > (p[1] != 0))
3954 || WORD_SWITCH_TAKES_ARG (p))
3956 int j = 0;
3957 int n_args = WORD_SWITCH_TAKES_ARG (p);
3959 if (n_args == 0)
3961 /* Count only the option arguments in separate argv elements. */
3962 n_args = SWITCH_TAKES_ARG (c) - (p[1] != 0);
3964 if (i + n_args >= argc)
3965 fatal ("argument to `-%s' is missing", p);
3966 switches[n_switches].args
3967 = xmalloc ((n_args + 1) * sizeof(const char *));
3968 while (j < n_args)
3969 switches[n_switches].args[j++] = argv[++i];
3970 /* Null-terminate the vector. */
3971 switches[n_switches].args[j] = 0;
3973 else if (strchr (switches_need_spaces, c))
3975 /* On some systems, ld cannot handle some options without
3976 a space. So split the option from its argument. */
3977 char *part1 = xmalloc (2);
3978 part1[0] = c;
3979 part1[1] = '\0';
3981 switches[n_switches].part1 = part1;
3982 switches[n_switches].args = xmalloc (2 * sizeof (const char *));
3983 switches[n_switches].args[0] = xstrdup (p+1);
3984 switches[n_switches].args[1] = 0;
3986 else
3987 switches[n_switches].args = 0;
3989 switches[n_switches].live_cond = SWITCH_OK;
3990 switches[n_switches].validated = 0;
3991 switches[n_switches].ordering = 0;
3992 /* These are always valid, since gcc.c itself understands them. */
3993 if (!strcmp (p, "save-temps")
3994 || !strcmp (p, "static-libgcc")
3995 || !strcmp (p, "shared-libgcc")
3996 || !strcmp (p, "pipe"))
3997 switches[n_switches].validated = 1;
3998 else
4000 char ch = switches[n_switches].part1[0];
4001 if (ch == 'B')
4002 switches[n_switches].validated = 1;
4004 n_switches++;
4006 else
4008 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4009 argv[i] = convert_filename (argv[i], 0, access (argv[i], F_OK));
4010 #endif
4012 if (strcmp (argv[i], "-") != 0 && access (argv[i], F_OK) < 0)
4014 perror_with_name (argv[i]);
4015 error_count++;
4017 else
4019 infiles[n_infiles].language = spec_lang;
4020 infiles[n_infiles++].name = argv[i];
4025 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4026 error ("warning: `-x %s' after last input file has no effect", spec_lang);
4028 /* Ensure we only invoke each subprocess once. */
4029 if (target_help_flag || print_help_list)
4031 n_infiles = 1;
4033 /* Create a dummy input file, so that we can pass --target-help on to
4034 the various sub-processes. */
4035 infiles[0].language = "c";
4036 infiles[0].name = "help-dummy";
4038 if (target_help_flag)
4040 switches[n_switches].part1 = "--target-help";
4041 switches[n_switches].args = 0;
4042 switches[n_switches].live_cond = SWITCH_OK;
4043 switches[n_switches].validated = 0;
4045 n_switches++;
4048 if (print_help_list)
4050 switches[n_switches].part1 = "--help";
4051 switches[n_switches].args = 0;
4052 switches[n_switches].live_cond = SWITCH_OK;
4053 switches[n_switches].validated = 0;
4055 n_switches++;
4059 switches[n_switches].part1 = 0;
4060 infiles[n_infiles].name = 0;
4063 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4064 and place that in the environment. */
4066 static void
4067 set_collect_gcc_options (void)
4069 int i;
4070 int first_time;
4072 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4073 the compiler. */
4074 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4075 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4077 first_time = TRUE;
4078 for (i = 0; (int) i < n_switches; i++)
4080 const char *const *args;
4081 const char *p, *q;
4082 if (!first_time)
4083 obstack_grow (&collect_obstack, " ", 1);
4085 first_time = FALSE;
4087 /* Ignore elided switches. */
4088 if (switches[i].live_cond == SWITCH_IGNORE)
4089 continue;
4091 obstack_grow (&collect_obstack, "'-", 2);
4092 q = switches[i].part1;
4093 while ((p = strchr (q, '\'')))
4095 obstack_grow (&collect_obstack, q, p - q);
4096 obstack_grow (&collect_obstack, "'\\''", 4);
4097 q = ++p;
4099 obstack_grow (&collect_obstack, q, strlen (q));
4100 obstack_grow (&collect_obstack, "'", 1);
4102 for (args = switches[i].args; args && *args; args++)
4104 obstack_grow (&collect_obstack, " '", 2);
4105 q = *args;
4106 while ((p = strchr (q, '\'')))
4108 obstack_grow (&collect_obstack, q, p - q);
4109 obstack_grow (&collect_obstack, "'\\''", 4);
4110 q = ++p;
4112 obstack_grow (&collect_obstack, q, strlen (q));
4113 obstack_grow (&collect_obstack, "'", 1);
4116 obstack_grow (&collect_obstack, "\0", 1);
4117 putenv (obstack_finish (&collect_obstack));
4120 /* Process a spec string, accumulating and running commands. */
4122 /* These variables describe the input file name.
4123 input_file_number is the index on outfiles of this file,
4124 so that the output file name can be stored for later use by %o.
4125 input_basename is the start of the part of the input file
4126 sans all directory names, and basename_length is the number
4127 of characters starting there excluding the suffix .c or whatever. */
4129 static const char *input_filename;
4130 static int input_file_number;
4131 size_t input_filename_length;
4132 static int basename_length;
4133 static int suffixed_basename_length;
4134 static const char *input_basename;
4135 static const char *input_suffix;
4136 static struct stat input_stat;
4137 static int input_stat_set;
4139 /* The compiler used to process the current input file. */
4140 static struct compiler *input_file_compiler;
4142 /* These are variables used within do_spec and do_spec_1. */
4144 /* Nonzero if an arg has been started and not yet terminated
4145 (with space, tab or newline). */
4146 static int arg_going;
4148 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4149 is a temporary file name. */
4150 static int delete_this_arg;
4152 /* Nonzero means %w has been seen; the next arg to be terminated
4153 is the output file name of this compilation. */
4154 static int this_is_output_file;
4156 /* Nonzero means %s has been seen; the next arg to be terminated
4157 is the name of a library file and we should try the standard
4158 search dirs for it. */
4159 static int this_is_library_file;
4161 /* Nonzero means that the input of this command is coming from a pipe. */
4162 static int input_from_pipe;
4164 /* Nonnull means substitute this for any suffix when outputting a switches
4165 arguments. */
4166 static const char *suffix_subst;
4168 /* Process the spec SPEC and run the commands specified therein.
4169 Returns 0 if the spec is successfully processed; -1 if failed. */
4172 do_spec (const char *spec)
4174 int value;
4176 value = do_spec_2 (spec);
4178 /* Force out any unfinished command.
4179 If -pipe, this forces out the last command if it ended in `|'. */
4180 if (value == 0)
4182 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4183 argbuf_index--;
4185 set_collect_gcc_options ();
4187 if (argbuf_index > 0)
4188 value = execute ();
4191 return value;
4194 static int
4195 do_spec_2 (const char *spec)
4197 const char *string;
4198 int result;
4200 clear_args ();
4201 arg_going = 0;
4202 delete_this_arg = 0;
4203 this_is_output_file = 0;
4204 this_is_library_file = 0;
4205 input_from_pipe = 0;
4206 suffix_subst = NULL;
4208 result = do_spec_1 (spec, 0, NULL);
4210 /* End any pending argument. */
4211 if (arg_going)
4213 obstack_1grow (&obstack, 0);
4214 string = obstack_finish (&obstack);
4215 if (this_is_library_file)
4216 string = find_file (string);
4217 store_arg (string, delete_this_arg, this_is_output_file);
4218 if (this_is_output_file)
4219 outfiles[input_file_number] = string;
4220 arg_going = 0;
4223 return result;
4227 /* Process the given spec string and add any new options to the end
4228 of the switches/n_switches array. */
4230 static void
4231 do_option_spec (const char *name, const char *spec)
4233 unsigned int i, value_count, value_len;
4234 const char *p, *q, *value;
4235 char *tmp_spec, *tmp_spec_p;
4237 if (configure_default_options[0].name == NULL)
4238 return;
4240 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4241 if (strcmp (configure_default_options[i].name, name) == 0)
4242 break;
4243 if (i == ARRAY_SIZE (configure_default_options))
4244 return;
4246 value = configure_default_options[i].value;
4247 value_len = strlen (value);
4249 /* Compute the size of the final spec. */
4250 value_count = 0;
4251 p = spec;
4252 while ((p = strstr (p, "%(VALUE)")) != NULL)
4254 p ++;
4255 value_count ++;
4258 /* Replace each %(VALUE) by the specified value. */
4259 tmp_spec = alloca (strlen (spec) + 1
4260 + value_count * (value_len - strlen ("%(VALUE)")));
4261 tmp_spec_p = tmp_spec;
4262 q = spec;
4263 while ((p = strstr (q, "%(VALUE)")) != NULL)
4265 memcpy (tmp_spec_p, q, p - q);
4266 tmp_spec_p = tmp_spec_p + (p - q);
4267 memcpy (tmp_spec_p, value, value_len);
4268 tmp_spec_p += value_len;
4269 q = p + strlen ("%(VALUE)");
4271 strcpy (tmp_spec_p, q);
4273 do_self_spec (tmp_spec);
4276 /* Process the given spec string and add any new options to the end
4277 of the switches/n_switches array. */
4279 static void
4280 do_self_spec (const char *spec)
4282 do_spec_2 (spec);
4283 do_spec_1 (" ", 0, NULL);
4285 if (argbuf_index > 0)
4287 int i, first;
4289 first = n_switches;
4290 n_switches += argbuf_index;
4291 switches = xrealloc (switches,
4292 sizeof (struct switchstr) * (n_switches + 1));
4294 switches[n_switches] = switches[first];
4295 for (i = 0; i < argbuf_index; i++)
4297 struct switchstr *sw;
4299 /* Each switch should start with '-'. */
4300 if (argbuf[i][0] != '-')
4301 abort ();
4303 sw = &switches[i + first];
4304 sw->part1 = &argbuf[i][1];
4305 sw->args = 0;
4306 sw->live_cond = SWITCH_OK;
4307 sw->validated = 0;
4308 sw->ordering = 0;
4313 /* Process the sub-spec SPEC as a portion of a larger spec.
4314 This is like processing a whole spec except that we do
4315 not initialize at the beginning and we do not supply a
4316 newline by default at the end.
4317 INSWITCH nonzero means don't process %-sequences in SPEC;
4318 in this case, % is treated as an ordinary character.
4319 This is used while substituting switches.
4320 INSWITCH nonzero also causes SPC not to terminate an argument.
4322 Value is zero unless a line was finished
4323 and the command on that line reported an error. */
4325 static int
4326 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4328 const char *p = spec;
4329 int c;
4330 int i;
4331 const char *string;
4332 int value;
4334 while ((c = *p++))
4335 /* If substituting a switch, treat all chars like letters.
4336 Otherwise, NL, SPC, TAB and % are special. */
4337 switch (inswitch ? 'a' : c)
4339 case '\n':
4340 /* End of line: finish any pending argument,
4341 then run the pending command if one has been started. */
4342 if (arg_going)
4344 obstack_1grow (&obstack, 0);
4345 string = obstack_finish (&obstack);
4346 if (this_is_library_file)
4347 string = find_file (string);
4348 store_arg (string, delete_this_arg, this_is_output_file);
4349 if (this_is_output_file)
4350 outfiles[input_file_number] = string;
4352 arg_going = 0;
4354 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4356 /* A `|' before the newline means use a pipe here,
4357 but only if -pipe was specified.
4358 Otherwise, execute now and don't pass the `|' as an arg. */
4359 if (use_pipes)
4361 input_from_pipe = 1;
4362 break;
4364 else
4365 argbuf_index--;
4368 set_collect_gcc_options ();
4370 if (argbuf_index > 0)
4372 value = execute ();
4373 if (value)
4374 return value;
4376 /* Reinitialize for a new command, and for a new argument. */
4377 clear_args ();
4378 arg_going = 0;
4379 delete_this_arg = 0;
4380 this_is_output_file = 0;
4381 this_is_library_file = 0;
4382 input_from_pipe = 0;
4383 break;
4385 case '|':
4386 /* End any pending argument. */
4387 if (arg_going)
4389 obstack_1grow (&obstack, 0);
4390 string = obstack_finish (&obstack);
4391 if (this_is_library_file)
4392 string = find_file (string);
4393 store_arg (string, delete_this_arg, this_is_output_file);
4394 if (this_is_output_file)
4395 outfiles[input_file_number] = string;
4398 /* Use pipe */
4399 obstack_1grow (&obstack, c);
4400 arg_going = 1;
4401 break;
4403 case '\t':
4404 case ' ':
4405 /* Space or tab ends an argument if one is pending. */
4406 if (arg_going)
4408 obstack_1grow (&obstack, 0);
4409 string = obstack_finish (&obstack);
4410 if (this_is_library_file)
4411 string = find_file (string);
4412 store_arg (string, delete_this_arg, this_is_output_file);
4413 if (this_is_output_file)
4414 outfiles[input_file_number] = string;
4416 /* Reinitialize for a new argument. */
4417 arg_going = 0;
4418 delete_this_arg = 0;
4419 this_is_output_file = 0;
4420 this_is_library_file = 0;
4421 break;
4423 case '%':
4424 switch (c = *p++)
4426 case 0:
4427 fatal ("invalid specification! Bug in cc");
4429 case 'b':
4430 obstack_grow (&obstack, input_basename, basename_length);
4431 arg_going = 1;
4432 break;
4434 case 'B':
4435 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4436 arg_going = 1;
4437 break;
4439 case 'd':
4440 delete_this_arg = 2;
4441 break;
4443 /* Dump out the directories specified with LIBRARY_PATH,
4444 followed by the absolute directories
4445 that we search for startfiles. */
4446 case 'D':
4448 struct prefix_list *pl = startfile_prefixes.plist;
4449 size_t bufsize = 100;
4450 char *buffer = xmalloc (bufsize);
4451 int idx;
4453 for (; pl; pl = pl->next)
4455 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4456 /* Used on systems which record the specified -L dirs
4457 and use them to search for dynamic linking. */
4458 /* Relative directories always come from -B,
4459 and it is better not to use them for searching
4460 at run time. In particular, stage1 loses. */
4461 if (!IS_ABSOLUTE_PATH (pl->prefix))
4462 continue;
4463 #endif
4464 /* Try subdirectory if there is one. */
4465 if (multilib_dir != NULL
4466 || (pl->os_multilib && multilib_os_dir != NULL))
4468 const char *multi_dir;
4470 multi_dir = pl->os_multilib ? multilib_os_dir
4471 : multilib_dir;
4472 if (machine_suffix && multilib_dir)
4474 if (strlen (pl->prefix) + strlen (machine_suffix)
4475 >= bufsize)
4476 bufsize = (strlen (pl->prefix)
4477 + strlen (machine_suffix)) * 2 + 1;
4478 buffer = xrealloc (buffer, bufsize);
4479 strcpy (buffer, pl->prefix);
4480 strcat (buffer, machine_suffix);
4481 if (is_directory (buffer, multilib_dir, 1))
4483 do_spec_1 ("-L", 0, NULL);
4484 #ifdef SPACE_AFTER_L_OPTION
4485 do_spec_1 (" ", 0, NULL);
4486 #endif
4487 do_spec_1 (buffer, 1, NULL);
4488 do_spec_1 (multilib_dir, 1, NULL);
4489 /* Make this a separate argument. */
4490 do_spec_1 (" ", 0, NULL);
4493 if (!pl->require_machine_suffix)
4495 if (is_directory (pl->prefix, multi_dir, 1))
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 (pl->prefix, 1, NULL);
4502 do_spec_1 (multi_dir, 1, NULL);
4503 /* Make this a separate argument. */
4504 do_spec_1 (" ", 0, NULL);
4508 if (machine_suffix)
4510 if (is_directory (pl->prefix, machine_suffix, 1))
4512 do_spec_1 ("-L", 0, NULL);
4513 #ifdef SPACE_AFTER_L_OPTION
4514 do_spec_1 (" ", 0, NULL);
4515 #endif
4516 do_spec_1 (pl->prefix, 1, NULL);
4517 /* Remove slash from machine_suffix. */
4518 if (strlen (machine_suffix) >= bufsize)
4519 bufsize = strlen (machine_suffix) * 2 + 1;
4520 buffer = xrealloc (buffer, bufsize);
4521 strcpy (buffer, machine_suffix);
4522 idx = strlen (buffer);
4523 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4524 buffer[idx - 1] = 0;
4525 do_spec_1 (buffer, 1, NULL);
4526 /* Make this a separate argument. */
4527 do_spec_1 (" ", 0, NULL);
4530 if (!pl->require_machine_suffix)
4532 if (is_directory (pl->prefix, "", 1))
4534 do_spec_1 ("-L", 0, NULL);
4535 #ifdef SPACE_AFTER_L_OPTION
4536 do_spec_1 (" ", 0, NULL);
4537 #endif
4538 /* Remove slash from pl->prefix. */
4539 if (strlen (pl->prefix) >= bufsize)
4540 bufsize = strlen (pl->prefix) * 2 + 1;
4541 buffer = xrealloc (buffer, bufsize);
4542 strcpy (buffer, pl->prefix);
4543 idx = strlen (buffer);
4544 if (IS_DIR_SEPARATOR (buffer[idx - 1]))
4545 buffer[idx - 1] = 0;
4546 do_spec_1 (buffer, 1, NULL);
4547 /* Make this a separate argument. */
4548 do_spec_1 (" ", 0, NULL);
4552 free (buffer);
4554 break;
4556 case 'e':
4557 /* %efoo means report an error with `foo' as error message
4558 and don't execute any more commands for this file. */
4560 const char *q = p;
4561 char *buf;
4562 while (*p != 0 && *p != '\n')
4563 p++;
4564 buf = alloca (p - q + 1);
4565 strncpy (buf, q, p - q);
4566 buf[p - q] = 0;
4567 error ("%s", buf);
4568 return -1;
4570 break;
4571 case 'n':
4572 /* %nfoo means report a notice with `foo' on stderr. */
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 notice ("%s\n", buf);
4582 if (*p)
4583 p++;
4585 break;
4587 case 'j':
4589 struct stat st;
4591 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4592 defined, and it is not a directory, and it is
4593 writable, use it. Otherwise, treat this like any
4594 other temporary file. */
4596 if ((!save_temps_flag)
4597 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4598 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4600 obstack_grow (&obstack, HOST_BIT_BUCKET,
4601 strlen (HOST_BIT_BUCKET));
4602 delete_this_arg = 0;
4603 arg_going = 1;
4604 break;
4607 goto create_temp_file;
4608 case '|':
4609 if (use_pipes)
4611 obstack_1grow (&obstack, '-');
4612 delete_this_arg = 0;
4613 arg_going = 1;
4615 /* consume suffix */
4616 while (*p == '.' || ISALPHA ((unsigned char) *p))
4617 p++;
4618 if (p[0] == '%' && p[1] == 'O')
4619 p += 2;
4621 break;
4623 goto create_temp_file;
4624 case 'm':
4625 if (use_pipes)
4627 /* consume suffix */
4628 while (*p == '.' || ISALPHA ((unsigned char) *p))
4629 p++;
4630 if (p[0] == '%' && p[1] == 'O')
4631 p += 2;
4633 break;
4635 goto create_temp_file;
4636 case 'g':
4637 case 'u':
4638 case 'U':
4639 create_temp_file:
4641 struct temp_name *t;
4642 int suffix_length;
4643 const char *suffix = p;
4644 char *saved_suffix = NULL;
4646 while (*p == '.' || ISALPHA ((unsigned char) *p))
4647 p++;
4648 suffix_length = p - suffix;
4649 if (p[0] == '%' && p[1] == 'O')
4651 p += 2;
4652 /* We don't support extra suffix characters after %O. */
4653 if (*p == '.' || ISALPHA ((unsigned char) *p))
4654 abort ();
4655 if (suffix_length == 0)
4656 suffix = TARGET_OBJECT_SUFFIX;
4657 else
4659 saved_suffix
4660 = xmalloc (suffix_length
4661 + strlen (TARGET_OBJECT_SUFFIX));
4662 strncpy (saved_suffix, suffix, suffix_length);
4663 strcpy (saved_suffix + suffix_length,
4664 TARGET_OBJECT_SUFFIX);
4666 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4669 /* If the input_filename has the same suffix specified
4670 for the %g, %u, or %U, and -save-temps is specified,
4671 we could end up using that file as an intermediate
4672 thus clobbering the user's source file (.e.g.,
4673 gcc -save-temps foo.s would clobber foo.s with the
4674 output of cpp0). So check for this condition and
4675 generate a temp file as the intermediate. */
4677 if (save_temps_flag)
4679 temp_filename_length = basename_length + suffix_length;
4680 temp_filename = alloca (temp_filename_length + 1);
4681 strncpy ((char *) temp_filename, input_basename, basename_length);
4682 strncpy ((char *) temp_filename + basename_length, suffix,
4683 suffix_length);
4684 *((char *) temp_filename + temp_filename_length) = '\0';
4685 if (strcmp (temp_filename, input_filename) != 0)
4687 struct stat st_temp;
4689 /* Note, set_input() resets input_stat_set to 0. */
4690 if (input_stat_set == 0)
4692 input_stat_set = stat (input_filename, &input_stat);
4693 if (input_stat_set >= 0)
4694 input_stat_set = 1;
4697 /* If we have the stat for the input_filename
4698 and we can do the stat for the temp_filename
4699 then the they could still refer to the same
4700 file if st_dev/st_ino's are the same. */
4702 if (input_stat_set != 1
4703 || stat (temp_filename, &st_temp) < 0
4704 || input_stat.st_dev != st_temp.st_dev
4705 || input_stat.st_ino != st_temp.st_ino)
4707 temp_filename = save_string (temp_filename,
4708 temp_filename_length + 1);
4709 obstack_grow (&obstack, temp_filename,
4710 temp_filename_length);
4711 arg_going = 1;
4712 delete_this_arg = 0;
4713 break;
4718 /* See if we already have an association of %g/%u/%U and
4719 suffix. */
4720 for (t = temp_names; t; t = t->next)
4721 if (t->length == suffix_length
4722 && strncmp (t->suffix, suffix, suffix_length) == 0
4723 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4724 break;
4726 /* Make a new association if needed. %u and %j
4727 require one. */
4728 if (t == 0 || c == 'u' || c == 'j')
4730 if (t == 0)
4732 t = xmalloc (sizeof (struct temp_name));
4733 t->next = temp_names;
4734 temp_names = t;
4736 t->length = suffix_length;
4737 if (saved_suffix)
4739 t->suffix = saved_suffix;
4740 saved_suffix = NULL;
4742 else
4743 t->suffix = save_string (suffix, suffix_length);
4744 t->unique = (c == 'u' || c == 'U' || c == 'j');
4745 temp_filename = make_temp_file (t->suffix);
4746 temp_filename_length = strlen (temp_filename);
4747 t->filename = temp_filename;
4748 t->filename_length = temp_filename_length;
4751 if (saved_suffix)
4752 free (saved_suffix);
4754 obstack_grow (&obstack, t->filename, t->filename_length);
4755 delete_this_arg = 1;
4757 arg_going = 1;
4758 break;
4760 case 'i':
4761 if (combine_inputs)
4763 for (i = 0; (int) i < n_infiles; i++)
4764 store_arg (infiles[i].name, 0, 0);
4766 else
4768 obstack_grow (&obstack, input_filename, input_filename_length);
4769 arg_going = 1;
4771 break;
4773 case 'I':
4775 struct prefix_list *pl = include_prefixes.plist;
4777 if (gcc_exec_prefix)
4779 do_spec_1 ("-iprefix", 1, NULL);
4780 /* Make this a separate argument. */
4781 do_spec_1 (" ", 0, NULL);
4782 do_spec_1 (gcc_exec_prefix, 1, NULL);
4783 do_spec_1 (" ", 0, NULL);
4786 if (target_system_root_changed ||
4787 (target_system_root && target_sysroot_hdrs_suffix))
4789 do_spec_1 ("-isysroot", 1, NULL);
4790 /* Make this a separate argument. */
4791 do_spec_1 (" ", 0, NULL);
4792 do_spec_1 (target_system_root, 1, NULL);
4793 if (target_sysroot_hdrs_suffix)
4794 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
4795 do_spec_1 (" ", 0, NULL);
4798 for (; pl; pl = pl->next)
4800 do_spec_1 ("-isystem", 1, NULL);
4801 /* Make this a separate argument. */
4802 do_spec_1 (" ", 0, NULL);
4803 do_spec_1 (pl->prefix, 1, NULL);
4804 do_spec_1 (" ", 0, NULL);
4807 break;
4809 case 'o':
4811 int max = n_infiles;
4812 max += lang_specific_extra_outfiles;
4814 for (i = 0; i < max; i++)
4815 if (outfiles[i])
4816 store_arg (outfiles[i], 0, 0);
4817 break;
4820 case 'O':
4821 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
4822 arg_going = 1;
4823 break;
4825 case 's':
4826 this_is_library_file = 1;
4827 break;
4829 case 'V':
4830 outfiles[input_file_number] = NULL;
4831 break;
4833 case 'w':
4834 this_is_output_file = 1;
4835 break;
4837 case 'W':
4839 int cur_index = argbuf_index;
4840 /* Handle the {...} following the %W. */
4841 if (*p != '{')
4842 abort ();
4843 p = handle_braces (p + 1);
4844 if (p == 0)
4845 return -1;
4846 /* End any pending argument. */
4847 if (arg_going)
4849 obstack_1grow (&obstack, 0);
4850 string = obstack_finish (&obstack);
4851 if (this_is_library_file)
4852 string = find_file (string);
4853 store_arg (string, delete_this_arg, this_is_output_file);
4854 if (this_is_output_file)
4855 outfiles[input_file_number] = string;
4856 arg_going = 0;
4858 /* If any args were output, mark the last one for deletion
4859 on failure. */
4860 if (argbuf_index != cur_index)
4861 record_temp_file (argbuf[argbuf_index - 1], 0, 1);
4862 break;
4865 /* %x{OPTION} records OPTION for %X to output. */
4866 case 'x':
4868 const char *p1 = p;
4869 char *string;
4871 /* Skip past the option value and make a copy. */
4872 if (*p != '{')
4873 abort ();
4874 while (*p++ != '}')
4876 string = save_string (p1 + 1, p - p1 - 2);
4878 /* See if we already recorded this option. */
4879 for (i = 0; i < n_linker_options; i++)
4880 if (! strcmp (string, linker_options[i]))
4882 free (string);
4883 return 0;
4886 /* This option is new; add it. */
4887 add_linker_option (string, strlen (string));
4889 break;
4891 /* Dump out the options accumulated previously using %x. */
4892 case 'X':
4893 for (i = 0; i < n_linker_options; i++)
4895 do_spec_1 (linker_options[i], 1, NULL);
4896 /* Make each accumulated option a separate argument. */
4897 do_spec_1 (" ", 0, NULL);
4899 break;
4901 /* Dump out the options accumulated previously using -Wa,. */
4902 case 'Y':
4903 for (i = 0; i < n_assembler_options; i++)
4905 do_spec_1 (assembler_options[i], 1, NULL);
4906 /* Make each accumulated option a separate argument. */
4907 do_spec_1 (" ", 0, NULL);
4909 break;
4911 /* Dump out the options accumulated previously using -Wp,. */
4912 case 'Z':
4913 for (i = 0; i < n_preprocessor_options; i++)
4915 do_spec_1 (preprocessor_options[i], 1, NULL);
4916 /* Make each accumulated option a separate argument. */
4917 do_spec_1 (" ", 0, NULL);
4919 break;
4921 /* Here are digits and numbers that just process
4922 a certain constant string as a spec. */
4924 case '1':
4925 value = do_spec_1 (cc1_spec, 0, NULL);
4926 if (value != 0)
4927 return value;
4928 break;
4930 case '2':
4931 value = do_spec_1 (cc1plus_spec, 0, NULL);
4932 if (value != 0)
4933 return value;
4934 break;
4936 case 'a':
4937 value = do_spec_1 (asm_spec, 0, NULL);
4938 if (value != 0)
4939 return value;
4940 break;
4942 case 'A':
4943 value = do_spec_1 (asm_final_spec, 0, NULL);
4944 if (value != 0)
4945 return value;
4946 break;
4948 case 'C':
4950 const char *const spec
4951 = (input_file_compiler->cpp_spec
4952 ? input_file_compiler->cpp_spec
4953 : cpp_spec);
4954 value = do_spec_1 (spec, 0, NULL);
4955 if (value != 0)
4956 return value;
4958 break;
4960 case 'E':
4961 value = do_spec_1 (endfile_spec, 0, NULL);
4962 if (value != 0)
4963 return value;
4964 break;
4966 case 'l':
4967 value = do_spec_1 (link_spec, 0, NULL);
4968 if (value != 0)
4969 return value;
4970 break;
4972 case 'L':
4973 value = do_spec_1 (lib_spec, 0, NULL);
4974 if (value != 0)
4975 return value;
4976 break;
4978 case 'G':
4979 value = do_spec_1 (libgcc_spec, 0, NULL);
4980 if (value != 0)
4981 return value;
4982 break;
4984 case 'M':
4985 if (multilib_dir && strcmp (multilib_dir, ".") != 0)
4987 char *p;
4988 const char *q;
4989 size_t len;
4991 len = strlen (multilib_dir);
4992 obstack_blank (&obstack, len + 1);
4993 p = obstack_next_free (&obstack) - (len + 1);
4995 *p++ = '_';
4996 for (q = multilib_dir; *q ; ++q, ++p)
4997 *p = (IS_DIR_SEPARATOR (*q) ? '_' : *q);
4999 break;
5001 case 'R':
5002 /* We assume there is a directory
5003 separator at the end of this string. */
5004 if (target_system_root)
5006 obstack_grow (&obstack, target_system_root,
5007 strlen (target_system_root));
5008 if (target_sysroot_suffix)
5009 obstack_grow (&obstack, target_sysroot_suffix,
5010 strlen (target_sysroot_suffix));
5012 break;
5014 case 'S':
5015 value = do_spec_1 (startfile_spec, 0, NULL);
5016 if (value != 0)
5017 return value;
5018 break;
5020 /* Here we define characters other than letters and digits. */
5022 case '{':
5023 p = handle_braces (p);
5024 if (p == 0)
5025 return -1;
5026 break;
5028 case ':':
5029 p = handle_spec_function (p);
5030 if (p == 0)
5031 return -1;
5032 break;
5034 case '%':
5035 obstack_1grow (&obstack, '%');
5036 break;
5038 case '.':
5040 unsigned len = 0;
5042 while (p[len] && p[len] != ' ' && p[len] != '%')
5043 len++;
5044 suffix_subst = save_string (p - 1, len + 1);
5045 p += len;
5047 break;
5049 /* Henceforth ignore the option(s) matching the pattern
5050 after the %<. */
5051 case '<':
5053 unsigned len = 0;
5054 int have_wildcard = 0;
5055 int i;
5057 while (p[len] && p[len] != ' ' && p[len] != '\t')
5058 len++;
5060 if (p[len-1] == '*')
5061 have_wildcard = 1;
5063 for (i = 0; i < n_switches; i++)
5064 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5065 && (have_wildcard || switches[i].part1[len] == '\0'))
5067 switches[i].live_cond = SWITCH_IGNORE;
5068 switches[i].validated = 1;
5071 p += len;
5073 break;
5075 case '*':
5076 if (soft_matched_part)
5078 do_spec_1 (soft_matched_part, 1, NULL);
5079 do_spec_1 (" ", 0, NULL);
5081 else
5082 /* Catch the case where a spec string contains something like
5083 '%{foo:%*}'. ie there is no * in the pattern on the left
5084 hand side of the :. */
5085 error ("spec failure: '%%*' has not been initialized by pattern match");
5086 break;
5088 /* Process a string found as the value of a spec given by name.
5089 This feature allows individual machine descriptions
5090 to add and use their own specs.
5091 %[...] modifies -D options the way %P does;
5092 %(...) uses the spec unmodified. */
5093 case '[':
5094 error ("warning: use of obsolete %%[ operator in specs");
5095 case '(':
5097 const char *name = p;
5098 struct spec_list *sl;
5099 int len;
5101 /* The string after the S/P is the name of a spec that is to be
5102 processed. */
5103 while (*p && *p != ')' && *p != ']')
5104 p++;
5106 /* See if it's in the list. */
5107 for (len = p - name, sl = specs; sl; sl = sl->next)
5108 if (sl->name_len == len && !strncmp (sl->name, name, len))
5110 name = *(sl->ptr_spec);
5111 #ifdef DEBUG_SPECS
5112 notice ("Processing spec %c%s%c, which is '%s'\n",
5113 c, sl->name, (c == '(') ? ')' : ']', name);
5114 #endif
5115 break;
5118 if (sl)
5120 if (c == '(')
5122 value = do_spec_1 (name, 0, NULL);
5123 if (value != 0)
5124 return value;
5126 else
5128 char *x = alloca (strlen (name) * 2 + 1);
5129 char *buf = x;
5130 const char *y = name;
5131 int flag = 0;
5133 /* Copy all of NAME into BUF, but put __ after
5134 every -D and at the end of each arg. */
5135 while (1)
5137 if (! strncmp (y, "-D", 2))
5139 *x++ = '-';
5140 *x++ = 'D';
5141 *x++ = '_';
5142 *x++ = '_';
5143 y += 2;
5144 flag = 1;
5145 continue;
5147 else if (flag
5148 && (*y == ' ' || *y == '\t' || *y == '='
5149 || *y == '}' || *y == 0))
5151 *x++ = '_';
5152 *x++ = '_';
5153 flag = 0;
5155 if (*y == 0)
5156 break;
5157 else
5158 *x++ = *y++;
5160 *x = 0;
5162 value = do_spec_1 (buf, 0, NULL);
5163 if (value != 0)
5164 return value;
5168 /* Discard the closing paren or bracket. */
5169 if (*p)
5170 p++;
5172 break;
5174 default:
5175 error ("spec failure: unrecognized spec option '%c'", c);
5176 break;
5178 break;
5180 case '\\':
5181 /* Backslash: treat next character as ordinary. */
5182 c = *p++;
5184 /* Fall through. */
5185 default:
5186 /* Ordinary character: put it into the current argument. */
5187 obstack_1grow (&obstack, c);
5188 arg_going = 1;
5191 /* End of string. If we are processing a spec function, we need to
5192 end any pending argument. */
5193 if (processing_spec_function && arg_going)
5195 obstack_1grow (&obstack, 0);
5196 string = obstack_finish (&obstack);
5197 if (this_is_library_file)
5198 string = find_file (string);
5199 store_arg (string, delete_this_arg, this_is_output_file);
5200 if (this_is_output_file)
5201 outfiles[input_file_number] = string;
5202 arg_going = 0;
5205 return 0;
5208 /* Look up a spec function. */
5210 static const struct spec_function *
5211 lookup_spec_function (const char *name)
5213 static const struct spec_function * const spec_function_tables[] =
5215 static_spec_functions,
5216 lang_specific_spec_functions,
5218 const struct spec_function *sf;
5219 unsigned int i;
5221 for (i = 0; i < ARRAY_SIZE (spec_function_tables); i++)
5223 for (sf = spec_function_tables[i]; sf->name != NULL; sf++)
5224 if (strcmp (sf->name, name) == 0)
5225 return sf;
5228 return NULL;
5231 /* Evaluate a spec function. */
5233 static const char *
5234 eval_spec_function (const char *func, const char *args)
5236 const struct spec_function *sf;
5237 const char *funcval;
5239 /* Saved spec processing context. */
5240 int save_argbuf_index;
5241 int save_argbuf_length;
5242 const char **save_argbuf;
5244 int save_arg_going;
5245 int save_delete_this_arg;
5246 int save_this_is_output_file;
5247 int save_this_is_library_file;
5248 int save_input_from_pipe;
5249 const char *save_suffix_subst;
5252 sf = lookup_spec_function (func);
5253 if (sf == NULL)
5254 fatal ("unknown spec function `%s'", func);
5256 /* Push the spec processing context. */
5257 save_argbuf_index = argbuf_index;
5258 save_argbuf_length = argbuf_length;
5259 save_argbuf = argbuf;
5261 save_arg_going = arg_going;
5262 save_delete_this_arg = delete_this_arg;
5263 save_this_is_output_file = this_is_output_file;
5264 save_this_is_library_file = this_is_library_file;
5265 save_input_from_pipe = input_from_pipe;
5266 save_suffix_subst = suffix_subst;
5268 /* Create a new spec processing context, and build the function
5269 arguments. */
5271 alloc_args ();
5272 if (do_spec_2 (args) < 0)
5273 fatal ("error in args to spec function `%s'", func);
5275 /* argbuf_index is an index for the next argument to be inserted, and
5276 so contains the count of the args already inserted. */
5278 funcval = (*sf->func) (argbuf_index, argbuf);
5280 /* Pop the spec processing context. */
5281 argbuf_index = save_argbuf_index;
5282 argbuf_length = save_argbuf_length;
5283 free (argbuf);
5284 argbuf = save_argbuf;
5286 arg_going = save_arg_going;
5287 delete_this_arg = save_delete_this_arg;
5288 this_is_output_file = save_this_is_output_file;
5289 this_is_library_file = save_this_is_library_file;
5290 input_from_pipe = save_input_from_pipe;
5291 suffix_subst = save_suffix_subst;
5293 return funcval;
5296 /* Handle a spec function call of the form:
5298 %:function(args)
5300 ARGS is processed as a spec in a separate context and split into an
5301 argument vector in the normal fashion. The function returns a string
5302 containing a spec which we then process in the caller's context, or
5303 NULL if no processing is required. */
5305 static const char *
5306 handle_spec_function (const char *p)
5308 char *func, *args;
5309 const char *endp, *funcval;
5310 int count;
5312 processing_spec_function++;
5314 /* Get the function name. */
5315 for (endp = p; *endp != '\0'; endp++)
5317 if (*endp == '(') /* ) */
5318 break;
5319 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5320 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5321 fatal ("malformed spec function name");
5323 if (*endp != '(') /* ) */
5324 fatal ("no arguments for spec function");
5325 func = save_string (p, endp - p);
5326 p = ++endp;
5328 /* Get the arguments. */
5329 for (count = 0; *endp != '\0'; endp++)
5331 /* ( */
5332 if (*endp == ')')
5334 if (count == 0)
5335 break;
5336 count--;
5338 else if (*endp == '(') /* ) */
5339 count++;
5341 /* ( */
5342 if (*endp != ')')
5343 fatal ("malformed spec function arguments");
5344 args = save_string (p, endp - p);
5345 p = ++endp;
5347 /* p now points to just past the end of the spec function expression. */
5349 funcval = eval_spec_function (func, args);
5350 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5351 p = NULL;
5353 free (func);
5354 free (args);
5356 processing_spec_function--;
5358 return p;
5361 /* Inline subroutine of handle_braces. Returns true if the current
5362 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5363 static inline bool
5364 input_suffix_matches (const char *atom, const char *end_atom)
5366 return (input_suffix
5367 && !strncmp (input_suffix, atom, end_atom - atom)
5368 && input_suffix[end_atom - atom] == '\0');
5371 /* Inline subroutine of handle_braces. Returns true if a switch
5372 matching the atom bracketed by ATOM and END_ATOM appeared on the
5373 command line. */
5374 static inline bool
5375 switch_matches (const char *atom, const char *end_atom, int starred)
5377 int i;
5378 int len = end_atom - atom;
5379 int plen = starred ? len : -1;
5381 for (i = 0; i < n_switches; i++)
5382 if (!strncmp (switches[i].part1, atom, len)
5383 && (starred || switches[i].part1[len] == '\0')
5384 && check_live_switch (i, plen))
5385 return true;
5387 return false;
5390 /* Inline subroutine of handle_braces. Mark all of the switches which
5391 match ATOM (extends to END_ATOM; STARRED indicates whether there
5392 was a star after the atom) for later processing. */
5393 static inline void
5394 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5396 int i;
5397 int len = end_atom - atom;
5398 int plen = starred ? len : -1;
5400 for (i = 0; i < n_switches; i++)
5401 if (!strncmp (switches[i].part1, atom, len)
5402 && (starred || switches[i].part1[len] == '\0')
5403 && check_live_switch (i, plen))
5404 switches[i].ordering = 1;
5407 /* Inline subroutine of handle_braces. Process all the currently
5408 marked switches through give_switch, and clear the marks. */
5409 static inline void
5410 process_marked_switches (void)
5412 int i;
5414 for (i = 0; i < n_switches; i++)
5415 if (switches[i].ordering == 1)
5417 switches[i].ordering = 0;
5418 give_switch (i, 0);
5422 /* Handle a %{ ... } construct. P points just inside the leading {.
5423 Returns a pointer one past the end of the brace block, or 0
5424 if we call do_spec_1 and that returns -1. */
5426 static const char *
5427 handle_braces (const char *p)
5429 const char *atom, *end_atom;
5430 const char *d_atom = NULL, *d_end_atom = NULL;
5432 bool a_is_suffix;
5433 bool a_is_starred;
5434 bool a_is_negated;
5435 bool a_matched;
5437 bool a_must_be_last = false;
5438 bool ordered_set = false;
5439 bool disjunct_set = false;
5440 bool disj_matched = false;
5441 bool disj_starred = true;
5442 bool n_way_choice = false;
5443 bool n_way_matched = false;
5445 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5449 if (a_must_be_last)
5450 abort ();
5452 /* Scan one "atom" (S in the description above of %{}, possibly
5453 with !, ., or * modifiers). */
5454 a_matched = a_is_suffix = a_is_starred = a_is_negated = false;
5456 SKIP_WHITE();
5457 if (*p == '!')
5458 p++, a_is_negated = true;
5460 SKIP_WHITE();
5461 if (*p == '.')
5462 p++, a_is_suffix = true;
5464 atom = p;
5465 while (ISIDNUM(*p) || *p == '-' || *p == '+' || *p == '='
5466 || *p == ',' || *p == '.' || *p == '@')
5467 p++;
5468 end_atom = p;
5470 if (*p == '*')
5471 p++, a_is_starred = 1;
5473 SKIP_WHITE();
5474 if (*p == '&' || *p == '}')
5476 /* Substitute the switch(es) indicated by the current atom. */
5477 ordered_set = true;
5478 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5479 || atom == end_atom)
5480 abort ();
5482 mark_matching_switches (atom, end_atom, a_is_starred);
5484 if (*p == '}')
5485 process_marked_switches ();
5487 else if (*p == '|' || *p == ':')
5489 /* Substitute some text if the current atom appears as a switch
5490 or suffix. */
5491 disjunct_set = true;
5492 if (ordered_set)
5493 abort ();
5495 if (atom == end_atom)
5497 if (!n_way_choice || disj_matched || *p == '|'
5498 || a_is_negated || a_is_suffix || a_is_starred)
5499 abort ();
5501 /* An empty term may appear as the last choice of an
5502 N-way choice set; it means "otherwise". */
5503 a_must_be_last = true;
5504 disj_matched = !n_way_matched;
5505 disj_starred = false;
5507 else
5509 if (a_is_suffix && a_is_starred)
5510 abort ();
5512 if (!a_is_starred)
5513 disj_starred = false;
5515 /* Don't bother testing this atom if we already have a
5516 match. */
5517 if (!disj_matched && !n_way_matched)
5519 if (a_is_suffix)
5520 a_matched = input_suffix_matches (atom, end_atom);
5521 else
5522 a_matched = switch_matches (atom, end_atom, a_is_starred);
5524 if (a_matched != a_is_negated)
5526 disj_matched = true;
5527 d_atom = atom;
5528 d_end_atom = end_atom;
5533 if (*p == ':')
5535 /* Found the body, that is, the text to substitute if the
5536 current disjunction matches. */
5537 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5538 disj_matched && !n_way_matched);
5539 if (p == 0)
5540 return 0;
5542 /* If we have an N-way choice, reset state for the next
5543 disjunction. */
5544 if (*p == ';')
5546 n_way_choice = true;
5547 n_way_matched |= disj_matched;
5548 disj_matched = false;
5549 disj_starred = true;
5550 d_atom = d_end_atom = NULL;
5554 else
5555 abort ();
5557 while (*p++ != '}');
5559 return p;
5561 #undef SKIP_WHITE
5564 /* Subroutine of handle_braces. Scan and process a brace substitution body
5565 (X in the description of %{} syntax). P points one past the colon;
5566 ATOM and END_ATOM bracket the first atom which was found to be true
5567 (present) in the current disjunction; STARRED indicates whether all
5568 the atoms in the current disjunction were starred (for syntax validation);
5569 MATCHED indicates whether the disjunction matched or not, and therefore
5570 whether or not the body is to be processed through do_spec_1 or just
5571 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5572 returns -1. */
5574 static const char *
5575 process_brace_body (const char *p, const char *atom, const char *end_atom,
5576 int starred, int matched)
5578 const char *body, *end_body;
5579 unsigned int nesting_level;
5580 bool have_subst = false;
5582 /* Locate the closing } or ;, honoring nested braces.
5583 Trim trailing whitespace. */
5584 body = p;
5585 nesting_level = 1;
5586 for (;;)
5588 if (*p == '{')
5589 nesting_level++;
5590 else if (*p == '}')
5592 if (!--nesting_level)
5593 break;
5595 else if (*p == ';' && nesting_level == 1)
5596 break;
5597 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5598 have_subst = true;
5599 else if (*p == '\0')
5600 abort ();
5601 p++;
5604 end_body = p;
5605 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5606 end_body--;
5608 if (have_subst && !starred)
5609 abort ();
5611 if (matched)
5613 /* Copy the substitution body to permanent storage and execute it.
5614 If have_subst is false, this is a simple matter of running the
5615 body through do_spec_1... */
5616 char *string = save_string (body, end_body - body);
5617 if (!have_subst)
5619 if (do_spec_1 (string, 0, NULL) < 0)
5620 return 0;
5622 else
5624 /* ... but if have_subst is true, we have to process the
5625 body once for each matching switch, with %* set to the
5626 variant part of the switch. */
5627 unsigned int hard_match_len = end_atom - atom;
5628 int i;
5630 for (i = 0; i < n_switches; i++)
5631 if (!strncmp (switches[i].part1, atom, hard_match_len)
5632 && check_live_switch (i, hard_match_len))
5634 if (do_spec_1 (string, 0,
5635 &switches[i].part1[hard_match_len]) < 0)
5636 return 0;
5637 /* Pass any arguments this switch has. */
5638 give_switch (i, 1);
5639 suffix_subst = NULL;
5644 return p;
5647 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5648 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5649 spec, or -1 if either exact match or %* is used.
5651 A -O switch is obsoleted by a later -O switch. A -f, -m, or -W switch
5652 whose value does not begin with "no-" is obsoleted by the same value
5653 with the "no-", similarly for a switch with the "no-" prefix. */
5655 static int
5656 check_live_switch (int switchnum, int prefix_length)
5658 const char *name = switches[switchnum].part1;
5659 int i;
5661 /* In the common case of {<at-most-one-letter>*}, a negating
5662 switch would always match, so ignore that case. We will just
5663 send the conflicting switches to the compiler phase. */
5664 if (prefix_length >= 0 && prefix_length <= 1)
5665 return 1;
5667 /* If we already processed this switch and determined if it was
5668 live or not, return our past determination. */
5669 if (switches[switchnum].live_cond != 0)
5670 return switches[switchnum].live_cond > 0;
5672 /* Now search for duplicate in a manner that depends on the name. */
5673 switch (*name)
5675 case 'O':
5676 for (i = switchnum + 1; i < n_switches; i++)
5677 if (switches[i].part1[0] == 'O')
5679 switches[switchnum].validated = 1;
5680 switches[switchnum].live_cond = SWITCH_FALSE;
5681 return 0;
5683 break;
5685 case 'W': case 'f': case 'm':
5686 if (! strncmp (name + 1, "no-", 3))
5688 /* We have Xno-YYY, search for XYYY. */
5689 for (i = switchnum + 1; i < n_switches; i++)
5690 if (switches[i].part1[0] == name[0]
5691 && ! strcmp (&switches[i].part1[1], &name[4]))
5693 switches[switchnum].validated = 1;
5694 switches[switchnum].live_cond = SWITCH_FALSE;
5695 return 0;
5698 else
5700 /* We have XYYY, search for Xno-YYY. */
5701 for (i = switchnum + 1; i < n_switches; i++)
5702 if (switches[i].part1[0] == name[0]
5703 && switches[i].part1[1] == 'n'
5704 && switches[i].part1[2] == 'o'
5705 && switches[i].part1[3] == '-'
5706 && !strcmp (&switches[i].part1[4], &name[1]))
5708 switches[switchnum].validated = 1;
5709 switches[switchnum].live_cond = SWITCH_FALSE;
5710 return 0;
5713 break;
5716 /* Otherwise the switch is live. */
5717 switches[switchnum].live_cond = SWITCH_LIVE;
5718 return 1;
5721 /* Pass a switch to the current accumulating command
5722 in the same form that we received it.
5723 SWITCHNUM identifies the switch; it is an index into
5724 the vector of switches gcc received, which is `switches'.
5725 This cannot fail since it never finishes a command line.
5727 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
5729 static void
5730 give_switch (int switchnum, int omit_first_word)
5732 if (switches[switchnum].live_cond == SWITCH_IGNORE)
5733 return;
5735 if (!omit_first_word)
5737 do_spec_1 ("-", 0, NULL);
5738 do_spec_1 (switches[switchnum].part1, 1, NULL);
5741 if (switches[switchnum].args != 0)
5743 const char **p;
5744 for (p = switches[switchnum].args; *p; p++)
5746 const char *arg = *p;
5748 do_spec_1 (" ", 0, NULL);
5749 if (suffix_subst)
5751 unsigned length = strlen (arg);
5752 int dot = 0;
5754 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
5755 if (arg[length] == '.')
5757 ((char *)arg)[length] = 0;
5758 dot = 1;
5759 break;
5761 do_spec_1 (arg, 1, NULL);
5762 if (dot)
5763 ((char *)arg)[length] = '.';
5764 do_spec_1 (suffix_subst, 1, NULL);
5766 else
5767 do_spec_1 (arg, 1, NULL);
5771 do_spec_1 (" ", 0, NULL);
5772 switches[switchnum].validated = 1;
5775 /* Search for a file named NAME trying various prefixes including the
5776 user's -B prefix and some standard ones.
5777 Return the absolute file name found. If nothing is found, return NAME. */
5779 static const char *
5780 find_file (const char *name)
5782 char *newname;
5784 /* Try multilib_dir if it is defined. */
5785 if (multilib_os_dir != NULL)
5787 newname = find_a_file (&startfile_prefixes, name, R_OK, 1);
5789 /* If we don't find it in the multi library dir, then fall
5790 through and look for it in the normal places. */
5791 if (newname != NULL)
5792 return newname;
5795 newname = find_a_file (&startfile_prefixes, name, R_OK, 0);
5796 return newname ? newname : name;
5799 /* Determine whether a directory exists. If LINKER, return 0 for
5800 certain fixed names not needed by the linker. If not LINKER, it is
5801 only important to return 0 if the host machine has a small ARG_MAX
5802 limit. */
5804 static int
5805 is_directory (const char *path1, const char *path2, int linker)
5807 int len1 = strlen (path1);
5808 int len2 = strlen (path2);
5809 char *path = alloca (3 + len1 + len2);
5810 char *cp;
5811 struct stat st;
5813 #ifndef SMALL_ARG_MAX
5814 if (! linker)
5815 return 1;
5816 #endif
5818 /* Construct the path from the two parts. Ensure the string ends with "/.".
5819 The resulting path will be a directory even if the given path is a
5820 symbolic link. */
5821 memcpy (path, path1, len1);
5822 memcpy (path + len1, path2, len2);
5823 cp = path + len1 + len2;
5824 if (!IS_DIR_SEPARATOR (cp[-1]))
5825 *cp++ = DIR_SEPARATOR;
5826 *cp++ = '.';
5827 *cp = '\0';
5829 /* Exclude directories that the linker is known to search. */
5830 if (linker
5831 && ((cp - path == 6
5832 && strcmp (path, concat (dir_separator_str, "lib",
5833 dir_separator_str, ".", NULL)) == 0)
5834 || (cp - path == 10
5835 && strcmp (path, concat (dir_separator_str, "usr",
5836 dir_separator_str, "lib",
5837 dir_separator_str, ".", NULL)) == 0)))
5838 return 0;
5840 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
5843 /* Set up the various global variables to indicate that we're processing
5844 the input file named FILENAME. */
5846 void
5847 set_input (const char *filename)
5849 const char *p;
5851 input_filename = filename;
5852 input_filename_length = strlen (input_filename);
5854 input_basename = input_filename;
5855 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
5856 /* Skip drive name so 'x:foo' is handled properly. */
5857 if (input_basename[1] == ':')
5858 input_basename += 2;
5859 #endif
5860 for (p = input_basename; *p; p++)
5861 if (IS_DIR_SEPARATOR (*p))
5862 input_basename = p + 1;
5864 /* Find a suffix starting with the last period,
5865 and set basename_length to exclude that suffix. */
5866 basename_length = strlen (input_basename);
5867 suffixed_basename_length = basename_length;
5868 p = input_basename + basename_length;
5869 while (p != input_basename && *p != '.')
5870 --p;
5871 if (*p == '.' && p != input_basename)
5873 basename_length = p - input_basename;
5874 input_suffix = p + 1;
5876 else
5877 input_suffix = "";
5879 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
5880 we will need to do a stat on the input_filename. The
5881 INPUT_STAT_SET signals that the stat is needed. */
5882 input_stat_set = 0;
5885 /* On fatal signals, delete all the temporary files. */
5887 static void
5888 fatal_error (int signum)
5890 signal (signum, SIG_DFL);
5891 delete_failure_queue ();
5892 delete_temp_files ();
5893 /* Get the same signal again, this time not handled,
5894 so its normal effect occurs. */
5895 kill (getpid (), signum);
5898 extern int main (int, const char *const *);
5901 main (int argc, const char *const *argv)
5903 size_t i;
5904 int value;
5905 int linker_was_run = 0;
5906 int num_linker_inputs = 0;
5907 char *explicit_link_files;
5908 char *specs_file;
5909 const char *p;
5910 struct user_specs *uptr;
5912 p = argv[0] + strlen (argv[0]);
5913 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
5914 --p;
5915 programname = p;
5917 xmalloc_set_program_name (programname);
5919 #ifdef GCC_DRIVER_HOST_INITIALIZATION
5920 /* Perform host dependent initialization when needed. */
5921 GCC_DRIVER_HOST_INITIALIZATION;
5922 #endif
5924 gcc_init_libintl ();
5926 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
5927 signal (SIGINT, fatal_error);
5928 #ifdef SIGHUP
5929 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
5930 signal (SIGHUP, fatal_error);
5931 #endif
5932 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
5933 signal (SIGTERM, fatal_error);
5934 #ifdef SIGPIPE
5935 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
5936 signal (SIGPIPE, fatal_error);
5937 #endif
5938 #ifdef SIGCHLD
5939 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
5940 receive the signal. A different setting is inheritable */
5941 signal (SIGCHLD, SIG_DFL);
5942 #endif
5944 /* Allocate the argument vector. */
5945 alloc_args ();
5947 obstack_init (&obstack);
5949 /* Build multilib_select, et. al from the separate lines that make up each
5950 multilib selection. */
5952 const char *const *q = multilib_raw;
5953 int need_space;
5955 obstack_init (&multilib_obstack);
5956 while ((p = *q++) != (char *) 0)
5957 obstack_grow (&multilib_obstack, p, strlen (p));
5959 obstack_1grow (&multilib_obstack, 0);
5960 multilib_select = obstack_finish (&multilib_obstack);
5962 q = multilib_matches_raw;
5963 while ((p = *q++) != (char *) 0)
5964 obstack_grow (&multilib_obstack, p, strlen (p));
5966 obstack_1grow (&multilib_obstack, 0);
5967 multilib_matches = obstack_finish (&multilib_obstack);
5969 q = multilib_exclusions_raw;
5970 while ((p = *q++) != (char *) 0)
5971 obstack_grow (&multilib_obstack, p, strlen (p));
5973 obstack_1grow (&multilib_obstack, 0);
5974 multilib_exclusions = obstack_finish (&multilib_obstack);
5976 need_space = FALSE;
5977 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
5979 if (need_space)
5980 obstack_1grow (&multilib_obstack, ' ');
5981 obstack_grow (&multilib_obstack,
5982 multilib_defaults_raw[i],
5983 strlen (multilib_defaults_raw[i]));
5984 need_space = TRUE;
5987 obstack_1grow (&multilib_obstack, 0);
5988 multilib_defaults = obstack_finish (&multilib_obstack);
5991 /* Set up to remember the pathname of gcc and any options
5992 needed for collect. We use argv[0] instead of programname because
5993 we need the complete pathname. */
5994 obstack_init (&collect_obstack);
5995 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
5996 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
5997 putenv (obstack_finish (&collect_obstack));
5999 #ifdef INIT_ENVIRONMENT
6000 /* Set up any other necessary machine specific environment variables. */
6001 putenv (INIT_ENVIRONMENT);
6002 #endif
6004 /* Make a table of what switches there are (switches, n_switches).
6005 Make a table of specified input files (infiles, n_infiles).
6006 Decode switches that are handled locally. */
6008 process_command (argc, argv);
6010 /* Initialize the vector of specs to just the default.
6011 This means one element containing 0s, as a terminator. */
6013 compilers = xmalloc (sizeof default_compilers);
6014 memcpy (compilers, default_compilers, sizeof default_compilers);
6015 n_compilers = n_default_compilers;
6017 /* Read specs from a file if there is one. */
6019 machine_suffix = concat (spec_machine, dir_separator_str,
6020 spec_version, dir_separator_str, NULL);
6021 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6023 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, 0);
6024 /* Read the specs file unless it is a default one. */
6025 if (specs_file != 0 && strcmp (specs_file, "specs"))
6026 read_specs (specs_file, TRUE);
6027 else
6028 init_spec ();
6030 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6031 for any override of as, ld and libraries. */
6032 specs_file = alloca (strlen (standard_exec_prefix)
6033 + strlen (just_machine_suffix) + sizeof ("specs"));
6035 strcpy (specs_file, standard_exec_prefix);
6036 strcat (specs_file, just_machine_suffix);
6037 strcat (specs_file, "specs");
6038 if (access (specs_file, R_OK) == 0)
6039 read_specs (specs_file, TRUE);
6041 /* Process any configure-time defaults specified for the command line
6042 options, via OPTION_DEFAULT_SPECS. */
6043 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6044 do_option_spec (option_default_specs[i].name,
6045 option_default_specs[i].spec);
6047 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6048 of the command line. */
6050 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6051 do_self_spec (driver_self_specs[i]);
6053 /* If not cross-compiling, look for executables in the standard
6054 places. */
6055 if (*cross_compile == '0')
6057 if (*md_exec_prefix)
6059 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6060 PREFIX_PRIORITY_LAST, 0, NULL, 0);
6064 /* Process sysroot_suffix_spec. */
6065 if (*sysroot_suffix_spec != 0
6066 && do_spec_2 (sysroot_suffix_spec) == 0)
6068 if (argbuf_index > 1)
6069 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC.");
6070 else if (argbuf_index == 1)
6071 target_sysroot_suffix = xstrdup (argbuf[argbuf_index -1]);
6074 /* Process sysroot_hdrs_suffix_spec. */
6075 if (*sysroot_hdrs_suffix_spec != 0
6076 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6078 if (argbuf_index > 1)
6079 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC.");
6080 else if (argbuf_index == 1)
6081 target_sysroot_hdrs_suffix = xstrdup (argbuf[argbuf_index -1]);
6084 /* Look for startfiles in the standard places. */
6085 if (*startfile_prefix_spec != 0
6086 && do_spec_2 (startfile_prefix_spec) == 0
6087 && do_spec_1 (" ", 0, NULL) == 0)
6089 int ndx;
6090 for (ndx = 0; ndx < argbuf_index; ndx++)
6091 add_sysrooted_prefix (&startfile_prefixes, argbuf[ndx], "BINUTILS",
6092 PREFIX_PRIORITY_LAST, 0, NULL, 1);
6094 /* We should eventually get rid of all these and stick to
6095 startfile_prefix_spec exclusively. */
6096 else if (*cross_compile == '0' || target_system_root)
6098 if (*md_exec_prefix)
6099 add_sysrooted_prefix (&startfile_prefixes, md_exec_prefix, "GCC",
6100 PREFIX_PRIORITY_LAST, 0, NULL, 1);
6102 if (*md_startfile_prefix)
6103 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6104 "GCC", PREFIX_PRIORITY_LAST, 0, NULL, 1);
6106 if (*md_startfile_prefix_1)
6107 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6108 "GCC", PREFIX_PRIORITY_LAST, 0, NULL, 1);
6110 /* If standard_startfile_prefix is relative, base it on
6111 standard_exec_prefix. This lets us move the installed tree
6112 as a unit. If GCC_EXEC_PREFIX is defined, base
6113 standard_startfile_prefix on that as well.
6115 If the prefix is relative, only search it for native compilers;
6116 otherwise we will search a directory containing host libraries. */
6117 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6118 add_sysrooted_prefix (&startfile_prefixes,
6119 standard_startfile_prefix, "BINUTILS",
6120 PREFIX_PRIORITY_LAST, 0, NULL, 1);
6121 else if (*cross_compile == '0')
6123 if (gcc_exec_prefix)
6124 add_prefix (&startfile_prefixes,
6125 concat (gcc_exec_prefix, machine_suffix,
6126 standard_startfile_prefix, NULL),
6127 NULL, PREFIX_PRIORITY_LAST, 0, NULL, 1);
6128 add_prefix (&startfile_prefixes,
6129 concat (standard_exec_prefix,
6130 machine_suffix,
6131 standard_startfile_prefix, NULL),
6132 NULL, PREFIX_PRIORITY_LAST, 0, NULL, 1);
6135 add_sysrooted_prefix (&startfile_prefixes, standard_startfile_prefix_1,
6136 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL, 1);
6137 add_sysrooted_prefix (&startfile_prefixes, standard_startfile_prefix_2,
6138 "BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL, 1);
6139 #if 0 /* Can cause surprises, and one can use -B./ instead. */
6140 add_prefix (&startfile_prefixes, "./", NULL,
6141 PREFIX_PRIORITY_LAST, 1, NULL, 0);
6142 #endif
6145 /* Process any user specified specs in the order given on the command
6146 line. */
6147 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6149 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6150 R_OK, 0);
6151 read_specs (filename ? filename : uptr->filename, FALSE);
6154 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6155 if (gcc_exec_prefix)
6156 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6157 spec_version, dir_separator_str, NULL);
6159 /* Now we have the specs.
6160 Set the `valid' bits for switches that match anything in any spec. */
6162 validate_all_switches ();
6164 /* Now that we have the switches and the specs, set
6165 the subdirectory based on the options. */
6166 set_multilib_dir ();
6168 /* Warn about any switches that no pass was interested in. */
6170 for (i = 0; (int) i < n_switches; i++)
6171 if (! switches[i].validated)
6172 error ("unrecognized option `-%s'", switches[i].part1);
6174 /* Obey some of the options. */
6176 if (print_search_dirs)
6178 printf (_("install: %s%s\n"), standard_exec_prefix, machine_suffix);
6179 printf (_("programs: %s\n"), build_search_list (&exec_prefixes, "", 0));
6180 printf (_("libraries: %s\n"), build_search_list (&startfile_prefixes, "", 0));
6181 return (0);
6184 if (print_file_name)
6186 printf ("%s\n", find_file (print_file_name));
6187 return (0);
6190 if (print_prog_name)
6192 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6193 printf ("%s\n", (newname ? newname : print_prog_name));
6194 return (0);
6197 if (print_multi_lib)
6199 print_multilib_info ();
6200 return (0);
6203 if (print_multi_directory)
6205 if (multilib_dir == NULL)
6206 printf (".\n");
6207 else
6208 printf ("%s\n", multilib_dir);
6209 return (0);
6212 if (print_multi_os_directory)
6214 if (multilib_os_dir == NULL)
6215 printf (".\n");
6216 else
6217 printf ("%s\n", multilib_os_dir);
6218 return (0);
6221 if (target_help_flag)
6223 /* Print if any target specific options. */
6225 /* We do not exit here. Instead we have created a fake input file
6226 called 'target-dummy' which needs to be compiled, and we pass this
6227 on to the various sub-processes, along with the --target-help
6228 switch. */
6231 if (print_help_list)
6233 display_help ();
6235 if (! verbose_flag)
6237 printf (_("\nFor bug reporting instructions, please see:\n"));
6238 printf ("%s.\n", bug_report_url);
6240 return (0);
6243 /* We do not exit here. Instead we have created a fake input file
6244 called 'help-dummy' which needs to be compiled, and we pass this
6245 on the various sub-processes, along with the --help switch. */
6248 if (verbose_flag)
6250 int n;
6251 const char *thrmod;
6253 notice ("Configured with: %s\n", configuration_arguments);
6255 #ifdef THREAD_MODEL_SPEC
6256 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6257 but there's no point in doing all this processing just to get
6258 thread_model back. */
6259 obstack_init (&obstack);
6260 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6261 obstack_1grow (&obstack, '\0');
6262 thrmod = obstack_finish (&obstack);
6263 #else
6264 thrmod = thread_model;
6265 #endif
6267 notice ("Thread model: %s\n", thrmod);
6269 /* compiler_version is truncated at the first space when initialized
6270 from version string, so truncate version_string at the first space
6271 before comparing. */
6272 for (n = 0; version_string[n]; n++)
6273 if (version_string[n] == ' ')
6274 break;
6276 if (! strncmp (version_string, compiler_version, n)
6277 && compiler_version[n] == 0)
6278 notice ("gcc version %s\n", version_string);
6279 else
6280 notice ("gcc driver version %s executing gcc version %s\n",
6281 version_string, compiler_version);
6283 if (n_infiles == 0)
6284 return (0);
6287 if (n_infiles == added_libraries)
6288 fatal ("no input files");
6290 /* Make a place to record the compiler output file names
6291 that correspond to the input files. */
6293 i = n_infiles;
6294 i += lang_specific_extra_outfiles;
6295 outfiles = xcalloc (i, sizeof (char *));
6297 /* Record which files were specified explicitly as link input. */
6299 explicit_link_files = xcalloc (1, n_infiles);
6301 if (combine_inputs)
6303 int lang_n_infiles = 0;
6304 for (i = 0; (int) i < n_infiles; i++)
6306 const char *name = infiles[i].name;
6307 struct compiler *compiler
6308 = lookup_compiler (name, strlen (name), infiles[i].language);
6309 if (compiler == NULL)
6310 error ("%s: linker input file unused because linking not done",
6311 name);
6312 else if (lang_n_infiles > 0 && compiler != input_file_compiler)
6313 fatal ("cannot specify -o with -c or -S and multiple languages");
6314 else
6316 lang_n_infiles++;
6317 input_file_compiler = compiler;
6322 for (i = 0; (int) i < (combine_inputs ? 1 : n_infiles); i++)
6324 int this_file_error = 0;
6326 /* Tell do_spec what to substitute for %i. */
6328 input_file_number = i;
6329 set_input (infiles[i].name);
6331 /* Use the same thing in %o, unless cp->spec says otherwise. */
6333 outfiles[i] = input_filename;
6335 /* Figure out which compiler from the file's suffix. */
6337 if (! combine_inputs)
6338 input_file_compiler
6339 = lookup_compiler (infiles[i].name, input_filename_length,
6340 infiles[i].language);
6342 if (input_file_compiler)
6344 /* Ok, we found an applicable compiler. Run its spec. */
6346 if (input_file_compiler->spec[0] == '#')
6348 error ("%s: %s compiler not installed on this system",
6349 input_filename, &input_file_compiler->spec[1]);
6350 this_file_error = 1;
6352 else
6354 value = do_spec (input_file_compiler->spec);
6355 if (value < 0)
6356 this_file_error = 1;
6360 /* If this file's name does not contain a recognized suffix,
6361 record it as explicit linker input. */
6363 else
6364 explicit_link_files[i] = 1;
6366 /* Clear the delete-on-failure queue, deleting the files in it
6367 if this compilation failed. */
6369 if (this_file_error)
6371 delete_failure_queue ();
6372 error_count++;
6374 /* If this compilation succeeded, don't delete those files later. */
6375 clear_failure_queue ();
6378 /* Reset the output file name to the first input file name, for use
6379 with %b in LINK_SPEC on a target that prefers not to emit a.out
6380 by default. */
6381 if (n_infiles > 0)
6382 set_input (infiles[0].name);
6384 if (error_count == 0)
6386 /* Make sure INPUT_FILE_NUMBER points to first available open
6387 slot. */
6388 input_file_number = n_infiles;
6389 if (lang_specific_pre_link ())
6390 error_count++;
6393 /* Determine if there are any linker input files. */
6394 num_linker_inputs = 0;
6395 for (i = 0; (int) i < n_infiles; i++)
6396 if (explicit_link_files[i] || outfiles[i] != NULL)
6397 num_linker_inputs++;
6399 /* Run ld to link all the compiler output files. */
6401 if (num_linker_inputs > 0 && error_count == 0)
6403 int tmp = execution_count;
6405 /* We'll use ld if we can't find collect2. */
6406 if (! strcmp (linker_name_spec, "collect2"))
6408 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, 0);
6409 if (s == NULL)
6410 linker_name_spec = "ld";
6412 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
6413 for collect. */
6414 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH");
6415 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV);
6417 value = do_spec (link_command_spec);
6418 if (value < 0)
6419 error_count = 1;
6420 linker_was_run = (tmp != execution_count);
6423 /* If options said don't run linker,
6424 complain about input files to be given to the linker. */
6426 if (! linker_was_run && error_count == 0)
6427 for (i = 0; (int) i < n_infiles; i++)
6428 if (explicit_link_files[i])
6429 error ("%s: linker input file unused because linking not done",
6430 outfiles[i]);
6432 /* Delete some or all of the temporary files we made. */
6434 if (error_count)
6435 delete_failure_queue ();
6436 delete_temp_files ();
6438 if (print_help_list)
6440 printf (("\nFor bug reporting instructions, please see:\n"));
6441 printf ("%s\n", bug_report_url);
6444 return (signal_count != 0 ? 2
6445 : error_count > 0 ? (pass_exit_codes ? greatest_status : 1)
6446 : 0);
6449 /* Find the proper compilation spec for the file name NAME,
6450 whose length is LENGTH. LANGUAGE is the specified language,
6451 or 0 if this file is to be passed to the linker. */
6453 static struct compiler *
6454 lookup_compiler (const char *name, size_t length, const char *language)
6456 struct compiler *cp;
6458 /* If this was specified by the user to be a linker input, indicate that. */
6459 if (language != 0 && language[0] == '*')
6460 return 0;
6462 /* Otherwise, look for the language, if one is spec'd. */
6463 if (language != 0)
6465 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6466 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
6467 return cp;
6469 error ("language %s not recognized", language);
6470 return 0;
6473 /* Look for a suffix. */
6474 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6476 if (/* The suffix `-' matches only the file name `-'. */
6477 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6478 || (strlen (cp->suffix) < length
6479 /* See if the suffix matches the end of NAME. */
6480 && !strcmp (cp->suffix,
6481 name + length - strlen (cp->suffix))
6483 break;
6486 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
6487 /* look again, but case-insensitively this time. */
6488 if (cp < compilers)
6489 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6491 if (/* The suffix `-' matches only the file name `-'. */
6492 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6493 || (strlen (cp->suffix) < length
6494 /* See if the suffix matches the end of NAME. */
6495 && ((!strcmp (cp->suffix,
6496 name + length - strlen (cp->suffix))
6497 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
6498 && !strcasecmp (cp->suffix,
6499 name + length - strlen (cp->suffix)))
6501 break;
6503 #endif
6505 if (cp >= compilers)
6507 if (cp->spec[0] != '@')
6508 /* A non-alias entry: return it. */
6509 return cp;
6511 /* An alias entry maps a suffix to a language.
6512 Search for the language; pass 0 for NAME and LENGTH
6513 to avoid infinite recursion if language not found. */
6514 return lookup_compiler (NULL, 0, cp->spec + 1);
6516 return 0;
6519 static char *
6520 save_string (const char *s, int len)
6522 char *result = xmalloc (len + 1);
6524 memcpy (result, s, len);
6525 result[len] = 0;
6526 return result;
6529 void
6530 pfatal_with_name (const char *name)
6532 perror_with_name (name);
6533 delete_temp_files ();
6534 exit (1);
6537 static void
6538 perror_with_name (const char *name)
6540 error ("%s: %s", name, xstrerror (errno));
6543 static void
6544 pfatal_pexecute (const char *errmsg_fmt, const char *errmsg_arg)
6546 if (errmsg_arg)
6548 int save_errno = errno;
6550 /* Space for trailing '\0' is in %s. */
6551 char *msg = xmalloc (strlen (errmsg_fmt) + strlen (errmsg_arg));
6552 sprintf (msg, errmsg_fmt, errmsg_arg);
6553 errmsg_fmt = msg;
6555 errno = save_errno;
6558 pfatal_with_name (errmsg_fmt);
6561 /* Output an error message and exit. */
6563 void
6564 fancy_abort (void)
6566 fatal ("internal gcc abort");
6569 /* Output an error message and exit. */
6571 void
6572 fatal (const char *msgid, ...)
6574 va_list ap;
6576 va_start (ap, msgid);
6578 fprintf (stderr, "%s: ", programname);
6579 vfprintf (stderr, _(msgid), ap);
6580 va_end (ap);
6581 fprintf (stderr, "\n");
6582 delete_temp_files ();
6583 exit (1);
6586 void
6587 error (const char *msgid, ...)
6589 va_list ap;
6591 va_start (ap, msgid);
6592 fprintf (stderr, "%s: ", programname);
6593 vfprintf (stderr, _(msgid), ap);
6594 va_end (ap);
6596 fprintf (stderr, "\n");
6599 static void
6600 notice (const char *msgid, ...)
6602 va_list ap;
6604 va_start (ap, msgid);
6605 vfprintf (stderr, _(msgid), ap);
6606 va_end (ap);
6609 static inline void
6610 validate_switches_from_spec (const char *spec)
6612 const char *p = spec;
6613 char c;
6614 while ((c = *p++))
6615 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
6616 /* We have a switch spec. */
6617 p = validate_switches (p + 1);
6620 static void
6621 validate_all_switches (void)
6623 struct compiler *comp;
6624 struct spec_list *spec;
6626 for (comp = compilers; comp->spec; comp++)
6627 validate_switches_from_spec (comp->spec);
6629 /* Look through the linked list of specs read from the specs file. */
6630 for (spec = specs; spec; spec = spec->next)
6631 validate_switches_from_spec (*spec->ptr_spec);
6633 validate_switches_from_spec (link_command_spec);
6636 /* Look at the switch-name that comes after START
6637 and mark as valid all supplied switches that match it. */
6639 static const char *
6640 validate_switches (const char *start)
6642 const char *p = start;
6643 const char *atom;
6644 size_t len;
6645 int i;
6646 bool suffix = false;
6647 bool starred = false;
6649 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
6651 next_member:
6652 SKIP_WHITE ();
6654 if (*p == '!')
6655 p++;
6657 SKIP_WHITE ();
6658 if (*p == '.')
6659 suffix = true, p++;
6661 atom = p;
6662 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
6663 || *p == ',' || *p == '.' || *p == '@')
6664 p++;
6665 len = p - atom;
6667 if (*p == '*')
6668 starred = true, p++;
6670 SKIP_WHITE ();
6672 if (!suffix)
6674 /* Mark all matching switches as valid. */
6675 for (i = 0; i < n_switches; i++)
6676 if (!strncmp (switches[i].part1, atom, len)
6677 && (starred || switches[i].part1[len] == 0))
6678 switches[i].validated = 1;
6681 if (*p) p++;
6682 if (*p && (p[-1] == '|' || p[-1] == '&'))
6683 goto next_member;
6685 if (*p && p[-1] == ':')
6687 while (*p && *p != ';' && *p != '}')
6689 if (*p == '%')
6691 p++;
6692 if (*p == '{' || *p == '<')
6693 p = validate_switches (p+1);
6694 else if (p[0] == 'W' && p[1] == '{')
6695 p = validate_switches (p+2);
6697 else
6698 p++;
6701 if (*p) p++;
6702 if (*p && p[-1] == ';')
6703 goto next_member;
6706 return p;
6707 #undef SKIP_WHITE
6710 struct mdswitchstr
6712 const char *str;
6713 int len;
6716 static struct mdswitchstr *mdswitches;
6717 static int n_mdswitches;
6719 /* Check whether a particular argument was used. The first time we
6720 canonicalize the switches to keep only the ones we care about. */
6722 static int
6723 used_arg (const char *p, int len)
6725 struct mswitchstr
6727 const char *str;
6728 const char *replace;
6729 int len;
6730 int rep_len;
6733 static struct mswitchstr *mswitches;
6734 static int n_mswitches;
6735 int i, j;
6737 if (!mswitches)
6739 struct mswitchstr *matches;
6740 const char *q;
6741 int cnt = 0;
6743 /* Break multilib_matches into the component strings of string
6744 and replacement string. */
6745 for (q = multilib_matches; *q != '\0'; q++)
6746 if (*q == ';')
6747 cnt++;
6749 matches = alloca ((sizeof (struct mswitchstr)) * cnt);
6750 i = 0;
6751 q = multilib_matches;
6752 while (*q != '\0')
6754 matches[i].str = q;
6755 while (*q != ' ')
6757 if (*q == '\0')
6758 abort ();
6759 q++;
6761 matches[i].len = q - matches[i].str;
6763 matches[i].replace = ++q;
6764 while (*q != ';' && *q != '\0')
6766 if (*q == ' ')
6767 abort ();
6768 q++;
6770 matches[i].rep_len = q - matches[i].replace;
6771 i++;
6772 if (*q == ';')
6773 q++;
6776 /* Now build a list of the replacement string for switches that we care
6777 about. Make sure we allocate at least one entry. This prevents
6778 xmalloc from calling fatal, and prevents us from re-executing this
6779 block of code. */
6780 mswitches
6781 = xmalloc (sizeof (struct mswitchstr)
6782 * (n_mdswitches + (n_switches ? n_switches : 1)));
6783 for (i = 0; i < n_switches; i++)
6785 int xlen = strlen (switches[i].part1);
6786 for (j = 0; j < cnt; j++)
6787 if (xlen == matches[j].len
6788 && ! strncmp (switches[i].part1, matches[j].str, xlen))
6790 mswitches[n_mswitches].str = matches[j].replace;
6791 mswitches[n_mswitches].len = matches[j].rep_len;
6792 mswitches[n_mswitches].replace = (char *) 0;
6793 mswitches[n_mswitches].rep_len = 0;
6794 n_mswitches++;
6795 break;
6799 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
6800 on the command line nor any options mutually incompatible with
6801 them. */
6802 for (i = 0; i < n_mdswitches; i++)
6804 const char *r;
6806 for (q = multilib_options; *q != '\0'; q++)
6808 while (*q == ' ')
6809 q++;
6811 r = q;
6812 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
6813 || strchr (" /", q[mdswitches[i].len]) == NULL)
6815 while (*q != ' ' && *q != '/' && *q != '\0')
6816 q++;
6817 if (*q != '/')
6818 break;
6819 q++;
6822 if (*q != ' ' && *q != '\0')
6824 while (*r != ' ' && *r != '\0')
6826 q = r;
6827 while (*q != ' ' && *q != '/' && *q != '\0')
6828 q++;
6830 if (used_arg (r, q - r))
6831 break;
6833 if (*q != '/')
6835 mswitches[n_mswitches].str = mdswitches[i].str;
6836 mswitches[n_mswitches].len = mdswitches[i].len;
6837 mswitches[n_mswitches].replace = (char *) 0;
6838 mswitches[n_mswitches].rep_len = 0;
6839 n_mswitches++;
6840 break;
6843 r = q + 1;
6845 break;
6851 for (i = 0; i < n_mswitches; i++)
6852 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
6853 return 1;
6855 return 0;
6858 static int
6859 default_arg (const char *p, int len)
6861 int i;
6863 for (i = 0; i < n_mdswitches; i++)
6864 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
6865 return 1;
6867 return 0;
6870 /* Work out the subdirectory to use based on the options. The format of
6871 multilib_select is a list of elements. Each element is a subdirectory
6872 name followed by a list of options followed by a semicolon. The format
6873 of multilib_exclusions is the same, but without the preceding
6874 directory. First gcc will check the exclusions, if none of the options
6875 beginning with an exclamation point are present, and all of the other
6876 options are present, then we will ignore this completely. Passing
6877 that, gcc will consider each multilib_select in turn using the same
6878 rules for matching the options. If a match is found, that subdirectory
6879 will be used. */
6881 static void
6882 set_multilib_dir (void)
6884 const char *p;
6885 unsigned int this_path_len;
6886 const char *this_path, *this_arg;
6887 const char *start, *end;
6888 int not_arg;
6889 int ok, ndfltok, first;
6891 n_mdswitches = 0;
6892 start = multilib_defaults;
6893 while (*start == ' ' || *start == '\t')
6894 start++;
6895 while (*start != '\0')
6897 n_mdswitches++;
6898 while (*start != ' ' && *start != '\t' && *start != '\0')
6899 start++;
6900 while (*start == ' ' || *start == '\t')
6901 start++;
6904 if (n_mdswitches)
6906 int i = 0;
6908 mdswitches = xmalloc (sizeof (struct mdswitchstr) * n_mdswitches);
6909 for (start = multilib_defaults; *start != '\0'; start = end + 1)
6911 while (*start == ' ' || *start == '\t')
6912 start++;
6914 if (*start == '\0')
6915 break;
6917 for (end = start + 1;
6918 *end != ' ' && *end != '\t' && *end != '\0'; end++)
6921 obstack_grow (&multilib_obstack, start, end - start);
6922 obstack_1grow (&multilib_obstack, 0);
6923 mdswitches[i].str = obstack_finish (&multilib_obstack);
6924 mdswitches[i++].len = end - start;
6926 if (*end == '\0')
6927 break;
6931 p = multilib_exclusions;
6932 while (*p != '\0')
6934 /* Ignore newlines. */
6935 if (*p == '\n')
6937 ++p;
6938 continue;
6941 /* Check the arguments. */
6942 ok = 1;
6943 while (*p != ';')
6945 if (*p == '\0')
6946 abort ();
6948 if (! ok)
6950 ++p;
6951 continue;
6954 this_arg = p;
6955 while (*p != ' ' && *p != ';')
6957 if (*p == '\0')
6958 abort ();
6959 ++p;
6962 if (*this_arg != '!')
6963 not_arg = 0;
6964 else
6966 not_arg = 1;
6967 ++this_arg;
6970 ok = used_arg (this_arg, p - this_arg);
6971 if (not_arg)
6972 ok = ! ok;
6974 if (*p == ' ')
6975 ++p;
6978 if (ok)
6979 return;
6981 ++p;
6984 first = 1;
6985 p = multilib_select;
6986 while (*p != '\0')
6988 /* Ignore newlines. */
6989 if (*p == '\n')
6991 ++p;
6992 continue;
6995 /* Get the initial path. */
6996 this_path = p;
6997 while (*p != ' ')
6999 if (*p == '\0')
7000 abort ();
7001 ++p;
7003 this_path_len = p - this_path;
7005 /* Check the arguments. */
7006 ok = 1;
7007 ndfltok = 1;
7008 ++p;
7009 while (*p != ';')
7011 if (*p == '\0')
7012 abort ();
7014 if (! ok)
7016 ++p;
7017 continue;
7020 this_arg = p;
7021 while (*p != ' ' && *p != ';')
7023 if (*p == '\0')
7024 abort ();
7025 ++p;
7028 if (*this_arg != '!')
7029 not_arg = 0;
7030 else
7032 not_arg = 1;
7033 ++this_arg;
7036 /* If this is a default argument, we can just ignore it.
7037 This is true even if this_arg begins with '!'. Beginning
7038 with '!' does not mean that this argument is necessarily
7039 inappropriate for this library: it merely means that
7040 there is a more specific library which uses this
7041 argument. If this argument is a default, we need not
7042 consider that more specific library. */
7043 ok = used_arg (this_arg, p - this_arg);
7044 if (not_arg)
7045 ok = ! ok;
7047 if (! ok)
7048 ndfltok = 0;
7050 if (default_arg (this_arg, p - this_arg))
7051 ok = 1;
7053 if (*p == ' ')
7054 ++p;
7057 if (ok && first)
7059 if (this_path_len != 1
7060 || this_path[0] != '.')
7062 char *new_multilib_dir = xmalloc (this_path_len + 1);
7063 char *q;
7065 strncpy (new_multilib_dir, this_path, this_path_len);
7066 new_multilib_dir[this_path_len] = '\0';
7067 q = strchr (new_multilib_dir, ':');
7068 if (q != NULL)
7069 *q = '\0';
7070 multilib_dir = new_multilib_dir;
7072 first = 0;
7075 if (ndfltok)
7077 const char *q = this_path, *end = this_path + this_path_len;
7079 while (q < end && *q != ':')
7080 q++;
7081 if (q < end)
7083 char *new_multilib_os_dir = xmalloc (end - q);
7084 memcpy (new_multilib_os_dir, q + 1, end - q - 1);
7085 new_multilib_os_dir[end - q - 1] = '\0';
7086 multilib_os_dir = new_multilib_os_dir;
7087 break;
7091 ++p;
7094 if (multilib_dir == NULL && multilib_os_dir != NULL
7095 && strcmp (multilib_os_dir, ".") == 0)
7097 free ((char *) multilib_os_dir);
7098 multilib_os_dir = NULL;
7100 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7101 multilib_os_dir = multilib_dir;
7104 /* Print out the multiple library subdirectory selection
7105 information. This prints out a series of lines. Each line looks
7106 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7107 required. Only the desired options are printed out, the negative
7108 matches. The options are print without a leading dash. There are
7109 no spaces to make it easy to use the information in the shell.
7110 Each subdirectory is printed only once. This assumes the ordering
7111 generated by the genmultilib script. Also, we leave out ones that match
7112 the exclusions. */
7114 static void
7115 print_multilib_info (void)
7117 const char *p = multilib_select;
7118 const char *last_path = 0, *this_path;
7119 int skip;
7120 unsigned int last_path_len = 0;
7122 while (*p != '\0')
7124 skip = 0;
7125 /* Ignore newlines. */
7126 if (*p == '\n')
7128 ++p;
7129 continue;
7132 /* Get the initial path. */
7133 this_path = p;
7134 while (*p != ' ')
7136 if (*p == '\0')
7137 abort ();
7138 ++p;
7141 /* When --disable-multilib was used but target defines
7142 MULTILIB_OSDIRNAMES, entries starting with .: are there just
7143 to find multilib_os_dir, so skip them from output. */
7144 if (this_path[0] == '.' && this_path[1] == ':')
7145 skip = 1;
7147 /* Check for matches with the multilib_exclusions. We don't bother
7148 with the '!' in either list. If any of the exclusion rules match
7149 all of its options with the select rule, we skip it. */
7151 const char *e = multilib_exclusions;
7152 const char *this_arg;
7154 while (*e != '\0')
7156 int m = 1;
7157 /* Ignore newlines. */
7158 if (*e == '\n')
7160 ++e;
7161 continue;
7164 /* Check the arguments. */
7165 while (*e != ';')
7167 const char *q;
7168 int mp = 0;
7170 if (*e == '\0')
7171 abort ();
7173 if (! m)
7175 ++e;
7176 continue;
7179 this_arg = e;
7181 while (*e != ' ' && *e != ';')
7183 if (*e == '\0')
7184 abort ();
7185 ++e;
7188 q = p + 1;
7189 while (*q != ';')
7191 const char *arg;
7192 int len = e - this_arg;
7194 if (*q == '\0')
7195 abort ();
7197 arg = q;
7199 while (*q != ' ' && *q != ';')
7201 if (*q == '\0')
7202 abort ();
7203 ++q;
7206 if (! strncmp (arg, this_arg, (len < q - arg) ? q - arg : len) ||
7207 default_arg (this_arg, e - this_arg))
7209 mp = 1;
7210 break;
7213 if (*q == ' ')
7214 ++q;
7217 if (! mp)
7218 m = 0;
7220 if (*e == ' ')
7221 ++e;
7224 if (m)
7226 skip = 1;
7227 break;
7230 if (*e != '\0')
7231 ++e;
7235 if (! skip)
7237 /* If this is a duplicate, skip it. */
7238 skip = (last_path != 0 && (unsigned int) (p - this_path) == last_path_len
7239 && ! strncmp (last_path, this_path, last_path_len));
7241 last_path = this_path;
7242 last_path_len = p - this_path;
7245 /* If this directory requires any default arguments, we can skip
7246 it. We will already have printed a directory identical to
7247 this one which does not require that default argument. */
7248 if (! skip)
7250 const char *q;
7252 q = p + 1;
7253 while (*q != ';')
7255 const char *arg;
7257 if (*q == '\0')
7258 abort ();
7260 if (*q == '!')
7261 arg = NULL;
7262 else
7263 arg = q;
7265 while (*q != ' ' && *q != ';')
7267 if (*q == '\0')
7268 abort ();
7269 ++q;
7272 if (arg != NULL
7273 && default_arg (arg, q - arg))
7275 skip = 1;
7276 break;
7279 if (*q == ' ')
7280 ++q;
7284 if (! skip)
7286 const char *p1;
7288 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
7289 putchar (*p1);
7290 putchar (';');
7293 ++p;
7294 while (*p != ';')
7296 int use_arg;
7298 if (*p == '\0')
7299 abort ();
7301 if (skip)
7303 ++p;
7304 continue;
7307 use_arg = *p != '!';
7309 if (use_arg)
7310 putchar ('@');
7312 while (*p != ' ' && *p != ';')
7314 if (*p == '\0')
7315 abort ();
7316 if (use_arg)
7317 putchar (*p);
7318 ++p;
7321 if (*p == ' ')
7322 ++p;
7325 if (! skip)
7327 /* If there are extra options, print them now. */
7328 if (multilib_extra && *multilib_extra)
7330 int print_at = TRUE;
7331 const char *q;
7333 for (q = multilib_extra; *q != '\0'; q++)
7335 if (*q == ' ')
7336 print_at = TRUE;
7337 else
7339 if (print_at)
7340 putchar ('@');
7341 putchar (*q);
7342 print_at = FALSE;
7347 putchar ('\n');
7350 ++p;
7354 /* if-exists built-in spec function.
7356 Checks to see if the file specified by the absolute pathname in
7357 ARGS exists. Returns that pathname if found.
7359 The usual use for this function is to check for a library file
7360 (whose name has been expanded with %s). */
7362 static const char *
7363 if_exists_spec_function (int argc, const char **argv)
7365 /* Must have only one argument. */
7366 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7367 return argv[0];
7369 return NULL;
7372 /* if-exists-else built-in spec function.
7374 This is like if-exists, but takes an additional argument which
7375 is returned if the first argument does not exist. */
7377 static const char *
7378 if_exists_else_spec_function (int argc, const char **argv)
7380 /* Must have exactly two arguments. */
7381 if (argc != 2)
7382 return NULL;
7384 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7385 return argv[0];
7387 return argv[1];