* gcc.dg/pr26570.c: Clean up coverage files.
[official-gcc.git] / gcc / gcc.c
bloba7bb71e87603b1e7609ecb1997bf8f6766a618cb
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
3 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006 Free Software Foundation,
4 Inc.
6 This file is part of GCC.
8 GCC is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 2, or (at your option) any later
11 version.
13 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 for more details.
18 You should have received a copy of the GNU General Public License
19 along with GCC; see the file COPYING. If not, write to the Free
20 Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA
21 02110-1301, USA.
23 This paragraph is here to try to keep Sun CC from dying.
24 The number of chars here seems crucial!!!! */
26 /* This program is the user interface to the C compiler and possibly to
27 other compilers. It is used because compilation is a complicated procedure
28 which involves running several programs and passing temporary files between
29 them, forwarding the users switches to those programs selectively,
30 and deleting the temporary files at the end.
32 CC recognizes how to compile each input file by suffixes in the file names.
33 Once it knows which kind of compilation to perform, the procedure for
34 compilation is specified by a string called a "spec". */
36 /* A Short Introduction to Adding a Command-Line Option.
38 Before adding a command-line option, consider if it is really
39 necessary. Each additional command-line option adds complexity and
40 is difficult to remove in subsequent versions.
42 In the following, consider adding the command-line argument
43 `--bar'.
45 1. Each command-line option is specified in the specs file. The
46 notation is described below in the comment entitled "The Specs
47 Language". Read it.
49 2. In this file, add an entry to "option_map" equating the long
50 `--' argument version and any shorter, single letter version. Read
51 the comments in the declaration of "struct option_map" for an
52 explanation. Do not omit the first `-'.
54 3. Look in the "specs" file to determine which program or option
55 list should be given the argument, e.g., "cc1_options". Add the
56 appropriate syntax for the shorter option version to the
57 corresponding "const char *" entry in this file. Omit the first
58 `-' from the option. For example, use `-bar', rather than `--bar'.
60 4. If the argument takes an argument, e.g., `--baz argument1',
61 modify either DEFAULT_SWITCH_TAKES_ARG or
62 DEFAULT_WORD_SWITCH_TAKES_ARG in gcc.h. Omit the first `-'
63 from `--baz'.
65 5. Document the option in this file's display_help(). If the
66 option is passed to a subprogram, modify its corresponding
67 function, e.g., cppinit.c:print_help() or toplev.c:display_help(),
68 instead.
70 6. Compile and test. Make sure that your new specs file is being
71 read. For example, use a debugger to investigate the value of
72 "specs_file" in main(). */
74 #include "config.h"
75 #include "system.h"
76 #include "coretypes.h"
77 #include "multilib.h" /* before tm.h */
78 #include "tm.h"
79 #include <signal.h>
80 #if ! defined( SIGCHLD ) && defined( SIGCLD )
81 # define SIGCHLD SIGCLD
82 #endif
83 #include "xregex.h"
84 #include "obstack.h"
85 #include "intl.h"
86 #include "prefix.h"
87 #include "gcc.h"
88 #include "flags.h"
89 #include "opts.h"
91 /* By default there is no special suffix for target executables. */
92 /* FIXME: when autoconf is fixed, remove the host check - dj */
93 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
94 #define HAVE_TARGET_EXECUTABLE_SUFFIX
95 #endif
97 /* By default there is no special suffix for host executables. */
98 #ifdef HOST_EXECUTABLE_SUFFIX
99 #define HAVE_HOST_EXECUTABLE_SUFFIX
100 #else
101 #define HOST_EXECUTABLE_SUFFIX ""
102 #endif
104 /* By default, the suffix for target object files is ".o". */
105 #ifdef TARGET_OBJECT_SUFFIX
106 #define HAVE_TARGET_OBJECT_SUFFIX
107 #else
108 #define TARGET_OBJECT_SUFFIX ".o"
109 #endif
111 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
113 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
114 #ifndef LIBRARY_PATH_ENV
115 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
116 #endif
118 #ifndef HAVE_KILL
119 #define kill(p,s) raise(s)
120 #endif
122 /* If a stage of compilation returns an exit status >= 1,
123 compilation of that file ceases. */
125 #define MIN_FATAL_STATUS 1
127 /* Flag set by cppspec.c to 1. */
128 int is_cpp_driver;
130 /* Flag saying to pass the greatest exit code returned by a sub-process
131 to the calling program. */
132 static int pass_exit_codes;
134 /* Definition of string containing the arguments given to configure. */
135 #include "configargs.h"
137 /* Flag saying to print the directories gcc will search through looking for
138 programs, libraries, etc. */
140 static int print_search_dirs;
142 /* Flag saying to print the full filename of this file
143 as found through our usual search mechanism. */
145 static const char *print_file_name = NULL;
147 /* As print_file_name, but search for executable file. */
149 static const char *print_prog_name = NULL;
151 /* Flag saying to print the relative path we'd use to
152 find libgcc.a given the current compiler flags. */
154 static int print_multi_directory;
156 /* Flag saying to print the relative path we'd use to
157 find OS libraries given the current compiler flags. */
159 static int print_multi_os_directory;
161 /* Flag saying to print the list of subdirectories and
162 compiler flags used to select them in a standard form. */
164 static int print_multi_lib;
166 /* Flag saying to print the command line options understood by gcc and its
167 sub-processes. */
169 static int print_help_list;
171 /* Flag indicating whether we should print the command and arguments */
173 static int verbose_flag;
175 /* Flag indicating whether we should ONLY print the command and
176 arguments (like verbose_flag) without executing the command.
177 Displayed arguments are quoted so that the generated command
178 line is suitable for execution. This is intended for use in
179 shell scripts to capture the driver-generated command line. */
180 static int verbose_only_flag;
182 /* Flag indicating to print target specific command line options. */
184 static int target_help_flag;
186 /* Flag indicating whether we should report subprocess execution times
187 (if this is supported by the system - see pexecute.c). */
189 static int report_times;
191 /* Nonzero means place this string before uses of /, so that include
192 and library files can be found in an alternate location. */
194 #ifdef TARGET_SYSTEM_ROOT
195 static const char *target_system_root = TARGET_SYSTEM_ROOT;
196 #else
197 static const char *target_system_root = 0;
198 #endif
200 /* Nonzero means pass the updated target_system_root to the compiler. */
202 static int target_system_root_changed;
204 /* Nonzero means append this string to target_system_root. */
206 static const char *target_sysroot_suffix = 0;
208 /* Nonzero means append this string to target_system_root for headers. */
210 static const char *target_sysroot_hdrs_suffix = 0;
212 /* Nonzero means write "temp" files in source directory
213 and use the source file's name in them, and don't delete them. */
215 static int save_temps_flag;
217 /* Nonzero means pass multiple source files to the compiler at one time. */
219 static int combine_flag = 0;
221 /* Nonzero means use pipes to communicate between subprocesses.
222 Overridden by either of the above two flags. */
224 static int use_pipes;
226 /* The compiler version. */
228 static const char *compiler_version;
230 /* The target version specified with -V */
232 static const char *const spec_version = DEFAULT_TARGET_VERSION;
234 /* The target machine specified with -b. */
236 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
238 /* Nonzero if cross-compiling.
239 When -b is used, the value comes from the `specs' file. */
241 #ifdef CROSS_DIRECTORY_STRUCTURE
242 static const char *cross_compile = "1";
243 #else
244 static const char *cross_compile = "0";
245 #endif
247 #ifdef MODIFY_TARGET_NAME
249 /* Information on how to alter the target name based on a command-line
250 switch. The only case we support now is simply appending or deleting a
251 string to or from the end of the first part of the configuration name. */
253 static const struct modify_target
255 const char *const sw;
256 const enum add_del {ADD, DELETE} add_del;
257 const char *const str;
259 modify_target[] = MODIFY_TARGET_NAME;
260 #endif
262 /* The number of errors that have occurred; the link phase will not be
263 run if this is nonzero. */
264 static int error_count = 0;
266 /* Greatest exit code of sub-processes that has been encountered up to
267 now. */
268 static int greatest_status = 1;
270 /* This is the obstack which we use to allocate many strings. */
272 static struct obstack obstack;
274 /* This is the obstack to build an environment variable to pass to
275 collect2 that describes all of the relevant switches of what to
276 pass the compiler in building the list of pointers to constructors
277 and destructors. */
279 static struct obstack collect_obstack;
281 /* Forward declaration for prototypes. */
282 struct path_prefix;
283 struct prefix_list;
285 static void init_spec (void);
286 static void store_arg (const char *, int, int);
287 static char *load_specs (const char *);
288 static void read_specs (const char *, int);
289 static void set_spec (const char *, const char *);
290 static struct compiler *lookup_compiler (const char *, size_t, const char *);
291 static char *build_search_list (const struct path_prefix *, const char *,
292 bool, bool);
293 static void putenv_from_prefixes (const struct path_prefix *, const char *,
294 bool);
295 static int access_check (const char *, int);
296 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
297 static void add_prefix (struct path_prefix *, const char *, const char *,
298 int, int, int);
299 static void add_sysrooted_prefix (struct path_prefix *, const char *,
300 const char *, int, int, int);
301 static void translate_options (int *, const char *const **);
302 static char *skip_whitespace (char *);
303 static void delete_if_ordinary (const char *);
304 static void delete_temp_files (void);
305 static void delete_failure_queue (void);
306 static void clear_failure_queue (void);
307 static int check_live_switch (int, int);
308 static const char *handle_braces (const char *);
309 static inline bool input_suffix_matches (const char *, const char *);
310 static inline bool switch_matches (const char *, const char *, int);
311 static inline void mark_matching_switches (const char *, const char *, int);
312 static inline void process_marked_switches (void);
313 static const char *process_brace_body (const char *, const char *, const char *, int, int);
314 static const struct spec_function *lookup_spec_function (const char *);
315 static const char *eval_spec_function (const char *, const char *);
316 static const char *handle_spec_function (const char *);
317 static char *save_string (const char *, int);
318 static void set_collect_gcc_options (void);
319 static int do_spec_1 (const char *, int, const char *);
320 static int do_spec_2 (const char *);
321 static void do_option_spec (const char *, const char *);
322 static void do_self_spec (const char *);
323 static const char *find_file (const char *);
324 static int is_directory (const char *, bool);
325 static const char *validate_switches (const char *);
326 static void validate_all_switches (void);
327 static inline void validate_switches_from_spec (const char *);
328 static void give_switch (int, int);
329 static int used_arg (const char *, int);
330 static int default_arg (const char *, int);
331 static void set_multilib_dir (void);
332 static void print_multilib_info (void);
333 static void perror_with_name (const char *);
334 static void fatal_ice (const char *, ...) ATTRIBUTE_PRINTF_1 ATTRIBUTE_NORETURN;
335 static void notice (const char *, ...) ATTRIBUTE_PRINTF_1;
336 static void display_help (void);
337 static void add_preprocessor_option (const char *, int);
338 static void add_assembler_option (const char *, int);
339 static void add_linker_option (const char *, int);
340 static void process_command (int, const char **);
341 static int execute (void);
342 static void alloc_args (void);
343 static void clear_args (void);
344 static void fatal_error (int);
345 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
346 static void init_gcc_specs (struct obstack *, const char *, const char *,
347 const char *);
348 #endif
349 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
350 static const char *convert_filename (const char *, int, int);
351 #endif
353 static const char *if_exists_spec_function (int, const char **);
354 static const char *if_exists_else_spec_function (int, const char **);
355 static const char *replace_outfile_spec_function (int, const char **);
356 static const char *version_compare_spec_function (int, const char **);
357 static const char *include_spec_function (int, const char **);
359 /* The Specs Language
361 Specs are strings containing lines, each of which (if not blank)
362 is made up of a program name, and arguments separated by spaces.
363 The program name must be exact and start from root, since no path
364 is searched and it is unreliable to depend on the current working directory.
365 Redirection of input or output is not supported; the subprograms must
366 accept filenames saying what files to read and write.
368 In addition, the specs can contain %-sequences to substitute variable text
369 or for conditional text. Here is a table of all defined %-sequences.
370 Note that spaces are not generated automatically around the results of
371 expanding these sequences; therefore, you can concatenate them together
372 or with constant text in a single argument.
374 %% substitute one % into the program name or argument.
375 %i substitute the name of the input file being processed.
376 %b substitute the basename of the input file being processed.
377 This is the substring up to (and not including) the last period
378 and not including the directory.
379 %B same as %b, but include the file suffix (text after the last period).
380 %gSUFFIX
381 substitute a file name that has suffix SUFFIX and is chosen
382 once per compilation, and mark the argument a la %d. To reduce
383 exposure to denial-of-service attacks, the file name is now
384 chosen in a way that is hard to predict even when previously
385 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
386 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
387 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
388 had been pre-processed. Previously, %g was simply substituted
389 with a file name chosen once per compilation, without regard
390 to any appended suffix (which was therefore treated just like
391 ordinary text), making such attacks more likely to succeed.
392 %|SUFFIX
393 like %g, but if -pipe is in effect, expands simply to "-".
394 %mSUFFIX
395 like %g, but if -pipe is in effect, expands to nothing. (We have both
396 %| and %m to accommodate differences between system assemblers; see
397 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
398 %uSUFFIX
399 like %g, but generates a new temporary file name even if %uSUFFIX
400 was already seen.
401 %USUFFIX
402 substitutes the last file name generated with %uSUFFIX, generating a
403 new one if there is no such last file name. In the absence of any
404 %uSUFFIX, this is just like %gSUFFIX, except they don't share
405 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
406 would involve the generation of two distinct file names, one
407 for each `%g.s' and another for each `%U.s'. Previously, %U was
408 simply substituted with a file name chosen for the previous %u,
409 without regard to any appended suffix.
410 %jSUFFIX
411 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
412 writable, and if save-temps is off; otherwise, substitute the name
413 of a temporary file, just like %u. This temporary file is not
414 meant for communication between processes, but rather as a junk
415 disposal mechanism.
416 %.SUFFIX
417 substitutes .SUFFIX for the suffixes of a matched switch's args when
418 it is subsequently output with %*. SUFFIX is terminated by the next
419 space or %.
420 %d marks the argument containing or following the %d as a
421 temporary file name, so that that file will be deleted if CC exits
422 successfully. Unlike %g, this contributes no text to the argument.
423 %w marks the argument containing or following the %w as the
424 "output file" of this compilation. This puts the argument
425 into the sequence of arguments that %o will substitute later.
426 %V indicates that this compilation produces no "output file".
427 %W{...}
428 like %{...} but mark last argument supplied within
429 as a file to be deleted on failure.
430 %o substitutes the names of all the output files, with spaces
431 automatically placed around them. You should write spaces
432 around the %o as well or the results are undefined.
433 %o is for use in the specs for running the linker.
434 Input files whose names have no recognized suffix are not compiled
435 at all, but they are included among the output files, so they will
436 be linked.
437 %O substitutes the suffix for object files. Note that this is
438 handled specially when it immediately follows %g, %u, or %U
439 (with or without a suffix argument) because of the need for
440 those to form complete file names. The handling is such that
441 %O is treated exactly as if it had already been substituted,
442 except that %g, %u, and %U do not currently support additional
443 SUFFIX characters following %O as they would following, for
444 example, `.o'.
445 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
446 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
447 and -B options) and -imultilib as necessary.
448 %s current argument is the name of a library or startup file of some sort.
449 Search for that file in a standard list of directories
450 and substitute the full name found.
451 %eSTR Print STR as an error message. STR is terminated by a newline.
452 Use this when inconsistent options are detected.
453 %nSTR Print STR as a notice. STR is terminated by a newline.
454 %x{OPTION} Accumulate an option for %X.
455 %X Output the accumulated linker options specified by compilations.
456 %Y Output the accumulated assembler options specified by compilations.
457 %Z Output the accumulated preprocessor options specified by compilations.
458 %a process ASM_SPEC as a spec.
459 This allows config.h to specify part of the spec for running as.
460 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
461 used here. This can be used to run a post-processor after the
462 assembler has done its job.
463 %D Dump out a -L option for each directory in startfile_prefixes.
464 If multilib_dir is set, extra entries are generated with it affixed.
465 %l process LINK_SPEC as a spec.
466 %L process LIB_SPEC as a spec.
467 %G process LIBGCC_SPEC as a spec.
468 %R Output the concatenation of target_system_root and
469 target_sysroot_suffix.
470 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
471 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
472 %C process CPP_SPEC as a spec.
473 %1 process CC1_SPEC as a spec.
474 %2 process CC1PLUS_SPEC as a spec.
475 %* substitute the variable part of a matched option. (See below.)
476 Note that each comma in the substituted string is replaced by
477 a single space.
478 %<S remove all occurrences of -S from the command line.
479 Note - this command is position dependent. % commands in the
480 spec string before this one will see -S, % commands in the
481 spec string after this one will not.
482 %<S* remove all occurrences of all switches beginning with -S from the
483 command line.
484 %:function(args)
485 Call the named function FUNCTION, passing it ARGS. ARGS is
486 first processed as a nested spec string, then split into an
487 argument vector in the usual fashion. The function returns
488 a string which is processed as if it had appeared literally
489 as part of the current spec.
490 %{S} substitutes the -S switch, if that switch was given to CC.
491 If that switch was not specified, this substitutes nothing.
492 Here S is a metasyntactic variable.
493 %{S*} substitutes all the switches specified to CC whose names start
494 with -S. This is used for -o, -I, etc; switches that take
495 arguments. CC considers `-o foo' as being one switch whose
496 name starts with `o'. %{o*} would substitute this text,
497 including the space; thus, two arguments would be generated.
498 %{S*&T*} likewise, but preserve order of S and T options (the order
499 of S and T in the spec is not significant). Can be any number
500 of ampersand-separated variables; for each the wild card is
501 optional. Useful for CPP as %{D*&U*&A*}.
503 %{S:X} substitutes X, if the -S switch was given to CC.
504 %{!S:X} substitutes X, if the -S switch was NOT given to CC.
505 %{S*:X} substitutes X if one or more switches whose names start
506 with -S was given to CC. Normally X is substituted only
507 once, no matter how many such switches appeared. However,
508 if %* appears somewhere in X, then X will be substituted
509 once for each matching switch, with the %* replaced by the
510 part of that switch that matched the '*'.
511 %{.S:X} substitutes X, if processing a file with suffix S.
512 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
514 %{S|T:X} substitutes X if either -S or -T was given to CC. This may be
515 combined with !, ., and * as above binding stronger than the OR.
516 If %* appears in X, all of the alternatives must be starred, and
517 only the first matching alternative is substituted.
518 %{S:X; if S was given to CC, substitutes X;
519 T:Y; else if T was given to CC, substitutes Y;
520 :D} else substitutes D. There can be as many clauses as you need.
521 This may be combined with ., !, |, and * as above.
523 %(Spec) processes a specification defined in a specs file as *Spec:
524 %[Spec] as above, but put __ around -D arguments
526 The conditional text X in a %{S:X} or similar construct may contain
527 other nested % constructs or spaces, or even newlines. They are
528 processed as usual, as described above. Trailing white space in X is
529 ignored. White space may also appear anywhere on the left side of the
530 colon in these constructs, except between . or * and the corresponding
531 word.
533 The -O, -f, -m, and -W switches are handled specifically in these
534 constructs. If another value of -O or the negated form of a -f, -m, or
535 -W switch is found later in the command line, the earlier switch
536 value is ignored, except with {S*} where S is just one letter; this
537 passes all matching options.
539 The character | at the beginning of the predicate text is used to indicate
540 that a command should be piped to the following command, but only if -pipe
541 is specified.
543 Note that it is built into CC which switches take arguments and which
544 do not. You might think it would be useful to generalize this to
545 allow each compiler's spec to say which switches take arguments. But
546 this cannot be done in a consistent fashion. CC cannot even decide
547 which input files have been specified without knowing which switches
548 take arguments, and it must know which input files to compile in order
549 to tell which compilers to run.
551 CC also knows implicitly that arguments starting in `-l' are to be
552 treated as compiler output files, and passed to the linker in their
553 proper position among the other output files. */
555 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
557 /* config.h can define ASM_SPEC to provide extra args to the assembler
558 or extra switch-translations. */
559 #ifndef ASM_SPEC
560 #define ASM_SPEC ""
561 #endif
563 /* config.h can define ASM_FINAL_SPEC to run a post processor after
564 the assembler has run. */
565 #ifndef ASM_FINAL_SPEC
566 #define ASM_FINAL_SPEC ""
567 #endif
569 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
570 or extra switch-translations. */
571 #ifndef CPP_SPEC
572 #define CPP_SPEC ""
573 #endif
575 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
576 or extra switch-translations. */
577 #ifndef CC1_SPEC
578 #define CC1_SPEC ""
579 #endif
581 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
582 or extra switch-translations. */
583 #ifndef CC1PLUS_SPEC
584 #define CC1PLUS_SPEC ""
585 #endif
587 /* config.h can define LINK_SPEC to provide extra args to the linker
588 or extra switch-translations. */
589 #ifndef LINK_SPEC
590 #define LINK_SPEC ""
591 #endif
593 /* config.h can define LIB_SPEC to override the default libraries. */
594 #ifndef LIB_SPEC
595 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
596 #endif
598 /* mudflap specs */
599 #ifndef MFWRAP_SPEC
600 /* XXX: valid only for GNU ld */
601 /* XXX: should exactly match hooks provided by libmudflap.a */
602 #define MFWRAP_SPEC " %{static: %{fmudflap|fmudflapth: \
603 --wrap=malloc --wrap=free --wrap=calloc --wrap=realloc\
604 --wrap=mmap --wrap=munmap --wrap=alloca\
605 } %{fmudflapth: --wrap=pthread_create\
606 }} %{fmudflap|fmudflapth: --wrap=main}"
607 #endif
608 #ifndef MFLIB_SPEC
609 #define MFLIB_SPEC "%{fmudflap|fmudflapth: -export-dynamic}"
610 #endif
612 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
613 included. */
614 #ifndef LIBGCC_SPEC
615 #if defined(REAL_LIBGCC_SPEC)
616 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
617 #elif defined(LINK_LIBGCC_SPECIAL_1)
618 /* Have gcc do the search for libgcc.a. */
619 #define LIBGCC_SPEC "libgcc.a%s"
620 #else
621 #define LIBGCC_SPEC "-lgcc"
622 #endif
623 #endif
625 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
626 #ifndef STARTFILE_SPEC
627 #define STARTFILE_SPEC \
628 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
629 #endif
631 /* config.h can define SWITCHES_NEED_SPACES to control which options
632 require spaces between the option and the argument. */
633 #ifndef SWITCHES_NEED_SPACES
634 #define SWITCHES_NEED_SPACES ""
635 #endif
637 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
638 #ifndef ENDFILE_SPEC
639 #define ENDFILE_SPEC ""
640 #endif
642 #ifndef LINKER_NAME
643 #define LINKER_NAME "collect2"
644 #endif
646 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
647 to the assembler. */
648 #ifndef ASM_DEBUG_SPEC
649 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
650 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
651 # define ASM_DEBUG_SPEC \
652 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
653 ? "%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}" \
654 : "%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}")
655 # else
656 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
657 # define ASM_DEBUG_SPEC "%{g*:--gstabs}"
658 # endif
659 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
660 # define ASM_DEBUG_SPEC "%{g*:--gdwarf2}"
661 # endif
662 # endif
663 #endif
664 #ifndef ASM_DEBUG_SPEC
665 # define ASM_DEBUG_SPEC ""
666 #endif
668 /* Here is the spec for running the linker, after compiling all files. */
670 /* This is overridable by the target in case they need to specify the
671 -lgcc and -lc order specially, yet not require them to override all
672 of LINK_COMMAND_SPEC. */
673 #ifndef LINK_GCC_C_SEQUENCE_SPEC
674 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
675 #endif
677 #ifndef LINK_SSP_SPEC
678 #ifdef TARGET_LIBC_PROVIDES_SSP
679 #define LINK_SSP_SPEC "%{fstack-protector:}"
680 #else
681 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all:-lssp_nonshared -lssp}"
682 #endif
683 #endif
685 #ifndef LINK_PIE_SPEC
686 #ifdef HAVE_LD_PIE
687 #define LINK_PIE_SPEC "%{pie:-pie} "
688 #else
689 #define LINK_PIE_SPEC "%{pie:} "
690 #endif
691 #endif
693 /* -u* was put back because both BSD and SysV seem to support it. */
694 /* %{static:} simply prevents an error message if the target machine
695 doesn't handle -static. */
696 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
697 scripts which exist in user specified directories, or in standard
698 directories. */
699 #ifndef LINK_COMMAND_SPEC
700 #define LINK_COMMAND_SPEC "\
701 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
702 %(linker) %l " LINK_PIE_SPEC "%X %{o*} %{A} %{d} %{e*} %{m} %{N} %{n} %{r}\
703 %{s} %{t} %{u*} %{x} %{z} %{Z} %{!A:%{!nostdlib:%{!nostartfiles:%S}}}\
704 %{static:} %{L*} %(mfwrap) %(link_libgcc) %o\
705 %{fopenmp:%:include(libgomp.spec)%(link_gomp)} %(mflib)\
706 %{fprofile-arcs|fprofile-generate|coverage:-lgcov}\
707 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
708 %{!A:%{!nostdlib:%{!nostartfiles:%E}}} %{T*} }}}}}}"
709 #endif
711 #ifndef LINK_LIBGCC_SPEC
712 /* Generate -L options for startfile prefix list. */
713 # define LINK_LIBGCC_SPEC "%D"
714 #endif
716 #ifndef STARTFILE_PREFIX_SPEC
717 # define STARTFILE_PREFIX_SPEC ""
718 #endif
720 #ifndef SYSROOT_SPEC
721 # define SYSROOT_SPEC "--sysroot=%R"
722 #endif
724 #ifndef SYSROOT_SUFFIX_SPEC
725 # define SYSROOT_SUFFIX_SPEC ""
726 #endif
728 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
729 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
730 #endif
732 static const char *asm_debug;
733 static const char *cpp_spec = CPP_SPEC;
734 static const char *cc1_spec = CC1_SPEC;
735 static const char *cc1plus_spec = CC1PLUS_SPEC;
736 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
737 static const char *link_ssp_spec = LINK_SSP_SPEC;
738 static const char *asm_spec = ASM_SPEC;
739 static const char *asm_final_spec = ASM_FINAL_SPEC;
740 static const char *link_spec = LINK_SPEC;
741 static const char *lib_spec = LIB_SPEC;
742 static const char *mfwrap_spec = MFWRAP_SPEC;
743 static const char *mflib_spec = MFLIB_SPEC;
744 static const char *link_gomp_spec = "";
745 static const char *libgcc_spec = LIBGCC_SPEC;
746 static const char *endfile_spec = ENDFILE_SPEC;
747 static const char *startfile_spec = STARTFILE_SPEC;
748 static const char *switches_need_spaces = SWITCHES_NEED_SPACES;
749 static const char *linker_name_spec = LINKER_NAME;
750 static const char *link_command_spec = LINK_COMMAND_SPEC;
751 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
752 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
753 static const char *sysroot_spec = SYSROOT_SPEC;
754 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
755 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
757 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
758 There should be no need to override these in target dependent files,
759 but we need to copy them to the specs file so that newer versions
760 of the GCC driver can correctly drive older tool chains with the
761 appropriate -B options. */
763 /* When cpplib handles traditional preprocessing, get rid of this, and
764 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
765 that we default the front end language better. */
766 static const char *trad_capable_cpp =
767 "cc1 -E %{traditional|ftraditional|traditional-cpp:-traditional-cpp}";
769 /* We don't wrap .d files in %W{} since a missing .d file, and
770 therefore no dependency entry, confuses make into thinking a .o
771 file that happens to exist is up-to-date. */
772 static const char *cpp_unique_options =
773 "%{C|CC:%{!E:%eGCC does not support -C or -CC without -E}}\
774 %{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
775 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
776 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
777 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
778 %{!E:%{!M:%{!MM:%{MD|MMD:%{o*:-MQ %*}}}}}\
779 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
780 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
781 %{fmudflap:-D_MUDFLAP -include mf-runtime.h}\
782 %{fmudflapth:-D_MUDFLAP -D_MUDFLAPTH -include mf-runtime.h}\
783 %{E|M|MM:%W{o*}}";
785 /* This contains cpp options which are common with cc1_options and are passed
786 only when preprocessing only to avoid duplication. We pass the cc1 spec
787 options to the preprocessor so that it the cc1 spec may manipulate
788 options used to set target flags. Those special target flags settings may
789 in turn cause preprocessor symbols to be defined specially. */
790 static const char *cpp_options =
791 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
792 %{f*} %{g*:%{!g0:%{!fno-working-directory:-fworking-directory}}} %{O*}\
793 %{undef} %{save-temps:-fpch-preprocess}";
795 /* This contains cpp options which are not passed when the preprocessor
796 output will be used by another program. */
797 static const char *cpp_debug_options = "%{d*}";
799 /* NB: This is shared amongst all front-ends. */
800 static const char *cc1_options =
801 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
802 %1 %{!Q:-quiet} -dumpbase %B %{d*} %{m*} %{a*}\
803 %{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}%{!c:%{!S:-auxbase %b}}\
804 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
805 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
806 %{Qn:-fno-ident} %{--help:--help}\
807 %{--target-help:--target-help}\
808 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
809 %{fsyntax-only:-o %j} %{-param*}\
810 %{fmudflap|fmudflapth:-fno-builtin -fno-merge-constants}\
811 %{coverage:-fprofile-arcs -ftest-coverage}";
813 static const char *asm_options =
814 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
816 static const char *invoke_as =
817 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
818 "%{!S:-o %|.s |\n as %(asm_options) %|.s %A }";
819 #else
820 "%{!S:-o %|.s |\n as %(asm_options) %m.s %A }";
821 #endif
823 /* Some compilers have limits on line lengths, and the multilib_select
824 and/or multilib_matches strings can be very long, so we build them at
825 run time. */
826 static struct obstack multilib_obstack;
827 static const char *multilib_select;
828 static const char *multilib_matches;
829 static const char *multilib_defaults;
830 static const char *multilib_exclusions;
832 /* Check whether a particular argument is a default argument. */
834 #ifndef MULTILIB_DEFAULTS
835 #define MULTILIB_DEFAULTS { "" }
836 #endif
838 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
840 #ifndef DRIVER_SELF_SPECS
841 #define DRIVER_SELF_SPECS ""
842 #endif
844 /* Adding -fopenmp should imply pthreads. This is particularly important
845 for targets that use different start files and suchlike. */
846 #ifndef GOMP_SELF_SPECS
847 #define GOMP_SELF_SPECS "%{fopenmp: -pthread}"
848 #endif
850 static const char *const driver_self_specs[] = {
851 DRIVER_SELF_SPECS, GOMP_SELF_SPECS
854 #ifndef OPTION_DEFAULT_SPECS
855 #define OPTION_DEFAULT_SPECS { "", "" }
856 #endif
858 struct default_spec
860 const char *name;
861 const char *spec;
864 static const struct default_spec
865 option_default_specs[] = { OPTION_DEFAULT_SPECS };
867 struct user_specs
869 struct user_specs *next;
870 const char *filename;
873 static struct user_specs *user_specs_head, *user_specs_tail;
875 #ifndef SWITCH_TAKES_ARG
876 #define SWITCH_TAKES_ARG(CHAR) DEFAULT_SWITCH_TAKES_ARG(CHAR)
877 #endif
879 #ifndef WORD_SWITCH_TAKES_ARG
880 #define WORD_SWITCH_TAKES_ARG(STR) DEFAULT_WORD_SWITCH_TAKES_ARG (STR)
881 #endif
883 #ifdef HAVE_TARGET_EXECUTABLE_SUFFIX
884 /* This defines which switches stop a full compilation. */
885 #define DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR) \
886 ((CHAR) == 'c' || (CHAR) == 'S')
888 #ifndef SWITCH_CURTAILS_COMPILATION
889 #define SWITCH_CURTAILS_COMPILATION(CHAR) \
890 DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR)
891 #endif
892 #endif
894 /* Record the mapping from file suffixes for compilation specs. */
896 struct compiler
898 const char *suffix; /* Use this compiler for input files
899 whose names end in this suffix. */
901 const char *spec; /* To use this compiler, run this spec. */
903 const char *cpp_spec; /* If non-NULL, substitute this spec
904 for `%C', rather than the usual
905 cpp_spec. */
906 const int combinable; /* If nonzero, compiler can deal with
907 multiple source files at once (IMA). */
908 const int needs_preprocessing; /* If nonzero, source files need to
909 be run through a preprocessor. */
912 /* Pointer to a vector of `struct compiler' that gives the spec for
913 compiling a file, based on its suffix.
914 A file that does not end in any of these suffixes will be passed
915 unchanged to the loader and nothing else will be done to it.
917 An entry containing two 0s is used to terminate the vector.
919 If multiple entries match a file, the last matching one is used. */
921 static struct compiler *compilers;
923 /* Number of entries in `compilers', not counting the null terminator. */
925 static int n_compilers;
927 /* The default list of file name suffixes and their compilation specs. */
929 static const struct compiler default_compilers[] =
931 /* Add lists of suffixes of known languages here. If those languages
932 were not present when we built the driver, we will hit these copies
933 and be given a more meaningful error than "file not used since
934 linking is not done". */
935 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
936 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
937 {".mii", "#Objective-C++", 0, 0, 0},
938 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
939 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
940 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
941 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
942 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
943 {".f", "#Fortran", 0, 0, 0}, {".for", "#Fortran", 0, 0, 0},
944 {".fpp", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
945 {".FOR", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
946 {".f90", "#Fortran", 0, 0, 0}, {".f95", "#Fortran", 0, 0, 0},
947 {".F90", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
948 {".r", "#Ratfor", 0, 0, 0},
949 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
950 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
951 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
952 /* Next come the entries for C. */
953 {".c", "@c", 0, 1, 1},
954 {"@c",
955 /* cc1 has an integrated ISO C preprocessor. We should invoke the
956 external preprocessor if -save-temps is given. */
957 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
958 %{!E:%{!M:%{!MM:\
959 %{traditional|ftraditional:\
960 %eGNU C no longer supports -traditional without -E}\
961 %{!combine:\
962 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
963 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i} \n\
964 cc1 -fpreprocessed %{save-temps:%b.i} %{!save-temps:%g.i} \
965 %(cc1_options)}\
966 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
967 cc1 %(cpp_unique_options) %(cc1_options)}}}\
968 %{!fsyntax-only:%(invoke_as)}} \
969 %{combine:\
970 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
971 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i}}\
972 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
973 cc1 %(cpp_unique_options) %(cc1_options)}}\
974 %{!fsyntax-only:%(invoke_as)}}}}}}", 0, 1, 1},
975 {"-",
976 "%{!E:%e-E or -x required when input is from standard input}\
977 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
978 {".h", "@c-header", 0, 0, 0},
979 {"@c-header",
980 /* cc1 has an integrated ISO C preprocessor. We should invoke the
981 external preprocessor if -save-temps is given. */
982 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
983 %{!E:%{!M:%{!MM:\
984 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
985 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i} \n\
986 cc1 -fpreprocessed %{save-temps:%b.i} %{!save-temps:%g.i} \
987 %(cc1_options)\
988 -o %g.s %{!o*:--output-pch=%i.gch}\
989 %W{o*:--output-pch=%*}%V}\
990 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
991 cc1 %(cpp_unique_options) %(cc1_options)\
992 -o %g.s %{!o*:--output-pch=%i.gch}\
993 %W{o*:--output-pch=%*}%V}}}}}}", 0, 0, 0},
994 {".i", "@cpp-output", 0, 1, 0},
995 {"@cpp-output",
996 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 1, 0},
997 {".s", "@assembler", 0, 1, 0},
998 {"@assembler",
999 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 1, 0},
1000 {".S", "@assembler-with-cpp", 0, 1, 0},
1001 {"@assembler-with-cpp",
1002 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1003 "%(trad_capable_cpp) -lang-asm %(cpp_options)\
1004 %{E|M|MM:%(cpp_debug_options)}\
1005 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1006 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1007 #else
1008 "%(trad_capable_cpp) -lang-asm %(cpp_options)\
1009 %{E|M|MM:%(cpp_debug_options)}\
1010 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1011 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1012 #endif
1013 , 0, 1, 0},
1015 #include "specs.h"
1016 /* Mark end of table. */
1017 {0, 0, 0, 0, 0}
1020 /* Number of elements in default_compilers, not counting the terminator. */
1022 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1024 /* A vector of options to give to the linker.
1025 These options are accumulated by %x,
1026 and substituted into the linker command with %X. */
1027 static int n_linker_options;
1028 static char **linker_options;
1030 /* A vector of options to give to the assembler.
1031 These options are accumulated by -Wa,
1032 and substituted into the assembler command with %Y. */
1033 static int n_assembler_options;
1034 static char **assembler_options;
1036 /* A vector of options to give to the preprocessor.
1037 These options are accumulated by -Wp,
1038 and substituted into the preprocessor command with %Z. */
1039 static int n_preprocessor_options;
1040 static char **preprocessor_options;
1042 /* Define how to map long options into short ones. */
1044 /* This structure describes one mapping. */
1045 struct option_map
1047 /* The long option's name. */
1048 const char *const name;
1049 /* The equivalent short option. */
1050 const char *const equivalent;
1051 /* Argument info. A string of flag chars; NULL equals no options.
1052 a => argument required.
1053 o => argument optional.
1054 j => join argument to equivalent, making one word.
1055 * => require other text after NAME as an argument. */
1056 const char *const arg_info;
1059 /* This is the table of mappings. Mappings are tried sequentially
1060 for each option encountered; the first one that matches, wins. */
1062 static const struct option_map option_map[] =
1064 {"--all-warnings", "-Wall", 0},
1065 {"--ansi", "-ansi", 0},
1066 {"--assemble", "-S", 0},
1067 {"--assert", "-A", "a"},
1068 {"--classpath", "-fclasspath=", "aj"},
1069 {"--bootclasspath", "-fbootclasspath=", "aj"},
1070 {"--CLASSPATH", "-fclasspath=", "aj"},
1071 {"--combine", "-combine", 0},
1072 {"--comments", "-C", 0},
1073 {"--comments-in-macros", "-CC", 0},
1074 {"--compile", "-c", 0},
1075 {"--debug", "-g", "oj"},
1076 {"--define-macro", "-D", "aj"},
1077 {"--dependencies", "-M", 0},
1078 {"--dump", "-d", "a"},
1079 {"--dumpbase", "-dumpbase", "a"},
1080 {"--encoding", "-fencoding=", "aj"},
1081 {"--entry", "-e", 0},
1082 {"--extra-warnings", "-W", 0},
1083 {"--extdirs", "-fextdirs=", "aj"},
1084 {"--for-assembler", "-Wa", "a"},
1085 {"--for-linker", "-Xlinker", "a"},
1086 {"--force-link", "-u", "a"},
1087 {"--coverage", "-coverage", 0},
1088 {"--imacros", "-imacros", "a"},
1089 {"--include", "-include", "a"},
1090 {"--include-barrier", "-I-", 0},
1091 {"--include-directory", "-I", "aj"},
1092 {"--include-directory-after", "-idirafter", "a"},
1093 {"--include-prefix", "-iprefix", "a"},
1094 {"--include-with-prefix", "-iwithprefix", "a"},
1095 {"--include-with-prefix-before", "-iwithprefixbefore", "a"},
1096 {"--include-with-prefix-after", "-iwithprefix", "a"},
1097 {"--language", "-x", "a"},
1098 {"--library-directory", "-L", "a"},
1099 {"--machine", "-m", "aj"},
1100 {"--machine-", "-m", "*j"},
1101 {"--no-integrated-cpp", "-no-integrated-cpp", 0},
1102 {"--no-line-commands", "-P", 0},
1103 {"--no-precompiled-includes", "-noprecomp", 0},
1104 {"--no-standard-includes", "-nostdinc", 0},
1105 {"--no-standard-libraries", "-nostdlib", 0},
1106 {"--no-warnings", "-w", 0},
1107 {"--optimize", "-O", "oj"},
1108 {"--output", "-o", "a"},
1109 {"--output-class-directory", "-foutput-class-dir=", "ja"},
1110 {"--param", "--param", "a"},
1111 {"--pass-exit-codes", "-pass-exit-codes", 0},
1112 {"--pedantic", "-pedantic", 0},
1113 {"--pedantic-errors", "-pedantic-errors", 0},
1114 {"--pie", "-pie", 0},
1115 {"--pipe", "-pipe", 0},
1116 {"--prefix", "-B", "a"},
1117 {"--preprocess", "-E", 0},
1118 {"--print-search-dirs", "-print-search-dirs", 0},
1119 {"--print-file-name", "-print-file-name=", "aj"},
1120 {"--print-libgcc-file-name", "-print-libgcc-file-name", 0},
1121 {"--print-missing-file-dependencies", "-MG", 0},
1122 {"--print-multi-lib", "-print-multi-lib", 0},
1123 {"--print-multi-directory", "-print-multi-directory", 0},
1124 {"--print-multi-os-directory", "-print-multi-os-directory", 0},
1125 {"--print-prog-name", "-print-prog-name=", "aj"},
1126 {"--profile", "-p", 0},
1127 {"--profile-blocks", "-a", 0},
1128 {"--quiet", "-q", 0},
1129 {"--resource", "-fcompile-resource=", "aj"},
1130 {"--save-temps", "-save-temps", 0},
1131 {"--shared", "-shared", 0},
1132 {"--silent", "-q", 0},
1133 {"--specs", "-specs=", "aj"},
1134 {"--static", "-static", 0},
1135 {"--std", "-std=", "aj"},
1136 {"--symbolic", "-symbolic", 0},
1137 {"--sysroot", "--sysroot=", "aj"},
1138 {"--time", "-time", 0},
1139 {"--trace-includes", "-H", 0},
1140 {"--traditional", "-traditional", 0},
1141 {"--traditional-cpp", "-traditional-cpp", 0},
1142 {"--trigraphs", "-trigraphs", 0},
1143 {"--undefine-macro", "-U", "aj"},
1144 {"--user-dependencies", "-MM", 0},
1145 {"--verbose", "-v", 0},
1146 {"--warn-", "-W", "*j"},
1147 {"--write-dependencies", "-MD", 0},
1148 {"--write-user-dependencies", "-MMD", 0},
1149 {"--", "-f", "*j"}
1153 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1154 static const struct {
1155 const char *const option_found;
1156 const char *const replacements;
1157 } target_option_translations[] =
1159 TARGET_OPTION_TRANSLATE_TABLE,
1160 { 0, 0 }
1162 #endif
1164 /* Translate the options described by *ARGCP and *ARGVP.
1165 Make a new vector and store it back in *ARGVP,
1166 and store its length in *ARGVC. */
1168 static void
1169 translate_options (int *argcp, const char *const **argvp)
1171 int i;
1172 int argc = *argcp;
1173 const char *const *argv = *argvp;
1174 int newvsize = (argc + 2) * 2 * sizeof (const char *);
1175 const char **newv = xmalloc (newvsize);
1176 int newindex = 0;
1178 i = 0;
1179 newv[newindex++] = argv[i++];
1181 while (i < argc)
1183 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1184 int tott_idx;
1186 for (tott_idx = 0;
1187 target_option_translations[tott_idx].option_found;
1188 tott_idx++)
1190 if (strcmp (target_option_translations[tott_idx].option_found,
1191 argv[i]) == 0)
1193 int spaces = 1;
1194 const char *sp;
1195 char *np;
1197 for (sp = target_option_translations[tott_idx].replacements;
1198 *sp; sp++)
1200 if (*sp == ' ')
1201 spaces ++;
1204 newvsize += spaces * sizeof (const char *);
1205 newv = xrealloc (newv, newvsize);
1207 sp = target_option_translations[tott_idx].replacements;
1208 np = xstrdup (sp);
1210 while (1)
1212 while (*np == ' ')
1213 np++;
1214 if (*np == 0)
1215 break;
1216 newv[newindex++] = np;
1217 while (*np != ' ' && *np)
1218 np++;
1219 if (*np == 0)
1220 break;
1221 *np++ = 0;
1224 i ++;
1225 break;
1228 if (target_option_translations[tott_idx].option_found)
1229 continue;
1230 #endif
1232 /* Translate -- options. */
1233 if (argv[i][0] == '-' && argv[i][1] == '-')
1235 size_t j;
1236 /* Find a mapping that applies to this option. */
1237 for (j = 0; j < ARRAY_SIZE (option_map); j++)
1239 size_t optlen = strlen (option_map[j].name);
1240 size_t arglen = strlen (argv[i]);
1241 size_t complen = arglen > optlen ? optlen : arglen;
1242 const char *arginfo = option_map[j].arg_info;
1244 if (arginfo == 0)
1245 arginfo = "";
1247 if (!strncmp (argv[i], option_map[j].name, complen))
1249 const char *arg = 0;
1251 if (arglen < optlen)
1253 size_t k;
1254 for (k = j + 1; k < ARRAY_SIZE (option_map); k++)
1255 if (strlen (option_map[k].name) >= arglen
1256 && !strncmp (argv[i], option_map[k].name, arglen))
1258 error ("ambiguous abbreviation %s", argv[i]);
1259 break;
1262 if (k != ARRAY_SIZE (option_map))
1263 break;
1266 if (arglen > optlen)
1268 /* If the option has an argument, accept that. */
1269 if (argv[i][optlen] == '=')
1270 arg = argv[i] + optlen + 1;
1272 /* If this mapping requires extra text at end of name,
1273 accept that as "argument". */
1274 else if (strchr (arginfo, '*') != 0)
1275 arg = argv[i] + optlen;
1277 /* Otherwise, extra text at end means mismatch.
1278 Try other mappings. */
1279 else
1280 continue;
1283 else if (strchr (arginfo, '*') != 0)
1285 error ("incomplete '%s' option", option_map[j].name);
1286 break;
1289 /* Handle arguments. */
1290 if (strchr (arginfo, 'a') != 0)
1292 if (arg == 0)
1294 if (i + 1 == argc)
1296 error ("missing argument to '%s' option",
1297 option_map[j].name);
1298 break;
1301 arg = argv[++i];
1304 else if (strchr (arginfo, '*') != 0)
1306 else if (strchr (arginfo, 'o') == 0)
1308 if (arg != 0)
1309 error ("extraneous argument to '%s' option",
1310 option_map[j].name);
1311 arg = 0;
1314 /* Store the translation as one argv elt or as two. */
1315 if (arg != 0 && strchr (arginfo, 'j') != 0)
1316 newv[newindex++] = concat (option_map[j].equivalent, arg,
1317 NULL);
1318 else if (arg != 0)
1320 newv[newindex++] = option_map[j].equivalent;
1321 newv[newindex++] = arg;
1323 else
1324 newv[newindex++] = option_map[j].equivalent;
1326 break;
1329 i++;
1332 /* Handle old-fashioned options--just copy them through,
1333 with their arguments. */
1334 else if (argv[i][0] == '-')
1336 const char *p = argv[i] + 1;
1337 int c = *p;
1338 int nskip = 1;
1340 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
1341 nskip += SWITCH_TAKES_ARG (c) - (p[1] != 0);
1342 else if (WORD_SWITCH_TAKES_ARG (p))
1343 nskip += WORD_SWITCH_TAKES_ARG (p);
1344 else if ((c == 'B' || c == 'b' || c == 'x')
1345 && p[1] == 0)
1346 nskip += 1;
1347 else if (! strcmp (p, "Xlinker"))
1348 nskip += 1;
1349 else if (! strcmp (p, "Xpreprocessor"))
1350 nskip += 1;
1351 else if (! strcmp (p, "Xassembler"))
1352 nskip += 1;
1354 /* Watch out for an option at the end of the command line that
1355 is missing arguments, and avoid skipping past the end of the
1356 command line. */
1357 if (nskip + i > argc)
1358 nskip = argc - i;
1360 while (nskip > 0)
1362 newv[newindex++] = argv[i++];
1363 nskip--;
1366 else
1367 /* Ordinary operands, or +e options. */
1368 newv[newindex++] = argv[i++];
1371 newv[newindex] = 0;
1373 *argvp = newv;
1374 *argcp = newindex;
1377 static char *
1378 skip_whitespace (char *p)
1380 while (1)
1382 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1383 be considered whitespace. */
1384 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1385 return p + 1;
1386 else if (*p == '\n' || *p == ' ' || *p == '\t')
1387 p++;
1388 else if (*p == '#')
1390 while (*p != '\n')
1391 p++;
1392 p++;
1394 else
1395 break;
1398 return p;
1400 /* Structures to keep track of prefixes to try when looking for files. */
1402 struct prefix_list
1404 const char *prefix; /* String to prepend to the path. */
1405 struct prefix_list *next; /* Next in linked list. */
1406 int require_machine_suffix; /* Don't use without machine_suffix. */
1407 /* 2 means try both machine_suffix and just_machine_suffix. */
1408 int priority; /* Sort key - priority within list. */
1409 int os_multilib; /* 1 if OS multilib scheme should be used,
1410 0 for GCC multilib scheme. */
1413 struct path_prefix
1415 struct prefix_list *plist; /* List of prefixes to try */
1416 int max_len; /* Max length of a prefix in PLIST */
1417 const char *name; /* Name of this list (used in config stuff) */
1420 /* List of prefixes to try when looking for executables. */
1422 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1424 /* List of prefixes to try when looking for startup (crt0) files. */
1426 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1428 /* List of prefixes to try when looking for include files. */
1430 static struct path_prefix include_prefixes = { 0, 0, "include" };
1432 /* Suffix to attach to directories searched for commands.
1433 This looks like `MACHINE/VERSION/'. */
1435 static const char *machine_suffix = 0;
1437 /* Suffix to attach to directories searched for commands.
1438 This is just `MACHINE/'. */
1440 static const char *just_machine_suffix = 0;
1442 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1444 static const char *gcc_exec_prefix;
1446 /* Adjusted value of standard_libexec_prefix. */
1448 static const char *gcc_libexec_prefix;
1450 /* Default prefixes to attach to command names. */
1452 #ifndef STANDARD_STARTFILE_PREFIX_1
1453 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1454 #endif
1455 #ifndef STANDARD_STARTFILE_PREFIX_2
1456 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1457 #endif
1459 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1460 #undef MD_EXEC_PREFIX
1461 #undef MD_STARTFILE_PREFIX
1462 #undef MD_STARTFILE_PREFIX_1
1463 #endif
1465 /* If no prefixes defined, use the null string, which will disable them. */
1466 #ifndef MD_EXEC_PREFIX
1467 #define MD_EXEC_PREFIX ""
1468 #endif
1469 #ifndef MD_STARTFILE_PREFIX
1470 #define MD_STARTFILE_PREFIX ""
1471 #endif
1472 #ifndef MD_STARTFILE_PREFIX_1
1473 #define MD_STARTFILE_PREFIX_1 ""
1474 #endif
1476 /* These directories are locations set at configure-time based on the
1477 --prefix option provided to configure. Their initializers are
1478 defined in Makefile.in. These paths are not *directly* used when
1479 gcc_exec_prefix is set because, in that case, we know where the
1480 compiler has been installed, and use paths relative to that
1481 location instead. */
1482 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1483 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1484 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1485 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1487 /* For native compilers, these are well-known paths containing
1488 components that may be provided by the system. For cross
1489 compilers, these paths are not used. */
1490 static const char *const standard_exec_prefix_1 = "/usr/libexec/gcc/";
1491 static const char *const standard_exec_prefix_2 = "/usr/lib/gcc/";
1492 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1493 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1494 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1495 static const char *const standard_startfile_prefix_1
1496 = STANDARD_STARTFILE_PREFIX_1;
1497 static const char *const standard_startfile_prefix_2
1498 = STANDARD_STARTFILE_PREFIX_2;
1500 /* A relative path to be used in finding the location of tools
1501 relative to the driver. */
1502 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1504 /* Subdirectory to use for locating libraries. Set by
1505 set_multilib_dir based on the compilation options. */
1507 static const char *multilib_dir;
1509 /* Subdirectory to use for locating libraries in OS conventions. Set by
1510 set_multilib_dir based on the compilation options. */
1512 static const char *multilib_os_dir;
1514 /* Structure to keep track of the specs that have been defined so far.
1515 These are accessed using %(specname) or %[specname] in a compiler
1516 or link spec. */
1518 struct spec_list
1520 /* The following 2 fields must be first */
1521 /* to allow EXTRA_SPECS to be initialized */
1522 const char *name; /* name of the spec. */
1523 const char *ptr; /* available ptr if no static pointer */
1525 /* The following fields are not initialized */
1526 /* by EXTRA_SPECS */
1527 const char **ptr_spec; /* pointer to the spec itself. */
1528 struct spec_list *next; /* Next spec in linked list. */
1529 int name_len; /* length of the name */
1530 int alloc_p; /* whether string was allocated */
1533 #define INIT_STATIC_SPEC(NAME,PTR) \
1534 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, 0 }
1536 /* List of statically defined specs. */
1537 static struct spec_list static_specs[] =
1539 INIT_STATIC_SPEC ("asm", &asm_spec),
1540 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1541 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1542 INIT_STATIC_SPEC ("asm_options", &asm_options),
1543 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1544 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1545 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1546 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1547 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1548 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1549 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1550 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1551 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1552 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1553 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1554 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1555 INIT_STATIC_SPEC ("link", &link_spec),
1556 INIT_STATIC_SPEC ("lib", &lib_spec),
1557 INIT_STATIC_SPEC ("mfwrap", &mfwrap_spec),
1558 INIT_STATIC_SPEC ("mflib", &mflib_spec),
1559 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1560 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1561 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1562 INIT_STATIC_SPEC ("switches_need_spaces", &switches_need_spaces),
1563 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1564 INIT_STATIC_SPEC ("version", &compiler_version),
1565 INIT_STATIC_SPEC ("multilib", &multilib_select),
1566 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1567 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1568 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1569 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1570 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1571 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1572 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1573 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1574 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1575 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1576 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1577 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1578 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1579 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1582 #ifdef EXTRA_SPECS /* additional specs needed */
1583 /* Structure to keep track of just the first two args of a spec_list.
1584 That is all that the EXTRA_SPECS macro gives us. */
1585 struct spec_list_1
1587 const char *const name;
1588 const char *const ptr;
1591 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1592 static struct spec_list *extra_specs = (struct spec_list *) 0;
1593 #endif
1595 /* List of dynamically allocates specs that have been defined so far. */
1597 static struct spec_list *specs = (struct spec_list *) 0;
1599 /* List of static spec functions. */
1601 static const struct spec_function static_spec_functions[] =
1603 { "if-exists", if_exists_spec_function },
1604 { "if-exists-else", if_exists_else_spec_function },
1605 { "replace-outfile", replace_outfile_spec_function },
1606 { "version-compare", version_compare_spec_function },
1607 { "include", include_spec_function },
1608 #ifdef EXTRA_SPEC_FUNCTIONS
1609 EXTRA_SPEC_FUNCTIONS
1610 #endif
1611 { 0, 0 }
1614 static int processing_spec_function;
1616 /* Add appropriate libgcc specs to OBSTACK, taking into account
1617 various permutations of -shared-libgcc, -shared, and such. */
1619 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1621 #ifndef USE_LD_AS_NEEDED
1622 #define USE_LD_AS_NEEDED 0
1623 #endif
1625 static void
1626 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1627 const char *static_name, const char *eh_name)
1629 char *buf;
1631 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1632 "%{!static:%{!static-libgcc:"
1633 #if USE_LD_AS_NEEDED
1634 "%{!shared-libgcc:",
1635 static_name, " --as-needed ", shared_name, " --no-as-needed"
1637 "%{shared-libgcc:",
1638 shared_name, "%{!shared: ", static_name, "}"
1640 #else
1641 "%{!shared:"
1642 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1643 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1645 #ifdef LINK_EH_SPEC
1646 "%{shared:"
1647 "%{shared-libgcc:", shared_name, "}"
1648 "%{!shared-libgcc:", static_name, "}"
1650 #else
1651 "%{shared:", shared_name, "}"
1652 #endif
1653 #endif
1654 "}}", NULL);
1656 obstack_grow (obstack, buf, strlen (buf));
1657 free (buf);
1659 #endif /* ENABLE_SHARED_LIBGCC */
1661 /* Initialize the specs lookup routines. */
1663 static void
1664 init_spec (void)
1666 struct spec_list *next = (struct spec_list *) 0;
1667 struct spec_list *sl = (struct spec_list *) 0;
1668 int i;
1670 if (specs)
1671 return; /* Already initialized. */
1673 if (verbose_flag)
1674 notice ("Using built-in specs.\n");
1676 #ifdef EXTRA_SPECS
1677 extra_specs = xcalloc (sizeof (struct spec_list),
1678 ARRAY_SIZE (extra_specs_1));
1680 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1682 sl = &extra_specs[i];
1683 sl->name = extra_specs_1[i].name;
1684 sl->ptr = extra_specs_1[i].ptr;
1685 sl->next = next;
1686 sl->name_len = strlen (sl->name);
1687 sl->ptr_spec = &sl->ptr;
1688 next = sl;
1690 #endif
1692 /* Initialize here, not in definition. The IRIX 6 O32 cc sometimes chokes
1693 on ?: in file-scope variable initializations. */
1694 asm_debug = ASM_DEBUG_SPEC;
1696 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1698 sl = &static_specs[i];
1699 sl->next = next;
1700 next = sl;
1703 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1704 /* ??? If neither -shared-libgcc nor --static-libgcc was
1705 seen, then we should be making an educated guess. Some proposed
1706 heuristics for ELF include:
1708 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1709 program will be doing dynamic loading, which will likely
1710 need the shared libgcc.
1712 (2) If "-ldl", then it's also a fair bet that we're doing
1713 dynamic loading.
1715 (3) For each ET_DYN we're linking against (either through -lfoo
1716 or /some/path/foo.so), check to see whether it or one of
1717 its dependencies depends on a shared libgcc.
1719 (4) If "-shared"
1721 If the runtime is fixed to look for program headers instead
1722 of calling __register_frame_info at all, for each object,
1723 use the shared libgcc if any EH symbol referenced.
1725 If crtstuff is fixed to not invoke __register_frame_info
1726 automatically, for each object, use the shared libgcc if
1727 any non-empty unwind section found.
1729 Doing any of this probably requires invoking an external program to
1730 do the actual object file scanning. */
1732 const char *p = libgcc_spec;
1733 int in_sep = 1;
1735 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1736 when given the proper command line arguments. */
1737 while (*p)
1739 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1741 init_gcc_specs (&obstack,
1742 "-lgcc_s"
1743 #ifdef USE_LIBUNWIND_EXCEPTIONS
1744 " -lunwind"
1745 #endif
1747 "-lgcc",
1748 "-lgcc_eh"
1749 #ifdef USE_LIBUNWIND_EXCEPTIONS
1750 # ifdef HAVE_LD_STATIC_DYNAMIC
1751 " %{!static:-Bstatic} -lunwind %{!static:-Bdynamic}"
1752 # else
1753 " -lunwind"
1754 # endif
1755 #endif
1758 p += 5;
1759 in_sep = 0;
1761 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1763 /* Ug. We don't know shared library extensions. Hope that
1764 systems that use this form don't do shared libraries. */
1765 init_gcc_specs (&obstack,
1766 "-lgcc_s",
1767 "libgcc.a%s",
1768 "libgcc_eh.a%s"
1769 #ifdef USE_LIBUNWIND_EXCEPTIONS
1770 " -lunwind"
1771 #endif
1773 p += 10;
1774 in_sep = 0;
1776 else
1778 obstack_1grow (&obstack, *p);
1779 in_sep = (*p == ' ');
1780 p += 1;
1784 obstack_1grow (&obstack, '\0');
1785 libgcc_spec = XOBFINISH (&obstack, const char *);
1787 #endif
1788 #ifdef USE_AS_TRADITIONAL_FORMAT
1789 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1791 static const char tf[] = "--traditional-format ";
1792 obstack_grow (&obstack, tf, sizeof(tf) - 1);
1793 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1794 asm_spec = XOBFINISH (&obstack, const char *);
1796 #endif
1797 #ifdef LINK_EH_SPEC
1798 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1799 obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1800 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1801 link_spec = XOBFINISH (&obstack, const char *);
1802 #endif
1804 specs = sl;
1807 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1808 removed; If the spec starts with a + then SPEC is added to the end of the
1809 current spec. */
1811 static void
1812 set_spec (const char *name, const char *spec)
1814 struct spec_list *sl;
1815 const char *old_spec;
1816 int name_len = strlen (name);
1817 int i;
1819 /* If this is the first call, initialize the statically allocated specs. */
1820 if (!specs)
1822 struct spec_list *next = (struct spec_list *) 0;
1823 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1825 sl = &static_specs[i];
1826 sl->next = next;
1827 next = sl;
1829 specs = sl;
1832 /* See if the spec already exists. */
1833 for (sl = specs; sl; sl = sl->next)
1834 if (name_len == sl->name_len && !strcmp (sl->name, name))
1835 break;
1837 if (!sl)
1839 /* Not found - make it. */
1840 sl = XNEW (struct spec_list);
1841 sl->name = xstrdup (name);
1842 sl->name_len = name_len;
1843 sl->ptr_spec = &sl->ptr;
1844 sl->alloc_p = 0;
1845 *(sl->ptr_spec) = "";
1846 sl->next = specs;
1847 specs = sl;
1850 old_spec = *(sl->ptr_spec);
1851 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1852 ? concat (old_spec, spec + 1, NULL)
1853 : xstrdup (spec));
1855 #ifdef DEBUG_SPECS
1856 if (verbose_flag)
1857 notice ("Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1858 #endif
1860 /* Free the old spec. */
1861 if (old_spec && sl->alloc_p)
1862 free ((void *) old_spec);
1864 sl->alloc_p = 1;
1867 /* Accumulate a command (program name and args), and run it. */
1869 /* Vector of pointers to arguments in the current line of specifications. */
1871 static const char **argbuf;
1873 /* Number of elements allocated in argbuf. */
1875 static int argbuf_length;
1877 /* Number of elements in argbuf currently in use (containing args). */
1879 static int argbuf_index;
1881 /* Position in the argbuf array containing the name of the output file
1882 (the value associated with the "-o" flag). */
1884 static int have_o_argbuf_index = 0;
1886 /* Were the options -c or -S passed. */
1887 static int have_c = 0;
1889 /* Was the option -o passed. */
1890 static int have_o = 0;
1892 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1893 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1894 it here. */
1896 static struct temp_name {
1897 const char *suffix; /* suffix associated with the code. */
1898 int length; /* strlen (suffix). */
1899 int unique; /* Indicates whether %g or %u/%U was used. */
1900 const char *filename; /* associated filename. */
1901 int filename_length; /* strlen (filename). */
1902 struct temp_name *next;
1903 } *temp_names;
1905 /* Number of commands executed so far. */
1907 static int execution_count;
1909 /* Number of commands that exited with a signal. */
1911 static int signal_count;
1913 /* Name with which this program was invoked. */
1915 static const char *programname;
1917 /* Allocate the argument vector. */
1919 static void
1920 alloc_args (void)
1922 argbuf_length = 10;
1923 argbuf = XNEWVEC (const char *, argbuf_length);
1926 /* Clear out the vector of arguments (after a command is executed). */
1928 static void
1929 clear_args (void)
1931 argbuf_index = 0;
1934 /* Add one argument to the vector at the end.
1935 This is done when a space is seen or at the end of the line.
1936 If DELETE_ALWAYS is nonzero, the arg is a filename
1937 and the file should be deleted eventually.
1938 If DELETE_FAILURE is nonzero, the arg is a filename
1939 and the file should be deleted if this compilation fails. */
1941 static void
1942 store_arg (const char *arg, int delete_always, int delete_failure)
1944 if (argbuf_index + 1 == argbuf_length)
1945 argbuf = xrealloc (argbuf, (argbuf_length *= 2) * sizeof (const char *));
1947 argbuf[argbuf_index++] = arg;
1948 argbuf[argbuf_index] = 0;
1950 if (strcmp (arg, "-o") == 0)
1951 have_o_argbuf_index = argbuf_index;
1952 if (delete_always || delete_failure)
1953 record_temp_file (arg, delete_always, delete_failure);
1956 /* Load specs from a file name named FILENAME, replacing occurrences of
1957 various different types of line-endings, \r\n, \n\r and just \r, with
1958 a single \n. */
1960 static char *
1961 load_specs (const char *filename)
1963 int desc;
1964 int readlen;
1965 struct stat statbuf;
1966 char *buffer;
1967 char *buffer_p;
1968 char *specs;
1969 char *specs_p;
1971 if (verbose_flag)
1972 notice ("Reading specs from %s\n", filename);
1974 /* Open and stat the file. */
1975 desc = open (filename, O_RDONLY, 0);
1976 if (desc < 0)
1977 pfatal_with_name (filename);
1978 if (stat (filename, &statbuf) < 0)
1979 pfatal_with_name (filename);
1981 /* Read contents of file into BUFFER. */
1982 buffer = XNEWVEC (char, statbuf.st_size + 1);
1983 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1984 if (readlen < 0)
1985 pfatal_with_name (filename);
1986 buffer[readlen] = 0;
1987 close (desc);
1989 specs = XNEWVEC (char, readlen + 1);
1990 specs_p = specs;
1991 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1993 int skip = 0;
1994 char c = *buffer_p;
1995 if (c == '\r')
1997 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1998 skip = 1;
1999 else if (*(buffer_p + 1) == '\n') /* \r\n */
2000 skip = 1;
2001 else /* \r */
2002 c = '\n';
2004 if (! skip)
2005 *specs_p++ = c;
2007 *specs_p = '\0';
2009 free (buffer);
2010 return (specs);
2013 /* Read compilation specs from a file named FILENAME,
2014 replacing the default ones.
2016 A suffix which starts with `*' is a definition for
2017 one of the machine-specific sub-specs. The "suffix" should be
2018 *asm, *cc1, *cpp, *link, *startfile, etc.
2019 The corresponding spec is stored in asm_spec, etc.,
2020 rather than in the `compilers' vector.
2022 Anything invalid in the file is a fatal error. */
2024 static void
2025 read_specs (const char *filename, int main_p)
2027 char *buffer;
2028 char *p;
2030 buffer = load_specs (filename);
2032 /* Scan BUFFER for specs, putting them in the vector. */
2033 p = buffer;
2034 while (1)
2036 char *suffix;
2037 char *spec;
2038 char *in, *out, *p1, *p2, *p3;
2040 /* Advance P in BUFFER to the next nonblank nocomment line. */
2041 p = skip_whitespace (p);
2042 if (*p == 0)
2043 break;
2045 /* Is this a special command that starts with '%'? */
2046 /* Don't allow this for the main specs file, since it would
2047 encourage people to overwrite it. */
2048 if (*p == '%' && !main_p)
2050 p1 = p;
2051 while (*p && *p != '\n')
2052 p++;
2054 /* Skip '\n'. */
2055 p++;
2057 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
2058 && (p1[sizeof "%include" - 1] == ' '
2059 || p1[sizeof "%include" - 1] == '\t'))
2061 char *new_filename;
2063 p1 += sizeof ("%include");
2064 while (*p1 == ' ' || *p1 == '\t')
2065 p1++;
2067 if (*p1++ != '<' || p[-2] != '>')
2068 fatal ("specs %%include syntax malformed after %ld characters",
2069 (long) (p1 - buffer + 1));
2071 p[-2] = '\0';
2072 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2073 read_specs (new_filename ? new_filename : p1, FALSE);
2074 continue;
2076 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
2077 && (p1[sizeof "%include_noerr" - 1] == ' '
2078 || p1[sizeof "%include_noerr" - 1] == '\t'))
2080 char *new_filename;
2082 p1 += sizeof "%include_noerr";
2083 while (*p1 == ' ' || *p1 == '\t')
2084 p1++;
2086 if (*p1++ != '<' || p[-2] != '>')
2087 fatal ("specs %%include syntax malformed after %ld characters",
2088 (long) (p1 - buffer + 1));
2090 p[-2] = '\0';
2091 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2092 if (new_filename)
2093 read_specs (new_filename, FALSE);
2094 else if (verbose_flag)
2095 notice ("could not find specs file %s\n", p1);
2096 continue;
2098 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
2099 && (p1[sizeof "%rename" - 1] == ' '
2100 || p1[sizeof "%rename" - 1] == '\t'))
2102 int name_len;
2103 struct spec_list *sl;
2104 struct spec_list *newsl;
2106 /* Get original name. */
2107 p1 += sizeof "%rename";
2108 while (*p1 == ' ' || *p1 == '\t')
2109 p1++;
2111 if (! ISALPHA ((unsigned char) *p1))
2112 fatal ("specs %%rename syntax malformed after %ld characters",
2113 (long) (p1 - buffer));
2115 p2 = p1;
2116 while (*p2 && !ISSPACE ((unsigned char) *p2))
2117 p2++;
2119 if (*p2 != ' ' && *p2 != '\t')
2120 fatal ("specs %%rename syntax malformed after %ld characters",
2121 (long) (p2 - buffer));
2123 name_len = p2 - p1;
2124 *p2++ = '\0';
2125 while (*p2 == ' ' || *p2 == '\t')
2126 p2++;
2128 if (! ISALPHA ((unsigned char) *p2))
2129 fatal ("specs %%rename syntax malformed after %ld characters",
2130 (long) (p2 - buffer));
2132 /* Get new spec name. */
2133 p3 = p2;
2134 while (*p3 && !ISSPACE ((unsigned char) *p3))
2135 p3++;
2137 if (p3 != p - 1)
2138 fatal ("specs %%rename syntax malformed after %ld characters",
2139 (long) (p3 - buffer));
2140 *p3 = '\0';
2142 for (sl = specs; sl; sl = sl->next)
2143 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2144 break;
2146 if (!sl)
2147 fatal ("specs %s spec was not found to be renamed", p1);
2149 if (strcmp (p1, p2) == 0)
2150 continue;
2152 for (newsl = specs; newsl; newsl = newsl->next)
2153 if (strcmp (newsl->name, p2) == 0)
2154 fatal ("%s: attempt to rename spec '%s' to already defined spec '%s'",
2155 filename, p1, p2);
2157 if (verbose_flag)
2159 notice ("rename spec %s to %s\n", p1, p2);
2160 #ifdef DEBUG_SPECS
2161 notice ("spec is '%s'\n\n", *(sl->ptr_spec));
2162 #endif
2165 set_spec (p2, *(sl->ptr_spec));
2166 if (sl->alloc_p)
2167 free ((void *) *(sl->ptr_spec));
2169 *(sl->ptr_spec) = "";
2170 sl->alloc_p = 0;
2171 continue;
2173 else
2174 fatal ("specs unknown %% command after %ld characters",
2175 (long) (p1 - buffer));
2178 /* Find the colon that should end the suffix. */
2179 p1 = p;
2180 while (*p1 && *p1 != ':' && *p1 != '\n')
2181 p1++;
2183 /* The colon shouldn't be missing. */
2184 if (*p1 != ':')
2185 fatal ("specs file malformed after %ld characters",
2186 (long) (p1 - buffer));
2188 /* Skip back over trailing whitespace. */
2189 p2 = p1;
2190 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2191 p2--;
2193 /* Copy the suffix to a string. */
2194 suffix = save_string (p, p2 - p);
2195 /* Find the next line. */
2196 p = skip_whitespace (p1 + 1);
2197 if (p[1] == 0)
2198 fatal ("specs file malformed after %ld characters",
2199 (long) (p - buffer));
2201 p1 = p;
2202 /* Find next blank line or end of string. */
2203 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2204 p1++;
2206 /* Specs end at the blank line and do not include the newline. */
2207 spec = save_string (p, p1 - p);
2208 p = p1;
2210 /* Delete backslash-newline sequences from the spec. */
2211 in = spec;
2212 out = spec;
2213 while (*in != 0)
2215 if (in[0] == '\\' && in[1] == '\n')
2216 in += 2;
2217 else if (in[0] == '#')
2218 while (*in && *in != '\n')
2219 in++;
2221 else
2222 *out++ = *in++;
2224 *out = 0;
2226 if (suffix[0] == '*')
2228 if (! strcmp (suffix, "*link_command"))
2229 link_command_spec = spec;
2230 else
2231 set_spec (suffix + 1, spec);
2233 else
2235 /* Add this pair to the vector. */
2236 compilers
2237 = xrealloc (compilers,
2238 (n_compilers + 2) * sizeof (struct compiler));
2240 compilers[n_compilers].suffix = suffix;
2241 compilers[n_compilers].spec = spec;
2242 n_compilers++;
2243 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2246 if (*suffix == 0)
2247 link_command_spec = spec;
2250 if (link_command_spec == 0)
2251 fatal ("spec file has no spec for linking");
2254 /* Record the names of temporary files we tell compilers to write,
2255 and delete them at the end of the run. */
2257 /* This is the common prefix we use to make temp file names.
2258 It is chosen once for each run of this program.
2259 It is substituted into a spec by %g or %j.
2260 Thus, all temp file names contain this prefix.
2261 In practice, all temp file names start with this prefix.
2263 This prefix comes from the envvar TMPDIR if it is defined;
2264 otherwise, from the P_tmpdir macro if that is defined;
2265 otherwise, in /usr/tmp or /tmp;
2266 or finally the current directory if all else fails. */
2268 static const char *temp_filename;
2270 /* Length of the prefix. */
2272 static int temp_filename_length;
2274 /* Define the list of temporary files to delete. */
2276 struct temp_file
2278 const char *name;
2279 struct temp_file *next;
2282 /* Queue of files to delete on success or failure of compilation. */
2283 static struct temp_file *always_delete_queue;
2284 /* Queue of files to delete on failure of compilation. */
2285 static struct temp_file *failure_delete_queue;
2287 /* Record FILENAME as a file to be deleted automatically.
2288 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2289 otherwise delete it in any case.
2290 FAIL_DELETE nonzero means delete it if a compilation step fails;
2291 otherwise delete it in any case. */
2293 void
2294 record_temp_file (const char *filename, int always_delete, int fail_delete)
2296 char *const name = xstrdup (filename);
2298 if (always_delete)
2300 struct temp_file *temp;
2301 for (temp = always_delete_queue; temp; temp = temp->next)
2302 if (! strcmp (name, temp->name))
2303 goto already1;
2305 temp = XNEW (struct temp_file);
2306 temp->next = always_delete_queue;
2307 temp->name = name;
2308 always_delete_queue = temp;
2310 already1:;
2313 if (fail_delete)
2315 struct temp_file *temp;
2316 for (temp = failure_delete_queue; temp; temp = temp->next)
2317 if (! strcmp (name, temp->name))
2318 goto already2;
2320 temp = XNEW (struct temp_file);
2321 temp->next = failure_delete_queue;
2322 temp->name = name;
2323 failure_delete_queue = temp;
2325 already2:;
2329 /* Delete all the temporary files whose names we previously recorded. */
2331 #ifndef DELETE_IF_ORDINARY
2332 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2333 do \
2335 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2336 if (unlink (NAME) < 0) \
2337 if (VERBOSE_FLAG) \
2338 perror_with_name (NAME); \
2339 } while (0)
2340 #endif
2342 static void
2343 delete_if_ordinary (const char *name)
2345 struct stat st;
2346 #ifdef DEBUG
2347 int i, c;
2349 printf ("Delete %s? (y or n) ", name);
2350 fflush (stdout);
2351 i = getchar ();
2352 if (i != '\n')
2353 while ((c = getchar ()) != '\n' && c != EOF)
2356 if (i == 'y' || i == 'Y')
2357 #endif /* DEBUG */
2358 DELETE_IF_ORDINARY (name, st, verbose_flag);
2361 static void
2362 delete_temp_files (void)
2364 struct temp_file *temp;
2366 for (temp = always_delete_queue; temp; temp = temp->next)
2367 delete_if_ordinary (temp->name);
2368 always_delete_queue = 0;
2371 /* Delete all the files to be deleted on error. */
2373 static void
2374 delete_failure_queue (void)
2376 struct temp_file *temp;
2378 for (temp = failure_delete_queue; temp; temp = temp->next)
2379 delete_if_ordinary (temp->name);
2382 static void
2383 clear_failure_queue (void)
2385 failure_delete_queue = 0;
2388 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2389 returns non-NULL.
2390 If DO_MULTI is true iterate over the paths twice, first with multilib
2391 suffix then without, otherwise iterate over the paths once without
2392 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2393 to avoid visiting the same path twice, but we could do better. For
2394 instance, /usr/lib/../lib is considered different from /usr/lib.
2395 At least EXTRA_SPACE chars past the end of the path passed to
2396 CALLBACK are available for use by the callback.
2397 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2399 Returns the value returned by CALLBACK. */
2401 static void *
2402 for_each_path (const struct path_prefix *paths,
2403 bool do_multi,
2404 size_t extra_space,
2405 void *(*callback) (char *, void *),
2406 void *callback_info)
2408 struct prefix_list *pl;
2409 const char *multi_dir = NULL;
2410 const char *multi_os_dir = NULL;
2411 const char *multi_suffix;
2412 const char *just_multi_suffix;
2413 char *path = NULL;
2414 void *ret = NULL;
2415 bool skip_multi_dir = false;
2416 bool skip_multi_os_dir = false;
2418 multi_suffix = machine_suffix;
2419 just_multi_suffix = just_machine_suffix;
2420 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2422 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2423 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2424 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2426 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2427 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2429 while (1)
2431 size_t multi_dir_len = 0;
2432 size_t multi_os_dir_len = 0;
2433 size_t suffix_len;
2434 size_t just_suffix_len;
2435 size_t len;
2437 if (multi_dir)
2438 multi_dir_len = strlen (multi_dir);
2439 if (multi_os_dir)
2440 multi_os_dir_len = strlen (multi_os_dir);
2441 suffix_len = strlen (multi_suffix);
2442 just_suffix_len = strlen (just_multi_suffix);
2444 if (path == NULL)
2446 len = paths->max_len + extra_space + 1;
2447 if (suffix_len > multi_os_dir_len)
2448 len += suffix_len;
2449 else
2450 len += multi_os_dir_len;
2451 path = XNEWVEC (char, len);
2454 for (pl = paths->plist; pl != 0; pl = pl->next)
2456 len = strlen (pl->prefix);
2457 memcpy (path, pl->prefix, len);
2459 /* Look first in MACHINE/VERSION subdirectory. */
2460 if (!skip_multi_dir)
2462 memcpy (path + len, multi_suffix, suffix_len + 1);
2463 ret = callback (path, callback_info);
2464 if (ret)
2465 break;
2468 /* Some paths are tried with just the machine (ie. target)
2469 subdir. This is used for finding as, ld, etc. */
2470 if (!skip_multi_dir
2471 && pl->require_machine_suffix == 2)
2473 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2474 ret = callback (path, callback_info);
2475 if (ret)
2476 break;
2479 /* Now try the base path. */
2480 if (!pl->require_machine_suffix
2481 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2483 const char *this_multi;
2484 size_t this_multi_len;
2486 if (pl->os_multilib)
2488 this_multi = multi_os_dir;
2489 this_multi_len = multi_os_dir_len;
2491 else
2493 this_multi = multi_dir;
2494 this_multi_len = multi_dir_len;
2497 if (this_multi_len)
2498 memcpy (path + len, this_multi, this_multi_len + 1);
2499 else
2500 path[len] = '\0';
2502 ret = callback (path, callback_info);
2503 if (ret)
2504 break;
2507 if (pl)
2508 break;
2510 if (multi_dir == NULL && multi_os_dir == NULL)
2511 break;
2513 /* Run through the paths again, this time without multilibs.
2514 Don't repeat any we have already seen. */
2515 if (multi_dir)
2517 free ((char *) multi_dir);
2518 multi_dir = NULL;
2519 free ((char *) multi_suffix);
2520 multi_suffix = machine_suffix;
2521 free ((char *) just_multi_suffix);
2522 just_multi_suffix = just_machine_suffix;
2524 else
2525 skip_multi_dir = true;
2526 if (multi_os_dir)
2528 free ((char *) multi_os_dir);
2529 multi_os_dir = NULL;
2531 else
2532 skip_multi_os_dir = true;
2535 if (multi_dir)
2537 free ((char *) multi_dir);
2538 free ((char *) multi_suffix);
2539 free ((char *) just_multi_suffix);
2541 if (multi_os_dir)
2542 free ((char *) multi_os_dir);
2543 if (ret != path)
2544 free (path);
2545 return ret;
2548 /* Callback for build_search_list. Adds path to obstack being built. */
2550 struct add_to_obstack_info {
2551 struct obstack *ob;
2552 bool check_dir;
2553 bool first_time;
2556 static void *
2557 add_to_obstack (char *path, void *data)
2559 struct add_to_obstack_info *info = data;
2561 if (info->check_dir && !is_directory (path, false))
2562 return NULL;
2564 if (!info->first_time)
2565 obstack_1grow (info->ob, PATH_SEPARATOR);
2567 obstack_grow (info->ob, path, strlen (path));
2569 info->first_time = false;
2570 return NULL;
2573 /* Build a list of search directories from PATHS.
2574 PREFIX is a string to prepend to the list.
2575 If CHECK_DIR_P is true we ensure the directory exists.
2576 If DO_MULTI is true, multilib paths are output first, then
2577 non-multilib paths.
2578 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2579 It is also used by the --print-search-dirs flag. */
2581 static char *
2582 build_search_list (const struct path_prefix *paths, const char *prefix,
2583 bool check_dir, bool do_multi)
2585 struct add_to_obstack_info info;
2587 info.ob = &collect_obstack;
2588 info.check_dir = check_dir;
2589 info.first_time = true;
2591 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2592 obstack_1grow (&collect_obstack, '=');
2594 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2596 obstack_1grow (&collect_obstack, '\0');
2597 return XOBFINISH (&collect_obstack, char *);
2600 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2601 for collect. */
2603 static void
2604 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2605 bool do_multi)
2607 putenv (build_search_list (paths, env_var, true, do_multi));
2610 /* Check whether NAME can be accessed in MODE. This is like access,
2611 except that it never considers directories to be executable. */
2613 static int
2614 access_check (const char *name, int mode)
2616 if (mode == X_OK)
2618 struct stat st;
2620 if (stat (name, &st) < 0
2621 || S_ISDIR (st.st_mode))
2622 return -1;
2625 return access (name, mode);
2628 /* Callback for find_a_file. Appends the file name to the directory
2629 path. If the resulting file exists in the right mode, return the
2630 full pathname to the file. */
2632 struct file_at_path_info {
2633 const char *name;
2634 const char *suffix;
2635 int name_len;
2636 int suffix_len;
2637 int mode;
2640 static void *
2641 file_at_path (char *path, void *data)
2643 struct file_at_path_info *info = data;
2644 size_t len = strlen (path);
2646 memcpy (path + len, info->name, info->name_len);
2647 len += info->name_len;
2649 /* Some systems have a suffix for executable files.
2650 So try appending that first. */
2651 if (info->suffix_len)
2653 memcpy (path + len, info->suffix, info->suffix_len + 1);
2654 if (access_check (path, info->mode) == 0)
2655 return path;
2658 path[len] = '\0';
2659 if (access_check (path, info->mode) == 0)
2660 return path;
2662 return NULL;
2665 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2666 access to check permissions. If DO_MULTI is true, search multilib
2667 paths then non-multilib paths, otherwise do not search multilib paths.
2668 Return 0 if not found, otherwise return its name, allocated with malloc. */
2670 static char *
2671 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2672 bool do_multi)
2674 struct file_at_path_info info;
2676 #ifdef DEFAULT_ASSEMBLER
2677 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2678 return xstrdup (DEFAULT_ASSEMBLER);
2679 #endif
2681 #ifdef DEFAULT_LINKER
2682 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2683 return xstrdup (DEFAULT_LINKER);
2684 #endif
2686 /* Determine the filename to execute (special case for absolute paths). */
2688 if (IS_ABSOLUTE_PATH (name))
2690 if (access (name, mode) == 0)
2691 return xstrdup (name);
2693 return NULL;
2696 info.name = name;
2697 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2698 info.name_len = strlen (info.name);
2699 info.suffix_len = strlen (info.suffix);
2700 info.mode = mode;
2702 return for_each_path (pprefix, do_multi, info.name_len + info.suffix_len,
2703 file_at_path, &info);
2706 /* Ranking of prefixes in the sort list. -B prefixes are put before
2707 all others. */
2709 enum path_prefix_priority
2711 PREFIX_PRIORITY_B_OPT,
2712 PREFIX_PRIORITY_LAST
2715 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2716 order according to PRIORITY. Within each PRIORITY, new entries are
2717 appended.
2719 If WARN is nonzero, we will warn if no file is found
2720 through this prefix. WARN should point to an int
2721 which will be set to 1 if this entry is used.
2723 COMPONENT is the value to be passed to update_path.
2725 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2726 the complete value of machine_suffix.
2727 2 means try both machine_suffix and just_machine_suffix. */
2729 static void
2730 add_prefix (struct path_prefix *pprefix, const char *prefix,
2731 const char *component, /* enum prefix_priority */ int priority,
2732 int require_machine_suffix, int os_multilib)
2734 struct prefix_list *pl, **prev;
2735 int len;
2737 for (prev = &pprefix->plist;
2738 (*prev) != NULL && (*prev)->priority <= priority;
2739 prev = &(*prev)->next)
2742 /* Keep track of the longest prefix. */
2744 prefix = update_path (prefix, component);
2745 len = strlen (prefix);
2746 if (len > pprefix->max_len)
2747 pprefix->max_len = len;
2749 pl = XNEW (struct prefix_list);
2750 pl->prefix = prefix;
2751 pl->require_machine_suffix = require_machine_suffix;
2752 pl->priority = priority;
2753 pl->os_multilib = os_multilib;
2755 /* Insert after PREV. */
2756 pl->next = (*prev);
2757 (*prev) = pl;
2760 /* Same as add_prefix, but prepending target_system_root to prefix. */
2761 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2762 static void
2763 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2764 const char *component,
2765 /* enum prefix_priority */ int priority,
2766 int require_machine_suffix, int os_multilib)
2768 if (!IS_ABSOLUTE_PATH (prefix))
2769 fatal ("system path '%s' is not absolute", prefix);
2771 if (target_system_root)
2773 if (target_sysroot_suffix)
2774 prefix = concat (target_sysroot_suffix, prefix, NULL);
2775 prefix = concat (target_system_root, prefix, NULL);
2777 /* We have to override this because GCC's notion of sysroot
2778 moves along with GCC. */
2779 component = "GCC";
2782 add_prefix (pprefix, prefix, component, priority,
2783 require_machine_suffix, os_multilib);
2786 /* Execute the command specified by the arguments on the current line of spec.
2787 When using pipes, this includes several piped-together commands
2788 with `|' between them.
2790 Return 0 if successful, -1 if failed. */
2792 static int
2793 execute (void)
2795 int i;
2796 int n_commands; /* # of command. */
2797 char *string;
2798 struct pex_obj *pex;
2799 struct command
2801 const char *prog; /* program name. */
2802 const char **argv; /* vector of args. */
2805 struct command *commands; /* each command buffer with above info. */
2807 gcc_assert (!processing_spec_function);
2809 /* Count # of piped commands. */
2810 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2811 if (strcmp (argbuf[i], "|") == 0)
2812 n_commands++;
2814 /* Get storage for each command. */
2815 commands = alloca (n_commands * sizeof (struct command));
2817 /* Split argbuf into its separate piped processes,
2818 and record info about each one.
2819 Also search for the programs that are to be run. */
2821 commands[0].prog = argbuf[0]; /* first command. */
2822 commands[0].argv = &argbuf[0];
2823 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2825 if (string)
2826 commands[0].argv[0] = string;
2828 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2829 if (strcmp (argbuf[i], "|") == 0)
2830 { /* each command. */
2831 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2832 fatal ("-pipe not supported");
2833 #endif
2834 argbuf[i] = 0; /* termination of command args. */
2835 commands[n_commands].prog = argbuf[i + 1];
2836 commands[n_commands].argv = &argbuf[i + 1];
2837 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2838 X_OK, false);
2839 if (string)
2840 commands[n_commands].argv[0] = string;
2841 n_commands++;
2844 argbuf[argbuf_index] = 0;
2846 /* If -v, print what we are about to do, and maybe query. */
2848 if (verbose_flag)
2850 /* For help listings, put a blank line between sub-processes. */
2851 if (print_help_list)
2852 fputc ('\n', stderr);
2854 /* Print each piped command as a separate line. */
2855 for (i = 0; i < n_commands; i++)
2857 const char *const *j;
2859 if (verbose_only_flag)
2861 for (j = commands[i].argv; *j; j++)
2863 const char *p;
2864 fprintf (stderr, " \"");
2865 for (p = *j; *p; ++p)
2867 if (*p == '"' || *p == '\\' || *p == '$')
2868 fputc ('\\', stderr);
2869 fputc (*p, stderr);
2871 fputc ('"', stderr);
2874 else
2875 for (j = commands[i].argv; *j; j++)
2876 fprintf (stderr, " %s", *j);
2878 /* Print a pipe symbol after all but the last command. */
2879 if (i + 1 != n_commands)
2880 fprintf (stderr, " |");
2881 fprintf (stderr, "\n");
2883 fflush (stderr);
2884 if (verbose_only_flag != 0)
2886 /* verbose_only_flag should act as if the spec was
2887 executed, so increment execution_count before
2888 returning. This prevents spurious warnings about
2889 unused linker input files, etc. */
2890 execution_count++;
2891 return 0;
2893 #ifdef DEBUG
2894 notice ("\nGo ahead? (y or n) ");
2895 fflush (stderr);
2896 i = getchar ();
2897 if (i != '\n')
2898 while (getchar () != '\n')
2901 if (i != 'y' && i != 'Y')
2902 return 0;
2903 #endif /* DEBUG */
2906 #ifdef ENABLE_VALGRIND_CHECKING
2907 /* Run the each command through valgrind. To simplify prepending the
2908 path to valgrind and the option "-q" (for quiet operation unless
2909 something triggers), we allocate a separate argv array. */
2911 for (i = 0; i < n_commands; i++)
2913 const char **argv;
2914 int argc;
2915 int j;
2917 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2920 argv = alloca ((argc + 3) * sizeof (char *));
2922 argv[0] = VALGRIND_PATH;
2923 argv[1] = "-q";
2924 for (j = 2; j < argc + 2; j++)
2925 argv[j] = commands[i].argv[j - 2];
2926 argv[j] = NULL;
2928 commands[i].argv = argv;
2929 commands[i].prog = argv[0];
2931 #endif
2933 /* Run each piped subprocess. */
2935 pex = pex_init (PEX_USE_PIPES | (report_times ? PEX_RECORD_TIMES : 0),
2936 programname, temp_filename);
2937 if (pex == NULL)
2938 pfatal_with_name (_("pex_init failed"));
2940 for (i = 0; i < n_commands; i++)
2942 const char *errmsg;
2943 int err;
2944 const char *string = commands[i].argv[0];
2946 errmsg = pex_run (pex,
2947 ((i + 1 == n_commands ? PEX_LAST : 0)
2948 | (string == commands[i].prog ? PEX_SEARCH : 0)),
2949 string, (char * const *) commands[i].argv,
2950 NULL, NULL, &err);
2951 if (errmsg != NULL)
2953 if (err == 0)
2954 fatal (errmsg);
2955 else
2957 errno = err;
2958 pfatal_with_name (errmsg);
2962 if (string != commands[i].prog)
2963 free ((void *) string);
2966 execution_count++;
2968 /* Wait for all the subprocesses to finish. */
2971 int *statuses;
2972 struct pex_time *times = NULL;
2973 int ret_code = 0;
2975 statuses = alloca (n_commands * sizeof (int));
2976 if (!pex_get_status (pex, n_commands, statuses))
2977 pfatal_with_name (_("failed to get exit status"));
2979 if (report_times)
2981 times = alloca (n_commands * sizeof (struct pex_time));
2982 if (!pex_get_times (pex, n_commands, times))
2983 pfatal_with_name (_("failed to get process times"));
2986 pex_free (pex);
2988 for (i = 0; i < n_commands; ++i)
2990 int status = statuses[i];
2992 if (WIFSIGNALED (status))
2994 #ifdef SIGPIPE
2995 /* SIGPIPE is a special case. It happens in -pipe mode
2996 when the compiler dies before the preprocessor is done,
2997 or the assembler dies before the compiler is done.
2998 There's generally been an error already, and this is
2999 just fallout. So don't generate another error unless
3000 we would otherwise have succeeded. */
3001 if (WTERMSIG (status) == SIGPIPE
3002 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
3004 signal_count++;
3005 ret_code = -1;
3007 else
3008 #endif
3009 fatal_ice ("\
3010 Internal error: %s (program %s)\n\
3011 Please submit a full bug report.\n\
3012 See %s for instructions.",
3013 strsignal (WTERMSIG (status)), commands[i].prog,
3014 bug_report_url);
3016 else if (WIFEXITED (status)
3017 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
3019 if (WEXITSTATUS (status) > greatest_status)
3020 greatest_status = WEXITSTATUS (status);
3021 ret_code = -1;
3024 if (report_times)
3026 struct pex_time *pt = &times[i];
3027 double ut, st;
3029 ut = ((double) pt->user_seconds
3030 + (double) pt->user_microseconds / 1.0e6);
3031 st = ((double) pt->system_seconds
3032 + (double) pt->system_microseconds / 1.0e6);
3034 if (ut + st != 0)
3035 notice ("# %s %.2f %.2f\n", commands[i].prog, ut, st);
3039 return ret_code;
3043 /* Find all the switches given to us
3044 and make a vector describing them.
3045 The elements of the vector are strings, one per switch given.
3046 If a switch uses following arguments, then the `part1' field
3047 is the switch itself and the `args' field
3048 is a null-terminated vector containing the following arguments.
3049 The `live_cond' field is:
3050 0 when initialized
3051 1 if the switch is true in a conditional spec,
3052 -1 if false (overridden by a later switch)
3053 -2 if this switch should be ignored (used in %<S)
3054 The `validated' field is nonzero if any spec has looked at this switch;
3055 if it remains zero at the end of the run, it must be meaningless. */
3057 #define SWITCH_OK 0
3058 #define SWITCH_FALSE -1
3059 #define SWITCH_IGNORE -2
3060 #define SWITCH_LIVE 1
3062 struct switchstr
3064 const char *part1;
3065 const char **args;
3066 int live_cond;
3067 unsigned char validated;
3068 unsigned char ordering;
3071 static struct switchstr *switches;
3073 static int n_switches;
3075 /* Language is one of three things:
3077 1) The name of a real programming language.
3078 2) NULL, indicating that no one has figured out
3079 what it is yet.
3080 3) '*', indicating that the file should be passed
3081 to the linker. */
3082 struct infile
3084 const char *name;
3085 const char *language;
3086 struct compiler *incompiler;
3087 bool compiled;
3088 bool preprocessed;
3091 /* Also a vector of input files specified. */
3093 static struct infile *infiles;
3095 int n_infiles;
3097 /* True if multiple input files are being compiled to a single
3098 assembly file. */
3100 static bool combine_inputs;
3102 /* This counts the number of libraries added by lang_specific_driver, so that
3103 we can tell if there were any user supplied any files or libraries. */
3105 static int added_libraries;
3107 /* And a vector of corresponding output files is made up later. */
3109 const char **outfiles;
3111 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3113 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3114 is true if we should look for an executable suffix. DO_OBJ
3115 is true if we should look for an object suffix. */
3117 static const char *
3118 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3119 int do_obj ATTRIBUTE_UNUSED)
3121 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3122 int i;
3123 #endif
3124 int len;
3126 if (name == NULL)
3127 return NULL;
3129 len = strlen (name);
3131 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3132 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3133 if (do_obj && len > 2
3134 && name[len - 2] == '.'
3135 && name[len - 1] == 'o')
3137 obstack_grow (&obstack, name, len - 2);
3138 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3139 name = XOBFINISH (&obstack, const char *);
3141 #endif
3143 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3144 /* If there is no filetype, make it the executable suffix (which includes
3145 the "."). But don't get confused if we have just "-o". */
3146 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3147 return name;
3149 for (i = len - 1; i >= 0; i--)
3150 if (IS_DIR_SEPARATOR (name[i]))
3151 break;
3153 for (i++; i < len; i++)
3154 if (name[i] == '.')
3155 return name;
3157 obstack_grow (&obstack, name, len);
3158 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3159 strlen (TARGET_EXECUTABLE_SUFFIX));
3160 name = XOBFINISH (&obstack, const char *);
3161 #endif
3163 return name;
3165 #endif
3167 /* Display the command line switches accepted by gcc. */
3168 static void
3169 display_help (void)
3171 printf (_("Usage: %s [options] file...\n"), programname);
3172 fputs (_("Options:\n"), stdout);
3174 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3175 fputs (_(" --help Display this information\n"), stdout);
3176 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3177 if (! verbose_flag)
3178 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3179 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3180 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3181 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3182 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3183 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3184 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3185 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3186 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3187 fputs (_("\
3188 -print-multi-lib Display the mapping between command line options and\n\
3189 multiple library search directories\n"), stdout);
3190 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3191 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3192 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3193 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3194 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3195 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3196 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3197 fputs (_(" -combine Pass multiple source files to compiler at once\n"), stdout);
3198 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3199 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3200 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3201 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3202 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3203 fputs (_("\
3204 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3205 and libraries\n"), stdout);
3206 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3207 fputs (_(" -b <machine> Run gcc for target <machine>, if installed\n"), stdout);
3208 fputs (_(" -V <version> Run gcc version number <version>, if installed\n"), stdout);
3209 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3210 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3211 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3212 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3213 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3214 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3215 fputs (_("\
3216 -x <language> Specify the language of the following input files\n\
3217 Permissible languages include: c c++ assembler none\n\
3218 'none' means revert to the default behavior of\n\
3219 guessing the language based on the file's extension\n\
3220 "), stdout);
3222 printf (_("\
3223 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3224 passed on to the various sub-processes invoked by %s. In order to pass\n\
3225 other options on to these processes the -W<letter> options must be used.\n\
3226 "), programname);
3228 /* The rest of the options are displayed by invocations of the various
3229 sub-processes. */
3232 static void
3233 add_preprocessor_option (const char *option, int len)
3235 n_preprocessor_options++;
3237 if (! preprocessor_options)
3238 preprocessor_options = XNEWVEC (char *, n_preprocessor_options);
3239 else
3240 preprocessor_options = xrealloc (preprocessor_options,
3241 n_preprocessor_options * sizeof (char *));
3243 preprocessor_options [n_preprocessor_options - 1] =
3244 save_string (option, len);
3247 static void
3248 add_assembler_option (const char *option, int len)
3250 n_assembler_options++;
3252 if (! assembler_options)
3253 assembler_options = XNEWVEC (char *, n_assembler_options);
3254 else
3255 assembler_options = xrealloc (assembler_options,
3256 n_assembler_options * sizeof (char *));
3258 assembler_options [n_assembler_options - 1] = save_string (option, len);
3261 static void
3262 add_linker_option (const char *option, int len)
3264 n_linker_options++;
3266 if (! linker_options)
3267 linker_options = XNEWVEC (char *, n_linker_options);
3268 else
3269 linker_options = xrealloc (linker_options,
3270 n_linker_options * sizeof (char *));
3272 linker_options [n_linker_options - 1] = save_string (option, len);
3275 /* Create the vector `switches' and its contents.
3276 Store its length in `n_switches'. */
3278 static void
3279 process_command (int argc, const char **argv)
3281 int i;
3282 const char *temp;
3283 char *temp1;
3284 const char *spec_lang = 0;
3285 int last_language_n_infiles;
3286 int lang_n_infiles = 0;
3287 #ifdef MODIFY_TARGET_NAME
3288 int is_modify_target_name;
3289 unsigned int j;
3290 #endif
3291 const char *tooldir_prefix;
3293 GET_ENVIRONMENT (gcc_exec_prefix, "GCC_EXEC_PREFIX");
3295 n_switches = 0;
3296 n_infiles = 0;
3297 added_libraries = 0;
3299 /* Figure compiler version from version string. */
3301 compiler_version = temp1 = xstrdup (version_string);
3303 for (; *temp1; ++temp1)
3305 if (*temp1 == ' ')
3307 *temp1 = '\0';
3308 break;
3312 /* If there is a -V or -b option (or both), process it now, before
3313 trying to interpret the rest of the command line.
3314 Use heuristic that all configuration names must have at least
3315 one dash '-'. This allows us to pass options starting with -b. */
3316 if (argc > 1 && argv[1][0] == '-'
3317 && (argv[1][1] == 'V' ||
3318 ((argv[1][1] == 'b') && (NULL != strchr(argv[1] + 2,'-')))))
3320 const char *new_version = DEFAULT_TARGET_VERSION;
3321 const char *new_machine = DEFAULT_TARGET_MACHINE;
3322 const char *progname = argv[0];
3323 char **new_argv;
3324 char *new_argv0;
3325 int baselen;
3327 while (argc > 1 && argv[1][0] == '-'
3328 && (argv[1][1] == 'V' ||
3329 ((argv[1][1] == 'b') && ( NULL != strchr(argv[1] + 2,'-')))))
3331 char opt = argv[1][1];
3332 const char *arg;
3333 if (argv[1][2] != '\0')
3335 arg = argv[1] + 2;
3336 argc -= 1;
3337 argv += 1;
3339 else if (argc > 2)
3341 arg = argv[2];
3342 argc -= 2;
3343 argv += 2;
3345 else
3346 fatal ("'-%c' option must have argument", opt);
3347 if (opt == 'V')
3348 new_version = arg;
3349 else
3350 new_machine = arg;
3353 for (baselen = strlen (progname); baselen > 0; baselen--)
3354 if (IS_DIR_SEPARATOR (progname[baselen-1]))
3355 break;
3356 new_argv0 = xmemdup (progname, baselen,
3357 baselen + concat_length (new_version, new_machine,
3358 "-gcc-", NULL) + 1);
3359 strcpy (new_argv0 + baselen, new_machine);
3360 strcat (new_argv0, "-gcc-");
3361 strcat (new_argv0, new_version);
3363 new_argv = xmemdup (argv, (argc + 1) * sizeof (argv[0]),
3364 (argc + 1) * sizeof (argv[0]));
3365 new_argv[0] = new_argv0;
3367 execvp (new_argv0, new_argv);
3368 fatal ("couldn't run '%s': %s", new_argv0, xstrerror (errno));
3371 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3372 see if we can create it from the pathname specified in argv[0]. */
3374 gcc_libexec_prefix = standard_libexec_prefix;
3375 #ifndef VMS
3376 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3377 if (!gcc_exec_prefix)
3379 gcc_exec_prefix = make_relative_prefix (argv[0], standard_bindir_prefix,
3380 standard_exec_prefix);
3381 gcc_libexec_prefix = make_relative_prefix (argv[0],
3382 standard_bindir_prefix,
3383 standard_libexec_prefix);
3384 if (gcc_exec_prefix)
3385 putenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3387 else
3389 /* make_relative_prefix requires a program name, but
3390 GCC_EXEC_PREFIX is typically a directory name with a trailing
3391 / (which is ignored by make_relative_prefix), so append a
3392 program name. */
3393 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
3394 gcc_libexec_prefix = make_relative_prefix (tmp_prefix,
3395 standard_exec_prefix,
3396 standard_libexec_prefix);
3398 /* The path is unrelocated, so fallback to the original setting. */
3399 if (!gcc_libexec_prefix)
3400 gcc_libexec_prefix = standard_libexec_prefix;
3402 free (tmp_prefix);
3404 #else
3405 #endif
3406 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
3407 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
3408 or an automatically created GCC_EXEC_PREFIX from argv[0]. */
3410 if (gcc_exec_prefix)
3412 int len = strlen (gcc_exec_prefix);
3414 if (len > (int) sizeof ("/lib/gcc/") - 1
3415 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3417 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3418 if (IS_DIR_SEPARATOR (*temp)
3419 && strncmp (temp + 1, "lib", 3) == 0
3420 && IS_DIR_SEPARATOR (temp[4])
3421 && strncmp (temp + 5, "gcc", 3) == 0)
3422 len -= sizeof ("/lib/gcc/") - 1;
3425 set_std_prefix (gcc_exec_prefix, len);
3426 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3427 PREFIX_PRIORITY_LAST, 0, 0);
3428 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3429 PREFIX_PRIORITY_LAST, 0, 0);
3432 /* COMPILER_PATH and LIBRARY_PATH have values
3433 that are lists of directory names with colons. */
3435 GET_ENVIRONMENT (temp, "COMPILER_PATH");
3436 if (temp)
3438 const char *startp, *endp;
3439 char *nstore = alloca (strlen (temp) + 3);
3441 startp = endp = temp;
3442 while (1)
3444 if (*endp == PATH_SEPARATOR || *endp == 0)
3446 strncpy (nstore, startp, endp - startp);
3447 if (endp == startp)
3448 strcpy (nstore, concat (".", dir_separator_str, NULL));
3449 else if (!IS_DIR_SEPARATOR (endp[-1]))
3451 nstore[endp - startp] = DIR_SEPARATOR;
3452 nstore[endp - startp + 1] = 0;
3454 else
3455 nstore[endp - startp] = 0;
3456 add_prefix (&exec_prefixes, nstore, 0,
3457 PREFIX_PRIORITY_LAST, 0, 0);
3458 add_prefix (&include_prefixes, nstore, 0,
3459 PREFIX_PRIORITY_LAST, 0, 0);
3460 if (*endp == 0)
3461 break;
3462 endp = startp = endp + 1;
3464 else
3465 endp++;
3469 GET_ENVIRONMENT (temp, LIBRARY_PATH_ENV);
3470 if (temp && *cross_compile == '0')
3472 const char *startp, *endp;
3473 char *nstore = alloca (strlen (temp) + 3);
3475 startp = endp = temp;
3476 while (1)
3478 if (*endp == PATH_SEPARATOR || *endp == 0)
3480 strncpy (nstore, startp, endp - startp);
3481 if (endp == startp)
3482 strcpy (nstore, concat (".", dir_separator_str, NULL));
3483 else if (!IS_DIR_SEPARATOR (endp[-1]))
3485 nstore[endp - startp] = DIR_SEPARATOR;
3486 nstore[endp - startp + 1] = 0;
3488 else
3489 nstore[endp - startp] = 0;
3490 add_prefix (&startfile_prefixes, nstore, NULL,
3491 PREFIX_PRIORITY_LAST, 0, 1);
3492 if (*endp == 0)
3493 break;
3494 endp = startp = endp + 1;
3496 else
3497 endp++;
3501 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3502 GET_ENVIRONMENT (temp, "LPATH");
3503 if (temp && *cross_compile == '0')
3505 const char *startp, *endp;
3506 char *nstore = alloca (strlen (temp) + 3);
3508 startp = endp = temp;
3509 while (1)
3511 if (*endp == PATH_SEPARATOR || *endp == 0)
3513 strncpy (nstore, startp, endp - startp);
3514 if (endp == startp)
3515 strcpy (nstore, concat (".", dir_separator_str, NULL));
3516 else if (!IS_DIR_SEPARATOR (endp[-1]))
3518 nstore[endp - startp] = DIR_SEPARATOR;
3519 nstore[endp - startp + 1] = 0;
3521 else
3522 nstore[endp - startp] = 0;
3523 add_prefix (&startfile_prefixes, nstore, NULL,
3524 PREFIX_PRIORITY_LAST, 0, 1);
3525 if (*endp == 0)
3526 break;
3527 endp = startp = endp + 1;
3529 else
3530 endp++;
3534 /* Convert new-style -- options to old-style. */
3535 translate_options (&argc, (const char *const **) &argv);
3537 /* Do language-specific adjustment/addition of flags. */
3538 lang_specific_driver (&argc, (const char *const **) &argv, &added_libraries);
3540 /* Scan argv twice. Here, the first time, just count how many switches
3541 there will be in their vector, and how many input files in theirs.
3542 Here we also parse the switches that cc itself uses (e.g. -v). */
3544 for (i = 1; i < argc; i++)
3546 if (! strcmp (argv[i], "-dumpspecs"))
3548 struct spec_list *sl;
3549 init_spec ();
3550 for (sl = specs; sl; sl = sl->next)
3551 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3552 if (link_command_spec)
3553 printf ("*link_command:\n%s\n\n", link_command_spec);
3554 exit (0);
3556 else if (! strcmp (argv[i], "-dumpversion"))
3558 printf ("%s\n", spec_version);
3559 exit (0);
3561 else if (! strcmp (argv[i], "-dumpmachine"))
3563 printf ("%s\n", spec_machine);
3564 exit (0);
3566 else if (strcmp (argv[i], "-fversion") == 0)
3568 /* translate_options () has turned --version into -fversion. */
3569 printf (_("%s (GCC) %s\n"), programname, version_string);
3570 printf ("Copyright %s 2006 Free Software Foundation, Inc.\n",
3571 _("(C)"));
3572 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
3573 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
3574 stdout);
3575 exit (0);
3577 else if (strcmp (argv[i], "-fhelp") == 0)
3579 /* translate_options () has turned --help into -fhelp. */
3580 print_help_list = 1;
3582 /* We will be passing a dummy file on to the sub-processes. */
3583 n_infiles++;
3584 n_switches++;
3586 /* CPP driver cannot obtain switch from cc1_options. */
3587 if (is_cpp_driver)
3588 add_preprocessor_option ("--help", 6);
3589 add_assembler_option ("--help", 6);
3590 add_linker_option ("--help", 6);
3592 else if (strcmp (argv[i], "-ftarget-help") == 0)
3594 /* translate_options() has turned --target-help into -ftarget-help. */
3595 target_help_flag = 1;
3597 /* We will be passing a dummy file on to the sub-processes. */
3598 n_infiles++;
3599 n_switches++;
3601 /* CPP driver cannot obtain switch from cc1_options. */
3602 if (is_cpp_driver)
3603 add_preprocessor_option ("--target-help", 13);
3604 add_assembler_option ("--target-help", 13);
3605 add_linker_option ("--target-help", 13);
3607 else if (! strcmp (argv[i], "-pass-exit-codes"))
3609 pass_exit_codes = 1;
3610 n_switches++;
3612 else if (! strcmp (argv[i], "-print-search-dirs"))
3613 print_search_dirs = 1;
3614 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3615 print_file_name = "libgcc.a";
3616 else if (! strncmp (argv[i], "-print-file-name=", 17))
3617 print_file_name = argv[i] + 17;
3618 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3619 print_prog_name = argv[i] + 17;
3620 else if (! strcmp (argv[i], "-print-multi-lib"))
3621 print_multi_lib = 1;
3622 else if (! strcmp (argv[i], "-print-multi-directory"))
3623 print_multi_directory = 1;
3624 else if (! strcmp (argv[i], "-print-multi-os-directory"))
3625 print_multi_os_directory = 1;
3626 else if (! strncmp (argv[i], "-Wa,", 4))
3628 int prev, j;
3629 /* Pass the rest of this option to the assembler. */
3631 /* Split the argument at commas. */
3632 prev = 4;
3633 for (j = 4; argv[i][j]; j++)
3634 if (argv[i][j] == ',')
3636 add_assembler_option (argv[i] + prev, j - prev);
3637 prev = j + 1;
3640 /* Record the part after the last comma. */
3641 add_assembler_option (argv[i] + prev, j - prev);
3643 else if (! strncmp (argv[i], "-Wp,", 4))
3645 int prev, j;
3646 /* Pass the rest of this option to the preprocessor. */
3648 /* Split the argument at commas. */
3649 prev = 4;
3650 for (j = 4; argv[i][j]; j++)
3651 if (argv[i][j] == ',')
3653 add_preprocessor_option (argv[i] + prev, j - prev);
3654 prev = j + 1;
3657 /* Record the part after the last comma. */
3658 add_preprocessor_option (argv[i] + prev, j - prev);
3660 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3661 /* The +e options to the C++ front-end. */
3662 n_switches++;
3663 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3665 int j;
3666 /* Split the argument at commas. */
3667 for (j = 3; argv[i][j]; j++)
3668 n_infiles += (argv[i][j] == ',');
3670 else if (strcmp (argv[i], "-Xlinker") == 0)
3672 if (i + 1 == argc)
3673 fatal ("argument to '-Xlinker' is missing");
3675 n_infiles++;
3676 i++;
3678 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
3680 if (i + 1 == argc)
3681 fatal ("argument to '-Xpreprocessor' is missing");
3683 add_preprocessor_option (argv[i+1], strlen (argv[i+1]));
3685 else if (strcmp (argv[i], "-Xassembler") == 0)
3687 if (i + 1 == argc)
3688 fatal ("argument to '-Xassembler' is missing");
3690 add_assembler_option (argv[i+1], strlen (argv[i+1]));
3692 else if (strcmp (argv[i], "-l") == 0)
3694 if (i + 1 == argc)
3695 fatal ("argument to '-l' is missing");
3697 n_infiles++;
3698 i++;
3700 else if (strncmp (argv[i], "-l", 2) == 0)
3701 n_infiles++;
3702 else if (strcmp (argv[i], "-save-temps") == 0)
3704 save_temps_flag = 1;
3705 n_switches++;
3707 else if (strcmp (argv[i], "-combine") == 0)
3709 combine_flag = 1;
3710 n_switches++;
3712 else if (strcmp (argv[i], "-specs") == 0)
3714 struct user_specs *user = XNEW (struct user_specs);
3715 if (++i >= argc)
3716 fatal ("argument to '-specs' is missing");
3718 user->next = (struct user_specs *) 0;
3719 user->filename = argv[i];
3720 if (user_specs_tail)
3721 user_specs_tail->next = user;
3722 else
3723 user_specs_head = user;
3724 user_specs_tail = user;
3726 else if (strncmp (argv[i], "-specs=", 7) == 0)
3728 struct user_specs *user = XNEW (struct user_specs);
3729 if (strlen (argv[i]) == 7)
3730 fatal ("argument to '-specs=' is missing");
3732 user->next = (struct user_specs *) 0;
3733 user->filename = argv[i] + 7;
3734 if (user_specs_tail)
3735 user_specs_tail->next = user;
3736 else
3737 user_specs_head = user;
3738 user_specs_tail = user;
3740 else if (strcmp (argv[i], "-time") == 0)
3741 report_times = 1;
3742 else if (strcmp (argv[i], "-pipe") == 0)
3744 /* -pipe has to go into the switches array as well as
3745 setting a flag. */
3746 use_pipes = 1;
3747 n_switches++;
3749 else if (strcmp (argv[i], "-###") == 0)
3751 /* This is similar to -v except that there is no execution
3752 of the commands and the echoed arguments are quoted. It
3753 is intended for use in shell scripts to capture the
3754 driver-generated command line. */
3755 verbose_only_flag++;
3756 verbose_flag++;
3758 else if (argv[i][0] == '-' && argv[i][1] != 0)
3760 const char *p = &argv[i][1];
3761 int c = *p;
3763 switch (c)
3765 case 'b':
3766 if (NULL == strchr(argv[i] + 2, '-'))
3767 goto normal_switch;
3769 /* Fall through. */
3770 case 'V':
3771 fatal ("'-%c' must come at the start of the command line", c);
3772 break;
3774 case 'B':
3776 const char *value;
3777 int len;
3779 if (p[1] == 0 && i + 1 == argc)
3780 fatal ("argument to '-B' is missing");
3781 if (p[1] == 0)
3782 value = argv[++i];
3783 else
3784 value = p + 1;
3786 len = strlen (value);
3788 /* Catch the case where the user has forgotten to append a
3789 directory separator to the path. Note, they may be using
3790 -B to add an executable name prefix, eg "i386-elf-", in
3791 order to distinguish between multiple installations of
3792 GCC in the same directory. Hence we must check to see
3793 if appending a directory separator actually makes a
3794 valid directory name. */
3795 if (! IS_DIR_SEPARATOR (value [len - 1])
3796 && is_directory (value, false))
3798 char *tmp = XNEWVEC (char, len + 2);
3799 strcpy (tmp, value);
3800 tmp[len] = DIR_SEPARATOR;
3801 tmp[++ len] = 0;
3802 value = tmp;
3805 /* As a kludge, if the arg is "[foo/]stageN/", just
3806 add "[foo/]include" to the include prefix. */
3807 if ((len == 7
3808 || (len > 7
3809 && (IS_DIR_SEPARATOR (value[len - 8]))))
3810 && strncmp (value + len - 7, "stage", 5) == 0
3811 && ISDIGIT (value[len - 2])
3812 && (IS_DIR_SEPARATOR (value[len - 1])))
3814 if (len == 7)
3815 add_prefix (&include_prefixes, "./", NULL,
3816 PREFIX_PRIORITY_B_OPT, 0, 0);
3817 else
3819 char *string = xmalloc (len - 6);
3820 memcpy (string, value, len - 7);
3821 string[len - 7] = 0;
3822 add_prefix (&include_prefixes, string, NULL,
3823 PREFIX_PRIORITY_B_OPT, 0, 0);
3827 add_prefix (&exec_prefixes, value, NULL,
3828 PREFIX_PRIORITY_B_OPT, 0, 0);
3829 add_prefix (&startfile_prefixes, value, NULL,
3830 PREFIX_PRIORITY_B_OPT, 0, 0);
3831 add_prefix (&include_prefixes, value, NULL,
3832 PREFIX_PRIORITY_B_OPT, 0, 0);
3833 n_switches++;
3835 break;
3837 case 'v': /* Print our subcommands and print versions. */
3838 n_switches++;
3839 /* If they do anything other than exactly `-v', don't set
3840 verbose_flag; rather, continue on to give the error. */
3841 if (p[1] != 0)
3842 break;
3843 verbose_flag++;
3844 break;
3846 case 'S':
3847 case 'c':
3848 if (p[1] == 0)
3850 have_c = 1;
3851 n_switches++;
3852 break;
3854 goto normal_switch;
3856 case 'o':
3857 have_o = 1;
3858 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3859 if (! have_c)
3861 int skip;
3863 /* Forward scan, just in case -S or -c is specified
3864 after -o. */
3865 int j = i + 1;
3866 if (p[1] == 0)
3867 ++j;
3868 while (j < argc)
3870 if (argv[j][0] == '-')
3872 if (SWITCH_CURTAILS_COMPILATION (argv[j][1])
3873 && argv[j][2] == 0)
3875 have_c = 1;
3876 break;
3878 else if ((skip = SWITCH_TAKES_ARG (argv[j][1])))
3879 j += skip - (argv[j][2] != 0);
3880 else if ((skip = WORD_SWITCH_TAKES_ARG (argv[j] + 1)))
3881 j += skip;
3883 j++;
3886 #endif
3887 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3888 if (p[1] == 0)
3889 argv[i + 1] = convert_filename (argv[i + 1], ! have_c, 0);
3890 else
3891 argv[i] = convert_filename (argv[i], ! have_c, 0);
3892 #endif
3893 goto normal_switch;
3895 default:
3896 normal_switch:
3898 #ifdef MODIFY_TARGET_NAME
3899 is_modify_target_name = 0;
3901 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
3902 if (! strcmp (argv[i], modify_target[j].sw))
3904 char *new_name = xmalloc (strlen (modify_target[j].str)
3905 + strlen (spec_machine));
3906 const char *p, *r;
3907 char *q;
3908 int made_addition = 0;
3910 is_modify_target_name = 1;
3911 for (p = spec_machine, q = new_name; *p != 0; )
3913 if (modify_target[j].add_del == DELETE
3914 && (! strncmp (q, modify_target[j].str,
3915 strlen (modify_target[j].str))))
3916 p += strlen (modify_target[j].str);
3917 else if (modify_target[j].add_del == ADD
3918 && ! made_addition && *p == '-')
3920 for (r = modify_target[j].str; *r != 0; )
3921 *q++ = *r++;
3922 made_addition = 1;
3925 *q++ = *p++;
3928 spec_machine = new_name;
3931 if (is_modify_target_name)
3932 break;
3933 #endif
3935 n_switches++;
3937 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
3938 i += SWITCH_TAKES_ARG (c) - (p[1] != 0);
3939 else if (WORD_SWITCH_TAKES_ARG (p))
3940 i += WORD_SWITCH_TAKES_ARG (p);
3943 else
3945 n_infiles++;
3946 lang_n_infiles++;
3950 if (save_temps_flag && use_pipes)
3952 /* -save-temps overrides -pipe, so that temp files are produced */
3953 if (save_temps_flag)
3954 error ("warning: -pipe ignored because -save-temps specified");
3955 use_pipes = 0;
3958 /* Set up the search paths. We add directories that we expect to
3959 contain GNU Toolchain components before directories specified by
3960 the machine description so that we will find GNU components (like
3961 the GNU assembler) before those of the host system. */
3963 /* If we don't know where the toolchain has been installed, use the
3964 configured-in locations. */
3965 if (!gcc_exec_prefix)
3967 #ifndef OS2
3968 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
3969 PREFIX_PRIORITY_LAST, 1, 0);
3970 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
3971 PREFIX_PRIORITY_LAST, 2, 0);
3972 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
3973 PREFIX_PRIORITY_LAST, 2, 0);
3974 #endif
3975 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
3976 PREFIX_PRIORITY_LAST, 1, 0);
3979 /* If not cross-compiling, search well-known system locations. */
3980 if (*cross_compile == '0')
3982 #ifndef OS2
3983 add_prefix (&exec_prefixes, standard_exec_prefix_1, "BINUTILS",
3984 PREFIX_PRIORITY_LAST, 2, 0);
3985 add_prefix (&exec_prefixes, standard_exec_prefix_2, "BINUTILS",
3986 PREFIX_PRIORITY_LAST, 2, 0);
3987 #endif
3988 add_prefix (&startfile_prefixes, standard_exec_prefix_2, "BINUTILS",
3989 PREFIX_PRIORITY_LAST, 1, 0);
3992 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
3993 tooldir_prefix = concat (tooldir_base_prefix, spec_machine,
3994 dir_separator_str, NULL);
3996 /* Look for tools relative to the location from which the driver is
3997 running, or, if that is not available, the configured prefix. */
3998 tooldir_prefix
3999 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4000 spec_machine, dir_separator_str,
4001 spec_version, dir_separator_str, tooldir_prefix, NULL);
4003 add_prefix (&exec_prefixes,
4004 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4005 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4006 add_prefix (&startfile_prefixes,
4007 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4008 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4010 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4011 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4012 then consider it to relocate with the rest of the GCC installation
4013 if GCC_EXEC_PREFIX is set.
4014 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4015 if (target_system_root && gcc_exec_prefix)
4017 char *tmp_prefix = make_relative_prefix (argv[0],
4018 standard_bindir_prefix,
4019 target_system_root);
4020 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4022 target_system_root = tmp_prefix;
4023 target_system_root_changed = 1;
4026 #endif
4028 /* More prefixes are enabled in main, after we read the specs file
4029 and determine whether this is cross-compilation or not. */
4031 /* Then create the space for the vectors and scan again. */
4033 switches = XNEWVEC (struct switchstr, n_switches + 1);
4034 infiles = XNEWVEC (struct infile, n_infiles + 1);
4035 n_switches = 0;
4036 n_infiles = 0;
4037 last_language_n_infiles = -1;
4039 /* This, time, copy the text of each switch and store a pointer
4040 to the copy in the vector of switches.
4041 Store all the infiles in their vector. */
4043 for (i = 1; i < argc; i++)
4045 /* Just skip the switches that were handled by the preceding loop. */
4046 #ifdef MODIFY_TARGET_NAME
4047 is_modify_target_name = 0;
4049 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
4050 if (! strcmp (argv[i], modify_target[j].sw))
4051 is_modify_target_name = 1;
4053 if (is_modify_target_name)
4055 else
4056 #endif
4057 if (! strncmp (argv[i], "-Wa,", 4))
4059 else if (! strncmp (argv[i], "-Wp,", 4))
4061 else if (! strcmp (argv[i], "-pass-exit-codes"))
4063 else if (! strcmp (argv[i], "-print-search-dirs"))
4065 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
4067 else if (! strncmp (argv[i], "-print-file-name=", 17))
4069 else if (! strncmp (argv[i], "-print-prog-name=", 17))
4071 else if (! strcmp (argv[i], "-print-multi-lib"))
4073 else if (! strcmp (argv[i], "-print-multi-directory"))
4075 else if (! strcmp (argv[i], "-print-multi-os-directory"))
4077 else if (! strcmp (argv[i], "-ftarget-help"))
4079 else if (! strcmp (argv[i], "-fhelp"))
4081 else if (! strncmp (argv[i], "--sysroot=", strlen ("--sysroot=")))
4083 target_system_root = argv[i] + strlen ("--sysroot=");
4084 target_system_root_changed = 1;
4086 else if (argv[i][0] == '+' && argv[i][1] == 'e')
4088 /* Compensate for the +e options to the C++ front-end;
4089 they're there simply for cfront call-compatibility. We do
4090 some magic in default_compilers to pass them down properly.
4091 Note we deliberately start at the `+' here, to avoid passing
4092 -e0 or -e1 down into the linker. */
4093 switches[n_switches].part1 = &argv[i][0];
4094 switches[n_switches].args = 0;
4095 switches[n_switches].live_cond = SWITCH_OK;
4096 switches[n_switches].validated = 0;
4097 n_switches++;
4099 else if (strncmp (argv[i], "-Wl,", 4) == 0)
4101 int prev, j;
4102 /* Split the argument at commas. */
4103 prev = 4;
4104 for (j = 4; argv[i][j]; j++)
4105 if (argv[i][j] == ',')
4107 infiles[n_infiles].language = "*";
4108 infiles[n_infiles++].name
4109 = save_string (argv[i] + prev, j - prev);
4110 prev = j + 1;
4112 /* Record the part after the last comma. */
4113 infiles[n_infiles].language = "*";
4114 infiles[n_infiles++].name = argv[i] + prev;
4116 else if (strcmp (argv[i], "-Xlinker") == 0)
4118 infiles[n_infiles].language = "*";
4119 infiles[n_infiles++].name = argv[++i];
4121 /* Xassembler and Xpreprocessor were already handled in the first argv
4122 scan, so all we need to do here is ignore them and their argument. */
4123 else if (strcmp (argv[i], "-Xassembler") == 0)
4124 i++;
4125 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
4126 i++;
4127 else if (strcmp (argv[i], "-l") == 0)
4128 { /* POSIX allows separation of -l and the lib arg;
4129 canonicalize by concatenating -l with its arg */
4130 infiles[n_infiles].language = "*";
4131 infiles[n_infiles++].name = concat ("-l", argv[++i], NULL);
4133 else if (strncmp (argv[i], "-l", 2) == 0)
4135 infiles[n_infiles].language = "*";
4136 infiles[n_infiles++].name = argv[i];
4138 else if (strcmp (argv[i], "-specs") == 0)
4139 i++;
4140 else if (strncmp (argv[i], "-specs=", 7) == 0)
4142 else if (strcmp (argv[i], "-time") == 0)
4144 else if (strcmp (argv[i], "-###") == 0)
4146 else if (argv[i][0] == '-' && argv[i][1] != 0)
4148 const char *p = &argv[i][1];
4149 int c = *p;
4151 if (c == 'x')
4153 if (p[1] == 0 && i + 1 == argc)
4154 fatal ("argument to '-x' is missing");
4155 if (p[1] == 0)
4156 spec_lang = argv[++i];
4157 else
4158 spec_lang = p + 1;
4159 if (! strcmp (spec_lang, "none"))
4160 /* Suppress the warning if -xnone comes after the last input
4161 file, because alternate command interfaces like g++ might
4162 find it useful to place -xnone after each input file. */
4163 spec_lang = 0;
4164 else
4165 last_language_n_infiles = n_infiles;
4166 continue;
4168 switches[n_switches].part1 = p;
4169 /* Deal with option arguments in separate argv elements. */
4170 if ((SWITCH_TAKES_ARG (c) > (p[1] != 0))
4171 || WORD_SWITCH_TAKES_ARG (p))
4173 int j = 0;
4174 int n_args = WORD_SWITCH_TAKES_ARG (p);
4176 if (n_args == 0)
4178 /* Count only the option arguments in separate argv elements. */
4179 n_args = SWITCH_TAKES_ARG (c) - (p[1] != 0);
4181 if (i + n_args >= argc)
4182 fatal ("argument to '-%s' is missing", p);
4183 switches[n_switches].args
4184 = XNEWVEC (const char *, n_args + 1);
4185 while (j < n_args)
4186 switches[n_switches].args[j++] = argv[++i];
4187 /* Null-terminate the vector. */
4188 switches[n_switches].args[j] = 0;
4190 else if (strchr (switches_need_spaces, c))
4192 /* On some systems, ld cannot handle some options without
4193 a space. So split the option from its argument. */
4194 char *part1 = XNEWVEC (char, 2);
4195 part1[0] = c;
4196 part1[1] = '\0';
4198 switches[n_switches].part1 = part1;
4199 switches[n_switches].args = XNEWVEC (const char *, 2);
4200 switches[n_switches].args[0] = xstrdup (p+1);
4201 switches[n_switches].args[1] = 0;
4203 else
4204 switches[n_switches].args = 0;
4206 switches[n_switches].live_cond = SWITCH_OK;
4207 switches[n_switches].validated = 0;
4208 switches[n_switches].ordering = 0;
4209 /* These are always valid, since gcc.c itself understands them. */
4210 if (!strcmp (p, "save-temps")
4211 || !strcmp (p, "static-libgcc")
4212 || !strcmp (p, "shared-libgcc")
4213 || !strcmp (p, "pipe"))
4214 switches[n_switches].validated = 1;
4215 else
4217 char ch = switches[n_switches].part1[0];
4218 if (ch == 'B')
4219 switches[n_switches].validated = 1;
4221 n_switches++;
4223 else
4225 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4226 argv[i] = convert_filename (argv[i], 0, access (argv[i], F_OK));
4227 #endif
4229 if (strcmp (argv[i], "-") != 0 && access (argv[i], F_OK) < 0)
4231 perror_with_name (argv[i]);
4232 error_count++;
4234 else
4236 infiles[n_infiles].language = spec_lang;
4237 infiles[n_infiles++].name = argv[i];
4242 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4243 error ("warning: '-x %s' after last input file has no effect", spec_lang);
4245 /* Ensure we only invoke each subprocess once. */
4246 if (target_help_flag || print_help_list)
4248 n_infiles = 1;
4250 /* Create a dummy input file, so that we can pass --target-help on to
4251 the various sub-processes. */
4252 infiles[0].language = "c";
4253 infiles[0].name = "help-dummy";
4255 if (target_help_flag)
4257 switches[n_switches].part1 = "--target-help";
4258 switches[n_switches].args = 0;
4259 switches[n_switches].live_cond = SWITCH_OK;
4260 switches[n_switches].validated = 0;
4262 n_switches++;
4265 if (print_help_list)
4267 switches[n_switches].part1 = "--help";
4268 switches[n_switches].args = 0;
4269 switches[n_switches].live_cond = SWITCH_OK;
4270 switches[n_switches].validated = 0;
4272 n_switches++;
4276 switches[n_switches].part1 = 0;
4277 infiles[n_infiles].name = 0;
4280 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4281 and place that in the environment. */
4283 static void
4284 set_collect_gcc_options (void)
4286 int i;
4287 int first_time;
4289 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4290 the compiler. */
4291 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4292 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4294 first_time = TRUE;
4295 for (i = 0; (int) i < n_switches; i++)
4297 const char *const *args;
4298 const char *p, *q;
4299 if (!first_time)
4300 obstack_grow (&collect_obstack, " ", 1);
4302 first_time = FALSE;
4304 /* Ignore elided switches. */
4305 if (switches[i].live_cond == SWITCH_IGNORE)
4306 continue;
4308 obstack_grow (&collect_obstack, "'-", 2);
4309 q = switches[i].part1;
4310 while ((p = strchr (q, '\'')))
4312 obstack_grow (&collect_obstack, q, p - q);
4313 obstack_grow (&collect_obstack, "'\\''", 4);
4314 q = ++p;
4316 obstack_grow (&collect_obstack, q, strlen (q));
4317 obstack_grow (&collect_obstack, "'", 1);
4319 for (args = switches[i].args; args && *args; args++)
4321 obstack_grow (&collect_obstack, " '", 2);
4322 q = *args;
4323 while ((p = strchr (q, '\'')))
4325 obstack_grow (&collect_obstack, q, p - q);
4326 obstack_grow (&collect_obstack, "'\\''", 4);
4327 q = ++p;
4329 obstack_grow (&collect_obstack, q, strlen (q));
4330 obstack_grow (&collect_obstack, "'", 1);
4333 obstack_grow (&collect_obstack, "\0", 1);
4334 putenv (XOBFINISH (&collect_obstack, char *));
4337 /* Process a spec string, accumulating and running commands. */
4339 /* These variables describe the input file name.
4340 input_file_number is the index on outfiles of this file,
4341 so that the output file name can be stored for later use by %o.
4342 input_basename is the start of the part of the input file
4343 sans all directory names, and basename_length is the number
4344 of characters starting there excluding the suffix .c or whatever. */
4346 static const char *input_filename;
4347 static int input_file_number;
4348 size_t input_filename_length;
4349 static int basename_length;
4350 static int suffixed_basename_length;
4351 static const char *input_basename;
4352 static const char *input_suffix;
4353 #ifndef HOST_LACKS_INODE_NUMBERS
4354 static struct stat input_stat;
4355 #endif
4356 static int input_stat_set;
4358 /* The compiler used to process the current input file. */
4359 static struct compiler *input_file_compiler;
4361 /* These are variables used within do_spec and do_spec_1. */
4363 /* Nonzero if an arg has been started and not yet terminated
4364 (with space, tab or newline). */
4365 static int arg_going;
4367 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4368 is a temporary file name. */
4369 static int delete_this_arg;
4371 /* Nonzero means %w has been seen; the next arg to be terminated
4372 is the output file name of this compilation. */
4373 static int this_is_output_file;
4375 /* Nonzero means %s has been seen; the next arg to be terminated
4376 is the name of a library file and we should try the standard
4377 search dirs for it. */
4378 static int this_is_library_file;
4380 /* Nonzero means that the input of this command is coming from a pipe. */
4381 static int input_from_pipe;
4383 /* Nonnull means substitute this for any suffix when outputting a switches
4384 arguments. */
4385 static const char *suffix_subst;
4387 /* Process the spec SPEC and run the commands specified therein.
4388 Returns 0 if the spec is successfully processed; -1 if failed. */
4391 do_spec (const char *spec)
4393 int value;
4395 value = do_spec_2 (spec);
4397 /* Force out any unfinished command.
4398 If -pipe, this forces out the last command if it ended in `|'. */
4399 if (value == 0)
4401 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4402 argbuf_index--;
4404 set_collect_gcc_options ();
4406 if (argbuf_index > 0)
4407 value = execute ();
4410 return value;
4413 static int
4414 do_spec_2 (const char *spec)
4416 const char *string;
4417 int result;
4419 clear_args ();
4420 arg_going = 0;
4421 delete_this_arg = 0;
4422 this_is_output_file = 0;
4423 this_is_library_file = 0;
4424 input_from_pipe = 0;
4425 suffix_subst = NULL;
4427 result = do_spec_1 (spec, 0, NULL);
4429 /* End any pending argument. */
4430 if (arg_going)
4432 obstack_1grow (&obstack, 0);
4433 string = XOBFINISH (&obstack, const char *);
4434 if (this_is_library_file)
4435 string = find_file (string);
4436 store_arg (string, delete_this_arg, this_is_output_file);
4437 if (this_is_output_file)
4438 outfiles[input_file_number] = string;
4439 arg_going = 0;
4442 return result;
4446 /* Process the given spec string and add any new options to the end
4447 of the switches/n_switches array. */
4449 static void
4450 do_option_spec (const char *name, const char *spec)
4452 unsigned int i, value_count, value_len;
4453 const char *p, *q, *value;
4454 char *tmp_spec, *tmp_spec_p;
4456 if (configure_default_options[0].name == NULL)
4457 return;
4459 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4460 if (strcmp (configure_default_options[i].name, name) == 0)
4461 break;
4462 if (i == ARRAY_SIZE (configure_default_options))
4463 return;
4465 value = configure_default_options[i].value;
4466 value_len = strlen (value);
4468 /* Compute the size of the final spec. */
4469 value_count = 0;
4470 p = spec;
4471 while ((p = strstr (p, "%(VALUE)")) != NULL)
4473 p ++;
4474 value_count ++;
4477 /* Replace each %(VALUE) by the specified value. */
4478 tmp_spec = alloca (strlen (spec) + 1
4479 + value_count * (value_len - strlen ("%(VALUE)")));
4480 tmp_spec_p = tmp_spec;
4481 q = spec;
4482 while ((p = strstr (q, "%(VALUE)")) != NULL)
4484 memcpy (tmp_spec_p, q, p - q);
4485 tmp_spec_p = tmp_spec_p + (p - q);
4486 memcpy (tmp_spec_p, value, value_len);
4487 tmp_spec_p += value_len;
4488 q = p + strlen ("%(VALUE)");
4490 strcpy (tmp_spec_p, q);
4492 do_self_spec (tmp_spec);
4495 /* Process the given spec string and add any new options to the end
4496 of the switches/n_switches array. */
4498 static void
4499 do_self_spec (const char *spec)
4501 do_spec_2 (spec);
4502 do_spec_1 (" ", 0, NULL);
4504 if (argbuf_index > 0)
4506 int i, first;
4508 first = n_switches;
4509 n_switches += argbuf_index;
4510 switches = xrealloc (switches,
4511 sizeof (struct switchstr) * (n_switches + 1));
4513 switches[n_switches] = switches[first];
4514 for (i = 0; i < argbuf_index; i++)
4516 struct switchstr *sw;
4518 /* Each switch should start with '-'. */
4519 if (argbuf[i][0] != '-')
4520 fatal ("switch '%s' does not start with '-'", argbuf[i]);
4522 sw = &switches[i + first];
4523 sw->part1 = &argbuf[i][1];
4524 sw->args = 0;
4525 sw->live_cond = SWITCH_OK;
4526 sw->validated = 0;
4527 sw->ordering = 0;
4532 /* Callback for processing %D and %I specs. */
4534 struct spec_path_info {
4535 const char *option;
4536 const char *append;
4537 size_t append_len;
4538 bool omit_relative;
4539 bool separate_options;
4542 static void *
4543 spec_path (char *path, void *data)
4545 struct spec_path_info *info = data;
4546 size_t len = 0;
4547 char save = 0;
4549 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4550 return NULL;
4552 if (info->append_len != 0)
4554 len = strlen (path);
4555 memcpy (path + len, info->append, info->append_len + 1);
4558 if (!is_directory (path, true))
4559 return NULL;
4561 do_spec_1 (info->option, 1, NULL);
4562 if (info->separate_options)
4563 do_spec_1 (" ", 0, NULL);
4565 if (info->append_len == 0)
4567 len = strlen (path);
4568 save = path[len - 1];
4569 if (IS_DIR_SEPARATOR (path[len - 1]))
4570 path[len - 1] = '\0';
4573 do_spec_1 (path, 1, NULL);
4574 do_spec_1 (" ", 0, NULL);
4576 /* Must not damage the original path. */
4577 if (info->append_len == 0)
4578 path[len - 1] = save;
4580 return NULL;
4583 /* Process the sub-spec SPEC as a portion of a larger spec.
4584 This is like processing a whole spec except that we do
4585 not initialize at the beginning and we do not supply a
4586 newline by default at the end.
4587 INSWITCH nonzero means don't process %-sequences in SPEC;
4588 in this case, % is treated as an ordinary character.
4589 This is used while substituting switches.
4590 INSWITCH nonzero also causes SPC not to terminate an argument.
4592 Value is zero unless a line was finished
4593 and the command on that line reported an error. */
4595 static int
4596 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4598 const char *p = spec;
4599 int c;
4600 int i;
4601 const char *string;
4602 int value;
4604 while ((c = *p++))
4605 /* If substituting a switch, treat all chars like letters.
4606 Otherwise, NL, SPC, TAB and % are special. */
4607 switch (inswitch ? 'a' : c)
4609 case '\n':
4610 /* End of line: finish any pending argument,
4611 then run the pending command if one has been started. */
4612 if (arg_going)
4614 obstack_1grow (&obstack, 0);
4615 string = XOBFINISH (&obstack, const char *);
4616 if (this_is_library_file)
4617 string = find_file (string);
4618 store_arg (string, delete_this_arg, this_is_output_file);
4619 if (this_is_output_file)
4620 outfiles[input_file_number] = string;
4622 arg_going = 0;
4624 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4626 /* A `|' before the newline means use a pipe here,
4627 but only if -pipe was specified.
4628 Otherwise, execute now and don't pass the `|' as an arg. */
4629 if (use_pipes)
4631 input_from_pipe = 1;
4632 break;
4634 else
4635 argbuf_index--;
4638 set_collect_gcc_options ();
4640 if (argbuf_index > 0)
4642 value = execute ();
4643 if (value)
4644 return value;
4646 /* Reinitialize for a new command, and for a new argument. */
4647 clear_args ();
4648 arg_going = 0;
4649 delete_this_arg = 0;
4650 this_is_output_file = 0;
4651 this_is_library_file = 0;
4652 input_from_pipe = 0;
4653 break;
4655 case '|':
4656 /* End any pending argument. */
4657 if (arg_going)
4659 obstack_1grow (&obstack, 0);
4660 string = XOBFINISH (&obstack, const char *);
4661 if (this_is_library_file)
4662 string = find_file (string);
4663 store_arg (string, delete_this_arg, this_is_output_file);
4664 if (this_is_output_file)
4665 outfiles[input_file_number] = string;
4668 /* Use pipe */
4669 obstack_1grow (&obstack, c);
4670 arg_going = 1;
4671 break;
4673 case '\t':
4674 case ' ':
4675 /* Space or tab ends an argument if one is pending. */
4676 if (arg_going)
4678 obstack_1grow (&obstack, 0);
4679 string = XOBFINISH (&obstack, const char *);
4680 if (this_is_library_file)
4681 string = find_file (string);
4682 store_arg (string, delete_this_arg, this_is_output_file);
4683 if (this_is_output_file)
4684 outfiles[input_file_number] = string;
4686 /* Reinitialize for a new argument. */
4687 arg_going = 0;
4688 delete_this_arg = 0;
4689 this_is_output_file = 0;
4690 this_is_library_file = 0;
4691 break;
4693 case '%':
4694 switch (c = *p++)
4696 case 0:
4697 fatal ("spec '%s' invalid", spec);
4699 case 'b':
4700 obstack_grow (&obstack, input_basename, basename_length);
4701 arg_going = 1;
4702 break;
4704 case 'B':
4705 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4706 arg_going = 1;
4707 break;
4709 case 'd':
4710 delete_this_arg = 2;
4711 break;
4713 /* Dump out the directories specified with LIBRARY_PATH,
4714 followed by the absolute directories
4715 that we search for startfiles. */
4716 case 'D':
4718 struct spec_path_info info;
4720 info.option = "-L";
4721 info.append_len = 0;
4722 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4723 /* Used on systems which record the specified -L dirs
4724 and use them to search for dynamic linking.
4725 Relative directories always come from -B,
4726 and it is better not to use them for searching
4727 at run time. In particular, stage1 loses. */
4728 info.omit_relative = true;
4729 #else
4730 info.omit_relative = false;
4731 #endif
4732 info.separate_options = false;
4734 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
4736 break;
4738 case 'e':
4739 /* %efoo means report an error with `foo' as error message
4740 and don't execute any more commands for this file. */
4742 const char *q = p;
4743 char *buf;
4744 while (*p != 0 && *p != '\n')
4745 p++;
4746 buf = alloca (p - q + 1);
4747 strncpy (buf, q, p - q);
4748 buf[p - q] = 0;
4749 error ("%s", buf);
4750 return -1;
4752 break;
4753 case 'n':
4754 /* %nfoo means report a notice with `foo' on stderr. */
4756 const char *q = p;
4757 char *buf;
4758 while (*p != 0 && *p != '\n')
4759 p++;
4760 buf = alloca (p - q + 1);
4761 strncpy (buf, q, p - q);
4762 buf[p - q] = 0;
4763 notice ("%s\n", buf);
4764 if (*p)
4765 p++;
4767 break;
4769 case 'j':
4771 struct stat st;
4773 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4774 defined, and it is not a directory, and it is
4775 writable, use it. Otherwise, treat this like any
4776 other temporary file. */
4778 if ((!save_temps_flag)
4779 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4780 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4782 obstack_grow (&obstack, HOST_BIT_BUCKET,
4783 strlen (HOST_BIT_BUCKET));
4784 delete_this_arg = 0;
4785 arg_going = 1;
4786 break;
4789 goto create_temp_file;
4790 case '|':
4791 if (use_pipes)
4793 obstack_1grow (&obstack, '-');
4794 delete_this_arg = 0;
4795 arg_going = 1;
4797 /* consume suffix */
4798 while (*p == '.' || ISALNUM ((unsigned char) *p))
4799 p++;
4800 if (p[0] == '%' && p[1] == 'O')
4801 p += 2;
4803 break;
4805 goto create_temp_file;
4806 case 'm':
4807 if (use_pipes)
4809 /* consume suffix */
4810 while (*p == '.' || ISALNUM ((unsigned char) *p))
4811 p++;
4812 if (p[0] == '%' && p[1] == 'O')
4813 p += 2;
4815 break;
4817 goto create_temp_file;
4818 case 'g':
4819 case 'u':
4820 case 'U':
4821 create_temp_file:
4823 struct temp_name *t;
4824 int suffix_length;
4825 const char *suffix = p;
4826 char *saved_suffix = NULL;
4828 while (*p == '.' || ISALNUM ((unsigned char) *p))
4829 p++;
4830 suffix_length = p - suffix;
4831 if (p[0] == '%' && p[1] == 'O')
4833 p += 2;
4834 /* We don't support extra suffix characters after %O. */
4835 if (*p == '.' || ISALNUM ((unsigned char) *p))
4836 fatal ("spec '%s' has invalid '%%0%c'", spec, *p);
4837 if (suffix_length == 0)
4838 suffix = TARGET_OBJECT_SUFFIX;
4839 else
4841 saved_suffix
4842 = XNEWVEC (char, suffix_length
4843 + strlen (TARGET_OBJECT_SUFFIX));
4844 strncpy (saved_suffix, suffix, suffix_length);
4845 strcpy (saved_suffix + suffix_length,
4846 TARGET_OBJECT_SUFFIX);
4848 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4851 /* If the input_filename has the same suffix specified
4852 for the %g, %u, or %U, and -save-temps is specified,
4853 we could end up using that file as an intermediate
4854 thus clobbering the user's source file (.e.g.,
4855 gcc -save-temps foo.s would clobber foo.s with the
4856 output of cpp0). So check for this condition and
4857 generate a temp file as the intermediate. */
4859 if (save_temps_flag)
4861 temp_filename_length = basename_length + suffix_length;
4862 temp_filename = alloca (temp_filename_length + 1);
4863 strncpy ((char *) temp_filename, input_basename, basename_length);
4864 strncpy ((char *) temp_filename + basename_length, suffix,
4865 suffix_length);
4866 *((char *) temp_filename + temp_filename_length) = '\0';
4867 if (strcmp (temp_filename, input_filename) != 0)
4869 #ifndef HOST_LACKS_INODE_NUMBERS
4870 struct stat st_temp;
4872 /* Note, set_input() resets input_stat_set to 0. */
4873 if (input_stat_set == 0)
4875 input_stat_set = stat (input_filename, &input_stat);
4876 if (input_stat_set >= 0)
4877 input_stat_set = 1;
4880 /* If we have the stat for the input_filename
4881 and we can do the stat for the temp_filename
4882 then the they could still refer to the same
4883 file if st_dev/st_ino's are the same. */
4884 if (input_stat_set != 1
4885 || stat (temp_filename, &st_temp) < 0
4886 || input_stat.st_dev != st_temp.st_dev
4887 || input_stat.st_ino != st_temp.st_ino)
4888 #else
4889 /* Just compare canonical pathnames. */
4890 char* input_realname = lrealpath (input_filename);
4891 char* temp_realname = lrealpath (temp_filename);
4892 bool files_differ = strcmp (input_realname, temp_realname);
4893 free (input_realname);
4894 free (temp_realname);
4895 if (files_differ)
4896 #endif
4898 temp_filename = save_string (temp_filename,
4899 temp_filename_length + 1);
4900 obstack_grow (&obstack, temp_filename,
4901 temp_filename_length);
4902 arg_going = 1;
4903 delete_this_arg = 0;
4904 break;
4909 /* See if we already have an association of %g/%u/%U and
4910 suffix. */
4911 for (t = temp_names; t; t = t->next)
4912 if (t->length == suffix_length
4913 && strncmp (t->suffix, suffix, suffix_length) == 0
4914 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4915 break;
4917 /* Make a new association if needed. %u and %j
4918 require one. */
4919 if (t == 0 || c == 'u' || c == 'j')
4921 if (t == 0)
4923 t = xmalloc (sizeof (struct temp_name));
4924 t->next = temp_names;
4925 temp_names = t;
4927 t->length = suffix_length;
4928 if (saved_suffix)
4930 t->suffix = saved_suffix;
4931 saved_suffix = NULL;
4933 else
4934 t->suffix = save_string (suffix, suffix_length);
4935 t->unique = (c == 'u' || c == 'U' || c == 'j');
4936 temp_filename = make_temp_file (t->suffix);
4937 temp_filename_length = strlen (temp_filename);
4938 t->filename = temp_filename;
4939 t->filename_length = temp_filename_length;
4942 if (saved_suffix)
4943 free (saved_suffix);
4945 obstack_grow (&obstack, t->filename, t->filename_length);
4946 delete_this_arg = 1;
4948 arg_going = 1;
4949 break;
4951 case 'i':
4952 if (combine_inputs)
4954 for (i = 0; (int) i < n_infiles; i++)
4955 if ((!infiles[i].language) || (infiles[i].language[0] != '*'))
4956 if (infiles[i].incompiler == input_file_compiler)
4958 store_arg (infiles[i].name, 0, 0);
4959 infiles[i].compiled = true;
4962 else
4964 obstack_grow (&obstack, input_filename, input_filename_length);
4965 arg_going = 1;
4967 break;
4969 case 'I':
4971 struct spec_path_info info;
4973 if (multilib_dir)
4975 do_spec_1 ("-imultilib", 1, NULL);
4976 /* Make this a separate argument. */
4977 do_spec_1 (" ", 0, NULL);
4978 do_spec_1 (multilib_dir, 1, NULL);
4979 do_spec_1 (" ", 0, NULL);
4982 if (gcc_exec_prefix)
4984 do_spec_1 ("-iprefix", 1, NULL);
4985 /* Make this a separate argument. */
4986 do_spec_1 (" ", 0, NULL);
4987 do_spec_1 (gcc_exec_prefix, 1, NULL);
4988 do_spec_1 (" ", 0, NULL);
4991 if (target_system_root_changed ||
4992 (target_system_root && target_sysroot_hdrs_suffix))
4994 do_spec_1 ("-isysroot", 1, NULL);
4995 /* Make this a separate argument. */
4996 do_spec_1 (" ", 0, NULL);
4997 do_spec_1 (target_system_root, 1, NULL);
4998 if (target_sysroot_hdrs_suffix)
4999 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
5000 do_spec_1 (" ", 0, NULL);
5003 info.option = "-isystem";
5004 info.append = "include";
5005 info.append_len = strlen (info.append);
5006 info.omit_relative = false;
5007 info.separate_options = true;
5009 for_each_path (&include_prefixes, false, info.append_len,
5010 spec_path, &info);
5012 break;
5014 case 'o':
5016 int max = n_infiles;
5017 max += lang_specific_extra_outfiles;
5019 for (i = 0; i < max; i++)
5020 if (outfiles[i])
5021 store_arg (outfiles[i], 0, 0);
5022 break;
5025 case 'O':
5026 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5027 arg_going = 1;
5028 break;
5030 case 's':
5031 this_is_library_file = 1;
5032 break;
5034 case 'V':
5035 outfiles[input_file_number] = NULL;
5036 break;
5038 case 'w':
5039 this_is_output_file = 1;
5040 break;
5042 case 'W':
5044 int cur_index = argbuf_index;
5045 /* Handle the {...} following the %W. */
5046 if (*p != '{')
5047 fatal ("spec '%s' has invalid '%%W%c", spec, *p);
5048 p = handle_braces (p + 1);
5049 if (p == 0)
5050 return -1;
5051 /* End any pending argument. */
5052 if (arg_going)
5054 obstack_1grow (&obstack, 0);
5055 string = XOBFINISH (&obstack, const char *);
5056 if (this_is_library_file)
5057 string = find_file (string);
5058 store_arg (string, delete_this_arg, this_is_output_file);
5059 if (this_is_output_file)
5060 outfiles[input_file_number] = string;
5061 arg_going = 0;
5063 /* If any args were output, mark the last one for deletion
5064 on failure. */
5065 if (argbuf_index != cur_index)
5066 record_temp_file (argbuf[argbuf_index - 1], 0, 1);
5067 break;
5070 /* %x{OPTION} records OPTION for %X to output. */
5071 case 'x':
5073 const char *p1 = p;
5074 char *string;
5076 /* Skip past the option value and make a copy. */
5077 if (*p != '{')
5078 fatal ("spec '%s' has invalid '%%x%c'", spec, *p);
5079 while (*p++ != '}')
5081 string = save_string (p1 + 1, p - p1 - 2);
5083 /* See if we already recorded this option. */
5084 for (i = 0; i < n_linker_options; i++)
5085 if (! strcmp (string, linker_options[i]))
5087 free (string);
5088 return 0;
5091 /* This option is new; add it. */
5092 add_linker_option (string, strlen (string));
5094 break;
5096 /* Dump out the options accumulated previously using %x. */
5097 case 'X':
5098 for (i = 0; i < n_linker_options; i++)
5100 do_spec_1 (linker_options[i], 1, NULL);
5101 /* Make each accumulated option a separate argument. */
5102 do_spec_1 (" ", 0, NULL);
5104 break;
5106 /* Dump out the options accumulated previously using -Wa,. */
5107 case 'Y':
5108 for (i = 0; i < n_assembler_options; i++)
5110 do_spec_1 (assembler_options[i], 1, NULL);
5111 /* Make each accumulated option a separate argument. */
5112 do_spec_1 (" ", 0, NULL);
5114 break;
5116 /* Dump out the options accumulated previously using -Wp,. */
5117 case 'Z':
5118 for (i = 0; i < n_preprocessor_options; i++)
5120 do_spec_1 (preprocessor_options[i], 1, NULL);
5121 /* Make each accumulated option a separate argument. */
5122 do_spec_1 (" ", 0, NULL);
5124 break;
5126 /* Here are digits and numbers that just process
5127 a certain constant string as a spec. */
5129 case '1':
5130 value = do_spec_1 (cc1_spec, 0, NULL);
5131 if (value != 0)
5132 return value;
5133 break;
5135 case '2':
5136 value = do_spec_1 (cc1plus_spec, 0, NULL);
5137 if (value != 0)
5138 return value;
5139 break;
5141 case 'a':
5142 value = do_spec_1 (asm_spec, 0, NULL);
5143 if (value != 0)
5144 return value;
5145 break;
5147 case 'A':
5148 value = do_spec_1 (asm_final_spec, 0, NULL);
5149 if (value != 0)
5150 return value;
5151 break;
5153 case 'C':
5155 const char *const spec
5156 = (input_file_compiler->cpp_spec
5157 ? input_file_compiler->cpp_spec
5158 : cpp_spec);
5159 value = do_spec_1 (spec, 0, NULL);
5160 if (value != 0)
5161 return value;
5163 break;
5165 case 'E':
5166 value = do_spec_1 (endfile_spec, 0, NULL);
5167 if (value != 0)
5168 return value;
5169 break;
5171 case 'l':
5172 value = do_spec_1 (link_spec, 0, NULL);
5173 if (value != 0)
5174 return value;
5175 break;
5177 case 'L':
5178 value = do_spec_1 (lib_spec, 0, NULL);
5179 if (value != 0)
5180 return value;
5181 break;
5183 case 'G':
5184 value = do_spec_1 (libgcc_spec, 0, NULL);
5185 if (value != 0)
5186 return value;
5187 break;
5189 case 'R':
5190 /* We assume there is a directory
5191 separator at the end of this string. */
5192 if (target_system_root)
5194 obstack_grow (&obstack, target_system_root,
5195 strlen (target_system_root));
5196 if (target_sysroot_suffix)
5197 obstack_grow (&obstack, target_sysroot_suffix,
5198 strlen (target_sysroot_suffix));
5200 break;
5202 case 'S':
5203 value = do_spec_1 (startfile_spec, 0, NULL);
5204 if (value != 0)
5205 return value;
5206 break;
5208 /* Here we define characters other than letters and digits. */
5210 case '{':
5211 p = handle_braces (p);
5212 if (p == 0)
5213 return -1;
5214 break;
5216 case ':':
5217 p = handle_spec_function (p);
5218 if (p == 0)
5219 return -1;
5220 break;
5222 case '%':
5223 obstack_1grow (&obstack, '%');
5224 break;
5226 case '.':
5228 unsigned len = 0;
5230 while (p[len] && p[len] != ' ' && p[len] != '%')
5231 len++;
5232 suffix_subst = save_string (p - 1, len + 1);
5233 p += len;
5235 break;
5237 /* Henceforth ignore the option(s) matching the pattern
5238 after the %<. */
5239 case '<':
5241 unsigned len = 0;
5242 int have_wildcard = 0;
5243 int i;
5245 while (p[len] && p[len] != ' ' && p[len] != '\t')
5246 len++;
5248 if (p[len-1] == '*')
5249 have_wildcard = 1;
5251 for (i = 0; i < n_switches; i++)
5252 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5253 && (have_wildcard || switches[i].part1[len] == '\0'))
5255 switches[i].live_cond = SWITCH_IGNORE;
5256 switches[i].validated = 1;
5259 p += len;
5261 break;
5263 case '*':
5264 if (soft_matched_part)
5266 do_spec_1 (soft_matched_part, 1, NULL);
5267 do_spec_1 (" ", 0, NULL);
5269 else
5270 /* Catch the case where a spec string contains something like
5271 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5272 hand side of the :. */
5273 error ("spec failure: '%%*' has not been initialized by pattern match");
5274 break;
5276 /* Process a string found as the value of a spec given by name.
5277 This feature allows individual machine descriptions
5278 to add and use their own specs.
5279 %[...] modifies -D options the way %P does;
5280 %(...) uses the spec unmodified. */
5281 case '[':
5282 error ("warning: use of obsolete %%[ operator in specs");
5283 case '(':
5285 const char *name = p;
5286 struct spec_list *sl;
5287 int len;
5289 /* The string after the S/P is the name of a spec that is to be
5290 processed. */
5291 while (*p && *p != ')' && *p != ']')
5292 p++;
5294 /* See if it's in the list. */
5295 for (len = p - name, sl = specs; sl; sl = sl->next)
5296 if (sl->name_len == len && !strncmp (sl->name, name, len))
5298 name = *(sl->ptr_spec);
5299 #ifdef DEBUG_SPECS
5300 notice ("Processing spec %c%s%c, which is '%s'\n",
5301 c, sl->name, (c == '(') ? ')' : ']', name);
5302 #endif
5303 break;
5306 if (sl)
5308 if (c == '(')
5310 value = do_spec_1 (name, 0, NULL);
5311 if (value != 0)
5312 return value;
5314 else
5316 char *x = alloca (strlen (name) * 2 + 1);
5317 char *buf = x;
5318 const char *y = name;
5319 int flag = 0;
5321 /* Copy all of NAME into BUF, but put __ after
5322 every -D and at the end of each arg. */
5323 while (1)
5325 if (! strncmp (y, "-D", 2))
5327 *x++ = '-';
5328 *x++ = 'D';
5329 *x++ = '_';
5330 *x++ = '_';
5331 y += 2;
5332 flag = 1;
5333 continue;
5335 else if (flag
5336 && (*y == ' ' || *y == '\t' || *y == '='
5337 || *y == '}' || *y == 0))
5339 *x++ = '_';
5340 *x++ = '_';
5341 flag = 0;
5343 if (*y == 0)
5344 break;
5345 else
5346 *x++ = *y++;
5348 *x = 0;
5350 value = do_spec_1 (buf, 0, NULL);
5351 if (value != 0)
5352 return value;
5356 /* Discard the closing paren or bracket. */
5357 if (*p)
5358 p++;
5360 break;
5362 default:
5363 error ("spec failure: unrecognized spec option '%c'", c);
5364 break;
5366 break;
5368 case '\\':
5369 /* Backslash: treat next character as ordinary. */
5370 c = *p++;
5372 /* Fall through. */
5373 default:
5374 /* Ordinary character: put it into the current argument. */
5375 obstack_1grow (&obstack, c);
5376 arg_going = 1;
5379 /* End of string. If we are processing a spec function, we need to
5380 end any pending argument. */
5381 if (processing_spec_function && arg_going)
5383 obstack_1grow (&obstack, 0);
5384 string = XOBFINISH (&obstack, const char *);
5385 if (this_is_library_file)
5386 string = find_file (string);
5387 store_arg (string, delete_this_arg, this_is_output_file);
5388 if (this_is_output_file)
5389 outfiles[input_file_number] = string;
5390 arg_going = 0;
5393 return 0;
5396 /* Look up a spec function. */
5398 static const struct spec_function *
5399 lookup_spec_function (const char *name)
5401 const struct spec_function *sf;
5403 for (sf = static_spec_functions; sf->name != NULL; sf++)
5404 if (strcmp (sf->name, name) == 0)
5405 return sf;
5407 return NULL;
5410 /* Evaluate a spec function. */
5412 static const char *
5413 eval_spec_function (const char *func, const char *args)
5415 const struct spec_function *sf;
5416 const char *funcval;
5418 /* Saved spec processing context. */
5419 int save_argbuf_index;
5420 int save_argbuf_length;
5421 const char **save_argbuf;
5423 int save_arg_going;
5424 int save_delete_this_arg;
5425 int save_this_is_output_file;
5426 int save_this_is_library_file;
5427 int save_input_from_pipe;
5428 const char *save_suffix_subst;
5431 sf = lookup_spec_function (func);
5432 if (sf == NULL)
5433 fatal ("unknown spec function '%s'", func);
5435 /* Push the spec processing context. */
5436 save_argbuf_index = argbuf_index;
5437 save_argbuf_length = argbuf_length;
5438 save_argbuf = argbuf;
5440 save_arg_going = arg_going;
5441 save_delete_this_arg = delete_this_arg;
5442 save_this_is_output_file = this_is_output_file;
5443 save_this_is_library_file = this_is_library_file;
5444 save_input_from_pipe = input_from_pipe;
5445 save_suffix_subst = suffix_subst;
5447 /* Create a new spec processing context, and build the function
5448 arguments. */
5450 alloc_args ();
5451 if (do_spec_2 (args) < 0)
5452 fatal ("error in args to spec function '%s'", func);
5454 /* argbuf_index is an index for the next argument to be inserted, and
5455 so contains the count of the args already inserted. */
5457 funcval = (*sf->func) (argbuf_index, argbuf);
5459 /* Pop the spec processing context. */
5460 argbuf_index = save_argbuf_index;
5461 argbuf_length = save_argbuf_length;
5462 free (argbuf);
5463 argbuf = save_argbuf;
5465 arg_going = save_arg_going;
5466 delete_this_arg = save_delete_this_arg;
5467 this_is_output_file = save_this_is_output_file;
5468 this_is_library_file = save_this_is_library_file;
5469 input_from_pipe = save_input_from_pipe;
5470 suffix_subst = save_suffix_subst;
5472 return funcval;
5475 /* Handle a spec function call of the form:
5477 %:function(args)
5479 ARGS is processed as a spec in a separate context and split into an
5480 argument vector in the normal fashion. The function returns a string
5481 containing a spec which we then process in the caller's context, or
5482 NULL if no processing is required. */
5484 static const char *
5485 handle_spec_function (const char *p)
5487 char *func, *args;
5488 const char *endp, *funcval;
5489 int count;
5491 processing_spec_function++;
5493 /* Get the function name. */
5494 for (endp = p; *endp != '\0'; endp++)
5496 if (*endp == '(') /* ) */
5497 break;
5498 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5499 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5500 fatal ("malformed spec function name");
5502 if (*endp != '(') /* ) */
5503 fatal ("no arguments for spec function");
5504 func = save_string (p, endp - p);
5505 p = ++endp;
5507 /* Get the arguments. */
5508 for (count = 0; *endp != '\0'; endp++)
5510 /* ( */
5511 if (*endp == ')')
5513 if (count == 0)
5514 break;
5515 count--;
5517 else if (*endp == '(') /* ) */
5518 count++;
5520 /* ( */
5521 if (*endp != ')')
5522 fatal ("malformed spec function arguments");
5523 args = save_string (p, endp - p);
5524 p = ++endp;
5526 /* p now points to just past the end of the spec function expression. */
5528 funcval = eval_spec_function (func, args);
5529 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5530 p = NULL;
5532 free (func);
5533 free (args);
5535 processing_spec_function--;
5537 return p;
5540 /* Inline subroutine of handle_braces. Returns true if the current
5541 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5542 static inline bool
5543 input_suffix_matches (const char *atom, const char *end_atom)
5545 /* We special case the semantics of {.s:...} and {.S:...} and their
5546 negative variants. Instead of testing the input filename suffix,
5547 we test whether the input source file is an assembler file or an
5548 assembler-with-cpp file respectively. This allows us to correctly
5549 handle the -x command line option. */
5551 if (atom + 1 == end_atom
5552 && input_file_compiler
5553 && input_file_compiler->suffix)
5555 if (*atom == 's')
5556 return !strcmp (input_file_compiler->suffix, "@assembler");
5557 if (*atom == 'S')
5558 return !strcmp (input_file_compiler->suffix, "@assembler-with-cpp");
5561 return (input_suffix
5562 && !strncmp (input_suffix, atom, end_atom - atom)
5563 && input_suffix[end_atom - atom] == '\0');
5566 /* Subroutine of handle_braces. Returns true if a switch
5567 matching the atom bracketed by ATOM and END_ATOM appeared on the
5568 command line. */
5569 static bool
5570 switch_matches (const char *atom, const char *end_atom, int starred)
5572 int i;
5573 int len = end_atom - atom;
5574 int plen = starred ? len : -1;
5576 for (i = 0; i < n_switches; i++)
5577 if (!strncmp (switches[i].part1, atom, len)
5578 && (starred || switches[i].part1[len] == '\0')
5579 && check_live_switch (i, plen))
5580 return true;
5582 return false;
5585 /* Inline subroutine of handle_braces. Mark all of the switches which
5586 match ATOM (extends to END_ATOM; STARRED indicates whether there
5587 was a star after the atom) for later processing. */
5588 static inline void
5589 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5591 int i;
5592 int len = end_atom - atom;
5593 int plen = starred ? len : -1;
5595 for (i = 0; i < n_switches; i++)
5596 if (!strncmp (switches[i].part1, atom, len)
5597 && (starred || switches[i].part1[len] == '\0')
5598 && check_live_switch (i, plen))
5599 switches[i].ordering = 1;
5602 /* Inline subroutine of handle_braces. Process all the currently
5603 marked switches through give_switch, and clear the marks. */
5604 static inline void
5605 process_marked_switches (void)
5607 int i;
5609 for (i = 0; i < n_switches; i++)
5610 if (switches[i].ordering == 1)
5612 switches[i].ordering = 0;
5613 give_switch (i, 0);
5617 /* Handle a %{ ... } construct. P points just inside the leading {.
5618 Returns a pointer one past the end of the brace block, or 0
5619 if we call do_spec_1 and that returns -1. */
5621 static const char *
5622 handle_braces (const char *p)
5624 const char *atom, *end_atom;
5625 const char *d_atom = NULL, *d_end_atom = NULL;
5626 const char *orig = p;
5628 bool a_is_suffix;
5629 bool a_is_starred;
5630 bool a_is_negated;
5631 bool a_matched;
5633 bool a_must_be_last = false;
5634 bool ordered_set = false;
5635 bool disjunct_set = false;
5636 bool disj_matched = false;
5637 bool disj_starred = true;
5638 bool n_way_choice = false;
5639 bool n_way_matched = false;
5641 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5645 if (a_must_be_last)
5646 goto invalid;
5648 /* Scan one "atom" (S in the description above of %{}, possibly
5649 with !, ., or * modifiers). */
5650 a_matched = a_is_suffix = a_is_starred = a_is_negated = false;
5652 SKIP_WHITE();
5653 if (*p == '!')
5654 p++, a_is_negated = true;
5656 SKIP_WHITE();
5657 if (*p == '.')
5658 p++, a_is_suffix = true;
5660 atom = p;
5661 while (ISIDNUM(*p) || *p == '-' || *p == '+' || *p == '='
5662 || *p == ',' || *p == '.' || *p == '@')
5663 p++;
5664 end_atom = p;
5666 if (*p == '*')
5667 p++, a_is_starred = 1;
5669 SKIP_WHITE();
5670 switch (*p)
5672 case '&': case '}':
5673 /* Substitute the switch(es) indicated by the current atom. */
5674 ordered_set = true;
5675 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5676 || atom == end_atom)
5677 goto invalid;
5679 mark_matching_switches (atom, end_atom, a_is_starred);
5681 if (*p == '}')
5682 process_marked_switches ();
5683 break;
5685 case '|': case ':':
5686 /* Substitute some text if the current atom appears as a switch
5687 or suffix. */
5688 disjunct_set = true;
5689 if (ordered_set)
5690 goto invalid;
5692 if (atom == end_atom)
5694 if (!n_way_choice || disj_matched || *p == '|'
5695 || a_is_negated || a_is_suffix || a_is_starred)
5696 goto invalid;
5698 /* An empty term may appear as the last choice of an
5699 N-way choice set; it means "otherwise". */
5700 a_must_be_last = true;
5701 disj_matched = !n_way_matched;
5702 disj_starred = false;
5704 else
5706 if (a_is_suffix && a_is_starred)
5707 goto invalid;
5709 if (!a_is_starred)
5710 disj_starred = false;
5712 /* Don't bother testing this atom if we already have a
5713 match. */
5714 if (!disj_matched && !n_way_matched)
5716 if (a_is_suffix)
5717 a_matched = input_suffix_matches (atom, end_atom);
5718 else
5719 a_matched = switch_matches (atom, end_atom, a_is_starred);
5721 if (a_matched != a_is_negated)
5723 disj_matched = true;
5724 d_atom = atom;
5725 d_end_atom = end_atom;
5730 if (*p == ':')
5732 /* Found the body, that is, the text to substitute if the
5733 current disjunction matches. */
5734 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5735 disj_matched && !n_way_matched);
5736 if (p == 0)
5737 return 0;
5739 /* If we have an N-way choice, reset state for the next
5740 disjunction. */
5741 if (*p == ';')
5743 n_way_choice = true;
5744 n_way_matched |= disj_matched;
5745 disj_matched = false;
5746 disj_starred = true;
5747 d_atom = d_end_atom = NULL;
5750 break;
5752 default:
5753 goto invalid;
5756 while (*p++ != '}');
5758 return p;
5760 invalid:
5761 fatal ("braced spec '%s' is invalid at '%c'", orig, *p);
5763 #undef SKIP_WHITE
5766 /* Subroutine of handle_braces. Scan and process a brace substitution body
5767 (X in the description of %{} syntax). P points one past the colon;
5768 ATOM and END_ATOM bracket the first atom which was found to be true
5769 (present) in the current disjunction; STARRED indicates whether all
5770 the atoms in the current disjunction were starred (for syntax validation);
5771 MATCHED indicates whether the disjunction matched or not, and therefore
5772 whether or not the body is to be processed through do_spec_1 or just
5773 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5774 returns -1. */
5776 static const char *
5777 process_brace_body (const char *p, const char *atom, const char *end_atom,
5778 int starred, int matched)
5780 const char *body, *end_body;
5781 unsigned int nesting_level;
5782 bool have_subst = false;
5784 /* Locate the closing } or ;, honoring nested braces.
5785 Trim trailing whitespace. */
5786 body = p;
5787 nesting_level = 1;
5788 for (;;)
5790 if (*p == '{')
5791 nesting_level++;
5792 else if (*p == '}')
5794 if (!--nesting_level)
5795 break;
5797 else if (*p == ';' && nesting_level == 1)
5798 break;
5799 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5800 have_subst = true;
5801 else if (*p == '\0')
5802 goto invalid;
5803 p++;
5806 end_body = p;
5807 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5808 end_body--;
5810 if (have_subst && !starred)
5811 goto invalid;
5813 if (matched)
5815 /* Copy the substitution body to permanent storage and execute it.
5816 If have_subst is false, this is a simple matter of running the
5817 body through do_spec_1... */
5818 char *string = save_string (body, end_body - body);
5819 if (!have_subst)
5821 if (do_spec_1 (string, 0, NULL) < 0)
5822 return 0;
5824 else
5826 /* ... but if have_subst is true, we have to process the
5827 body once for each matching switch, with %* set to the
5828 variant part of the switch. */
5829 unsigned int hard_match_len = end_atom - atom;
5830 int i;
5832 for (i = 0; i < n_switches; i++)
5833 if (!strncmp (switches[i].part1, atom, hard_match_len)
5834 && check_live_switch (i, hard_match_len))
5836 if (do_spec_1 (string, 0,
5837 &switches[i].part1[hard_match_len]) < 0)
5838 return 0;
5839 /* Pass any arguments this switch has. */
5840 give_switch (i, 1);
5841 suffix_subst = NULL;
5846 return p;
5848 invalid:
5849 fatal ("braced spec body '%s' is invalid", body);
5852 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5853 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5854 spec, or -1 if either exact match or %* is used.
5856 A -O switch is obsoleted by a later -O switch. A -f, -m, or -W switch
5857 whose value does not begin with "no-" is obsoleted by the same value
5858 with the "no-", similarly for a switch with the "no-" prefix. */
5860 static int
5861 check_live_switch (int switchnum, int prefix_length)
5863 const char *name = switches[switchnum].part1;
5864 int i;
5866 /* In the common case of {<at-most-one-letter>*}, a negating
5867 switch would always match, so ignore that case. We will just
5868 send the conflicting switches to the compiler phase. */
5869 if (prefix_length >= 0 && prefix_length <= 1)
5870 return 1;
5872 /* If we already processed this switch and determined if it was
5873 live or not, return our past determination. */
5874 if (switches[switchnum].live_cond != 0)
5875 return switches[switchnum].live_cond > 0;
5877 /* Now search for duplicate in a manner that depends on the name. */
5878 switch (*name)
5880 case 'O':
5881 for (i = switchnum + 1; i < n_switches; i++)
5882 if (switches[i].part1[0] == 'O')
5884 switches[switchnum].validated = 1;
5885 switches[switchnum].live_cond = SWITCH_FALSE;
5886 return 0;
5888 break;
5890 case 'W': case 'f': case 'm':
5891 if (! strncmp (name + 1, "no-", 3))
5893 /* We have Xno-YYY, search for XYYY. */
5894 for (i = switchnum + 1; i < n_switches; i++)
5895 if (switches[i].part1[0] == name[0]
5896 && ! strcmp (&switches[i].part1[1], &name[4]))
5898 switches[switchnum].validated = 1;
5899 switches[switchnum].live_cond = SWITCH_FALSE;
5900 return 0;
5903 else
5905 /* We have XYYY, search for Xno-YYY. */
5906 for (i = switchnum + 1; i < n_switches; i++)
5907 if (switches[i].part1[0] == name[0]
5908 && switches[i].part1[1] == 'n'
5909 && switches[i].part1[2] == 'o'
5910 && switches[i].part1[3] == '-'
5911 && !strcmp (&switches[i].part1[4], &name[1]))
5913 switches[switchnum].validated = 1;
5914 switches[switchnum].live_cond = SWITCH_FALSE;
5915 return 0;
5918 break;
5921 /* Otherwise the switch is live. */
5922 switches[switchnum].live_cond = SWITCH_LIVE;
5923 return 1;
5926 /* Pass a switch to the current accumulating command
5927 in the same form that we received it.
5928 SWITCHNUM identifies the switch; it is an index into
5929 the vector of switches gcc received, which is `switches'.
5930 This cannot fail since it never finishes a command line.
5932 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
5934 static void
5935 give_switch (int switchnum, int omit_first_word)
5937 if (switches[switchnum].live_cond == SWITCH_IGNORE)
5938 return;
5940 if (!omit_first_word)
5942 do_spec_1 ("-", 0, NULL);
5943 do_spec_1 (switches[switchnum].part1, 1, NULL);
5946 if (switches[switchnum].args != 0)
5948 const char **p;
5949 for (p = switches[switchnum].args; *p; p++)
5951 const char *arg = *p;
5953 do_spec_1 (" ", 0, NULL);
5954 if (suffix_subst)
5956 unsigned length = strlen (arg);
5957 int dot = 0;
5959 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
5960 if (arg[length] == '.')
5962 ((char *)arg)[length] = 0;
5963 dot = 1;
5964 break;
5966 do_spec_1 (arg, 1, NULL);
5967 if (dot)
5968 ((char *)arg)[length] = '.';
5969 do_spec_1 (suffix_subst, 1, NULL);
5971 else
5972 do_spec_1 (arg, 1, NULL);
5976 do_spec_1 (" ", 0, NULL);
5977 switches[switchnum].validated = 1;
5980 /* Search for a file named NAME trying various prefixes including the
5981 user's -B prefix and some standard ones.
5982 Return the absolute file name found. If nothing is found, return NAME. */
5984 static const char *
5985 find_file (const char *name)
5987 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
5988 return newname ? newname : name;
5991 /* Determine whether a directory exists. If LINKER, return 0 for
5992 certain fixed names not needed by the linker. */
5994 static int
5995 is_directory (const char *path1, bool linker)
5997 int len1;
5998 char *path;
5999 char *cp;
6000 struct stat st;
6002 /* Ensure the string ends with "/.". The resulting path will be a
6003 directory even if the given path is a symbolic link. */
6004 len1 = strlen (path1);
6005 path = alloca (3 + len1);
6006 memcpy (path, path1, len1);
6007 cp = path + len1;
6008 if (!IS_DIR_SEPARATOR (cp[-1]))
6009 *cp++ = DIR_SEPARATOR;
6010 *cp++ = '.';
6011 *cp = '\0';
6013 /* Exclude directories that the linker is known to search. */
6014 if (linker
6015 && IS_DIR_SEPARATOR (path[0])
6016 && ((cp - path == 6
6017 && strncmp (path + 1, "lib", 3) == 0)
6018 || (cp - path == 10
6019 && strncmp (path + 1, "usr", 3) == 0
6020 && IS_DIR_SEPARATOR (path[4])
6021 && strncmp (path + 5, "lib", 3) == 0)))
6022 return 0;
6024 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
6027 /* Set up the various global variables to indicate that we're processing
6028 the input file named FILENAME. */
6030 void
6031 set_input (const char *filename)
6033 const char *p;
6035 input_filename = filename;
6036 input_filename_length = strlen (input_filename);
6038 input_basename = input_filename;
6039 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
6040 /* Skip drive name so 'x:foo' is handled properly. */
6041 if (input_basename[1] == ':')
6042 input_basename += 2;
6043 #endif
6044 for (p = input_basename; *p; p++)
6045 if (IS_DIR_SEPARATOR (*p))
6046 input_basename = p + 1;
6048 /* Find a suffix starting with the last period,
6049 and set basename_length to exclude that suffix. */
6050 basename_length = strlen (input_basename);
6051 suffixed_basename_length = basename_length;
6052 p = input_basename + basename_length;
6053 while (p != input_basename && *p != '.')
6054 --p;
6055 if (*p == '.' && p != input_basename)
6057 basename_length = p - input_basename;
6058 input_suffix = p + 1;
6060 else
6061 input_suffix = "";
6063 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6064 we will need to do a stat on the input_filename. The
6065 INPUT_STAT_SET signals that the stat is needed. */
6066 input_stat_set = 0;
6069 /* On fatal signals, delete all the temporary files. */
6071 static void
6072 fatal_error (int signum)
6074 signal (signum, SIG_DFL);
6075 delete_failure_queue ();
6076 delete_temp_files ();
6077 /* Get the same signal again, this time not handled,
6078 so its normal effect occurs. */
6079 kill (getpid (), signum);
6082 extern int main (int, char **);
6085 main (int argc, char **argv)
6087 size_t i;
6088 int value;
6089 int linker_was_run = 0;
6090 int lang_n_infiles = 0;
6091 int num_linker_inputs = 0;
6092 char *explicit_link_files;
6093 char *specs_file;
6094 const char *p;
6095 struct user_specs *uptr;
6097 p = argv[0] + strlen (argv[0]);
6098 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
6099 --p;
6100 programname = p;
6102 xmalloc_set_program_name (programname);
6104 expandargv (&argc, &argv);
6106 prune_options (&argc, &argv);
6108 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6109 /* Perform host dependent initialization when needed. */
6110 GCC_DRIVER_HOST_INITIALIZATION;
6111 #endif
6113 /* Unlock the stdio streams. */
6114 unlock_std_streams ();
6116 gcc_init_libintl ();
6118 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6119 signal (SIGINT, fatal_error);
6120 #ifdef SIGHUP
6121 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6122 signal (SIGHUP, fatal_error);
6123 #endif
6124 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6125 signal (SIGTERM, fatal_error);
6126 #ifdef SIGPIPE
6127 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6128 signal (SIGPIPE, fatal_error);
6129 #endif
6130 #ifdef SIGCHLD
6131 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6132 receive the signal. A different setting is inheritable */
6133 signal (SIGCHLD, SIG_DFL);
6134 #endif
6136 /* Allocate the argument vector. */
6137 alloc_args ();
6139 obstack_init (&obstack);
6141 /* Build multilib_select, et. al from the separate lines that make up each
6142 multilib selection. */
6144 const char *const *q = multilib_raw;
6145 int need_space;
6147 obstack_init (&multilib_obstack);
6148 while ((p = *q++) != (char *) 0)
6149 obstack_grow (&multilib_obstack, p, strlen (p));
6151 obstack_1grow (&multilib_obstack, 0);
6152 multilib_select = XOBFINISH (&multilib_obstack, const char *);
6154 q = multilib_matches_raw;
6155 while ((p = *q++) != (char *) 0)
6156 obstack_grow (&multilib_obstack, p, strlen (p));
6158 obstack_1grow (&multilib_obstack, 0);
6159 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
6161 q = multilib_exclusions_raw;
6162 while ((p = *q++) != (char *) 0)
6163 obstack_grow (&multilib_obstack, p, strlen (p));
6165 obstack_1grow (&multilib_obstack, 0);
6166 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
6168 need_space = FALSE;
6169 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6171 if (need_space)
6172 obstack_1grow (&multilib_obstack, ' ');
6173 obstack_grow (&multilib_obstack,
6174 multilib_defaults_raw[i],
6175 strlen (multilib_defaults_raw[i]));
6176 need_space = TRUE;
6179 obstack_1grow (&multilib_obstack, 0);
6180 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
6183 /* Set up to remember the pathname of gcc and any options
6184 needed for collect. We use argv[0] instead of programname because
6185 we need the complete pathname. */
6186 obstack_init (&collect_obstack);
6187 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
6188 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
6189 putenv (XOBFINISH (&collect_obstack, char *));
6191 #ifdef INIT_ENVIRONMENT
6192 /* Set up any other necessary machine specific environment variables. */
6193 putenv (INIT_ENVIRONMENT);
6194 #endif
6196 /* Make a table of what switches there are (switches, n_switches).
6197 Make a table of specified input files (infiles, n_infiles).
6198 Decode switches that are handled locally. */
6200 process_command (argc, (const char **) argv);
6202 /* Initialize the vector of specs to just the default.
6203 This means one element containing 0s, as a terminator. */
6205 compilers = xmalloc (sizeof default_compilers);
6206 memcpy (compilers, default_compilers, sizeof default_compilers);
6207 n_compilers = n_default_compilers;
6209 /* Read specs from a file if there is one. */
6211 machine_suffix = concat (spec_machine, dir_separator_str,
6212 spec_version, dir_separator_str, NULL);
6213 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6215 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
6216 /* Read the specs file unless it is a default one. */
6217 if (specs_file != 0 && strcmp (specs_file, "specs"))
6218 read_specs (specs_file, TRUE);
6219 else
6220 init_spec ();
6222 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6223 for any override of as, ld and libraries. */
6224 specs_file = alloca (strlen (standard_exec_prefix)
6225 + strlen (just_machine_suffix) + sizeof ("specs"));
6227 strcpy (specs_file, standard_exec_prefix);
6228 strcat (specs_file, just_machine_suffix);
6229 strcat (specs_file, "specs");
6230 if (access (specs_file, R_OK) == 0)
6231 read_specs (specs_file, TRUE);
6233 /* Process any configure-time defaults specified for the command line
6234 options, via OPTION_DEFAULT_SPECS. */
6235 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6236 do_option_spec (option_default_specs[i].name,
6237 option_default_specs[i].spec);
6239 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6240 of the command line. */
6242 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6243 do_self_spec (driver_self_specs[i]);
6245 /* If not cross-compiling, look for executables in the standard
6246 places. */
6247 if (*cross_compile == '0')
6249 if (*md_exec_prefix)
6251 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6252 PREFIX_PRIORITY_LAST, 0, 0);
6256 /* Process sysroot_suffix_spec. */
6257 if (*sysroot_suffix_spec != 0
6258 && do_spec_2 (sysroot_suffix_spec) == 0)
6260 if (argbuf_index > 1)
6261 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
6262 else if (argbuf_index == 1)
6263 target_sysroot_suffix = xstrdup (argbuf[argbuf_index -1]);
6266 #ifdef HAVE_LD_SYSROOT
6267 /* Pass the --sysroot option to the linker, if it supports that. If
6268 there is a sysroot_suffix_spec, it has already been processed by
6269 this point, so target_system_root really is the system root we
6270 should be using. */
6271 if (target_system_root)
6273 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
6274 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
6275 set_spec ("link", XOBFINISH (&obstack, const char *));
6277 #endif
6279 /* Process sysroot_hdrs_suffix_spec. */
6280 if (*sysroot_hdrs_suffix_spec != 0
6281 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6283 if (argbuf_index > 1)
6284 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
6285 else if (argbuf_index == 1)
6286 target_sysroot_hdrs_suffix = xstrdup (argbuf[argbuf_index -1]);
6289 /* Look for startfiles in the standard places. */
6290 if (*startfile_prefix_spec != 0
6291 && do_spec_2 (startfile_prefix_spec) == 0
6292 && do_spec_1 (" ", 0, NULL) == 0)
6294 int ndx;
6295 for (ndx = 0; ndx < argbuf_index; ndx++)
6296 add_sysrooted_prefix (&startfile_prefixes, argbuf[ndx], "BINUTILS",
6297 PREFIX_PRIORITY_LAST, 0, 1);
6299 /* We should eventually get rid of all these and stick to
6300 startfile_prefix_spec exclusively. */
6301 else if (*cross_compile == '0' || target_system_root)
6303 if (*md_startfile_prefix)
6304 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6305 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6307 if (*md_startfile_prefix_1)
6308 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6309 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6311 /* If standard_startfile_prefix is relative, base it on
6312 standard_exec_prefix. This lets us move the installed tree
6313 as a unit. If GCC_EXEC_PREFIX is defined, base
6314 standard_startfile_prefix on that as well.
6316 If the prefix is relative, only search it for native compilers;
6317 otherwise we will search a directory containing host libraries. */
6318 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6319 add_sysrooted_prefix (&startfile_prefixes,
6320 standard_startfile_prefix, "BINUTILS",
6321 PREFIX_PRIORITY_LAST, 0, 1);
6322 else if (*cross_compile == '0')
6324 add_prefix (&startfile_prefixes,
6325 concat (gcc_exec_prefix
6326 ? gcc_exec_prefix : standard_exec_prefix,
6327 machine_suffix,
6328 standard_startfile_prefix, NULL),
6329 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6332 /* Sysrooted prefixes are relocated because target_system_root is
6333 also relocated by gcc_exec_prefix. */
6334 if (*standard_startfile_prefix_1)
6335 add_sysrooted_prefix (&startfile_prefixes,
6336 standard_startfile_prefix_1, "BINUTILS",
6337 PREFIX_PRIORITY_LAST, 0, 1);
6338 if (*standard_startfile_prefix_2)
6339 add_sysrooted_prefix (&startfile_prefixes,
6340 standard_startfile_prefix_2, "BINUTILS",
6341 PREFIX_PRIORITY_LAST, 0, 1);
6344 /* Process any user specified specs in the order given on the command
6345 line. */
6346 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6348 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6349 R_OK, true);
6350 read_specs (filename ? filename : uptr->filename, FALSE);
6353 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6354 if (gcc_exec_prefix)
6355 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6356 spec_version, dir_separator_str, NULL);
6358 /* Now we have the specs.
6359 Set the `valid' bits for switches that match anything in any spec. */
6361 validate_all_switches ();
6363 /* Now that we have the switches and the specs, set
6364 the subdirectory based on the options. */
6365 set_multilib_dir ();
6367 /* Warn about any switches that no pass was interested in. */
6369 for (i = 0; (int) i < n_switches; i++)
6370 if (! switches[i].validated)
6371 error ("unrecognized option '-%s'", switches[i].part1);
6373 /* Obey some of the options. */
6375 if (print_search_dirs)
6377 printf (_("install: %s%s\n"),
6378 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
6379 gcc_exec_prefix ? "" : machine_suffix);
6380 printf (_("programs: %s\n"),
6381 build_search_list (&exec_prefixes, "", false, false));
6382 printf (_("libraries: %s\n"),
6383 build_search_list (&startfile_prefixes, "", false, true));
6384 return (0);
6387 if (print_file_name)
6389 printf ("%s\n", find_file (print_file_name));
6390 return (0);
6393 if (print_prog_name)
6395 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6396 printf ("%s\n", (newname ? newname : print_prog_name));
6397 return (0);
6400 if (print_multi_lib)
6402 print_multilib_info ();
6403 return (0);
6406 if (print_multi_directory)
6408 if (multilib_dir == NULL)
6409 printf (".\n");
6410 else
6411 printf ("%s\n", multilib_dir);
6412 return (0);
6415 if (print_multi_os_directory)
6417 if (multilib_os_dir == NULL)
6418 printf (".\n");
6419 else
6420 printf ("%s\n", multilib_os_dir);
6421 return (0);
6424 if (target_help_flag)
6426 /* Print if any target specific options. */
6428 /* We do not exit here. Instead we have created a fake input file
6429 called 'target-dummy' which needs to be compiled, and we pass this
6430 on to the various sub-processes, along with the --target-help
6431 switch. */
6434 if (print_help_list)
6436 display_help ();
6438 if (! verbose_flag)
6440 printf (_("\nFor bug reporting instructions, please see:\n"));
6441 printf ("%s.\n", bug_report_url);
6443 return (0);
6446 /* We do not exit here. Instead we have created a fake input file
6447 called 'help-dummy' which needs to be compiled, and we pass this
6448 on the various sub-processes, along with the --help switch. */
6451 if (verbose_flag)
6453 int n;
6454 const char *thrmod;
6456 notice ("Target: %s\n", spec_machine);
6457 notice ("Configured with: %s\n", configuration_arguments);
6459 #ifdef THREAD_MODEL_SPEC
6460 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6461 but there's no point in doing all this processing just to get
6462 thread_model back. */
6463 obstack_init (&obstack);
6464 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6465 obstack_1grow (&obstack, '\0');
6466 thrmod = XOBFINISH (&obstack, const char *);
6467 #else
6468 thrmod = thread_model;
6469 #endif
6471 notice ("Thread model: %s\n", thrmod);
6473 /* compiler_version is truncated at the first space when initialized
6474 from version string, so truncate version_string at the first space
6475 before comparing. */
6476 for (n = 0; version_string[n]; n++)
6477 if (version_string[n] == ' ')
6478 break;
6480 if (! strncmp (version_string, compiler_version, n)
6481 && compiler_version[n] == 0)
6482 notice ("gcc version %s\n", version_string);
6483 else
6484 notice ("gcc driver version %s executing gcc version %s\n",
6485 version_string, compiler_version);
6487 if (n_infiles == 0)
6488 return (0);
6491 if (n_infiles == added_libraries)
6492 fatal ("no input files");
6494 /* Make a place to record the compiler output file names
6495 that correspond to the input files. */
6497 i = n_infiles;
6498 i += lang_specific_extra_outfiles;
6499 outfiles = XCNEWVEC (const char *, i);
6501 /* Record which files were specified explicitly as link input. */
6503 explicit_link_files = XCNEWVEC (char, n_infiles);
6505 if (combine_flag)
6506 combine_inputs = true;
6507 else
6508 combine_inputs = false;
6510 for (i = 0; (int) i < n_infiles; i++)
6512 const char *name = infiles[i].name;
6513 struct compiler *compiler = lookup_compiler (name,
6514 strlen (name),
6515 infiles[i].language);
6517 if (compiler && !(compiler->combinable))
6518 combine_inputs = false;
6520 if (lang_n_infiles > 0 && compiler != input_file_compiler
6521 && infiles[i].language && infiles[i].language[0] != '*')
6522 infiles[i].incompiler = compiler;
6523 else if (compiler)
6525 lang_n_infiles++;
6526 input_file_compiler = compiler;
6527 infiles[i].incompiler = compiler;
6529 else
6531 /* Since there is no compiler for this input file, assume it is a
6532 linker file. */
6533 explicit_link_files[i] = 1;
6534 infiles[i].incompiler = NULL;
6536 infiles[i].compiled = false;
6537 infiles[i].preprocessed = false;
6540 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
6541 fatal ("cannot specify -o with -c or -S with multiple files");
6543 if (combine_flag && save_temps_flag)
6545 bool save_combine_inputs = combine_inputs;
6546 /* Must do a separate pre-processing pass for C & Objective-C files, to
6547 obtain individual .i files. */
6549 combine_inputs = false;
6550 for (i = 0; (int) i < n_infiles; i++)
6552 int this_file_error = 0;
6554 input_file_number = i;
6555 set_input (infiles[i].name);
6556 if (infiles[i].incompiler
6557 && (infiles[i].incompiler)->needs_preprocessing)
6558 input_file_compiler = infiles[i].incompiler;
6559 else
6560 continue;
6562 if (input_file_compiler)
6564 if (input_file_compiler->spec[0] == '#')
6566 error ("%s: %s compiler not installed on this system",
6567 input_filename, &input_file_compiler->spec[1]);
6568 this_file_error = 1;
6570 else
6572 value = do_spec (input_file_compiler->spec);
6573 infiles[i].preprocessed = true;
6574 if (!have_o_argbuf_index)
6575 fatal ("spec '%s' is invalid", input_file_compiler->spec);
6576 infiles[i].name = argbuf[have_o_argbuf_index];
6577 infiles[i].incompiler
6578 = lookup_compiler (infiles[i].name,
6579 strlen (infiles[i].name),
6580 infiles[i].language);
6582 if (value < 0)
6583 this_file_error = 1;
6587 if (this_file_error)
6589 delete_failure_queue ();
6590 error_count++;
6591 break;
6593 clear_failure_queue ();
6595 combine_inputs = save_combine_inputs;
6598 for (i = 0; (int) i < n_infiles; i++)
6600 int this_file_error = 0;
6602 /* Tell do_spec what to substitute for %i. */
6604 input_file_number = i;
6605 set_input (infiles[i].name);
6607 if (infiles[i].compiled)
6608 continue;
6610 /* Use the same thing in %o, unless cp->spec says otherwise. */
6612 outfiles[i] = input_filename;
6614 /* Figure out which compiler from the file's suffix. */
6616 if (! combine_inputs)
6617 input_file_compiler
6618 = lookup_compiler (infiles[i].name, input_filename_length,
6619 infiles[i].language);
6620 else
6621 input_file_compiler = infiles[i].incompiler;
6623 if (input_file_compiler)
6625 /* Ok, we found an applicable compiler. Run its spec. */
6627 if (input_file_compiler->spec[0] == '#')
6629 error ("%s: %s compiler not installed on this system",
6630 input_filename, &input_file_compiler->spec[1]);
6631 this_file_error = 1;
6633 else
6635 value = do_spec (input_file_compiler->spec);
6636 infiles[i].compiled = true;
6637 if (value < 0)
6638 this_file_error = 1;
6642 /* If this file's name does not contain a recognized suffix,
6643 record it as explicit linker input. */
6645 else
6646 explicit_link_files[i] = 1;
6648 /* Clear the delete-on-failure queue, deleting the files in it
6649 if this compilation failed. */
6651 if (this_file_error)
6653 delete_failure_queue ();
6654 error_count++;
6656 /* If this compilation succeeded, don't delete those files later. */
6657 clear_failure_queue ();
6660 /* Reset the input file name to the first compile/object file name, for use
6661 with %b in LINK_SPEC. We use the first input file that we can find
6662 a compiler to compile it instead of using infiles.language since for
6663 languages other than C we use aliases that we then lookup later. */
6664 if (n_infiles > 0)
6666 int i;
6668 for (i = 0; i < n_infiles ; i++)
6669 if (infiles[i].language && infiles[i].language[0] != '*')
6671 set_input (infiles[i].name);
6672 break;
6676 if (error_count == 0)
6678 /* Make sure INPUT_FILE_NUMBER points to first available open
6679 slot. */
6680 input_file_number = n_infiles;
6681 if (lang_specific_pre_link ())
6682 error_count++;
6685 /* Determine if there are any linker input files. */
6686 num_linker_inputs = 0;
6687 for (i = 0; (int) i < n_infiles; i++)
6688 if (explicit_link_files[i] || outfiles[i] != NULL)
6689 num_linker_inputs++;
6691 /* Run ld to link all the compiler output files. */
6693 if (num_linker_inputs > 0 && error_count == 0)
6695 int tmp = execution_count;
6697 /* We'll use ld if we can't find collect2. */
6698 if (! strcmp (linker_name_spec, "collect2"))
6700 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
6701 if (s == NULL)
6702 linker_name_spec = "ld";
6704 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
6705 for collect. */
6706 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
6707 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
6709 value = do_spec (link_command_spec);
6710 if (value < 0)
6711 error_count = 1;
6712 linker_was_run = (tmp != execution_count);
6715 /* If options said don't run linker,
6716 complain about input files to be given to the linker. */
6718 if (! linker_was_run && error_count == 0)
6719 for (i = 0; (int) i < n_infiles; i++)
6720 if (explicit_link_files[i])
6721 error ("%s: linker input file unused because linking not done",
6722 outfiles[i]);
6724 /* Delete some or all of the temporary files we made. */
6726 if (error_count)
6727 delete_failure_queue ();
6728 delete_temp_files ();
6730 if (print_help_list)
6732 printf (("\nFor bug reporting instructions, please see:\n"));
6733 printf ("%s\n", bug_report_url);
6736 return (signal_count != 0 ? 2
6737 : error_count > 0 ? (pass_exit_codes ? greatest_status : 1)
6738 : 0);
6741 /* Find the proper compilation spec for the file name NAME,
6742 whose length is LENGTH. LANGUAGE is the specified language,
6743 or 0 if this file is to be passed to the linker. */
6745 static struct compiler *
6746 lookup_compiler (const char *name, size_t length, const char *language)
6748 struct compiler *cp;
6750 /* If this was specified by the user to be a linker input, indicate that. */
6751 if (language != 0 && language[0] == '*')
6752 return 0;
6754 /* Otherwise, look for the language, if one is spec'd. */
6755 if (language != 0)
6757 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6758 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
6759 return cp;
6761 error ("language %s not recognized", language);
6762 return 0;
6765 /* Look for a suffix. */
6766 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6768 if (/* The suffix `-' matches only the file name `-'. */
6769 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6770 || (strlen (cp->suffix) < length
6771 /* See if the suffix matches the end of NAME. */
6772 && !strcmp (cp->suffix,
6773 name + length - strlen (cp->suffix))
6775 break;
6778 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
6779 /* Look again, but case-insensitively this time. */
6780 if (cp < compilers)
6781 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6783 if (/* The suffix `-' matches only the file name `-'. */
6784 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6785 || (strlen (cp->suffix) < length
6786 /* See if the suffix matches the end of NAME. */
6787 && ((!strcmp (cp->suffix,
6788 name + length - strlen (cp->suffix))
6789 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
6790 && !strcasecmp (cp->suffix,
6791 name + length - strlen (cp->suffix)))
6793 break;
6795 #endif
6797 if (cp >= compilers)
6799 if (cp->spec[0] != '@')
6800 /* A non-alias entry: return it. */
6801 return cp;
6803 /* An alias entry maps a suffix to a language.
6804 Search for the language; pass 0 for NAME and LENGTH
6805 to avoid infinite recursion if language not found. */
6806 return lookup_compiler (NULL, 0, cp->spec + 1);
6808 return 0;
6811 static char *
6812 save_string (const char *s, int len)
6814 char *result = XNEWVEC (char, len + 1);
6816 memcpy (result, s, len);
6817 result[len] = 0;
6818 return result;
6821 void
6822 pfatal_with_name (const char *name)
6824 perror_with_name (name);
6825 delete_temp_files ();
6826 exit (1);
6829 static void
6830 perror_with_name (const char *name)
6832 error ("%s: %s", name, xstrerror (errno));
6835 /* Output an error message and exit. */
6837 void
6838 fancy_abort (const char *file, int line, const char *func)
6840 fatal_ice ("internal gcc abort in %s, at %s:%d", func, file, line);
6843 /* Output an error message and exit. */
6845 void
6846 fatal_ice (const char *cmsgid, ...)
6848 va_list ap;
6850 va_start (ap, cmsgid);
6852 fprintf (stderr, "%s: ", programname);
6853 vfprintf (stderr, _(cmsgid), ap);
6854 va_end (ap);
6855 fprintf (stderr, "\n");
6856 delete_temp_files ();
6857 exit (pass_exit_codes ? ICE_EXIT_CODE : 1);
6860 void
6861 fatal (const char *cmsgid, ...)
6863 va_list ap;
6865 va_start (ap, cmsgid);
6867 fprintf (stderr, "%s: ", programname);
6868 vfprintf (stderr, _(cmsgid), ap);
6869 va_end (ap);
6870 fprintf (stderr, "\n");
6871 delete_temp_files ();
6872 exit (1);
6875 /* The argument is actually c-format, not gcc-internal-format,
6876 but because functions with identical names are used through
6877 the rest of the compiler with gcc-internal-format, we just
6878 need to hope all users of these functions use the common
6879 subset between c-format and gcc-internal-format. */
6881 void
6882 error (const char *gmsgid, ...)
6884 va_list ap;
6886 va_start (ap, gmsgid);
6887 fprintf (stderr, "%s: ", programname);
6888 vfprintf (stderr, _(gmsgid), ap);
6889 va_end (ap);
6891 fprintf (stderr, "\n");
6894 static void
6895 notice (const char *cmsgid, ...)
6897 va_list ap;
6899 va_start (ap, cmsgid);
6900 vfprintf (stderr, _(cmsgid), ap);
6901 va_end (ap);
6904 static inline void
6905 validate_switches_from_spec (const char *spec)
6907 const char *p = spec;
6908 char c;
6909 while ((c = *p++))
6910 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
6911 /* We have a switch spec. */
6912 p = validate_switches (p + 1);
6915 static void
6916 validate_all_switches (void)
6918 struct compiler *comp;
6919 struct spec_list *spec;
6921 for (comp = compilers; comp->spec; comp++)
6922 validate_switches_from_spec (comp->spec);
6924 /* Look through the linked list of specs read from the specs file. */
6925 for (spec = specs; spec; spec = spec->next)
6926 validate_switches_from_spec (*spec->ptr_spec);
6928 validate_switches_from_spec (link_command_spec);
6931 /* Look at the switch-name that comes after START
6932 and mark as valid all supplied switches that match it. */
6934 static const char *
6935 validate_switches (const char *start)
6937 const char *p = start;
6938 const char *atom;
6939 size_t len;
6940 int i;
6941 bool suffix = false;
6942 bool starred = false;
6944 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
6946 next_member:
6947 SKIP_WHITE ();
6949 if (*p == '!')
6950 p++;
6952 SKIP_WHITE ();
6953 if (*p == '.')
6954 suffix = true, p++;
6956 atom = p;
6957 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
6958 || *p == ',' || *p == '.' || *p == '@')
6959 p++;
6960 len = p - atom;
6962 if (*p == '*')
6963 starred = true, p++;
6965 SKIP_WHITE ();
6967 if (!suffix)
6969 /* Mark all matching switches as valid. */
6970 for (i = 0; i < n_switches; i++)
6971 if (!strncmp (switches[i].part1, atom, len)
6972 && (starred || switches[i].part1[len] == 0))
6973 switches[i].validated = 1;
6976 if (*p) p++;
6977 if (*p && (p[-1] == '|' || p[-1] == '&'))
6978 goto next_member;
6980 if (*p && p[-1] == ':')
6982 while (*p && *p != ';' && *p != '}')
6984 if (*p == '%')
6986 p++;
6987 if (*p == '{' || *p == '<')
6988 p = validate_switches (p+1);
6989 else if (p[0] == 'W' && p[1] == '{')
6990 p = validate_switches (p+2);
6992 else
6993 p++;
6996 if (*p) p++;
6997 if (*p && p[-1] == ';')
6998 goto next_member;
7001 return p;
7002 #undef SKIP_WHITE
7005 struct mdswitchstr
7007 const char *str;
7008 int len;
7011 static struct mdswitchstr *mdswitches;
7012 static int n_mdswitches;
7014 /* Check whether a particular argument was used. The first time we
7015 canonicalize the switches to keep only the ones we care about. */
7017 static int
7018 used_arg (const char *p, int len)
7020 struct mswitchstr
7022 const char *str;
7023 const char *replace;
7024 int len;
7025 int rep_len;
7028 static struct mswitchstr *mswitches;
7029 static int n_mswitches;
7030 int i, j;
7032 if (!mswitches)
7034 struct mswitchstr *matches;
7035 const char *q;
7036 int cnt = 0;
7038 /* Break multilib_matches into the component strings of string
7039 and replacement string. */
7040 for (q = multilib_matches; *q != '\0'; q++)
7041 if (*q == ';')
7042 cnt++;
7044 matches = alloca ((sizeof (struct mswitchstr)) * cnt);
7045 i = 0;
7046 q = multilib_matches;
7047 while (*q != '\0')
7049 matches[i].str = q;
7050 while (*q != ' ')
7052 if (*q == '\0')
7054 invalid_matches:
7055 fatal ("multilib spec '%s' is invalid", multilib_matches);
7057 q++;
7059 matches[i].len = q - matches[i].str;
7061 matches[i].replace = ++q;
7062 while (*q != ';' && *q != '\0')
7064 if (*q == ' ')
7065 goto invalid_matches;
7066 q++;
7068 matches[i].rep_len = q - matches[i].replace;
7069 i++;
7070 if (*q == ';')
7071 q++;
7074 /* Now build a list of the replacement string for switches that we care
7075 about. Make sure we allocate at least one entry. This prevents
7076 xmalloc from calling fatal, and prevents us from re-executing this
7077 block of code. */
7078 mswitches
7079 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
7080 for (i = 0; i < n_switches; i++)
7081 if (switches[i].live_cond != SWITCH_IGNORE)
7083 int xlen = strlen (switches[i].part1);
7084 for (j = 0; j < cnt; j++)
7085 if (xlen == matches[j].len
7086 && ! strncmp (switches[i].part1, matches[j].str, xlen))
7088 mswitches[n_mswitches].str = matches[j].replace;
7089 mswitches[n_mswitches].len = matches[j].rep_len;
7090 mswitches[n_mswitches].replace = (char *) 0;
7091 mswitches[n_mswitches].rep_len = 0;
7092 n_mswitches++;
7093 break;
7097 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
7098 on the command line nor any options mutually incompatible with
7099 them. */
7100 for (i = 0; i < n_mdswitches; i++)
7102 const char *r;
7104 for (q = multilib_options; *q != '\0'; q++)
7106 while (*q == ' ')
7107 q++;
7109 r = q;
7110 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
7111 || strchr (" /", q[mdswitches[i].len]) == NULL)
7113 while (*q != ' ' && *q != '/' && *q != '\0')
7114 q++;
7115 if (*q != '/')
7116 break;
7117 q++;
7120 if (*q != ' ' && *q != '\0')
7122 while (*r != ' ' && *r != '\0')
7124 q = r;
7125 while (*q != ' ' && *q != '/' && *q != '\0')
7126 q++;
7128 if (used_arg (r, q - r))
7129 break;
7131 if (*q != '/')
7133 mswitches[n_mswitches].str = mdswitches[i].str;
7134 mswitches[n_mswitches].len = mdswitches[i].len;
7135 mswitches[n_mswitches].replace = (char *) 0;
7136 mswitches[n_mswitches].rep_len = 0;
7137 n_mswitches++;
7138 break;
7141 r = q + 1;
7143 break;
7149 for (i = 0; i < n_mswitches; i++)
7150 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7151 return 1;
7153 return 0;
7156 static int
7157 default_arg (const char *p, int len)
7159 int i;
7161 for (i = 0; i < n_mdswitches; i++)
7162 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7163 return 1;
7165 return 0;
7168 /* Work out the subdirectory to use based on the options. The format of
7169 multilib_select is a list of elements. Each element is a subdirectory
7170 name followed by a list of options followed by a semicolon. The format
7171 of multilib_exclusions is the same, but without the preceding
7172 directory. First gcc will check the exclusions, if none of the options
7173 beginning with an exclamation point are present, and all of the other
7174 options are present, then we will ignore this completely. Passing
7175 that, gcc will consider each multilib_select in turn using the same
7176 rules for matching the options. If a match is found, that subdirectory
7177 will be used. */
7179 static void
7180 set_multilib_dir (void)
7182 const char *p;
7183 unsigned int this_path_len;
7184 const char *this_path, *this_arg;
7185 const char *start, *end;
7186 int not_arg;
7187 int ok, ndfltok, first;
7189 n_mdswitches = 0;
7190 start = multilib_defaults;
7191 while (*start == ' ' || *start == '\t')
7192 start++;
7193 while (*start != '\0')
7195 n_mdswitches++;
7196 while (*start != ' ' && *start != '\t' && *start != '\0')
7197 start++;
7198 while (*start == ' ' || *start == '\t')
7199 start++;
7202 if (n_mdswitches)
7204 int i = 0;
7206 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
7207 for (start = multilib_defaults; *start != '\0'; start = end + 1)
7209 while (*start == ' ' || *start == '\t')
7210 start++;
7212 if (*start == '\0')
7213 break;
7215 for (end = start + 1;
7216 *end != ' ' && *end != '\t' && *end != '\0'; end++)
7219 obstack_grow (&multilib_obstack, start, end - start);
7220 obstack_1grow (&multilib_obstack, 0);
7221 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
7222 mdswitches[i++].len = end - start;
7224 if (*end == '\0')
7225 break;
7229 p = multilib_exclusions;
7230 while (*p != '\0')
7232 /* Ignore newlines. */
7233 if (*p == '\n')
7235 ++p;
7236 continue;
7239 /* Check the arguments. */
7240 ok = 1;
7241 while (*p != ';')
7243 if (*p == '\0')
7245 invalid_exclusions:
7246 fatal ("multilib exclusions '%s' is invalid",
7247 multilib_exclusions);
7250 if (! ok)
7252 ++p;
7253 continue;
7256 this_arg = p;
7257 while (*p != ' ' && *p != ';')
7259 if (*p == '\0')
7260 goto invalid_exclusions;
7261 ++p;
7264 if (*this_arg != '!')
7265 not_arg = 0;
7266 else
7268 not_arg = 1;
7269 ++this_arg;
7272 ok = used_arg (this_arg, p - this_arg);
7273 if (not_arg)
7274 ok = ! ok;
7276 if (*p == ' ')
7277 ++p;
7280 if (ok)
7281 return;
7283 ++p;
7286 first = 1;
7287 p = multilib_select;
7288 while (*p != '\0')
7290 /* Ignore newlines. */
7291 if (*p == '\n')
7293 ++p;
7294 continue;
7297 /* Get the initial path. */
7298 this_path = p;
7299 while (*p != ' ')
7301 if (*p == '\0')
7303 invalid_select:
7304 fatal ("multilib select '%s' is invalid",
7305 multilib_select);
7307 ++p;
7309 this_path_len = p - this_path;
7311 /* Check the arguments. */
7312 ok = 1;
7313 ndfltok = 1;
7314 ++p;
7315 while (*p != ';')
7317 if (*p == '\0')
7318 goto invalid_select;
7320 if (! ok)
7322 ++p;
7323 continue;
7326 this_arg = p;
7327 while (*p != ' ' && *p != ';')
7329 if (*p == '\0')
7330 goto invalid_select;
7331 ++p;
7334 if (*this_arg != '!')
7335 not_arg = 0;
7336 else
7338 not_arg = 1;
7339 ++this_arg;
7342 /* If this is a default argument, we can just ignore it.
7343 This is true even if this_arg begins with '!'. Beginning
7344 with '!' does not mean that this argument is necessarily
7345 inappropriate for this library: it merely means that
7346 there is a more specific library which uses this
7347 argument. If this argument is a default, we need not
7348 consider that more specific library. */
7349 ok = used_arg (this_arg, p - this_arg);
7350 if (not_arg)
7351 ok = ! ok;
7353 if (! ok)
7354 ndfltok = 0;
7356 if (default_arg (this_arg, p - this_arg))
7357 ok = 1;
7359 if (*p == ' ')
7360 ++p;
7363 if (ok && first)
7365 if (this_path_len != 1
7366 || this_path[0] != '.')
7368 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
7369 char *q;
7371 strncpy (new_multilib_dir, this_path, this_path_len);
7372 new_multilib_dir[this_path_len] = '\0';
7373 q = strchr (new_multilib_dir, ':');
7374 if (q != NULL)
7375 *q = '\0';
7376 multilib_dir = new_multilib_dir;
7378 first = 0;
7381 if (ndfltok)
7383 const char *q = this_path, *end = this_path + this_path_len;
7385 while (q < end && *q != ':')
7386 q++;
7387 if (q < end)
7389 char *new_multilib_os_dir = XNEWVEC (char, end - q);
7390 memcpy (new_multilib_os_dir, q + 1, end - q - 1);
7391 new_multilib_os_dir[end - q - 1] = '\0';
7392 multilib_os_dir = new_multilib_os_dir;
7393 break;
7397 ++p;
7400 if (multilib_dir == NULL && multilib_os_dir != NULL
7401 && strcmp (multilib_os_dir, ".") == 0)
7403 free ((char *) multilib_os_dir);
7404 multilib_os_dir = NULL;
7406 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7407 multilib_os_dir = multilib_dir;
7410 /* Print out the multiple library subdirectory selection
7411 information. This prints out a series of lines. Each line looks
7412 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7413 required. Only the desired options are printed out, the negative
7414 matches. The options are print without a leading dash. There are
7415 no spaces to make it easy to use the information in the shell.
7416 Each subdirectory is printed only once. This assumes the ordering
7417 generated by the genmultilib script. Also, we leave out ones that match
7418 the exclusions. */
7420 static void
7421 print_multilib_info (void)
7423 const char *p = multilib_select;
7424 const char *last_path = 0, *this_path;
7425 int skip;
7426 unsigned int last_path_len = 0;
7428 while (*p != '\0')
7430 skip = 0;
7431 /* Ignore newlines. */
7432 if (*p == '\n')
7434 ++p;
7435 continue;
7438 /* Get the initial path. */
7439 this_path = p;
7440 while (*p != ' ')
7442 if (*p == '\0')
7444 invalid_select:
7445 fatal ("multilib select '%s' is invalid", multilib_select);
7448 ++p;
7451 /* When --disable-multilib was used but target defines
7452 MULTILIB_OSDIRNAMES, entries starting with .: are there just
7453 to find multilib_os_dir, so skip them from output. */
7454 if (this_path[0] == '.' && this_path[1] == ':')
7455 skip = 1;
7457 /* Check for matches with the multilib_exclusions. We don't bother
7458 with the '!' in either list. If any of the exclusion rules match
7459 all of its options with the select rule, we skip it. */
7461 const char *e = multilib_exclusions;
7462 const char *this_arg;
7464 while (*e != '\0')
7466 int m = 1;
7467 /* Ignore newlines. */
7468 if (*e == '\n')
7470 ++e;
7471 continue;
7474 /* Check the arguments. */
7475 while (*e != ';')
7477 const char *q;
7478 int mp = 0;
7480 if (*e == '\0')
7482 invalid_exclusion:
7483 fatal ("multilib exclusion '%s' is invalid",
7484 multilib_exclusions);
7487 if (! m)
7489 ++e;
7490 continue;
7493 this_arg = e;
7495 while (*e != ' ' && *e != ';')
7497 if (*e == '\0')
7498 goto invalid_exclusion;
7499 ++e;
7502 q = p + 1;
7503 while (*q != ';')
7505 const char *arg;
7506 int len = e - this_arg;
7508 if (*q == '\0')
7509 goto invalid_select;
7511 arg = q;
7513 while (*q != ' ' && *q != ';')
7515 if (*q == '\0')
7516 goto invalid_select;
7517 ++q;
7520 if (! strncmp (arg, this_arg,
7521 (len < q - arg) ? q - arg : len)
7522 || default_arg (this_arg, e - this_arg))
7524 mp = 1;
7525 break;
7528 if (*q == ' ')
7529 ++q;
7532 if (! mp)
7533 m = 0;
7535 if (*e == ' ')
7536 ++e;
7539 if (m)
7541 skip = 1;
7542 break;
7545 if (*e != '\0')
7546 ++e;
7550 if (! skip)
7552 /* If this is a duplicate, skip it. */
7553 skip = (last_path != 0
7554 && (unsigned int) (p - this_path) == last_path_len
7555 && ! strncmp (last_path, this_path, last_path_len));
7557 last_path = this_path;
7558 last_path_len = p - this_path;
7561 /* If this directory requires any default arguments, we can skip
7562 it. We will already have printed a directory identical to
7563 this one which does not require that default argument. */
7564 if (! skip)
7566 const char *q;
7568 q = p + 1;
7569 while (*q != ';')
7571 const char *arg;
7573 if (*q == '\0')
7574 goto invalid_select;
7576 if (*q == '!')
7577 arg = NULL;
7578 else
7579 arg = q;
7581 while (*q != ' ' && *q != ';')
7583 if (*q == '\0')
7584 goto invalid_select;
7585 ++q;
7588 if (arg != NULL
7589 && default_arg (arg, q - arg))
7591 skip = 1;
7592 break;
7595 if (*q == ' ')
7596 ++q;
7600 if (! skip)
7602 const char *p1;
7604 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
7605 putchar (*p1);
7606 putchar (';');
7609 ++p;
7610 while (*p != ';')
7612 int use_arg;
7614 if (*p == '\0')
7615 goto invalid_select;
7617 if (skip)
7619 ++p;
7620 continue;
7623 use_arg = *p != '!';
7625 if (use_arg)
7626 putchar ('@');
7628 while (*p != ' ' && *p != ';')
7630 if (*p == '\0')
7631 goto invalid_select;
7632 if (use_arg)
7633 putchar (*p);
7634 ++p;
7637 if (*p == ' ')
7638 ++p;
7641 if (! skip)
7643 /* If there are extra options, print them now. */
7644 if (multilib_extra && *multilib_extra)
7646 int print_at = TRUE;
7647 const char *q;
7649 for (q = multilib_extra; *q != '\0'; q++)
7651 if (*q == ' ')
7652 print_at = TRUE;
7653 else
7655 if (print_at)
7656 putchar ('@');
7657 putchar (*q);
7658 print_at = FALSE;
7663 putchar ('\n');
7666 ++p;
7670 /* if-exists built-in spec function.
7672 Checks to see if the file specified by the absolute pathname in
7673 ARGS exists. Returns that pathname if found.
7675 The usual use for this function is to check for a library file
7676 (whose name has been expanded with %s). */
7678 static const char *
7679 if_exists_spec_function (int argc, const char **argv)
7681 /* Must have only one argument. */
7682 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7683 return argv[0];
7685 return NULL;
7688 /* if-exists-else built-in spec function.
7690 This is like if-exists, but takes an additional argument which
7691 is returned if the first argument does not exist. */
7693 static const char *
7694 if_exists_else_spec_function (int argc, const char **argv)
7696 /* Must have exactly two arguments. */
7697 if (argc != 2)
7698 return NULL;
7700 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7701 return argv[0];
7703 return argv[1];
7706 /* replace-outfile built-in spec function.
7708 This looks for the first argument in the outfiles array's name and
7709 replaces it with the second argument. */
7711 static const char *
7712 replace_outfile_spec_function (int argc, const char **argv)
7714 int i;
7715 /* Must have exactly two arguments. */
7716 if (argc != 2)
7717 abort ();
7719 for (i = 0; i < n_infiles; i++)
7721 if (outfiles[i] && !strcmp (outfiles[i], argv[0]))
7722 outfiles[i] = xstrdup (argv[1]);
7724 return NULL;
7727 /* Given two version numbers, compares the two numbers.
7728 A version number must match the regular expression
7729 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
7731 static int
7732 compare_version_strings (const char *v1, const char *v2)
7734 int rresult;
7735 regex_t r;
7737 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
7738 REG_EXTENDED | REG_NOSUB) != 0)
7739 abort ();
7740 rresult = regexec (&r, v1, 0, NULL, 0);
7741 if (rresult == REG_NOMATCH)
7742 fatal ("invalid version number `%s'", v1);
7743 else if (rresult != 0)
7744 abort ();
7745 rresult = regexec (&r, v2, 0, NULL, 0);
7746 if (rresult == REG_NOMATCH)
7747 fatal ("invalid version number `%s'", v2);
7748 else if (rresult != 0)
7749 abort ();
7751 return strverscmp (v1, v2);
7755 /* version_compare built-in spec function.
7757 This takes an argument of the following form:
7759 <comparison-op> <arg1> [<arg2>] <switch> <result>
7761 and produces "result" if the comparison evaluates to true,
7762 and nothing if it doesn't.
7764 The supported <comparison-op> values are:
7766 >= true if switch is a later (or same) version than arg1
7767 !> opposite of >=
7768 < true if switch is an earlier version than arg1
7769 !< opposite of <
7770 >< true if switch is arg1 or later, and earlier than arg2
7771 <> true if switch is earlier than arg1 or is arg2 or later
7773 If the switch is not present, the condition is false unless
7774 the first character of the <comparison-op> is '!'.
7776 For example,
7777 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
7778 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
7780 static const char *
7781 version_compare_spec_function (int argc, const char **argv)
7783 int comp1, comp2;
7784 size_t switch_len;
7785 const char *switch_value = NULL;
7786 int nargs = 1, i;
7787 bool result;
7789 if (argc < 3)
7790 fatal ("too few arguments to %%:version-compare");
7791 if (argv[0][0] == '\0')
7792 abort ();
7793 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
7794 nargs = 2;
7795 if (argc != nargs + 3)
7796 fatal ("too many arguments to %%:version-compare");
7798 switch_len = strlen (argv[nargs + 1]);
7799 for (i = 0; i < n_switches; i++)
7800 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
7801 && check_live_switch (i, switch_len))
7802 switch_value = switches[i].part1 + switch_len;
7804 if (switch_value == NULL)
7805 comp1 = comp2 = -1;
7806 else
7808 comp1 = compare_version_strings (switch_value, argv[1]);
7809 if (nargs == 2)
7810 comp2 = compare_version_strings (switch_value, argv[2]);
7811 else
7812 comp2 = -1; /* This value unused. */
7815 switch (argv[0][0] << 8 | argv[0][1])
7817 case '>' << 8 | '=':
7818 result = comp1 >= 0;
7819 break;
7820 case '!' << 8 | '<':
7821 result = comp1 >= 0 || switch_value == NULL;
7822 break;
7823 case '<' << 8:
7824 result = comp1 < 0;
7825 break;
7826 case '!' << 8 | '>':
7827 result = comp1 < 0 || switch_value == NULL;
7828 break;
7829 case '>' << 8 | '<':
7830 result = comp1 >= 0 && comp2 < 0;
7831 break;
7832 case '<' << 8 | '>':
7833 result = comp1 < 0 || comp2 >= 0;
7834 break;
7836 default:
7837 fatal ("unknown operator '%s' in %%:version-compare", argv[0]);
7839 if (! result)
7840 return NULL;
7842 return argv[nargs + 2];
7845 /* %:include builtin spec function. This differs from %include in that it
7846 can be nested inside a spec, and thus be conditionalized. It takes
7847 one argument, the filename, and looks for it in the startfile path.
7848 The result is always NULL, i.e. an empty expansion. */
7850 static const char *
7851 include_spec_function (int argc, const char **argv)
7853 char *file;
7855 if (argc != 1)
7856 abort ();
7858 file = find_a_file (&startfile_prefixes, argv[0], R_OK, 0);
7859 read_specs (file ? file : argv[0], FALSE);
7861 return NULL;