Merge -r 127928:132243 from trunk
[official-gcc.git] / gcc / gcc.c
blobb63c0da1d1aa6593aa98ee1cf2437d70c2b5e2c7
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
3 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007
4 Free Software Foundation, 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 3, 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 COPYING3. If not see
20 <http://www.gnu.org/licenses/>.
22 This paragraph is here to try to keep Sun CC from dying.
23 The number of chars here seems crucial!!!! */
25 /* This program is the user interface to the C compiler and possibly to
26 other compilers. It is used because compilation is a complicated procedure
27 which involves running several programs and passing temporary files between
28 them, forwarding the users switches to those programs selectively,
29 and deleting the temporary files at the end.
31 CC recognizes how to compile each input file by suffixes in the file names.
32 Once it knows which kind of compilation to perform, the procedure for
33 compilation is specified by a string called a "spec". */
35 /* A Short Introduction to Adding a Command-Line Option.
37 Before adding a command-line option, consider if it is really
38 necessary. Each additional command-line option adds complexity and
39 is difficult to remove in subsequent versions.
41 In the following, consider adding the command-line argument
42 `--bar'.
44 1. Each command-line option is specified in the specs file. The
45 notation is described below in the comment entitled "The Specs
46 Language". Read it.
48 2. In this file, add an entry to "option_map" equating the long
49 `--' argument version and any shorter, single letter version. Read
50 the comments in the declaration of "struct option_map" for an
51 explanation. Do not omit the first `-'.
53 3. Look in the "specs" file to determine which program or option
54 list should be given the argument, e.g., "cc1_options". Add the
55 appropriate syntax for the shorter option version to the
56 corresponding "const char *" entry in this file. Omit the first
57 `-' from the option. For example, use `-bar', rather than `--bar'.
59 4. If the argument takes an argument, e.g., `--baz argument1',
60 modify either DEFAULT_SWITCH_TAKES_ARG or
61 DEFAULT_WORD_SWITCH_TAKES_ARG in gcc.h. Omit the first `-'
62 from `--baz'.
64 5. Document the option in this file's display_help(). If the
65 option is passed to a subprogram, modify its corresponding
66 function, e.g., cppinit.c:print_help() or toplev.c:display_help(),
67 instead.
69 6. Compile and test. Make sure that your new specs file is being
70 read. For example, use a debugger to investigate the value of
71 "specs_file" in main(). */
73 #include "config.h"
74 #include "system.h"
75 #include "coretypes.h"
76 #include "multilib.h" /* before tm.h */
77 #include "tm.h"
78 #include <signal.h>
79 #if ! defined( SIGCHLD ) && defined( SIGCLD )
80 # define SIGCHLD SIGCLD
81 #endif
82 #include "xregex.h"
83 #include "obstack.h"
84 #include "intl.h"
85 #include "prefix.h"
86 #include "gcc.h"
87 #include "flags.h"
88 #include "opts.h"
90 /* By default there is no special suffix for target executables. */
91 /* FIXME: when autoconf is fixed, remove the host check - dj */
92 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
93 #define HAVE_TARGET_EXECUTABLE_SUFFIX
94 #endif
96 /* By default there is no special suffix for host executables. */
97 #ifdef HOST_EXECUTABLE_SUFFIX
98 #define HAVE_HOST_EXECUTABLE_SUFFIX
99 #else
100 #define HOST_EXECUTABLE_SUFFIX ""
101 #endif
103 /* By default, the suffix for target object files is ".o". */
104 #ifdef TARGET_OBJECT_SUFFIX
105 #define HAVE_TARGET_OBJECT_SUFFIX
106 #else
107 #define TARGET_OBJECT_SUFFIX ".o"
108 #endif
110 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
112 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
113 #ifndef LIBRARY_PATH_ENV
114 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
115 #endif
117 #ifndef HAVE_KILL
118 #define kill(p,s) raise(s)
119 #endif
121 /* If a stage of compilation returns an exit status >= 1,
122 compilation of that file ceases. */
124 #define MIN_FATAL_STATUS 1
126 /* Flag set by cppspec.c to 1. */
127 int is_cpp_driver;
129 /* Flag set to nonzero if an @file argument has been supplied to gcc. */
130 static bool at_file_supplied;
132 /* Flag saying to pass the greatest exit code returned by a sub-process
133 to the calling program. */
134 static int pass_exit_codes;
136 /* Definition of string containing the arguments given to configure. */
137 #include "configargs.h"
139 /* Flag saying to print the directories gcc will search through looking for
140 programs, libraries, etc. */
142 static int print_search_dirs;
144 /* Flag saying to print the full filename of this file
145 as found through our usual search mechanism. */
147 static const char *print_file_name = NULL;
149 /* As print_file_name, but search for executable file. */
151 static const char *print_prog_name = NULL;
153 /* Flag saying to print the relative path we'd use to
154 find libgcc.a given the current compiler flags. */
156 static int print_multi_directory;
158 /* Flag saying to print the relative path we'd use to
159 find OS libraries given the current compiler flags. */
161 static int print_multi_os_directory;
163 /* Flag saying to print the list of subdirectories and
164 compiler flags used to select them in a standard form. */
166 static int print_multi_lib;
168 /* Flag saying to print the command line options understood by gcc and its
169 sub-processes. */
171 static int print_help_list;
173 /* Flag saying to print the sysroot suffix used for searching for
174 headers. */
176 static int print_sysroot_headers_suffix;
178 /* Flag indicating whether we should print the command and arguments */
180 static int verbose_flag;
182 /* Flag indicating whether we should ONLY print the command and
183 arguments (like verbose_flag) without executing the command.
184 Displayed arguments are quoted so that the generated command
185 line is suitable for execution. This is intended for use in
186 shell scripts to capture the driver-generated command line. */
187 static int verbose_only_flag;
189 /* Flag indicating how to print command line options of sub-processes. */
191 static int print_subprocess_help;
193 /* Flag indicating whether we should report subprocess execution times
194 (if this is supported by the system - see pexecute.c). */
196 static int report_times;
198 /* Nonzero means place this string before uses of /, so that include
199 and library files can be found in an alternate location. */
201 #ifdef TARGET_SYSTEM_ROOT
202 static const char *target_system_root = TARGET_SYSTEM_ROOT;
203 #else
204 static const char *target_system_root = 0;
205 #endif
207 /* Nonzero means pass the updated target_system_root to the compiler. */
209 static int target_system_root_changed;
211 /* Nonzero means append this string to target_system_root. */
213 static const char *target_sysroot_suffix = 0;
215 /* Nonzero means append this string to target_system_root for headers. */
217 static const char *target_sysroot_hdrs_suffix = 0;
219 /* Nonzero means write "temp" files in source directory
220 and use the source file's name in them, and don't delete them. */
222 static int save_temps_flag;
224 /* Nonzero means pass multiple source files to the compiler at one time. */
226 static int combine_flag = 0;
228 /* Nonzero means use pipes to communicate between subprocesses.
229 Overridden by either of the above two flags. */
231 static int use_pipes;
233 /* The compiler version. */
235 static const char *compiler_version;
237 /* The target version specified with -V */
239 static const char *const spec_version = DEFAULT_TARGET_VERSION;
241 /* The target machine specified with -b. */
243 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
245 /* Nonzero if cross-compiling.
246 When -b is used, the value comes from the `specs' file. */
248 #ifdef CROSS_DIRECTORY_STRUCTURE
249 static const char *cross_compile = "1";
250 #else
251 static const char *cross_compile = "0";
252 #endif
254 #ifdef MODIFY_TARGET_NAME
256 /* Information on how to alter the target name based on a command-line
257 switch. The only case we support now is simply appending or deleting a
258 string to or from the end of the first part of the configuration name. */
260 static const struct modify_target
262 const char *const sw;
263 const enum add_del {ADD, DELETE} add_del;
264 const char *const str;
266 modify_target[] = MODIFY_TARGET_NAME;
267 #endif
269 /* The number of errors that have occurred; the link phase will not be
270 run if this is nonzero. */
271 static int error_count = 0;
273 /* Greatest exit code of sub-processes that has been encountered up to
274 now. */
275 static int greatest_status = 1;
277 /* This is the obstack which we use to allocate many strings. */
279 static struct obstack obstack;
281 /* This is the obstack to build an environment variable to pass to
282 collect2 that describes all of the relevant switches of what to
283 pass the compiler in building the list of pointers to constructors
284 and destructors. */
286 static struct obstack collect_obstack;
288 /* Forward declaration for prototypes. */
289 struct path_prefix;
290 struct prefix_list;
292 static void init_spec (void);
293 static void store_arg (const char *, int, int);
294 static char *load_specs (const char *);
295 static void read_specs (const char *, int);
296 static void set_spec (const char *, const char *);
297 static struct compiler *lookup_compiler (const char *, size_t, const char *);
298 static char *build_search_list (const struct path_prefix *, const char *,
299 bool, bool);
300 static void xputenv (const char *);
301 static void putenv_from_prefixes (const struct path_prefix *, const char *,
302 bool);
303 static int access_check (const char *, int);
304 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
305 static void add_prefix (struct path_prefix *, const char *, const char *,
306 int, int, int);
307 static void add_sysrooted_prefix (struct path_prefix *, const char *,
308 const char *, int, int, int);
309 static void translate_options (int *, const char *const **);
310 static char *skip_whitespace (char *);
311 static void delete_if_ordinary (const char *);
312 static void delete_temp_files (void);
313 static void delete_failure_queue (void);
314 static void clear_failure_queue (void);
315 static int check_live_switch (int, int);
316 static const char *handle_braces (const char *);
317 static inline bool input_suffix_matches (const char *, const char *);
318 static inline bool switch_matches (const char *, const char *, int);
319 static inline void mark_matching_switches (const char *, const char *, int);
320 static inline void process_marked_switches (void);
321 static const char *process_brace_body (const char *, const char *, const char *, int, int);
322 static const struct spec_function *lookup_spec_function (const char *);
323 static const char *eval_spec_function (const char *, const char *);
324 static const char *handle_spec_function (const char *);
325 static char *save_string (const char *, int);
326 static void set_collect_gcc_options (void);
327 static int do_spec_1 (const char *, int, const char *);
328 static int do_spec_2 (const char *);
329 static void do_option_spec (const char *, const char *);
330 static void do_self_spec (const char *);
331 static const char *find_file (const char *);
332 static int is_directory (const char *, bool);
333 static const char *validate_switches (const char *);
334 static void validate_all_switches (void);
335 static inline void validate_switches_from_spec (const char *);
336 static void give_switch (int, int);
337 static int used_arg (const char *, int);
338 static int default_arg (const char *, int);
339 static void set_multilib_dir (void);
340 static void print_multilib_info (void);
341 static void perror_with_name (const char *);
342 static void fatal_ice (const char *, ...) ATTRIBUTE_PRINTF_1 ATTRIBUTE_NORETURN;
343 static void notice (const char *, ...) ATTRIBUTE_PRINTF_1;
344 static void display_help (void);
345 static void add_preprocessor_option (const char *, int);
346 static void add_assembler_option (const char *, int);
347 static void add_linker_option (const char *, int);
348 static void process_command (int, const char **);
349 static int execute (void);
350 static void alloc_args (void);
351 static void clear_args (void);
352 static void fatal_error (int);
353 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
354 static void init_gcc_specs (struct obstack *, const char *, const char *,
355 const char *);
356 #endif
357 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
358 static const char *convert_filename (const char *, int, int);
359 #endif
361 static const char *getenv_spec_function (int, const char **);
362 static const char *if_exists_spec_function (int, const char **);
363 static const char *if_exists_else_spec_function (int, const char **);
364 static const char *replace_outfile_spec_function (int, const char **);
365 static const char *version_compare_spec_function (int, const char **);
366 static const char *include_spec_function (int, const char **);
367 static const char *print_asm_header_spec_function (int, const char **);
369 /* The Specs Language
371 Specs are strings containing lines, each of which (if not blank)
372 is made up of a program name, and arguments separated by spaces.
373 The program name must be exact and start from root, since no path
374 is searched and it is unreliable to depend on the current working directory.
375 Redirection of input or output is not supported; the subprograms must
376 accept filenames saying what files to read and write.
378 In addition, the specs can contain %-sequences to substitute variable text
379 or for conditional text. Here is a table of all defined %-sequences.
380 Note that spaces are not generated automatically around the results of
381 expanding these sequences; therefore, you can concatenate them together
382 or with constant text in a single argument.
384 %% substitute one % into the program name or argument.
385 %i substitute the name of the input file being processed.
386 %b substitute the basename of the input file being processed.
387 This is the substring up to (and not including) the last period
388 and not including the directory.
389 %B same as %b, but include the file suffix (text after the last period).
390 %gSUFFIX
391 substitute a file name that has suffix SUFFIX and is chosen
392 once per compilation, and mark the argument a la %d. To reduce
393 exposure to denial-of-service attacks, the file name is now
394 chosen in a way that is hard to predict even when previously
395 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
396 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
397 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
398 had been pre-processed. Previously, %g was simply substituted
399 with a file name chosen once per compilation, without regard
400 to any appended suffix (which was therefore treated just like
401 ordinary text), making such attacks more likely to succeed.
402 %|SUFFIX
403 like %g, but if -pipe is in effect, expands simply to "-".
404 %mSUFFIX
405 like %g, but if -pipe is in effect, expands to nothing. (We have both
406 %| and %m to accommodate differences between system assemblers; see
407 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
408 %uSUFFIX
409 like %g, but generates a new temporary file name even if %uSUFFIX
410 was already seen.
411 %USUFFIX
412 substitutes the last file name generated with %uSUFFIX, generating a
413 new one if there is no such last file name. In the absence of any
414 %uSUFFIX, this is just like %gSUFFIX, except they don't share
415 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
416 would involve the generation of two distinct file names, one
417 for each `%g.s' and another for each `%U.s'. Previously, %U was
418 simply substituted with a file name chosen for the previous %u,
419 without regard to any appended suffix.
420 %jSUFFIX
421 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
422 writable, and if save-temps is off; otherwise, substitute the name
423 of a temporary file, just like %u. This temporary file is not
424 meant for communication between processes, but rather as a junk
425 disposal mechanism.
426 %.SUFFIX
427 substitutes .SUFFIX for the suffixes of a matched switch's args when
428 it is subsequently output with %*. SUFFIX is terminated by the next
429 space or %.
430 %d marks the argument containing or following the %d as a
431 temporary file name, so that that file will be deleted if CC exits
432 successfully. Unlike %g, this contributes no text to the argument.
433 %w marks the argument containing or following the %w as the
434 "output file" of this compilation. This puts the argument
435 into the sequence of arguments that %o will substitute later.
436 %V indicates that this compilation produces no "output file".
437 %W{...}
438 like %{...} but mark last argument supplied within
439 as a file to be deleted on failure.
440 %o substitutes the names of all the output files, with spaces
441 automatically placed around them. You should write spaces
442 around the %o as well or the results are undefined.
443 %o is for use in the specs for running the linker.
444 Input files whose names have no recognized suffix are not compiled
445 at all, but they are included among the output files, so they will
446 be linked.
447 %O substitutes the suffix for object files. Note that this is
448 handled specially when it immediately follows %g, %u, or %U
449 (with or without a suffix argument) because of the need for
450 those to form complete file names. The handling is such that
451 %O is treated exactly as if it had already been substituted,
452 except that %g, %u, and %U do not currently support additional
453 SUFFIX characters following %O as they would following, for
454 example, `.o'.
455 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
456 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
457 and -B options) and -imultilib as necessary.
458 %s current argument is the name of a library or startup file of some sort.
459 Search for that file in a standard list of directories
460 and substitute the full name found.
461 %eSTR Print STR as an error message. STR is terminated by a newline.
462 Use this when inconsistent options are detected.
463 %nSTR Print STR as a notice. STR is terminated by a newline.
464 %x{OPTION} Accumulate an option for %X.
465 %X Output the accumulated linker options specified by compilations.
466 %Y Output the accumulated assembler options specified by compilations.
467 %Z Output the accumulated preprocessor options specified by compilations.
468 %a process ASM_SPEC as a spec.
469 This allows config.h to specify part of the spec for running as.
470 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
471 used here. This can be used to run a post-processor after the
472 assembler has done its job.
473 %D Dump out a -L option for each directory in startfile_prefixes.
474 If multilib_dir is set, extra entries are generated with it affixed.
475 %l process LINK_SPEC as a spec.
476 %L process LIB_SPEC as a spec.
477 %G process LIBGCC_SPEC as a spec.
478 %R Output the concatenation of target_system_root and
479 target_sysroot_suffix.
480 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
481 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
482 %C process CPP_SPEC as a spec.
483 %1 process CC1_SPEC as a spec.
484 %2 process CC1PLUS_SPEC as a spec.
485 %* substitute the variable part of a matched option. (See below.)
486 Note that each comma in the substituted string is replaced by
487 a single space.
488 %<S remove all occurrences of -S from the command line.
489 Note - this command is position dependent. % commands in the
490 spec string before this one will see -S, % commands in the
491 spec string after this one will not.
492 %<S* remove all occurrences of all switches beginning with -S from the
493 command line.
494 %:function(args)
495 Call the named function FUNCTION, passing it ARGS. ARGS is
496 first processed as a nested spec string, then split into an
497 argument vector in the usual fashion. The function returns
498 a string which is processed as if it had appeared literally
499 as part of the current spec.
500 %{S} substitutes the -S switch, if that switch was given to CC.
501 If that switch was not specified, this substitutes nothing.
502 Here S is a metasyntactic variable.
503 %{S*} substitutes all the switches specified to CC whose names start
504 with -S. This is used for -o, -I, etc; switches that take
505 arguments. CC considers `-o foo' as being one switch whose
506 name starts with `o'. %{o*} would substitute this text,
507 including the space; thus, two arguments would be generated.
508 %{S*&T*} likewise, but preserve order of S and T options (the order
509 of S and T in the spec is not significant). Can be any number
510 of ampersand-separated variables; for each the wild card is
511 optional. Useful for CPP as %{D*&U*&A*}.
513 %{S:X} substitutes X, if the -S switch was given to CC.
514 %{!S:X} substitutes X, if the -S switch was NOT given to CC.
515 %{S*:X} substitutes X if one or more switches whose names start
516 with -S was given to CC. Normally X is substituted only
517 once, no matter how many such switches appeared. However,
518 if %* appears somewhere in X, then X will be substituted
519 once for each matching switch, with the %* replaced by the
520 part of that switch that matched the '*'.
521 %{.S:X} substitutes X, if processing a file with suffix S.
522 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
523 %{,S:X} substitutes X, if processing a file which will use spec S.
524 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
526 %{S|T:X} substitutes X if either -S or -T was given to CC. This may be
527 combined with '!', '.', ',', and '*' as above binding stronger
528 than the OR.
529 If %* appears in X, all of the alternatives must be starred, and
530 only the first matching alternative is substituted.
531 %{S:X; if S was given to CC, substitutes X;
532 T:Y; else if T was given to CC, substitutes Y;
533 :D} else substitutes D. There can be as many clauses as you need.
534 This may be combined with '.', '!', ',', '|', and '*' as above.
536 %(Spec) processes a specification defined in a specs file as *Spec:
537 %[Spec] as above, but put __ around -D arguments
539 The conditional text X in a %{S:X} or similar construct may contain
540 other nested % constructs or spaces, or even newlines. They are
541 processed as usual, as described above. Trailing white space in X is
542 ignored. White space may also appear anywhere on the left side of the
543 colon in these constructs, except between . or * and the corresponding
544 word.
546 The -O, -f, -m, and -W switches are handled specifically in these
547 constructs. If another value of -O or the negated form of a -f, -m, or
548 -W switch is found later in the command line, the earlier switch
549 value is ignored, except with {S*} where S is just one letter; this
550 passes all matching options.
552 The character | at the beginning of the predicate text is used to indicate
553 that a command should be piped to the following command, but only if -pipe
554 is specified.
556 Note that it is built into CC which switches take arguments and which
557 do not. You might think it would be useful to generalize this to
558 allow each compiler's spec to say which switches take arguments. But
559 this cannot be done in a consistent fashion. CC cannot even decide
560 which input files have been specified without knowing which switches
561 take arguments, and it must know which input files to compile in order
562 to tell which compilers to run.
564 CC also knows implicitly that arguments starting in `-l' are to be
565 treated as compiler output files, and passed to the linker in their
566 proper position among the other output files. */
568 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
570 /* config.h can define ASM_SPEC to provide extra args to the assembler
571 or extra switch-translations. */
572 #ifndef ASM_SPEC
573 #define ASM_SPEC ""
574 #endif
576 /* config.h can define ASM_FINAL_SPEC to run a post processor after
577 the assembler has run. */
578 #ifndef ASM_FINAL_SPEC
579 #define ASM_FINAL_SPEC ""
580 #endif
582 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
583 or extra switch-translations. */
584 #ifndef CPP_SPEC
585 #define CPP_SPEC ""
586 #endif
588 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
589 or extra switch-translations. */
590 #ifndef CC1_SPEC
591 #define CC1_SPEC ""
592 #endif
594 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
595 or extra switch-translations. */
596 #ifndef CC1PLUS_SPEC
597 #define CC1PLUS_SPEC ""
598 #endif
600 /* config.h can define LINK_SPEC to provide extra args to the linker
601 or extra switch-translations. */
602 #ifndef LINK_SPEC
603 #define LINK_SPEC ""
604 #endif
606 /* config.h can define LIB_SPEC to override the default libraries. */
607 #ifndef LIB_SPEC
608 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
609 #endif
611 /* mudflap specs */
612 #ifndef MFWRAP_SPEC
613 /* XXX: valid only for GNU ld */
614 /* XXX: should exactly match hooks provided by libmudflap.a */
615 #define MFWRAP_SPEC " %{static: %{fmudflap|fmudflapth: \
616 --wrap=malloc --wrap=free --wrap=calloc --wrap=realloc\
617 --wrap=mmap --wrap=munmap --wrap=alloca\
618 } %{fmudflapth: --wrap=pthread_create\
619 }} %{fmudflap|fmudflapth: --wrap=main}"
620 #endif
621 #ifndef MFLIB_SPEC
622 #define MFLIB_SPEC "%{fmudflap|fmudflapth: -export-dynamic}"
623 #endif
625 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
626 included. */
627 #ifndef LIBGCC_SPEC
628 #if defined(REAL_LIBGCC_SPEC)
629 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
630 #elif defined(LINK_LIBGCC_SPECIAL_1)
631 /* Have gcc do the search for libgcc.a. */
632 #define LIBGCC_SPEC "libgcc.a%s"
633 #else
634 #define LIBGCC_SPEC "-lgcc"
635 #endif
636 #endif
638 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
639 #ifndef STARTFILE_SPEC
640 #define STARTFILE_SPEC \
641 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
642 #endif
644 /* config.h can define SWITCHES_NEED_SPACES to control which options
645 require spaces between the option and the argument. */
646 #ifndef SWITCHES_NEED_SPACES
647 #define SWITCHES_NEED_SPACES ""
648 #endif
650 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
651 #ifndef ENDFILE_SPEC
652 #define ENDFILE_SPEC ""
653 #endif
655 #ifndef LINKER_NAME
656 #define LINKER_NAME "collect2"
657 #endif
659 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
660 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
661 #else
662 #define ASM_MAP ""
663 #endif
665 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
666 to the assembler. */
667 #ifndef ASM_DEBUG_SPEC
668 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
669 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
670 # define ASM_DEBUG_SPEC \
671 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
672 ? "%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}" ASM_MAP \
673 : "%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}" ASM_MAP)
674 # else
675 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
676 # define ASM_DEBUG_SPEC "%{g*:--gstabs}" ASM_MAP
677 # endif
678 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
679 # define ASM_DEBUG_SPEC "%{g*:--gdwarf2}" ASM_MAP
680 # endif
681 # endif
682 #endif
683 #ifndef ASM_DEBUG_SPEC
684 # define ASM_DEBUG_SPEC ""
685 #endif
687 /* Here is the spec for running the linker, after compiling all files. */
689 /* This is overridable by the target in case they need to specify the
690 -lgcc and -lc order specially, yet not require them to override all
691 of LINK_COMMAND_SPEC. */
692 #ifndef LINK_GCC_C_SEQUENCE_SPEC
693 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
694 #endif
696 #ifndef LINK_SSP_SPEC
697 #ifdef TARGET_LIBC_PROVIDES_SSP
698 #define LINK_SSP_SPEC "%{fstack-protector:}"
699 #else
700 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all:-lssp_nonshared -lssp}"
701 #endif
702 #endif
704 #ifndef LINK_PIE_SPEC
705 #ifdef HAVE_LD_PIE
706 #define LINK_PIE_SPEC "%{pie:-pie} "
707 #else
708 #define LINK_PIE_SPEC "%{pie:} "
709 #endif
710 #endif
712 /* -u* was put back because both BSD and SysV seem to support it. */
713 /* %{static:} simply prevents an error message if the target machine
714 doesn't handle -static. */
715 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
716 scripts which exist in user specified directories, or in standard
717 directories. */
718 #ifndef LINK_COMMAND_SPEC
719 #define LINK_COMMAND_SPEC "\
720 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
721 %(linker) %l " LINK_PIE_SPEC "%X %{o*} %{A} %{d} %{e*} %{m} %{N} %{n} %{r}\
722 %{s} %{t} %{u*} %{x} %{z} %{Z} %{!A:%{!nostdlib:%{!nostartfiles:%S}}}\
723 %{static:} %{L*} %(mfwrap) %(link_libgcc) %o\
724 %{fopenmp|ftree-parallelize-loops=*:%:include(libgomp.spec)%(link_gomp)} %(mflib)\
725 %{fprofile-arcs|fprofile-generate|coverage:-lgcov}\
726 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
727 %{!A:%{!nostdlib:%{!nostartfiles:%E}}} %{T*} }}}}}}"
728 #endif
730 #ifndef LINK_LIBGCC_SPEC
731 /* Generate -L options for startfile prefix list. */
732 # define LINK_LIBGCC_SPEC "%D"
733 #endif
735 #ifndef STARTFILE_PREFIX_SPEC
736 # define STARTFILE_PREFIX_SPEC ""
737 #endif
739 #ifndef SYSROOT_SPEC
740 # define SYSROOT_SPEC "--sysroot=%R"
741 #endif
743 #ifndef SYSROOT_SUFFIX_SPEC
744 # define SYSROOT_SUFFIX_SPEC ""
745 #endif
747 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
748 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
749 #endif
751 static const char *asm_debug;
752 static const char *cpp_spec = CPP_SPEC;
753 static const char *cc1_spec = CC1_SPEC;
754 static const char *cc1plus_spec = CC1PLUS_SPEC;
755 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
756 static const char *link_ssp_spec = LINK_SSP_SPEC;
757 static const char *asm_spec = ASM_SPEC;
758 static const char *asm_final_spec = ASM_FINAL_SPEC;
759 static const char *link_spec = LINK_SPEC;
760 static const char *lib_spec = LIB_SPEC;
761 static const char *mfwrap_spec = MFWRAP_SPEC;
762 static const char *mflib_spec = MFLIB_SPEC;
763 static const char *link_gomp_spec = "";
764 static const char *libgcc_spec = LIBGCC_SPEC;
765 static const char *endfile_spec = ENDFILE_SPEC;
766 static const char *startfile_spec = STARTFILE_SPEC;
767 static const char *switches_need_spaces = SWITCHES_NEED_SPACES;
768 static const char *linker_name_spec = LINKER_NAME;
769 static const char *link_command_spec = LINK_COMMAND_SPEC;
770 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
771 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
772 static const char *sysroot_spec = SYSROOT_SPEC;
773 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
774 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
776 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
777 There should be no need to override these in target dependent files,
778 but we need to copy them to the specs file so that newer versions
779 of the GCC driver can correctly drive older tool chains with the
780 appropriate -B options. */
782 /* When cpplib handles traditional preprocessing, get rid of this, and
783 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
784 that we default the front end language better. */
785 static const char *trad_capable_cpp =
786 "cc1 -E %{traditional|ftraditional|traditional-cpp:-traditional-cpp}";
788 /* We don't wrap .d files in %W{} since a missing .d file, and
789 therefore no dependency entry, confuses make into thinking a .o
790 file that happens to exist is up-to-date. */
791 static const char *cpp_unique_options =
792 "%{C|CC:%{!E:%eGCC does not support -C or -CC without -E}}\
793 %{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
794 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
795 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
796 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
797 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
798 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
799 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
800 %{fmudflap:-D_MUDFLAP -include mf-runtime.h}\
801 %{fmudflapth:-D_MUDFLAP -D_MUDFLAPTH -include mf-runtime.h}\
802 %{E|M|MM:%W{o*}}";
804 /* This contains cpp options which are common with cc1_options and are passed
805 only when preprocessing only to avoid duplication. We pass the cc1 spec
806 options to the preprocessor so that it the cc1 spec may manipulate
807 options used to set target flags. Those special target flags settings may
808 in turn cause preprocessor symbols to be defined specially. */
809 static const char *cpp_options =
810 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
811 %{f*} %{g*:%{!g0:%{!fno-working-directory:-fworking-directory}}} %{O*}\
812 %{undef} %{save-temps:-fpch-preprocess}";
814 /* This contains cpp options which are not passed when the preprocessor
815 output will be used by another program. */
816 static const char *cpp_debug_options = "%{d*}";
818 /* NB: This is shared amongst all front-ends. */
819 static const char *cc1_options =
820 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
821 %1 %{!Q:-quiet} -dumpbase %B %{d*} %{m*} %{a*}\
822 %{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}%{!c:%{!S:-auxbase %b}}\
823 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
824 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
825 %{Qn:-fno-ident} %{--help:--help}\
826 %{--target-help:--target-help}\
827 %{--help=*:--help=%(VALUE)}\
828 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
829 %{fsyntax-only:-o %j} %{-param*}\
830 %{fmudflap|fmudflapth:-fno-builtin -fno-merge-constants}\
831 %{coverage:-fprofile-arcs -ftest-coverage}";
833 static const char *asm_options =
834 "%{--target-help:%:print-asm-header()} "
835 #if HAVE_GNU_AS
836 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
837 to the assembler equivalents. */
838 "%{v} %{w:-W} %{I*} "
839 #endif
840 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
842 static const char *invoke_as =
843 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
844 "%{!S:-o %|.s |\n as %(asm_options) %|.s %A }";
845 #else
846 "%{!S:-o %|.s |\n as %(asm_options) %m.s %A }";
847 #endif
849 /* Some compilers have limits on line lengths, and the multilib_select
850 and/or multilib_matches strings can be very long, so we build them at
851 run time. */
852 static struct obstack multilib_obstack;
853 static const char *multilib_select;
854 static const char *multilib_matches;
855 static const char *multilib_defaults;
856 static const char *multilib_exclusions;
858 /* Check whether a particular argument is a default argument. */
860 #ifndef MULTILIB_DEFAULTS
861 #define MULTILIB_DEFAULTS { "" }
862 #endif
864 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
866 #ifndef DRIVER_SELF_SPECS
867 #define DRIVER_SELF_SPECS ""
868 #endif
870 /* Adding -fopenmp should imply pthreads. This is particularly important
871 for targets that use different start files and suchlike. */
872 #ifndef GOMP_SELF_SPECS
873 #define GOMP_SELF_SPECS "%{fopenmp|ftree-parallelize-loops=*: -pthread}"
874 #endif
876 static const char *const driver_self_specs[] = {
877 DRIVER_SELF_SPECS, GOMP_SELF_SPECS
880 #ifndef OPTION_DEFAULT_SPECS
881 #define OPTION_DEFAULT_SPECS { "", "" }
882 #endif
884 struct default_spec
886 const char *name;
887 const char *spec;
890 static const struct default_spec
891 option_default_specs[] = { OPTION_DEFAULT_SPECS };
893 struct user_specs
895 struct user_specs *next;
896 const char *filename;
899 static struct user_specs *user_specs_head, *user_specs_tail;
901 #ifndef SWITCH_TAKES_ARG
902 #define SWITCH_TAKES_ARG(CHAR) DEFAULT_SWITCH_TAKES_ARG(CHAR)
903 #endif
905 #ifndef WORD_SWITCH_TAKES_ARG
906 #define WORD_SWITCH_TAKES_ARG(STR) DEFAULT_WORD_SWITCH_TAKES_ARG (STR)
907 #endif
909 #ifdef HAVE_TARGET_EXECUTABLE_SUFFIX
910 /* This defines which switches stop a full compilation. */
911 #define DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR) \
912 ((CHAR) == 'c' || (CHAR) == 'S')
914 #ifndef SWITCH_CURTAILS_COMPILATION
915 #define SWITCH_CURTAILS_COMPILATION(CHAR) \
916 DEFAULT_SWITCH_CURTAILS_COMPILATION(CHAR)
917 #endif
918 #endif
920 /* Record the mapping from file suffixes for compilation specs. */
922 struct compiler
924 const char *suffix; /* Use this compiler for input files
925 whose names end in this suffix. */
927 const char *spec; /* To use this compiler, run this spec. */
929 const char *cpp_spec; /* If non-NULL, substitute this spec
930 for `%C', rather than the usual
931 cpp_spec. */
932 const int combinable; /* If nonzero, compiler can deal with
933 multiple source files at once (IMA). */
934 const int needs_preprocessing; /* If nonzero, source files need to
935 be run through a preprocessor. */
938 /* Pointer to a vector of `struct compiler' that gives the spec for
939 compiling a file, based on its suffix.
940 A file that does not end in any of these suffixes will be passed
941 unchanged to the loader and nothing else will be done to it.
943 An entry containing two 0s is used to terminate the vector.
945 If multiple entries match a file, the last matching one is used. */
947 static struct compiler *compilers;
949 /* Number of entries in `compilers', not counting the null terminator. */
951 static int n_compilers;
953 /* The default list of file name suffixes and their compilation specs. */
955 static const struct compiler default_compilers[] =
957 /* Add lists of suffixes of known languages here. If those languages
958 were not present when we built the driver, we will hit these copies
959 and be given a more meaningful error than "file not used since
960 linking is not done". */
961 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
962 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
963 {".mii", "#Objective-C++", 0, 0, 0},
964 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
965 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
966 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
967 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
968 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
969 {".f", "#Fortran", 0, 0, 0}, {".for", "#Fortran", 0, 0, 0},
970 {".fpp", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
971 {".FOR", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
972 {".f90", "#Fortran", 0, 0, 0}, {".f95", "#Fortran", 0, 0, 0},
973 {".F90", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
974 {".r", "#Ratfor", 0, 0, 0},
975 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
976 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
977 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
978 /* Next come the entries for C. */
979 {".c", "@c", 0, 1, 1},
980 {"@c",
981 /* cc1 has an integrated ISO C preprocessor. We should invoke the
982 external preprocessor if -save-temps is given. */
983 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
984 %{!E:%{!M:%{!MM:\
985 %{traditional|ftraditional:\
986 %eGNU C no longer supports -traditional without -E}\
987 %{!combine:\
988 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
989 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i} \n\
990 cc1 -fpreprocessed %{save-temps:%b.i} %{!save-temps:%g.i} \
991 %(cc1_options)}\
992 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
993 cc1 %(cpp_unique_options) %(cc1_options)}}}\
994 %{!fsyntax-only:%(invoke_as)}} \
995 %{combine:\
996 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
997 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i}}\
998 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
999 cc1 %(cpp_unique_options) %(cc1_options)}}\
1000 %{!fsyntax-only:%(invoke_as)}}}}}}", 0, 1, 1},
1001 {"-",
1002 "%{!E:%e-E or -x required when input is from standard input}\
1003 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1004 {".h", "@c-header", 0, 0, 0},
1005 {"@c-header",
1006 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1007 external preprocessor if -save-temps is given. */
1008 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1009 %{!E:%{!M:%{!MM:\
1010 %{save-temps|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1011 %(cpp_options) -o %{save-temps:%b.i} %{!save-temps:%g.i} \n\
1012 cc1 -fpreprocessed %{save-temps:%b.i} %{!save-temps:%g.i} \
1013 %(cc1_options)\
1014 -o %g.s %{!o*:--output-pch=%i.gch}\
1015 %W{o*:--output-pch=%*}%V}\
1016 %{!save-temps:%{!traditional-cpp:%{!no-integrated-cpp:\
1017 cc1 %(cpp_unique_options) %(cc1_options)\
1018 -o %g.s %{!o*:--output-pch=%i.gch}\
1019 %W{o*:--output-pch=%*}%V}}}}}}", 0, 0, 0},
1020 {".i", "@cpp-output", 0, 1, 0},
1021 {"@cpp-output",
1022 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 1, 0},
1023 {".s", "@assembler", 0, 1, 0},
1024 {"@assembler",
1025 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 1, 0},
1026 {".sx", "@assembler-with-cpp", 0, 1, 0},
1027 {".S", "@assembler-with-cpp", 0, 1, 0},
1028 {"@assembler-with-cpp",
1029 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1030 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1031 %{E|M|MM:%(cpp_debug_options)}\
1032 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1033 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1034 #else
1035 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1036 %{E|M|MM:%(cpp_debug_options)}\
1037 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1038 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1039 #endif
1040 , 0, 1, 0},
1042 #include "specs.h"
1043 /* Mark end of table. */
1044 {0, 0, 0, 0, 0}
1047 /* Number of elements in default_compilers, not counting the terminator. */
1049 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1051 /* A vector of options to give to the linker.
1052 These options are accumulated by %x,
1053 and substituted into the linker command with %X. */
1054 static int n_linker_options;
1055 static char **linker_options;
1057 /* A vector of options to give to the assembler.
1058 These options are accumulated by -Wa,
1059 and substituted into the assembler command with %Y. */
1060 static int n_assembler_options;
1061 static char **assembler_options;
1063 /* A vector of options to give to the preprocessor.
1064 These options are accumulated by -Wp,
1065 and substituted into the preprocessor command with %Z. */
1066 static int n_preprocessor_options;
1067 static char **preprocessor_options;
1069 /* Define how to map long options into short ones. */
1071 /* This structure describes one mapping. */
1072 struct option_map
1074 /* The long option's name. */
1075 const char *const name;
1076 /* The equivalent short option. */
1077 const char *const equivalent;
1078 /* Argument info. A string of flag chars; NULL equals no options.
1079 a => argument required.
1080 o => argument optional.
1081 j => join argument to equivalent, making one word.
1082 * => require other text after NAME as an argument. */
1083 const char *const arg_info;
1086 /* This is the table of mappings. Mappings are tried sequentially
1087 for each option encountered; the first one that matches, wins. */
1089 static const struct option_map option_map[] =
1091 {"--all-warnings", "-Wall", 0},
1092 {"--ansi", "-ansi", 0},
1093 {"--assemble", "-S", 0},
1094 {"--assert", "-A", "a"},
1095 {"--classpath", "-fclasspath=", "aj"},
1096 {"--bootclasspath", "-fbootclasspath=", "aj"},
1097 {"--CLASSPATH", "-fclasspath=", "aj"},
1098 {"--combine", "-combine", 0},
1099 {"--comments", "-C", 0},
1100 {"--comments-in-macros", "-CC", 0},
1101 {"--compile", "-c", 0},
1102 {"--debug", "-g", "oj"},
1103 {"--define-macro", "-D", "aj"},
1104 {"--dependencies", "-M", 0},
1105 {"--dump", "-d", "a"},
1106 {"--dumpbase", "-dumpbase", "a"},
1107 {"--encoding", "-fencoding=", "aj"},
1108 {"--entry", "-e", 0},
1109 {"--extra-warnings", "-W", 0},
1110 {"--extdirs", "-fextdirs=", "aj"},
1111 {"--for-assembler", "-Wa", "a"},
1112 {"--for-linker", "-Xlinker", "a"},
1113 {"--force-link", "-u", "a"},
1114 {"--coverage", "-coverage", 0},
1115 {"--imacros", "-imacros", "a"},
1116 {"--include", "-include", "a"},
1117 {"--include-barrier", "-I-", 0},
1118 {"--include-directory", "-I", "aj"},
1119 {"--include-directory-after", "-idirafter", "a"},
1120 {"--include-prefix", "-iprefix", "a"},
1121 {"--include-with-prefix", "-iwithprefix", "a"},
1122 {"--include-with-prefix-before", "-iwithprefixbefore", "a"},
1123 {"--include-with-prefix-after", "-iwithprefix", "a"},
1124 {"--language", "-x", "a"},
1125 {"--library-directory", "-L", "a"},
1126 {"--machine", "-m", "aj"},
1127 {"--machine-", "-m", "*j"},
1128 {"--no-integrated-cpp", "-no-integrated-cpp", 0},
1129 {"--no-line-commands", "-P", 0},
1130 {"--no-precompiled-includes", "-noprecomp", 0},
1131 {"--no-standard-includes", "-nostdinc", 0},
1132 {"--no-standard-libraries", "-nostdlib", 0},
1133 {"--no-warnings", "-w", 0},
1134 {"--optimize", "-O", "oj"},
1135 {"--output", "-o", "a"},
1136 {"--output-class-directory", "-foutput-class-dir=", "ja"},
1137 {"--param", "--param", "a"},
1138 {"--pass-exit-codes", "-pass-exit-codes", 0},
1139 {"--pedantic", "-pedantic", 0},
1140 {"--pedantic-errors", "-pedantic-errors", 0},
1141 {"--pie", "-pie", 0},
1142 {"--pipe", "-pipe", 0},
1143 {"--prefix", "-B", "a"},
1144 {"--preprocess", "-E", 0},
1145 {"--print-search-dirs", "-print-search-dirs", 0},
1146 {"--print-file-name", "-print-file-name=", "aj"},
1147 {"--print-libgcc-file-name", "-print-libgcc-file-name", 0},
1148 {"--print-missing-file-dependencies", "-MG", 0},
1149 {"--print-multi-lib", "-print-multi-lib", 0},
1150 {"--print-multi-directory", "-print-multi-directory", 0},
1151 {"--print-multi-os-directory", "-print-multi-os-directory", 0},
1152 {"--print-prog-name", "-print-prog-name=", "aj"},
1153 {"--print-sysroot-headers-suffix", "-print-sysroot-headers-suffix", 0},
1154 {"--profile", "-p", 0},
1155 {"--profile-blocks", "-a", 0},
1156 {"--quiet", "-q", 0},
1157 {"--resource", "-fcompile-resource=", "aj"},
1158 {"--save-temps", "-save-temps", 0},
1159 {"--shared", "-shared", 0},
1160 {"--silent", "-q", 0},
1161 {"--specs", "-specs=", "aj"},
1162 {"--static", "-static", 0},
1163 {"--std", "-std=", "aj"},
1164 {"--symbolic", "-symbolic", 0},
1165 {"--sysroot", "--sysroot=", "aj"},
1166 {"--time", "-time", 0},
1167 {"--trace-includes", "-H", 0},
1168 {"--traditional", "-traditional", 0},
1169 {"--traditional-cpp", "-traditional-cpp", 0},
1170 {"--trigraphs", "-trigraphs", 0},
1171 {"--undefine-macro", "-U", "aj"},
1172 {"--user-dependencies", "-MM", 0},
1173 {"--verbose", "-v", 0},
1174 {"--warn-", "-W", "*j"},
1175 {"--write-dependencies", "-MD", 0},
1176 {"--write-user-dependencies", "-MMD", 0},
1177 {"--", "-f", "*j"}
1181 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1182 static const struct {
1183 const char *const option_found;
1184 const char *const replacements;
1185 } target_option_translations[] =
1187 TARGET_OPTION_TRANSLATE_TABLE,
1188 { 0, 0 }
1190 #endif
1192 /* Translate the options described by *ARGCP and *ARGVP.
1193 Make a new vector and store it back in *ARGVP,
1194 and store its length in *ARGVC. */
1196 static void
1197 translate_options (int *argcp, const char *const **argvp)
1199 int i;
1200 int argc = *argcp;
1201 const char *const *argv = *argvp;
1202 int newvsize = (argc + 2) * 2 * sizeof (const char *);
1203 const char **newv = xmalloc (newvsize);
1204 int newindex = 0;
1206 i = 0;
1207 newv[newindex++] = argv[i++];
1209 while (i < argc)
1211 #ifdef TARGET_OPTION_TRANSLATE_TABLE
1212 int tott_idx;
1214 for (tott_idx = 0;
1215 target_option_translations[tott_idx].option_found;
1216 tott_idx++)
1218 if (strcmp (target_option_translations[tott_idx].option_found,
1219 argv[i]) == 0)
1221 int spaces = 1;
1222 const char *sp;
1223 char *np;
1225 for (sp = target_option_translations[tott_idx].replacements;
1226 *sp; sp++)
1228 if (*sp == ' ')
1229 spaces ++;
1232 newvsize += spaces * sizeof (const char *);
1233 newv = xrealloc (newv, newvsize);
1235 sp = target_option_translations[tott_idx].replacements;
1236 np = xstrdup (sp);
1238 while (1)
1240 while (*np == ' ')
1241 np++;
1242 if (*np == 0)
1243 break;
1244 newv[newindex++] = np;
1245 while (*np != ' ' && *np)
1246 np++;
1247 if (*np == 0)
1248 break;
1249 *np++ = 0;
1252 i ++;
1253 break;
1256 if (target_option_translations[tott_idx].option_found)
1257 continue;
1258 #endif
1260 /* Translate -- options. */
1261 if (argv[i][0] == '-' && argv[i][1] == '-')
1263 size_t j;
1264 /* Find a mapping that applies to this option. */
1265 for (j = 0; j < ARRAY_SIZE (option_map); j++)
1267 size_t optlen = strlen (option_map[j].name);
1268 size_t arglen = strlen (argv[i]);
1269 size_t complen = arglen > optlen ? optlen : arglen;
1270 const char *arginfo = option_map[j].arg_info;
1272 if (arginfo == 0)
1273 arginfo = "";
1275 if (!strncmp (argv[i], option_map[j].name, complen))
1277 const char *arg = 0;
1279 if (arglen < optlen)
1281 size_t k;
1282 for (k = j + 1; k < ARRAY_SIZE (option_map); k++)
1283 if (strlen (option_map[k].name) >= arglen
1284 && !strncmp (argv[i], option_map[k].name, arglen))
1286 error ("ambiguous abbreviation %s", argv[i]);
1287 break;
1290 if (k != ARRAY_SIZE (option_map))
1291 break;
1294 if (arglen > optlen)
1296 /* If the option has an argument, accept that. */
1297 if (argv[i][optlen] == '=')
1298 arg = argv[i] + optlen + 1;
1300 /* If this mapping requires extra text at end of name,
1301 accept that as "argument". */
1302 else if (strchr (arginfo, '*') != 0)
1303 arg = argv[i] + optlen;
1305 /* Otherwise, extra text at end means mismatch.
1306 Try other mappings. */
1307 else
1308 continue;
1311 else if (strchr (arginfo, '*') != 0)
1313 error ("incomplete '%s' option", option_map[j].name);
1314 break;
1317 /* Handle arguments. */
1318 if (strchr (arginfo, 'a') != 0)
1320 if (arg == 0)
1322 if (i + 1 == argc)
1324 error ("missing argument to '%s' option",
1325 option_map[j].name);
1326 break;
1329 arg = argv[++i];
1332 else if (strchr (arginfo, '*') != 0)
1334 else if (strchr (arginfo, 'o') == 0)
1336 if (arg != 0)
1337 error ("extraneous argument to '%s' option",
1338 option_map[j].name);
1339 arg = 0;
1342 /* Store the translation as one argv elt or as two. */
1343 if (arg != 0 && strchr (arginfo, 'j') != 0)
1344 newv[newindex++] = concat (option_map[j].equivalent, arg,
1345 NULL);
1346 else if (arg != 0)
1348 newv[newindex++] = option_map[j].equivalent;
1349 newv[newindex++] = arg;
1351 else
1352 newv[newindex++] = option_map[j].equivalent;
1354 break;
1357 i++;
1360 /* Handle old-fashioned options--just copy them through,
1361 with their arguments. */
1362 else if (argv[i][0] == '-')
1364 const char *p = argv[i] + 1;
1365 int c = *p;
1366 int nskip = 1;
1368 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
1369 nskip += SWITCH_TAKES_ARG (c) - (p[1] != 0);
1370 else if (WORD_SWITCH_TAKES_ARG (p))
1371 nskip += WORD_SWITCH_TAKES_ARG (p);
1372 else if ((c == 'B' || c == 'b' || c == 'x')
1373 && p[1] == 0)
1374 nskip += 1;
1375 else if (! strcmp (p, "Xlinker"))
1376 nskip += 1;
1377 else if (! strcmp (p, "Xpreprocessor"))
1378 nskip += 1;
1379 else if (! strcmp (p, "Xassembler"))
1380 nskip += 1;
1382 /* Watch out for an option at the end of the command line that
1383 is missing arguments, and avoid skipping past the end of the
1384 command line. */
1385 if (nskip + i > argc)
1386 nskip = argc - i;
1388 while (nskip > 0)
1390 newv[newindex++] = argv[i++];
1391 nskip--;
1394 else
1395 /* Ordinary operands, or +e options. */
1396 newv[newindex++] = argv[i++];
1399 newv[newindex] = 0;
1401 *argvp = newv;
1402 *argcp = newindex;
1405 static char *
1406 skip_whitespace (char *p)
1408 while (1)
1410 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1411 be considered whitespace. */
1412 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1413 return p + 1;
1414 else if (*p == '\n' || *p == ' ' || *p == '\t')
1415 p++;
1416 else if (*p == '#')
1418 while (*p != '\n')
1419 p++;
1420 p++;
1422 else
1423 break;
1426 return p;
1428 /* Structures to keep track of prefixes to try when looking for files. */
1430 struct prefix_list
1432 const char *prefix; /* String to prepend to the path. */
1433 struct prefix_list *next; /* Next in linked list. */
1434 int require_machine_suffix; /* Don't use without machine_suffix. */
1435 /* 2 means try both machine_suffix and just_machine_suffix. */
1436 int priority; /* Sort key - priority within list. */
1437 int os_multilib; /* 1 if OS multilib scheme should be used,
1438 0 for GCC multilib scheme. */
1441 struct path_prefix
1443 struct prefix_list *plist; /* List of prefixes to try */
1444 int max_len; /* Max length of a prefix in PLIST */
1445 const char *name; /* Name of this list (used in config stuff) */
1448 /* List of prefixes to try when looking for executables. */
1450 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1452 /* List of prefixes to try when looking for startup (crt0) files. */
1454 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1456 /* List of prefixes to try when looking for include files. */
1458 static struct path_prefix include_prefixes = { 0, 0, "include" };
1460 /* Suffix to attach to directories searched for commands.
1461 This looks like `MACHINE/VERSION/'. */
1463 static const char *machine_suffix = 0;
1465 /* Suffix to attach to directories searched for commands.
1466 This is just `MACHINE/'. */
1468 static const char *just_machine_suffix = 0;
1470 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1472 static const char *gcc_exec_prefix;
1474 /* Adjusted value of standard_libexec_prefix. */
1476 static const char *gcc_libexec_prefix;
1478 /* Default prefixes to attach to command names. */
1480 #ifndef STANDARD_STARTFILE_PREFIX_1
1481 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1482 #endif
1483 #ifndef STANDARD_STARTFILE_PREFIX_2
1484 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1485 #endif
1487 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1488 #undef MD_EXEC_PREFIX
1489 #undef MD_STARTFILE_PREFIX
1490 #undef MD_STARTFILE_PREFIX_1
1491 #endif
1493 /* If no prefixes defined, use the null string, which will disable them. */
1494 #ifndef MD_EXEC_PREFIX
1495 #define MD_EXEC_PREFIX ""
1496 #endif
1497 #ifndef MD_STARTFILE_PREFIX
1498 #define MD_STARTFILE_PREFIX ""
1499 #endif
1500 #ifndef MD_STARTFILE_PREFIX_1
1501 #define MD_STARTFILE_PREFIX_1 ""
1502 #endif
1504 /* These directories are locations set at configure-time based on the
1505 --prefix option provided to configure. Their initializers are
1506 defined in Makefile.in. These paths are not *directly* used when
1507 gcc_exec_prefix is set because, in that case, we know where the
1508 compiler has been installed, and use paths relative to that
1509 location instead. */
1510 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1511 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1512 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1513 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1515 /* For native compilers, these are well-known paths containing
1516 components that may be provided by the system. For cross
1517 compilers, these paths are not used. */
1518 static const char *const standard_exec_prefix_1 = "/usr/libexec/gcc/";
1519 static const char *const standard_exec_prefix_2 = "/usr/lib/gcc/";
1520 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1521 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1522 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1523 static const char *const standard_startfile_prefix_1
1524 = STANDARD_STARTFILE_PREFIX_1;
1525 static const char *const standard_startfile_prefix_2
1526 = STANDARD_STARTFILE_PREFIX_2;
1528 /* A relative path to be used in finding the location of tools
1529 relative to the driver. */
1530 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1532 /* Subdirectory to use for locating libraries. Set by
1533 set_multilib_dir based on the compilation options. */
1535 static const char *multilib_dir;
1537 /* Subdirectory to use for locating libraries in OS conventions. Set by
1538 set_multilib_dir based on the compilation options. */
1540 static const char *multilib_os_dir;
1542 /* Structure to keep track of the specs that have been defined so far.
1543 These are accessed using %(specname) or %[specname] in a compiler
1544 or link spec. */
1546 struct spec_list
1548 /* The following 2 fields must be first */
1549 /* to allow EXTRA_SPECS to be initialized */
1550 const char *name; /* name of the spec. */
1551 const char *ptr; /* available ptr if no static pointer */
1553 /* The following fields are not initialized */
1554 /* by EXTRA_SPECS */
1555 const char **ptr_spec; /* pointer to the spec itself. */
1556 struct spec_list *next; /* Next spec in linked list. */
1557 int name_len; /* length of the name */
1558 int alloc_p; /* whether string was allocated */
1561 #define INIT_STATIC_SPEC(NAME,PTR) \
1562 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, 0 }
1564 /* List of statically defined specs. */
1565 static struct spec_list static_specs[] =
1567 INIT_STATIC_SPEC ("asm", &asm_spec),
1568 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1569 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1570 INIT_STATIC_SPEC ("asm_options", &asm_options),
1571 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1572 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1573 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1574 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1575 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1576 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1577 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1578 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1579 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1580 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1581 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1582 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1583 INIT_STATIC_SPEC ("link", &link_spec),
1584 INIT_STATIC_SPEC ("lib", &lib_spec),
1585 INIT_STATIC_SPEC ("mfwrap", &mfwrap_spec),
1586 INIT_STATIC_SPEC ("mflib", &mflib_spec),
1587 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1588 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1589 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1590 INIT_STATIC_SPEC ("switches_need_spaces", &switches_need_spaces),
1591 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1592 INIT_STATIC_SPEC ("version", &compiler_version),
1593 INIT_STATIC_SPEC ("multilib", &multilib_select),
1594 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1595 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1596 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1597 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1598 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1599 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1600 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1601 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1602 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1603 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1604 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1605 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1606 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1607 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1610 #ifdef EXTRA_SPECS /* additional specs needed */
1611 /* Structure to keep track of just the first two args of a spec_list.
1612 That is all that the EXTRA_SPECS macro gives us. */
1613 struct spec_list_1
1615 const char *const name;
1616 const char *const ptr;
1619 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1620 static struct spec_list *extra_specs = (struct spec_list *) 0;
1621 #endif
1623 /* List of dynamically allocates specs that have been defined so far. */
1625 static struct spec_list *specs = (struct spec_list *) 0;
1627 /* List of static spec functions. */
1629 static const struct spec_function static_spec_functions[] =
1631 { "getenv", getenv_spec_function },
1632 { "if-exists", if_exists_spec_function },
1633 { "if-exists-else", if_exists_else_spec_function },
1634 { "replace-outfile", replace_outfile_spec_function },
1635 { "version-compare", version_compare_spec_function },
1636 { "include", include_spec_function },
1637 { "print-asm-header", print_asm_header_spec_function },
1638 #ifdef EXTRA_SPEC_FUNCTIONS
1639 EXTRA_SPEC_FUNCTIONS
1640 #endif
1641 { 0, 0 }
1644 static int processing_spec_function;
1646 /* Add appropriate libgcc specs to OBSTACK, taking into account
1647 various permutations of -shared-libgcc, -shared, and such. */
1649 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1651 #ifndef USE_LD_AS_NEEDED
1652 #define USE_LD_AS_NEEDED 0
1653 #endif
1655 static void
1656 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1657 const char *static_name, const char *eh_name)
1659 char *buf;
1661 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1662 "%{!static:%{!static-libgcc:"
1663 #if USE_LD_AS_NEEDED
1664 "%{!shared-libgcc:",
1665 static_name, " --as-needed ", shared_name, " --no-as-needed"
1667 "%{shared-libgcc:",
1668 shared_name, "%{!shared: ", static_name, "}"
1670 #else
1671 "%{!shared:"
1672 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1673 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1675 #ifdef LINK_EH_SPEC
1676 "%{shared:"
1677 "%{shared-libgcc:", shared_name, "}"
1678 "%{!shared-libgcc:", static_name, "}"
1680 #else
1681 "%{shared:", shared_name, "}"
1682 #endif
1683 #endif
1684 "}}", NULL);
1686 obstack_grow (obstack, buf, strlen (buf));
1687 free (buf);
1689 #endif /* ENABLE_SHARED_LIBGCC */
1691 /* Initialize the specs lookup routines. */
1693 static void
1694 init_spec (void)
1696 struct spec_list *next = (struct spec_list *) 0;
1697 struct spec_list *sl = (struct spec_list *) 0;
1698 int i;
1700 if (specs)
1701 return; /* Already initialized. */
1703 if (verbose_flag)
1704 notice ("Using built-in specs.\n");
1706 #ifdef EXTRA_SPECS
1707 extra_specs = xcalloc (sizeof (struct spec_list),
1708 ARRAY_SIZE (extra_specs_1));
1710 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1712 sl = &extra_specs[i];
1713 sl->name = extra_specs_1[i].name;
1714 sl->ptr = extra_specs_1[i].ptr;
1715 sl->next = next;
1716 sl->name_len = strlen (sl->name);
1717 sl->ptr_spec = &sl->ptr;
1718 next = sl;
1720 #endif
1722 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1724 sl = &static_specs[i];
1725 sl->next = next;
1726 next = sl;
1729 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1730 /* ??? If neither -shared-libgcc nor --static-libgcc was
1731 seen, then we should be making an educated guess. Some proposed
1732 heuristics for ELF include:
1734 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1735 program will be doing dynamic loading, which will likely
1736 need the shared libgcc.
1738 (2) If "-ldl", then it's also a fair bet that we're doing
1739 dynamic loading.
1741 (3) For each ET_DYN we're linking against (either through -lfoo
1742 or /some/path/foo.so), check to see whether it or one of
1743 its dependencies depends on a shared libgcc.
1745 (4) If "-shared"
1747 If the runtime is fixed to look for program headers instead
1748 of calling __register_frame_info at all, for each object,
1749 use the shared libgcc if any EH symbol referenced.
1751 If crtstuff is fixed to not invoke __register_frame_info
1752 automatically, for each object, use the shared libgcc if
1753 any non-empty unwind section found.
1755 Doing any of this probably requires invoking an external program to
1756 do the actual object file scanning. */
1758 const char *p = libgcc_spec;
1759 int in_sep = 1;
1761 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1762 when given the proper command line arguments. */
1763 while (*p)
1765 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1767 init_gcc_specs (&obstack,
1768 "-lgcc_s"
1769 #ifdef USE_LIBUNWIND_EXCEPTIONS
1770 " -lunwind"
1771 #endif
1773 "-lgcc",
1774 "-lgcc_eh"
1775 #ifdef USE_LIBUNWIND_EXCEPTIONS
1776 # ifdef HAVE_LD_STATIC_DYNAMIC
1777 " %{!static:-Bstatic} -lunwind %{!static:-Bdynamic}"
1778 # else
1779 " -lunwind"
1780 # endif
1781 #endif
1784 p += 5;
1785 in_sep = 0;
1787 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1789 /* Ug. We don't know shared library extensions. Hope that
1790 systems that use this form don't do shared libraries. */
1791 init_gcc_specs (&obstack,
1792 "-lgcc_s",
1793 "libgcc.a%s",
1794 "libgcc_eh.a%s"
1795 #ifdef USE_LIBUNWIND_EXCEPTIONS
1796 " -lunwind"
1797 #endif
1799 p += 10;
1800 in_sep = 0;
1802 else
1804 obstack_1grow (&obstack, *p);
1805 in_sep = (*p == ' ');
1806 p += 1;
1810 obstack_1grow (&obstack, '\0');
1811 libgcc_spec = XOBFINISH (&obstack, const char *);
1813 #endif
1814 #ifdef USE_AS_TRADITIONAL_FORMAT
1815 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1817 static const char tf[] = "--traditional-format ";
1818 obstack_grow (&obstack, tf, sizeof(tf) - 1);
1819 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1820 asm_spec = XOBFINISH (&obstack, const char *);
1822 #endif
1823 #ifdef LINK_EH_SPEC
1824 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1825 obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1826 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1827 link_spec = XOBFINISH (&obstack, const char *);
1828 #endif
1830 specs = sl;
1833 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1834 removed; If the spec starts with a + then SPEC is added to the end of the
1835 current spec. */
1837 static void
1838 set_spec (const char *name, const char *spec)
1840 struct spec_list *sl;
1841 const char *old_spec;
1842 int name_len = strlen (name);
1843 int i;
1845 /* If this is the first call, initialize the statically allocated specs. */
1846 if (!specs)
1848 struct spec_list *next = (struct spec_list *) 0;
1849 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1851 sl = &static_specs[i];
1852 sl->next = next;
1853 next = sl;
1855 specs = sl;
1858 /* See if the spec already exists. */
1859 for (sl = specs; sl; sl = sl->next)
1860 if (name_len == sl->name_len && !strcmp (sl->name, name))
1861 break;
1863 if (!sl)
1865 /* Not found - make it. */
1866 sl = XNEW (struct spec_list);
1867 sl->name = xstrdup (name);
1868 sl->name_len = name_len;
1869 sl->ptr_spec = &sl->ptr;
1870 sl->alloc_p = 0;
1871 *(sl->ptr_spec) = "";
1872 sl->next = specs;
1873 specs = sl;
1876 old_spec = *(sl->ptr_spec);
1877 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1878 ? concat (old_spec, spec + 1, NULL)
1879 : xstrdup (spec));
1881 #ifdef DEBUG_SPECS
1882 if (verbose_flag)
1883 notice ("Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1884 #endif
1886 /* Free the old spec. */
1887 if (old_spec && sl->alloc_p)
1888 free (CONST_CAST(char *, old_spec));
1890 sl->alloc_p = 1;
1893 /* Accumulate a command (program name and args), and run it. */
1895 /* Vector of pointers to arguments in the current line of specifications. */
1897 static const char **argbuf;
1899 /* Number of elements allocated in argbuf. */
1901 static int argbuf_length;
1903 /* Number of elements in argbuf currently in use (containing args). */
1905 static int argbuf_index;
1907 /* Position in the argbuf array containing the name of the output file
1908 (the value associated with the "-o" flag). */
1910 static int have_o_argbuf_index = 0;
1912 /* Were the options -c or -S passed. */
1913 static int have_c = 0;
1915 /* Was the option -o passed. */
1916 static int have_o = 0;
1918 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1919 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1920 it here. */
1922 static struct temp_name {
1923 const char *suffix; /* suffix associated with the code. */
1924 int length; /* strlen (suffix). */
1925 int unique; /* Indicates whether %g or %u/%U was used. */
1926 const char *filename; /* associated filename. */
1927 int filename_length; /* strlen (filename). */
1928 struct temp_name *next;
1929 } *temp_names;
1931 /* Number of commands executed so far. */
1933 static int execution_count;
1935 /* Number of commands that exited with a signal. */
1937 static int signal_count;
1939 /* Name with which this program was invoked. */
1941 static const char *programname;
1943 /* Allocate the argument vector. */
1945 static void
1946 alloc_args (void)
1948 argbuf_length = 10;
1949 argbuf = XNEWVEC (const char *, argbuf_length);
1952 /* Clear out the vector of arguments (after a command is executed). */
1954 static void
1955 clear_args (void)
1957 argbuf_index = 0;
1960 /* Add one argument to the vector at the end.
1961 This is done when a space is seen or at the end of the line.
1962 If DELETE_ALWAYS is nonzero, the arg is a filename
1963 and the file should be deleted eventually.
1964 If DELETE_FAILURE is nonzero, the arg is a filename
1965 and the file should be deleted if this compilation fails. */
1967 static void
1968 store_arg (const char *arg, int delete_always, int delete_failure)
1970 if (argbuf_index + 1 == argbuf_length)
1971 argbuf = xrealloc (argbuf, (argbuf_length *= 2) * sizeof (const char *));
1973 argbuf[argbuf_index++] = arg;
1974 argbuf[argbuf_index] = 0;
1976 if (strcmp (arg, "-o") == 0)
1977 have_o_argbuf_index = argbuf_index;
1978 if (delete_always || delete_failure)
1979 record_temp_file (arg, delete_always, delete_failure);
1982 /* Load specs from a file name named FILENAME, replacing occurrences of
1983 various different types of line-endings, \r\n, \n\r and just \r, with
1984 a single \n. */
1986 static char *
1987 load_specs (const char *filename)
1989 int desc;
1990 int readlen;
1991 struct stat statbuf;
1992 char *buffer;
1993 char *buffer_p;
1994 char *specs;
1995 char *specs_p;
1997 if (verbose_flag)
1998 notice ("Reading specs from %s\n", filename);
2000 /* Open and stat the file. */
2001 desc = open (filename, O_RDONLY, 0);
2002 if (desc < 0)
2003 pfatal_with_name (filename);
2004 if (stat (filename, &statbuf) < 0)
2005 pfatal_with_name (filename);
2007 /* Read contents of file into BUFFER. */
2008 buffer = XNEWVEC (char, statbuf.st_size + 1);
2009 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
2010 if (readlen < 0)
2011 pfatal_with_name (filename);
2012 buffer[readlen] = 0;
2013 close (desc);
2015 specs = XNEWVEC (char, readlen + 1);
2016 specs_p = specs;
2017 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
2019 int skip = 0;
2020 char c = *buffer_p;
2021 if (c == '\r')
2023 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
2024 skip = 1;
2025 else if (*(buffer_p + 1) == '\n') /* \r\n */
2026 skip = 1;
2027 else /* \r */
2028 c = '\n';
2030 if (! skip)
2031 *specs_p++ = c;
2033 *specs_p = '\0';
2035 free (buffer);
2036 return (specs);
2039 /* Read compilation specs from a file named FILENAME,
2040 replacing the default ones.
2042 A suffix which starts with `*' is a definition for
2043 one of the machine-specific sub-specs. The "suffix" should be
2044 *asm, *cc1, *cpp, *link, *startfile, etc.
2045 The corresponding spec is stored in asm_spec, etc.,
2046 rather than in the `compilers' vector.
2048 Anything invalid in the file is a fatal error. */
2050 static void
2051 read_specs (const char *filename, int main_p)
2053 char *buffer;
2054 char *p;
2056 buffer = load_specs (filename);
2058 /* Scan BUFFER for specs, putting them in the vector. */
2059 p = buffer;
2060 while (1)
2062 char *suffix;
2063 char *spec;
2064 char *in, *out, *p1, *p2, *p3;
2066 /* Advance P in BUFFER to the next nonblank nocomment line. */
2067 p = skip_whitespace (p);
2068 if (*p == 0)
2069 break;
2071 /* Is this a special command that starts with '%'? */
2072 /* Don't allow this for the main specs file, since it would
2073 encourage people to overwrite it. */
2074 if (*p == '%' && !main_p)
2076 p1 = p;
2077 while (*p && *p != '\n')
2078 p++;
2080 /* Skip '\n'. */
2081 p++;
2083 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
2084 && (p1[sizeof "%include" - 1] == ' '
2085 || p1[sizeof "%include" - 1] == '\t'))
2087 char *new_filename;
2089 p1 += sizeof ("%include");
2090 while (*p1 == ' ' || *p1 == '\t')
2091 p1++;
2093 if (*p1++ != '<' || p[-2] != '>')
2094 fatal ("specs %%include syntax malformed after %ld characters",
2095 (long) (p1 - buffer + 1));
2097 p[-2] = '\0';
2098 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2099 read_specs (new_filename ? new_filename : p1, FALSE);
2100 continue;
2102 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
2103 && (p1[sizeof "%include_noerr" - 1] == ' '
2104 || p1[sizeof "%include_noerr" - 1] == '\t'))
2106 char *new_filename;
2108 p1 += sizeof "%include_noerr";
2109 while (*p1 == ' ' || *p1 == '\t')
2110 p1++;
2112 if (*p1++ != '<' || p[-2] != '>')
2113 fatal ("specs %%include syntax malformed after %ld characters",
2114 (long) (p1 - buffer + 1));
2116 p[-2] = '\0';
2117 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
2118 if (new_filename)
2119 read_specs (new_filename, FALSE);
2120 else if (verbose_flag)
2121 notice ("could not find specs file %s\n", p1);
2122 continue;
2124 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
2125 && (p1[sizeof "%rename" - 1] == ' '
2126 || p1[sizeof "%rename" - 1] == '\t'))
2128 int name_len;
2129 struct spec_list *sl;
2130 struct spec_list *newsl;
2132 /* Get original name. */
2133 p1 += sizeof "%rename";
2134 while (*p1 == ' ' || *p1 == '\t')
2135 p1++;
2137 if (! ISALPHA ((unsigned char) *p1))
2138 fatal ("specs %%rename syntax malformed after %ld characters",
2139 (long) (p1 - buffer));
2141 p2 = p1;
2142 while (*p2 && !ISSPACE ((unsigned char) *p2))
2143 p2++;
2145 if (*p2 != ' ' && *p2 != '\t')
2146 fatal ("specs %%rename syntax malformed after %ld characters",
2147 (long) (p2 - buffer));
2149 name_len = p2 - p1;
2150 *p2++ = '\0';
2151 while (*p2 == ' ' || *p2 == '\t')
2152 p2++;
2154 if (! ISALPHA ((unsigned char) *p2))
2155 fatal ("specs %%rename syntax malformed after %ld characters",
2156 (long) (p2 - buffer));
2158 /* Get new spec name. */
2159 p3 = p2;
2160 while (*p3 && !ISSPACE ((unsigned char) *p3))
2161 p3++;
2163 if (p3 != p - 1)
2164 fatal ("specs %%rename syntax malformed after %ld characters",
2165 (long) (p3 - buffer));
2166 *p3 = '\0';
2168 for (sl = specs; sl; sl = sl->next)
2169 if (name_len == sl->name_len && !strcmp (sl->name, p1))
2170 break;
2172 if (!sl)
2173 fatal ("specs %s spec was not found to be renamed", p1);
2175 if (strcmp (p1, p2) == 0)
2176 continue;
2178 for (newsl = specs; newsl; newsl = newsl->next)
2179 if (strcmp (newsl->name, p2) == 0)
2180 fatal ("%s: attempt to rename spec '%s' to already defined spec '%s'",
2181 filename, p1, p2);
2183 if (verbose_flag)
2185 notice ("rename spec %s to %s\n", p1, p2);
2186 #ifdef DEBUG_SPECS
2187 notice ("spec is '%s'\n\n", *(sl->ptr_spec));
2188 #endif
2191 set_spec (p2, *(sl->ptr_spec));
2192 if (sl->alloc_p)
2193 free (CONST_CAST (char *, *(sl->ptr_spec)));
2195 *(sl->ptr_spec) = "";
2196 sl->alloc_p = 0;
2197 continue;
2199 else
2200 fatal ("specs unknown %% command after %ld characters",
2201 (long) (p1 - buffer));
2204 /* Find the colon that should end the suffix. */
2205 p1 = p;
2206 while (*p1 && *p1 != ':' && *p1 != '\n')
2207 p1++;
2209 /* The colon shouldn't be missing. */
2210 if (*p1 != ':')
2211 fatal ("specs file malformed after %ld characters",
2212 (long) (p1 - buffer));
2214 /* Skip back over trailing whitespace. */
2215 p2 = p1;
2216 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
2217 p2--;
2219 /* Copy the suffix to a string. */
2220 suffix = save_string (p, p2 - p);
2221 /* Find the next line. */
2222 p = skip_whitespace (p1 + 1);
2223 if (p[1] == 0)
2224 fatal ("specs file malformed after %ld characters",
2225 (long) (p - buffer));
2227 p1 = p;
2228 /* Find next blank line or end of string. */
2229 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
2230 p1++;
2232 /* Specs end at the blank line and do not include the newline. */
2233 spec = save_string (p, p1 - p);
2234 p = p1;
2236 /* Delete backslash-newline sequences from the spec. */
2237 in = spec;
2238 out = spec;
2239 while (*in != 0)
2241 if (in[0] == '\\' && in[1] == '\n')
2242 in += 2;
2243 else if (in[0] == '#')
2244 while (*in && *in != '\n')
2245 in++;
2247 else
2248 *out++ = *in++;
2250 *out = 0;
2252 if (suffix[0] == '*')
2254 if (! strcmp (suffix, "*link_command"))
2255 link_command_spec = spec;
2256 else
2257 set_spec (suffix + 1, spec);
2259 else
2261 /* Add this pair to the vector. */
2262 compilers
2263 = xrealloc (compilers,
2264 (n_compilers + 2) * sizeof (struct compiler));
2266 compilers[n_compilers].suffix = suffix;
2267 compilers[n_compilers].spec = spec;
2268 n_compilers++;
2269 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
2272 if (*suffix == 0)
2273 link_command_spec = spec;
2276 if (link_command_spec == 0)
2277 fatal ("spec file has no spec for linking");
2280 /* Record the names of temporary files we tell compilers to write,
2281 and delete them at the end of the run. */
2283 /* This is the common prefix we use to make temp file names.
2284 It is chosen once for each run of this program.
2285 It is substituted into a spec by %g or %j.
2286 Thus, all temp file names contain this prefix.
2287 In practice, all temp file names start with this prefix.
2289 This prefix comes from the envvar TMPDIR if it is defined;
2290 otherwise, from the P_tmpdir macro if that is defined;
2291 otherwise, in /usr/tmp or /tmp;
2292 or finally the current directory if all else fails. */
2294 static const char *temp_filename;
2296 /* Length of the prefix. */
2298 static int temp_filename_length;
2300 /* Define the list of temporary files to delete. */
2302 struct temp_file
2304 const char *name;
2305 struct temp_file *next;
2308 /* Queue of files to delete on success or failure of compilation. */
2309 static struct temp_file *always_delete_queue;
2310 /* Queue of files to delete on failure of compilation. */
2311 static struct temp_file *failure_delete_queue;
2313 /* Record FILENAME as a file to be deleted automatically.
2314 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2315 otherwise delete it in any case.
2316 FAIL_DELETE nonzero means delete it if a compilation step fails;
2317 otherwise delete it in any case. */
2319 void
2320 record_temp_file (const char *filename, int always_delete, int fail_delete)
2322 char *const name = xstrdup (filename);
2324 if (always_delete)
2326 struct temp_file *temp;
2327 for (temp = always_delete_queue; temp; temp = temp->next)
2328 if (! strcmp (name, temp->name))
2329 goto already1;
2331 temp = XNEW (struct temp_file);
2332 temp->next = always_delete_queue;
2333 temp->name = name;
2334 always_delete_queue = temp;
2336 already1:;
2339 if (fail_delete)
2341 struct temp_file *temp;
2342 for (temp = failure_delete_queue; temp; temp = temp->next)
2343 if (! strcmp (name, temp->name))
2344 goto already2;
2346 temp = XNEW (struct temp_file);
2347 temp->next = failure_delete_queue;
2348 temp->name = name;
2349 failure_delete_queue = temp;
2351 already2:;
2355 /* Delete all the temporary files whose names we previously recorded. */
2357 #ifndef DELETE_IF_ORDINARY
2358 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2359 do \
2361 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2362 if (unlink (NAME) < 0) \
2363 if (VERBOSE_FLAG) \
2364 perror_with_name (NAME); \
2365 } while (0)
2366 #endif
2368 static void
2369 delete_if_ordinary (const char *name)
2371 struct stat st;
2372 #ifdef DEBUG
2373 int i, c;
2375 printf ("Delete %s? (y or n) ", name);
2376 fflush (stdout);
2377 i = getchar ();
2378 if (i != '\n')
2379 while ((c = getchar ()) != '\n' && c != EOF)
2382 if (i == 'y' || i == 'Y')
2383 #endif /* DEBUG */
2384 DELETE_IF_ORDINARY (name, st, verbose_flag);
2387 static void
2388 delete_temp_files (void)
2390 struct temp_file *temp;
2392 for (temp = always_delete_queue; temp; temp = temp->next)
2393 delete_if_ordinary (temp->name);
2394 always_delete_queue = 0;
2397 /* Delete all the files to be deleted on error. */
2399 static void
2400 delete_failure_queue (void)
2402 struct temp_file *temp;
2404 for (temp = failure_delete_queue; temp; temp = temp->next)
2405 delete_if_ordinary (temp->name);
2408 static void
2409 clear_failure_queue (void)
2411 failure_delete_queue = 0;
2414 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2415 returns non-NULL.
2416 If DO_MULTI is true iterate over the paths twice, first with multilib
2417 suffix then without, otherwise iterate over the paths once without
2418 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2419 to avoid visiting the same path twice, but we could do better. For
2420 instance, /usr/lib/../lib is considered different from /usr/lib.
2421 At least EXTRA_SPACE chars past the end of the path passed to
2422 CALLBACK are available for use by the callback.
2423 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2425 Returns the value returned by CALLBACK. */
2427 static void *
2428 for_each_path (const struct path_prefix *paths,
2429 bool do_multi,
2430 size_t extra_space,
2431 void *(*callback) (char *, void *),
2432 void *callback_info)
2434 struct prefix_list *pl;
2435 const char *multi_dir = NULL;
2436 const char *multi_os_dir = NULL;
2437 const char *multi_suffix;
2438 const char *just_multi_suffix;
2439 char *path = NULL;
2440 void *ret = NULL;
2441 bool skip_multi_dir = false;
2442 bool skip_multi_os_dir = false;
2444 multi_suffix = machine_suffix;
2445 just_multi_suffix = just_machine_suffix;
2446 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2448 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2449 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2450 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2452 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2453 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2455 while (1)
2457 size_t multi_dir_len = 0;
2458 size_t multi_os_dir_len = 0;
2459 size_t suffix_len;
2460 size_t just_suffix_len;
2461 size_t len;
2463 if (multi_dir)
2464 multi_dir_len = strlen (multi_dir);
2465 if (multi_os_dir)
2466 multi_os_dir_len = strlen (multi_os_dir);
2467 suffix_len = strlen (multi_suffix);
2468 just_suffix_len = strlen (just_multi_suffix);
2470 if (path == NULL)
2472 len = paths->max_len + extra_space + 1;
2473 if (suffix_len > multi_os_dir_len)
2474 len += suffix_len;
2475 else
2476 len += multi_os_dir_len;
2477 path = XNEWVEC (char, len);
2480 for (pl = paths->plist; pl != 0; pl = pl->next)
2482 len = strlen (pl->prefix);
2483 memcpy (path, pl->prefix, len);
2485 /* Look first in MACHINE/VERSION subdirectory. */
2486 if (!skip_multi_dir)
2488 memcpy (path + len, multi_suffix, suffix_len + 1);
2489 ret = callback (path, callback_info);
2490 if (ret)
2491 break;
2494 /* Some paths are tried with just the machine (ie. target)
2495 subdir. This is used for finding as, ld, etc. */
2496 if (!skip_multi_dir
2497 && pl->require_machine_suffix == 2)
2499 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2500 ret = callback (path, callback_info);
2501 if (ret)
2502 break;
2505 /* Now try the base path. */
2506 if (!pl->require_machine_suffix
2507 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2509 const char *this_multi;
2510 size_t this_multi_len;
2512 if (pl->os_multilib)
2514 this_multi = multi_os_dir;
2515 this_multi_len = multi_os_dir_len;
2517 else
2519 this_multi = multi_dir;
2520 this_multi_len = multi_dir_len;
2523 if (this_multi_len)
2524 memcpy (path + len, this_multi, this_multi_len + 1);
2525 else
2526 path[len] = '\0';
2528 ret = callback (path, callback_info);
2529 if (ret)
2530 break;
2533 if (pl)
2534 break;
2536 if (multi_dir == NULL && multi_os_dir == NULL)
2537 break;
2539 /* Run through the paths again, this time without multilibs.
2540 Don't repeat any we have already seen. */
2541 if (multi_dir)
2543 free (CONST_CAST (char *, multi_dir));
2544 multi_dir = NULL;
2545 free (CONST_CAST (char *, multi_suffix));
2546 multi_suffix = machine_suffix;
2547 free (CONST_CAST (char *, just_multi_suffix));
2548 just_multi_suffix = just_machine_suffix;
2550 else
2551 skip_multi_dir = true;
2552 if (multi_os_dir)
2554 free (CONST_CAST (char *, multi_os_dir));
2555 multi_os_dir = NULL;
2557 else
2558 skip_multi_os_dir = true;
2561 if (multi_dir)
2563 free (CONST_CAST (char *, multi_dir));
2564 free (CONST_CAST (char *, multi_suffix));
2565 free (CONST_CAST (char *, just_multi_suffix));
2567 if (multi_os_dir)
2568 free (CONST_CAST (char *, multi_os_dir));
2569 if (ret != path)
2570 free (path);
2571 return ret;
2574 /* Callback for build_search_list. Adds path to obstack being built. */
2576 struct add_to_obstack_info {
2577 struct obstack *ob;
2578 bool check_dir;
2579 bool first_time;
2582 static void *
2583 add_to_obstack (char *path, void *data)
2585 struct add_to_obstack_info *info = data;
2587 if (info->check_dir && !is_directory (path, false))
2588 return NULL;
2590 if (!info->first_time)
2591 obstack_1grow (info->ob, PATH_SEPARATOR);
2593 obstack_grow (info->ob, path, strlen (path));
2595 info->first_time = false;
2596 return NULL;
2599 /* Add or change the value of an environment variable, outputting the
2600 change to standard error if in verbose mode. */
2601 static void
2602 xputenv (const char *string)
2604 if (verbose_flag)
2605 notice ("%s\n", string);
2606 putenv (CONST_CAST (char *, string));
2609 /* Build a list of search directories from PATHS.
2610 PREFIX is a string to prepend to the list.
2611 If CHECK_DIR_P is true we ensure the directory exists.
2612 If DO_MULTI is true, multilib paths are output first, then
2613 non-multilib paths.
2614 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2615 It is also used by the --print-search-dirs flag. */
2617 static char *
2618 build_search_list (const struct path_prefix *paths, const char *prefix,
2619 bool check_dir, bool do_multi)
2621 struct add_to_obstack_info info;
2623 info.ob = &collect_obstack;
2624 info.check_dir = check_dir;
2625 info.first_time = true;
2627 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2628 obstack_1grow (&collect_obstack, '=');
2630 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2632 obstack_1grow (&collect_obstack, '\0');
2633 return XOBFINISH (&collect_obstack, char *);
2636 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2637 for collect. */
2639 static void
2640 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2641 bool do_multi)
2643 xputenv (build_search_list (paths, env_var, true, do_multi));
2646 /* Check whether NAME can be accessed in MODE. This is like access,
2647 except that it never considers directories to be executable. */
2649 static int
2650 access_check (const char *name, int mode)
2652 if (mode == X_OK)
2654 struct stat st;
2656 if (stat (name, &st) < 0
2657 || S_ISDIR (st.st_mode))
2658 return -1;
2661 return access (name, mode);
2664 /* Callback for find_a_file. Appends the file name to the directory
2665 path. If the resulting file exists in the right mode, return the
2666 full pathname to the file. */
2668 struct file_at_path_info {
2669 const char *name;
2670 const char *suffix;
2671 int name_len;
2672 int suffix_len;
2673 int mode;
2676 static void *
2677 file_at_path (char *path, void *data)
2679 struct file_at_path_info *info = data;
2680 size_t len = strlen (path);
2682 memcpy (path + len, info->name, info->name_len);
2683 len += info->name_len;
2685 /* Some systems have a suffix for executable files.
2686 So try appending that first. */
2687 if (info->suffix_len)
2689 memcpy (path + len, info->suffix, info->suffix_len + 1);
2690 if (access_check (path, info->mode) == 0)
2691 return path;
2694 path[len] = '\0';
2695 if (access_check (path, info->mode) == 0)
2696 return path;
2698 return NULL;
2701 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2702 access to check permissions. If DO_MULTI is true, search multilib
2703 paths then non-multilib paths, otherwise do not search multilib paths.
2704 Return 0 if not found, otherwise return its name, allocated with malloc. */
2706 static char *
2707 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2708 bool do_multi)
2710 struct file_at_path_info info;
2712 #ifdef DEFAULT_ASSEMBLER
2713 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2714 return xstrdup (DEFAULT_ASSEMBLER);
2715 #endif
2717 #ifdef DEFAULT_LINKER
2718 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2719 return xstrdup (DEFAULT_LINKER);
2720 #endif
2722 /* Determine the filename to execute (special case for absolute paths). */
2724 if (IS_ABSOLUTE_PATH (name))
2726 if (access (name, mode) == 0)
2727 return xstrdup (name);
2729 return NULL;
2732 info.name = name;
2733 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2734 info.name_len = strlen (info.name);
2735 info.suffix_len = strlen (info.suffix);
2736 info.mode = mode;
2738 return for_each_path (pprefix, do_multi, info.name_len + info.suffix_len,
2739 file_at_path, &info);
2742 /* Ranking of prefixes in the sort list. -B prefixes are put before
2743 all others. */
2745 enum path_prefix_priority
2747 PREFIX_PRIORITY_B_OPT,
2748 PREFIX_PRIORITY_LAST
2751 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2752 order according to PRIORITY. Within each PRIORITY, new entries are
2753 appended.
2755 If WARN is nonzero, we will warn if no file is found
2756 through this prefix. WARN should point to an int
2757 which will be set to 1 if this entry is used.
2759 COMPONENT is the value to be passed to update_path.
2761 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2762 the complete value of machine_suffix.
2763 2 means try both machine_suffix and just_machine_suffix. */
2765 static void
2766 add_prefix (struct path_prefix *pprefix, const char *prefix,
2767 const char *component, /* enum prefix_priority */ int priority,
2768 int require_machine_suffix, int os_multilib)
2770 struct prefix_list *pl, **prev;
2771 int len;
2773 for (prev = &pprefix->plist;
2774 (*prev) != NULL && (*prev)->priority <= priority;
2775 prev = &(*prev)->next)
2778 /* Keep track of the longest prefix. */
2780 prefix = update_path (prefix, component);
2781 len = strlen (prefix);
2782 if (len > pprefix->max_len)
2783 pprefix->max_len = len;
2785 pl = XNEW (struct prefix_list);
2786 pl->prefix = prefix;
2787 pl->require_machine_suffix = require_machine_suffix;
2788 pl->priority = priority;
2789 pl->os_multilib = os_multilib;
2791 /* Insert after PREV. */
2792 pl->next = (*prev);
2793 (*prev) = pl;
2796 /* Same as add_prefix, but prepending target_system_root to prefix. */
2797 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2798 static void
2799 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2800 const char *component,
2801 /* enum prefix_priority */ int priority,
2802 int require_machine_suffix, int os_multilib)
2804 if (!IS_ABSOLUTE_PATH (prefix))
2805 fatal ("system path '%s' is not absolute", prefix);
2807 if (target_system_root)
2809 if (target_sysroot_suffix)
2810 prefix = concat (target_sysroot_suffix, prefix, NULL);
2811 prefix = concat (target_system_root, prefix, NULL);
2813 /* We have to override this because GCC's notion of sysroot
2814 moves along with GCC. */
2815 component = "GCC";
2818 add_prefix (pprefix, prefix, component, priority,
2819 require_machine_suffix, os_multilib);
2822 /* Execute the command specified by the arguments on the current line of spec.
2823 When using pipes, this includes several piped-together commands
2824 with `|' between them.
2826 Return 0 if successful, -1 if failed. */
2828 static int
2829 execute (void)
2831 int i;
2832 int n_commands; /* # of command. */
2833 char *string;
2834 struct pex_obj *pex;
2835 struct command
2837 const char *prog; /* program name. */
2838 const char **argv; /* vector of args. */
2841 struct command *commands; /* each command buffer with above info. */
2843 gcc_assert (!processing_spec_function);
2845 /* Count # of piped commands. */
2846 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2847 if (strcmp (argbuf[i], "|") == 0)
2848 n_commands++;
2850 /* Get storage for each command. */
2851 commands = alloca (n_commands * sizeof (struct command));
2853 /* Split argbuf into its separate piped processes,
2854 and record info about each one.
2855 Also search for the programs that are to be run. */
2857 commands[0].prog = argbuf[0]; /* first command. */
2858 commands[0].argv = &argbuf[0];
2859 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2861 if (string)
2862 commands[0].argv[0] = string;
2864 for (n_commands = 1, i = 0; i < argbuf_index; i++)
2865 if (strcmp (argbuf[i], "|") == 0)
2866 { /* each command. */
2867 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2868 fatal ("-pipe not supported");
2869 #endif
2870 argbuf[i] = 0; /* termination of command args. */
2871 commands[n_commands].prog = argbuf[i + 1];
2872 commands[n_commands].argv = &argbuf[i + 1];
2873 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2874 X_OK, false);
2875 if (string)
2876 commands[n_commands].argv[0] = string;
2877 n_commands++;
2880 argbuf[argbuf_index] = 0;
2882 /* If -v, print what we are about to do, and maybe query. */
2884 if (verbose_flag)
2886 /* For help listings, put a blank line between sub-processes. */
2887 if (print_help_list)
2888 fputc ('\n', stderr);
2890 /* Print each piped command as a separate line. */
2891 for (i = 0; i < n_commands; i++)
2893 const char *const *j;
2895 if (verbose_only_flag)
2897 for (j = commands[i].argv; *j; j++)
2899 const char *p;
2900 fprintf (stderr, " \"");
2901 for (p = *j; *p; ++p)
2903 if (*p == '"' || *p == '\\' || *p == '$')
2904 fputc ('\\', stderr);
2905 fputc (*p, stderr);
2907 fputc ('"', stderr);
2910 else
2911 for (j = commands[i].argv; *j; j++)
2912 fprintf (stderr, " %s", *j);
2914 /* Print a pipe symbol after all but the last command. */
2915 if (i + 1 != n_commands)
2916 fprintf (stderr, " |");
2917 fprintf (stderr, "\n");
2919 fflush (stderr);
2920 if (verbose_only_flag != 0)
2922 /* verbose_only_flag should act as if the spec was
2923 executed, so increment execution_count before
2924 returning. This prevents spurious warnings about
2925 unused linker input files, etc. */
2926 execution_count++;
2927 return 0;
2929 #ifdef DEBUG
2930 notice ("\nGo ahead? (y or n) ");
2931 fflush (stderr);
2932 i = getchar ();
2933 if (i != '\n')
2934 while (getchar () != '\n')
2937 if (i != 'y' && i != 'Y')
2938 return 0;
2939 #endif /* DEBUG */
2942 #ifdef ENABLE_VALGRIND_CHECKING
2943 /* Run the each command through valgrind. To simplify prepending the
2944 path to valgrind and the option "-q" (for quiet operation unless
2945 something triggers), we allocate a separate argv array. */
2947 for (i = 0; i < n_commands; i++)
2949 const char **argv;
2950 int argc;
2951 int j;
2953 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2956 argv = alloca ((argc + 3) * sizeof (char *));
2958 argv[0] = VALGRIND_PATH;
2959 argv[1] = "-q";
2960 for (j = 2; j < argc + 2; j++)
2961 argv[j] = commands[i].argv[j - 2];
2962 argv[j] = NULL;
2964 commands[i].argv = argv;
2965 commands[i].prog = argv[0];
2967 #endif
2969 /* Run each piped subprocess. */
2971 pex = pex_init (PEX_USE_PIPES | (report_times ? PEX_RECORD_TIMES : 0),
2972 programname, temp_filename);
2973 if (pex == NULL)
2974 pfatal_with_name (_("pex_init failed"));
2976 for (i = 0; i < n_commands; i++)
2978 const char *errmsg;
2979 int err;
2980 const char *string = commands[i].argv[0];
2982 errmsg = pex_run (pex,
2983 ((i + 1 == n_commands ? PEX_LAST : 0)
2984 | (string == commands[i].prog ? PEX_SEARCH : 0)),
2985 string, CONST_CAST (char **, commands[i].argv),
2986 NULL, NULL, &err);
2987 if (errmsg != NULL)
2989 if (err == 0)
2990 fatal (errmsg);
2991 else
2993 errno = err;
2994 pfatal_with_name (errmsg);
2998 if (string != commands[i].prog)
2999 free (CONST_CAST (char *, string));
3002 execution_count++;
3004 /* Wait for all the subprocesses to finish. */
3007 int *statuses;
3008 struct pex_time *times = NULL;
3009 int ret_code = 0;
3011 statuses = alloca (n_commands * sizeof (int));
3012 if (!pex_get_status (pex, n_commands, statuses))
3013 pfatal_with_name (_("failed to get exit status"));
3015 if (report_times)
3017 times = alloca (n_commands * sizeof (struct pex_time));
3018 if (!pex_get_times (pex, n_commands, times))
3019 pfatal_with_name (_("failed to get process times"));
3022 pex_free (pex);
3024 for (i = 0; i < n_commands; ++i)
3026 int status = statuses[i];
3028 if (WIFSIGNALED (status))
3030 #ifdef SIGPIPE
3031 /* SIGPIPE is a special case. It happens in -pipe mode
3032 when the compiler dies before the preprocessor is done,
3033 or the assembler dies before the compiler is done.
3034 There's generally been an error already, and this is
3035 just fallout. So don't generate another error unless
3036 we would otherwise have succeeded. */
3037 if (WTERMSIG (status) == SIGPIPE
3038 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
3040 signal_count++;
3041 ret_code = -1;
3043 else
3044 #endif
3045 fatal_ice ("\
3046 Internal error: %s (program %s)\n\
3047 Please submit a full bug report.\n\
3048 See %s for instructions.",
3049 strsignal (WTERMSIG (status)), commands[i].prog,
3050 bug_report_url);
3052 else if (WIFEXITED (status)
3053 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
3055 if (WEXITSTATUS (status) > greatest_status)
3056 greatest_status = WEXITSTATUS (status);
3057 ret_code = -1;
3060 if (report_times)
3062 struct pex_time *pt = &times[i];
3063 double ut, st;
3065 ut = ((double) pt->user_seconds
3066 + (double) pt->user_microseconds / 1.0e6);
3067 st = ((double) pt->system_seconds
3068 + (double) pt->system_microseconds / 1.0e6);
3070 if (ut + st != 0)
3071 notice ("# %s %.2f %.2f\n", commands[i].prog, ut, st);
3075 return ret_code;
3079 /* Find all the switches given to us
3080 and make a vector describing them.
3081 The elements of the vector are strings, one per switch given.
3082 If a switch uses following arguments, then the `part1' field
3083 is the switch itself and the `args' field
3084 is a null-terminated vector containing the following arguments.
3085 Bits in the `live_cond' field are:
3086 SWITCH_LIVE to indicate this switch is true in a conditional spec.
3087 SWITCH_FALSE to indicate this switch is overridden by a later switch.
3088 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
3089 The `validated' field is nonzero if any spec has looked at this switch;
3090 if it remains zero at the end of the run, it must be meaningless. */
3092 #define SWITCH_LIVE 0x1
3093 #define SWITCH_FALSE 0x2
3094 #define SWITCH_IGNORE 0x4
3096 struct switchstr
3098 const char *part1;
3099 const char **args;
3100 unsigned int live_cond;
3101 unsigned char validated;
3102 unsigned char ordering;
3105 static struct switchstr *switches;
3107 static int n_switches;
3109 /* Language is one of three things:
3111 1) The name of a real programming language.
3112 2) NULL, indicating that no one has figured out
3113 what it is yet.
3114 3) '*', indicating that the file should be passed
3115 to the linker. */
3116 struct infile
3118 const char *name;
3119 const char *language;
3120 struct compiler *incompiler;
3121 bool compiled;
3122 bool preprocessed;
3125 /* Also a vector of input files specified. */
3127 static struct infile *infiles;
3129 int n_infiles;
3131 /* True if multiple input files are being compiled to a single
3132 assembly file. */
3134 static bool combine_inputs;
3136 /* This counts the number of libraries added by lang_specific_driver, so that
3137 we can tell if there were any user supplied any files or libraries. */
3139 static int added_libraries;
3141 /* And a vector of corresponding output files is made up later. */
3143 const char **outfiles;
3145 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3147 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3148 is true if we should look for an executable suffix. DO_OBJ
3149 is true if we should look for an object suffix. */
3151 static const char *
3152 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3153 int do_obj ATTRIBUTE_UNUSED)
3155 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3156 int i;
3157 #endif
3158 int len;
3160 if (name == NULL)
3161 return NULL;
3163 len = strlen (name);
3165 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3166 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3167 if (do_obj && len > 2
3168 && name[len - 2] == '.'
3169 && name[len - 1] == 'o')
3171 obstack_grow (&obstack, name, len - 2);
3172 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3173 name = XOBFINISH (&obstack, const char *);
3175 #endif
3177 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3178 /* If there is no filetype, make it the executable suffix (which includes
3179 the "."). But don't get confused if we have just "-o". */
3180 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3181 return name;
3183 for (i = len - 1; i >= 0; i--)
3184 if (IS_DIR_SEPARATOR (name[i]))
3185 break;
3187 for (i++; i < len; i++)
3188 if (name[i] == '.')
3189 return name;
3191 obstack_grow (&obstack, name, len);
3192 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3193 strlen (TARGET_EXECUTABLE_SUFFIX));
3194 name = XOBFINISH (&obstack, const char *);
3195 #endif
3197 return name;
3199 #endif
3201 /* Display the command line switches accepted by gcc. */
3202 static void
3203 display_help (void)
3205 printf (_("Usage: %s [options] file...\n"), programname);
3206 fputs (_("Options:\n"), stdout);
3208 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3209 fputs (_(" --help Display this information\n"), stdout);
3210 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3211 fputs (_(" --help={target|optimizers|warnings|undocumented|params}[,{[^]joined|[^]separate}]\n"), stdout);
3212 fputs (_(" Display specific types of command line options\n"), stdout);
3213 if (! verbose_flag)
3214 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3215 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3216 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3217 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3218 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3219 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3220 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3221 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3222 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3223 fputs (_("\
3224 -print-multi-lib Display the mapping between command line options and\n\
3225 multiple library search directories\n"), stdout);
3226 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3227 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
3228 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3229 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3230 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3231 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3232 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3233 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3234 fputs (_(" -combine Pass multiple source files to compiler at once\n"), stdout);
3235 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3236 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3237 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3238 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3239 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3240 fputs (_("\
3241 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3242 and libraries\n"), stdout);
3243 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3244 fputs (_(" -b <machine> Run gcc for target <machine>, if installed\n"), stdout);
3245 fputs (_(" -V <version> Run gcc version number <version>, if installed\n"), stdout);
3246 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3247 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3248 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3249 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3250 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3251 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3252 fputs (_("\
3253 -x <language> Specify the language of the following input files\n\
3254 Permissible languages include: c c++ assembler none\n\
3255 'none' means revert to the default behavior of\n\
3256 guessing the language based on the file's extension\n\
3257 "), stdout);
3259 printf (_("\
3260 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3261 passed on to the various sub-processes invoked by %s. In order to pass\n\
3262 other options on to these processes the -W<letter> options must be used.\n\
3263 "), programname);
3265 /* The rest of the options are displayed by invocations of the various
3266 sub-processes. */
3269 static void
3270 add_preprocessor_option (const char *option, int len)
3272 n_preprocessor_options++;
3274 if (! preprocessor_options)
3275 preprocessor_options = XNEWVEC (char *, n_preprocessor_options);
3276 else
3277 preprocessor_options = xrealloc (preprocessor_options,
3278 n_preprocessor_options * sizeof (char *));
3280 preprocessor_options [n_preprocessor_options - 1] =
3281 save_string (option, len);
3284 static void
3285 add_assembler_option (const char *option, int len)
3287 n_assembler_options++;
3289 if (! assembler_options)
3290 assembler_options = XNEWVEC (char *, n_assembler_options);
3291 else
3292 assembler_options = xrealloc (assembler_options,
3293 n_assembler_options * sizeof (char *));
3295 assembler_options [n_assembler_options - 1] = save_string (option, len);
3298 static void
3299 add_linker_option (const char *option, int len)
3301 n_linker_options++;
3303 if (! linker_options)
3304 linker_options = XNEWVEC (char *, n_linker_options);
3305 else
3306 linker_options = xrealloc (linker_options,
3307 n_linker_options * sizeof (char *));
3309 linker_options [n_linker_options - 1] = save_string (option, len);
3312 /* Create the vector `switches' and its contents.
3313 Store its length in `n_switches'. */
3315 static void
3316 process_command (int argc, const char **argv)
3318 int i;
3319 const char *temp;
3320 char *temp1;
3321 const char *spec_lang = 0;
3322 int last_language_n_infiles;
3323 int lang_n_infiles = 0;
3324 #ifdef MODIFY_TARGET_NAME
3325 int is_modify_target_name;
3326 unsigned int j;
3327 #endif
3328 const char *tooldir_prefix;
3330 GET_ENVIRONMENT (gcc_exec_prefix, "GCC_EXEC_PREFIX");
3332 n_switches = 0;
3333 n_infiles = 0;
3334 added_libraries = 0;
3336 /* Figure compiler version from version string. */
3338 compiler_version = temp1 = xstrdup (version_string);
3340 for (; *temp1; ++temp1)
3342 if (*temp1 == ' ')
3344 *temp1 = '\0';
3345 break;
3349 /* If there is a -V or -b option (or both), process it now, before
3350 trying to interpret the rest of the command line.
3351 Use heuristic that all configuration names must have at least
3352 one dash '-'. This allows us to pass options starting with -b. */
3353 if (argc > 1 && argv[1][0] == '-'
3354 && (argv[1][1] == 'V' ||
3355 ((argv[1][1] == 'b') && (NULL != strchr(argv[1] + 2,'-')))))
3357 const char *new_version = DEFAULT_TARGET_VERSION;
3358 const char *new_machine = DEFAULT_TARGET_MACHINE;
3359 const char *progname = argv[0];
3360 char **new_argv;
3361 char *new_argv0;
3362 int baselen;
3364 while (argc > 1 && argv[1][0] == '-'
3365 && (argv[1][1] == 'V' ||
3366 ((argv[1][1] == 'b') && ( NULL != strchr(argv[1] + 2,'-')))))
3368 char opt = argv[1][1];
3369 const char *arg;
3370 if (argv[1][2] != '\0')
3372 arg = argv[1] + 2;
3373 argc -= 1;
3374 argv += 1;
3376 else if (argc > 2)
3378 arg = argv[2];
3379 argc -= 2;
3380 argv += 2;
3382 else
3383 fatal ("'-%c' option must have argument", opt);
3384 if (opt == 'V')
3385 new_version = arg;
3386 else
3387 new_machine = arg;
3390 for (baselen = strlen (progname); baselen > 0; baselen--)
3391 if (IS_DIR_SEPARATOR (progname[baselen-1]))
3392 break;
3393 new_argv0 = xmemdup (progname, baselen,
3394 baselen + concat_length (new_version, new_machine,
3395 "-gcc-", NULL) + 1);
3396 strcpy (new_argv0 + baselen, new_machine);
3397 strcat (new_argv0, "-gcc-");
3398 strcat (new_argv0, new_version);
3400 new_argv = xmemdup (argv, (argc + 1) * sizeof (argv[0]),
3401 (argc + 1) * sizeof (argv[0]));
3402 new_argv[0] = new_argv0;
3404 execvp (new_argv0, new_argv);
3405 fatal ("couldn't run '%s': %s", new_argv0, xstrerror (errno));
3408 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3409 see if we can create it from the pathname specified in argv[0]. */
3411 gcc_libexec_prefix = standard_libexec_prefix;
3412 #ifndef VMS
3413 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3414 if (!gcc_exec_prefix)
3416 gcc_exec_prefix = make_relative_prefix (argv[0], standard_bindir_prefix,
3417 standard_exec_prefix);
3418 gcc_libexec_prefix = make_relative_prefix (argv[0],
3419 standard_bindir_prefix,
3420 standard_libexec_prefix);
3421 if (gcc_exec_prefix)
3422 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3424 else
3426 /* make_relative_prefix requires a program name, but
3427 GCC_EXEC_PREFIX is typically a directory name with a trailing
3428 / (which is ignored by make_relative_prefix), so append a
3429 program name. */
3430 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
3431 gcc_libexec_prefix = make_relative_prefix (tmp_prefix,
3432 standard_exec_prefix,
3433 standard_libexec_prefix);
3435 /* The path is unrelocated, so fallback to the original setting. */
3436 if (!gcc_libexec_prefix)
3437 gcc_libexec_prefix = standard_libexec_prefix;
3439 free (tmp_prefix);
3441 #else
3442 #endif
3443 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
3444 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
3445 or an automatically created GCC_EXEC_PREFIX from argv[0]. */
3447 if (gcc_exec_prefix)
3449 int len = strlen (gcc_exec_prefix);
3451 if (len > (int) sizeof ("/lib/gcc/") - 1
3452 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3454 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3455 if (IS_DIR_SEPARATOR (*temp)
3456 && strncmp (temp + 1, "lib", 3) == 0
3457 && IS_DIR_SEPARATOR (temp[4])
3458 && strncmp (temp + 5, "gcc", 3) == 0)
3459 len -= sizeof ("/lib/gcc/") - 1;
3462 set_std_prefix (gcc_exec_prefix, len);
3463 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3464 PREFIX_PRIORITY_LAST, 0, 0);
3465 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3466 PREFIX_PRIORITY_LAST, 0, 0);
3469 /* COMPILER_PATH and LIBRARY_PATH have values
3470 that are lists of directory names with colons. */
3472 GET_ENVIRONMENT (temp, "COMPILER_PATH");
3473 if (temp)
3475 const char *startp, *endp;
3476 char *nstore = alloca (strlen (temp) + 3);
3478 startp = endp = temp;
3479 while (1)
3481 if (*endp == PATH_SEPARATOR || *endp == 0)
3483 strncpy (nstore, startp, endp - startp);
3484 if (endp == startp)
3485 strcpy (nstore, concat (".", dir_separator_str, NULL));
3486 else if (!IS_DIR_SEPARATOR (endp[-1]))
3488 nstore[endp - startp] = DIR_SEPARATOR;
3489 nstore[endp - startp + 1] = 0;
3491 else
3492 nstore[endp - startp] = 0;
3493 add_prefix (&exec_prefixes, nstore, 0,
3494 PREFIX_PRIORITY_LAST, 0, 0);
3495 add_prefix (&include_prefixes, nstore, 0,
3496 PREFIX_PRIORITY_LAST, 0, 0);
3497 if (*endp == 0)
3498 break;
3499 endp = startp = endp + 1;
3501 else
3502 endp++;
3506 GET_ENVIRONMENT (temp, LIBRARY_PATH_ENV);
3507 if (temp && *cross_compile == '0')
3509 const char *startp, *endp;
3510 char *nstore = alloca (strlen (temp) + 3);
3512 startp = endp = temp;
3513 while (1)
3515 if (*endp == PATH_SEPARATOR || *endp == 0)
3517 strncpy (nstore, startp, endp - startp);
3518 if (endp == startp)
3519 strcpy (nstore, concat (".", dir_separator_str, NULL));
3520 else if (!IS_DIR_SEPARATOR (endp[-1]))
3522 nstore[endp - startp] = DIR_SEPARATOR;
3523 nstore[endp - startp + 1] = 0;
3525 else
3526 nstore[endp - startp] = 0;
3527 add_prefix (&startfile_prefixes, nstore, NULL,
3528 PREFIX_PRIORITY_LAST, 0, 1);
3529 if (*endp == 0)
3530 break;
3531 endp = startp = endp + 1;
3533 else
3534 endp++;
3538 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3539 GET_ENVIRONMENT (temp, "LPATH");
3540 if (temp && *cross_compile == '0')
3542 const char *startp, *endp;
3543 char *nstore = alloca (strlen (temp) + 3);
3545 startp = endp = temp;
3546 while (1)
3548 if (*endp == PATH_SEPARATOR || *endp == 0)
3550 strncpy (nstore, startp, endp - startp);
3551 if (endp == startp)
3552 strcpy (nstore, concat (".", dir_separator_str, NULL));
3553 else if (!IS_DIR_SEPARATOR (endp[-1]))
3555 nstore[endp - startp] = DIR_SEPARATOR;
3556 nstore[endp - startp + 1] = 0;
3558 else
3559 nstore[endp - startp] = 0;
3560 add_prefix (&startfile_prefixes, nstore, NULL,
3561 PREFIX_PRIORITY_LAST, 0, 1);
3562 if (*endp == 0)
3563 break;
3564 endp = startp = endp + 1;
3566 else
3567 endp++;
3571 /* Convert new-style -- options to old-style. */
3572 translate_options (&argc, (const char *const **) &argv);
3574 /* Do language-specific adjustment/addition of flags. */
3575 lang_specific_driver (&argc, (const char *const **) &argv, &added_libraries);
3577 /* Scan argv twice. Here, the first time, just count how many switches
3578 there will be in their vector, and how many input files in theirs.
3579 Here we also parse the switches that cc itself uses (e.g. -v). */
3581 for (i = 1; i < argc; i++)
3583 if (! strcmp (argv[i], "-dumpspecs"))
3585 struct spec_list *sl;
3586 init_spec ();
3587 for (sl = specs; sl; sl = sl->next)
3588 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3589 if (link_command_spec)
3590 printf ("*link_command:\n%s\n\n", link_command_spec);
3591 exit (0);
3593 else if (! strcmp (argv[i], "-dumpversion"))
3595 printf ("%s\n", spec_version);
3596 exit (0);
3598 else if (! strcmp (argv[i], "-dumpmachine"))
3600 printf ("%s\n", spec_machine);
3601 exit (0);
3603 else if (strcmp (argv[i], "-fversion") == 0)
3605 /* translate_options () has turned --version into -fversion. */
3606 printf (_("%s %s%s\n"), programname, pkgversion_string,
3607 version_string);
3608 printf ("Copyright %s 2007 Free Software Foundation, Inc.\n",
3609 _("(C)"));
3610 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
3611 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
3612 stdout);
3613 exit (0);
3615 else if (strcmp (argv[i], "-fhelp") == 0)
3617 /* translate_options () has turned --help into -fhelp. */
3618 print_help_list = 1;
3620 /* We will be passing a dummy file on to the sub-processes. */
3621 n_infiles++;
3622 n_switches++;
3624 /* CPP driver cannot obtain switch from cc1_options. */
3625 if (is_cpp_driver)
3626 add_preprocessor_option ("--help", 6);
3627 add_assembler_option ("--help", 6);
3628 add_linker_option ("--help", 6);
3630 else if (strncmp (argv[i], "-fhelp=", 7) == 0)
3632 /* translate_options () has turned --help into -fhelp. */
3633 print_subprocess_help = 2;
3635 /* We will be passing a dummy file on to the sub-processes. */
3636 n_infiles++;
3637 n_switches++;
3639 else if (strcmp (argv[i], "-ftarget-help") == 0)
3641 /* translate_options() has turned --target-help into -ftarget-help. */
3642 print_subprocess_help = 1;
3644 /* We will be passing a dummy file on to the sub-processes. */
3645 n_infiles++;
3646 n_switches++;
3648 /* CPP driver cannot obtain switch from cc1_options. */
3649 if (is_cpp_driver)
3650 add_preprocessor_option ("--target-help", 13);
3651 add_assembler_option ("--target-help", 13);
3652 add_linker_option ("--target-help", 13);
3654 else if (! strcmp (argv[i], "-pass-exit-codes"))
3656 pass_exit_codes = 1;
3657 n_switches++;
3659 else if (! strcmp (argv[i], "-print-search-dirs"))
3660 print_search_dirs = 1;
3661 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
3662 print_file_name = "libgcc.a";
3663 else if (! strncmp (argv[i], "-print-file-name=", 17))
3664 print_file_name = argv[i] + 17;
3665 else if (! strncmp (argv[i], "-print-prog-name=", 17))
3666 print_prog_name = argv[i] + 17;
3667 else if (! strcmp (argv[i], "-print-multi-lib"))
3668 print_multi_lib = 1;
3669 else if (! strcmp (argv[i], "-print-multi-directory"))
3670 print_multi_directory = 1;
3671 else if (! strcmp (argv[i], "-print-multi-os-directory"))
3672 print_multi_os_directory = 1;
3673 else if (! strcmp (argv[i], "-print-sysroot-headers-suffix"))
3674 print_sysroot_headers_suffix = 1;
3675 else if (! strncmp (argv[i], "-Wa,", 4))
3677 int prev, j;
3678 /* Pass the rest of this option to the assembler. */
3680 /* Split the argument at commas. */
3681 prev = 4;
3682 for (j = 4; argv[i][j]; j++)
3683 if (argv[i][j] == ',')
3685 add_assembler_option (argv[i] + prev, j - prev);
3686 prev = j + 1;
3689 /* Record the part after the last comma. */
3690 add_assembler_option (argv[i] + prev, j - prev);
3692 else if (! strncmp (argv[i], "-Wp,", 4))
3694 int prev, j;
3695 /* Pass the rest of this option to the preprocessor. */
3697 /* Split the argument at commas. */
3698 prev = 4;
3699 for (j = 4; argv[i][j]; j++)
3700 if (argv[i][j] == ',')
3702 add_preprocessor_option (argv[i] + prev, j - prev);
3703 prev = j + 1;
3706 /* Record the part after the last comma. */
3707 add_preprocessor_option (argv[i] + prev, j - prev);
3709 else if (argv[i][0] == '+' && argv[i][1] == 'e')
3710 /* The +e options to the C++ front-end. */
3711 n_switches++;
3712 else if (strncmp (argv[i], "-Wl,", 4) == 0)
3714 int j;
3715 /* Split the argument at commas. */
3716 for (j = 3; argv[i][j]; j++)
3717 n_infiles += (argv[i][j] == ',');
3719 else if (strcmp (argv[i], "-Xlinker") == 0)
3721 if (i + 1 == argc)
3722 fatal ("argument to '-Xlinker' is missing");
3724 n_infiles++;
3725 i++;
3727 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
3729 if (i + 1 == argc)
3730 fatal ("argument to '-Xpreprocessor' is missing");
3732 add_preprocessor_option (argv[i+1], strlen (argv[i+1]));
3734 else if (strcmp (argv[i], "-Xassembler") == 0)
3736 if (i + 1 == argc)
3737 fatal ("argument to '-Xassembler' is missing");
3739 add_assembler_option (argv[i+1], strlen (argv[i+1]));
3741 else if (strcmp (argv[i], "-l") == 0)
3743 if (i + 1 == argc)
3744 fatal ("argument to '-l' is missing");
3746 n_infiles++;
3747 i++;
3749 else if (strncmp (argv[i], "-l", 2) == 0)
3750 n_infiles++;
3751 else if (strcmp (argv[i], "-save-temps") == 0)
3753 save_temps_flag = 1;
3754 n_switches++;
3756 else if (strcmp (argv[i], "-combine") == 0)
3758 combine_flag = 1;
3759 n_switches++;
3761 else if (strcmp (argv[i], "-specs") == 0)
3763 struct user_specs *user = XNEW (struct user_specs);
3764 if (++i >= argc)
3765 fatal ("argument to '-specs' is missing");
3767 user->next = (struct user_specs *) 0;
3768 user->filename = argv[i];
3769 if (user_specs_tail)
3770 user_specs_tail->next = user;
3771 else
3772 user_specs_head = user;
3773 user_specs_tail = user;
3775 else if (strncmp (argv[i], "-specs=", 7) == 0)
3777 struct user_specs *user = XNEW (struct user_specs);
3778 if (strlen (argv[i]) == 7)
3779 fatal ("argument to '-specs=' is missing");
3781 user->next = (struct user_specs *) 0;
3782 user->filename = argv[i] + 7;
3783 if (user_specs_tail)
3784 user_specs_tail->next = user;
3785 else
3786 user_specs_head = user;
3787 user_specs_tail = user;
3789 else if (strcmp (argv[i], "-time") == 0)
3790 report_times = 1;
3791 else if (strcmp (argv[i], "-pipe") == 0)
3793 /* -pipe has to go into the switches array as well as
3794 setting a flag. */
3795 use_pipes = 1;
3796 n_switches++;
3798 else if (strcmp (argv[i], "-###") == 0)
3800 /* This is similar to -v except that there is no execution
3801 of the commands and the echoed arguments are quoted. It
3802 is intended for use in shell scripts to capture the
3803 driver-generated command line. */
3804 verbose_only_flag++;
3805 verbose_flag++;
3807 else if (argv[i][0] == '-' && argv[i][1] != 0)
3809 const char *p = &argv[i][1];
3810 int c = *p;
3812 switch (c)
3814 case 'b':
3815 if (NULL == strchr(argv[i] + 2, '-'))
3816 goto normal_switch;
3818 /* Fall through. */
3819 case 'V':
3820 fatal ("'-%c' must come at the start of the command line", c);
3821 break;
3823 case 'B':
3825 const char *value;
3826 int len;
3828 if (p[1] == 0 && i + 1 == argc)
3829 fatal ("argument to '-B' is missing");
3830 if (p[1] == 0)
3831 value = argv[++i];
3832 else
3833 value = p + 1;
3835 len = strlen (value);
3837 /* Catch the case where the user has forgotten to append a
3838 directory separator to the path. Note, they may be using
3839 -B to add an executable name prefix, eg "i386-elf-", in
3840 order to distinguish between multiple installations of
3841 GCC in the same directory. Hence we must check to see
3842 if appending a directory separator actually makes a
3843 valid directory name. */
3844 if (! IS_DIR_SEPARATOR (value [len - 1])
3845 && is_directory (value, false))
3847 char *tmp = XNEWVEC (char, len + 2);
3848 strcpy (tmp, value);
3849 tmp[len] = DIR_SEPARATOR;
3850 tmp[++ len] = 0;
3851 value = tmp;
3854 add_prefix (&exec_prefixes, value, NULL,
3855 PREFIX_PRIORITY_B_OPT, 0, 0);
3856 add_prefix (&startfile_prefixes, value, NULL,
3857 PREFIX_PRIORITY_B_OPT, 0, 0);
3858 add_prefix (&include_prefixes, value, NULL,
3859 PREFIX_PRIORITY_B_OPT, 0, 0);
3860 n_switches++;
3862 break;
3864 case 'v': /* Print our subcommands and print versions. */
3865 n_switches++;
3866 /* If they do anything other than exactly `-v', don't set
3867 verbose_flag; rather, continue on to give the error. */
3868 if (p[1] != 0)
3869 break;
3870 verbose_flag++;
3871 break;
3873 case 'S':
3874 case 'c':
3875 if (p[1] == 0)
3877 have_c = 1;
3878 n_switches++;
3879 break;
3881 goto normal_switch;
3883 case 'o':
3884 have_o = 1;
3885 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3886 if (! have_c)
3888 int skip;
3890 /* Forward scan, just in case -S or -c is specified
3891 after -o. */
3892 int j = i + 1;
3893 if (p[1] == 0)
3894 ++j;
3895 while (j < argc)
3897 if (argv[j][0] == '-')
3899 if (SWITCH_CURTAILS_COMPILATION (argv[j][1])
3900 && argv[j][2] == 0)
3902 have_c = 1;
3903 break;
3905 else if ((skip = SWITCH_TAKES_ARG (argv[j][1])))
3906 j += skip - (argv[j][2] != 0);
3907 else if ((skip = WORD_SWITCH_TAKES_ARG (argv[j] + 1)))
3908 j += skip;
3910 j++;
3913 #endif
3914 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3915 if (p[1] == 0)
3916 argv[i + 1] = convert_filename (argv[i + 1], ! have_c, 0);
3917 else
3918 argv[i] = convert_filename (argv[i], ! have_c, 0);
3919 #endif
3920 goto normal_switch;
3922 default:
3923 normal_switch:
3925 #ifdef MODIFY_TARGET_NAME
3926 is_modify_target_name = 0;
3928 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
3929 if (! strcmp (argv[i], modify_target[j].sw))
3931 char *new_name = xmalloc (strlen (modify_target[j].str)
3932 + strlen (spec_machine));
3933 const char *p, *r;
3934 char *q;
3935 int made_addition = 0;
3937 is_modify_target_name = 1;
3938 for (p = spec_machine, q = new_name; *p != 0; )
3940 if (modify_target[j].add_del == DELETE
3941 && (! strncmp (q, modify_target[j].str,
3942 strlen (modify_target[j].str))))
3943 p += strlen (modify_target[j].str);
3944 else if (modify_target[j].add_del == ADD
3945 && ! made_addition && *p == '-')
3947 for (r = modify_target[j].str; *r != 0; )
3948 *q++ = *r++;
3949 made_addition = 1;
3952 *q++ = *p++;
3955 spec_machine = new_name;
3958 if (is_modify_target_name)
3959 break;
3960 #endif
3962 n_switches++;
3964 if (SWITCH_TAKES_ARG (c) > (p[1] != 0))
3965 i += SWITCH_TAKES_ARG (c) - (p[1] != 0);
3966 else if (WORD_SWITCH_TAKES_ARG (p))
3967 i += WORD_SWITCH_TAKES_ARG (p);
3970 else
3972 n_infiles++;
3973 lang_n_infiles++;
3977 if (save_temps_flag && use_pipes)
3979 /* -save-temps overrides -pipe, so that temp files are produced */
3980 if (save_temps_flag)
3981 error ("warning: -pipe ignored because -save-temps specified");
3982 use_pipes = 0;
3985 /* Set up the search paths. We add directories that we expect to
3986 contain GNU Toolchain components before directories specified by
3987 the machine description so that we will find GNU components (like
3988 the GNU assembler) before those of the host system. */
3990 /* If we don't know where the toolchain has been installed, use the
3991 configured-in locations. */
3992 if (!gcc_exec_prefix)
3994 #ifndef OS2
3995 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
3996 PREFIX_PRIORITY_LAST, 1, 0);
3997 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
3998 PREFIX_PRIORITY_LAST, 2, 0);
3999 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
4000 PREFIX_PRIORITY_LAST, 2, 0);
4001 #endif
4002 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
4003 PREFIX_PRIORITY_LAST, 1, 0);
4006 /* If not cross-compiling, search well-known system locations. */
4007 if (*cross_compile == '0')
4009 #ifndef OS2
4010 add_prefix (&exec_prefixes, standard_exec_prefix_1, "BINUTILS",
4011 PREFIX_PRIORITY_LAST, 2, 0);
4012 add_prefix (&exec_prefixes, standard_exec_prefix_2, "BINUTILS",
4013 PREFIX_PRIORITY_LAST, 2, 0);
4014 #endif
4015 add_prefix (&startfile_prefixes, standard_exec_prefix_2, "BINUTILS",
4016 PREFIX_PRIORITY_LAST, 1, 0);
4019 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
4020 tooldir_prefix = concat (tooldir_base_prefix, spec_machine,
4021 dir_separator_str, NULL);
4023 /* Look for tools relative to the location from which the driver is
4024 running, or, if that is not available, the configured prefix. */
4025 tooldir_prefix
4026 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4027 spec_machine, dir_separator_str,
4028 spec_version, dir_separator_str, tooldir_prefix, NULL);
4030 add_prefix (&exec_prefixes,
4031 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4032 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4033 add_prefix (&startfile_prefixes,
4034 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4035 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4037 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4038 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4039 then consider it to relocate with the rest of the GCC installation
4040 if GCC_EXEC_PREFIX is set.
4041 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4042 if (target_system_root && gcc_exec_prefix)
4044 char *tmp_prefix = make_relative_prefix (argv[0],
4045 standard_bindir_prefix,
4046 target_system_root);
4047 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4049 target_system_root = tmp_prefix;
4050 target_system_root_changed = 1;
4053 #endif
4055 /* More prefixes are enabled in main, after we read the specs file
4056 and determine whether this is cross-compilation or not. */
4058 /* Then create the space for the vectors and scan again. */
4060 switches = XNEWVEC (struct switchstr, n_switches + 1);
4061 infiles = XNEWVEC (struct infile, n_infiles + 1);
4062 n_switches = 0;
4063 n_infiles = 0;
4064 last_language_n_infiles = -1;
4066 /* This, time, copy the text of each switch and store a pointer
4067 to the copy in the vector of switches.
4068 Store all the infiles in their vector. */
4070 for (i = 1; i < argc; i++)
4072 /* Just skip the switches that were handled by the preceding loop. */
4073 #ifdef MODIFY_TARGET_NAME
4074 is_modify_target_name = 0;
4076 for (j = 0; j < ARRAY_SIZE (modify_target); j++)
4077 if (! strcmp (argv[i], modify_target[j].sw))
4078 is_modify_target_name = 1;
4080 if (is_modify_target_name)
4082 else
4083 #endif
4084 if (! strncmp (argv[i], "-Wa,", 4))
4086 else if (! strncmp (argv[i], "-Wp,", 4))
4088 else if (! strcmp (argv[i], "-pass-exit-codes"))
4090 else if (! strcmp (argv[i], "-print-search-dirs"))
4092 else if (! strcmp (argv[i], "-print-libgcc-file-name"))
4094 else if (! strncmp (argv[i], "-print-file-name=", 17))
4096 else if (! strncmp (argv[i], "-print-prog-name=", 17))
4098 else if (! strcmp (argv[i], "-print-multi-lib"))
4100 else if (! strcmp (argv[i], "-print-multi-directory"))
4102 else if (! strcmp (argv[i], "-print-multi-os-directory"))
4104 else if (! strcmp (argv[i], "-print-sysroot-headers-suffix"))
4106 else if (! strncmp (argv[i], "--sysroot=", strlen ("--sysroot=")))
4108 target_system_root = argv[i] + strlen ("--sysroot=");
4109 target_system_root_changed = 1;
4111 else if (argv[i][0] == '+' && argv[i][1] == 'e')
4113 /* Compensate for the +e options to the C++ front-end;
4114 they're there simply for cfront call-compatibility. We do
4115 some magic in default_compilers to pass them down properly.
4116 Note we deliberately start at the `+' here, to avoid passing
4117 -e0 or -e1 down into the linker. */
4118 switches[n_switches].part1 = &argv[i][0];
4119 switches[n_switches].args = 0;
4120 switches[n_switches].live_cond = 0;
4121 switches[n_switches].validated = 0;
4122 n_switches++;
4124 else if (strncmp (argv[i], "-Wl,", 4) == 0)
4126 int prev, j;
4127 /* Split the argument at commas. */
4128 prev = 4;
4129 for (j = 4; argv[i][j]; j++)
4130 if (argv[i][j] == ',')
4132 infiles[n_infiles].language = "*";
4133 infiles[n_infiles++].name
4134 = save_string (argv[i] + prev, j - prev);
4135 prev = j + 1;
4137 /* Record the part after the last comma. */
4138 infiles[n_infiles].language = "*";
4139 infiles[n_infiles++].name = argv[i] + prev;
4141 else if (strcmp (argv[i], "-Xlinker") == 0)
4143 infiles[n_infiles].language = "*";
4144 infiles[n_infiles++].name = argv[++i];
4146 /* Xassembler and Xpreprocessor were already handled in the first argv
4147 scan, so all we need to do here is ignore them and their argument. */
4148 else if (strcmp (argv[i], "-Xassembler") == 0)
4149 i++;
4150 else if (strcmp (argv[i], "-Xpreprocessor") == 0)
4151 i++;
4152 else if (strcmp (argv[i], "-l") == 0)
4153 { /* POSIX allows separation of -l and the lib arg;
4154 canonicalize by concatenating -l with its arg */
4155 infiles[n_infiles].language = "*";
4156 infiles[n_infiles++].name = concat ("-l", argv[++i], NULL);
4158 else if (strncmp (argv[i], "-l", 2) == 0)
4160 infiles[n_infiles].language = "*";
4161 infiles[n_infiles++].name = argv[i];
4163 else if (strcmp (argv[i], "-specs") == 0)
4164 i++;
4165 else if (strncmp (argv[i], "-specs=", 7) == 0)
4167 else if (strcmp (argv[i], "-time") == 0)
4169 else if (strcmp (argv[i], "-###") == 0)
4171 else if (argv[i][0] == '-' && argv[i][1] != 0)
4173 const char *p = &argv[i][1];
4174 int c = *p;
4176 if (c == 'x')
4178 if (p[1] == 0 && i + 1 == argc)
4179 fatal ("argument to '-x' is missing");
4180 if (p[1] == 0)
4181 spec_lang = argv[++i];
4182 else
4183 spec_lang = p + 1;
4184 if (! strcmp (spec_lang, "none"))
4185 /* Suppress the warning if -xnone comes after the last input
4186 file, because alternate command interfaces like g++ might
4187 find it useful to place -xnone after each input file. */
4188 spec_lang = 0;
4189 else
4190 last_language_n_infiles = n_infiles;
4191 continue;
4193 switches[n_switches].part1 = p;
4194 /* Deal with option arguments in separate argv elements. */
4195 if ((SWITCH_TAKES_ARG (c) > (p[1] != 0))
4196 || WORD_SWITCH_TAKES_ARG (p))
4198 int j = 0;
4199 int n_args = WORD_SWITCH_TAKES_ARG (p);
4201 if (n_args == 0)
4203 /* Count only the option arguments in separate argv elements. */
4204 n_args = SWITCH_TAKES_ARG (c) - (p[1] != 0);
4206 if (i + n_args >= argc)
4207 fatal ("argument to '-%s' is missing", p);
4208 switches[n_switches].args
4209 = XNEWVEC (const char *, n_args + 1);
4210 while (j < n_args)
4211 switches[n_switches].args[j++] = argv[++i];
4212 /* Null-terminate the vector. */
4213 switches[n_switches].args[j] = 0;
4215 else if (strchr (switches_need_spaces, c))
4217 /* On some systems, ld cannot handle some options without
4218 a space. So split the option from its argument. */
4219 char *part1 = XNEWVEC (char, 2);
4220 part1[0] = c;
4221 part1[1] = '\0';
4223 switches[n_switches].part1 = part1;
4224 switches[n_switches].args = XNEWVEC (const char *, 2);
4225 switches[n_switches].args[0] = xstrdup (p+1);
4226 switches[n_switches].args[1] = 0;
4228 else
4229 switches[n_switches].args = 0;
4231 switches[n_switches].live_cond = 0;
4232 switches[n_switches].validated = 0;
4233 switches[n_switches].ordering = 0;
4234 /* These are always valid, since gcc.c itself understands the
4235 first four and gfortranspec.c understands -static-libgfortran. */
4236 if (!strcmp (p, "save-temps")
4237 || !strcmp (p, "static-libgcc")
4238 || !strcmp (p, "shared-libgcc")
4239 || !strcmp (p, "pipe")
4240 || !strcmp (p, "static-libgfortran"))
4241 switches[n_switches].validated = 1;
4242 else
4244 char ch = switches[n_switches].part1[0];
4245 if (ch == 'B')
4246 switches[n_switches].validated = 1;
4248 n_switches++;
4250 else
4252 #ifdef HAVE_TARGET_OBJECT_SUFFIX
4253 argv[i] = convert_filename (argv[i], 0, access (argv[i], F_OK));
4254 #endif
4256 if (strcmp (argv[i], "-") != 0 && access (argv[i], F_OK) < 0)
4258 perror_with_name (argv[i]);
4259 error_count++;
4261 else
4263 infiles[n_infiles].language = spec_lang;
4264 infiles[n_infiles++].name = argv[i];
4269 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4270 error ("warning: '-x %s' after last input file has no effect", spec_lang);
4272 /* Ensure we only invoke each subprocess once. */
4273 if (print_subprocess_help || print_help_list)
4275 n_infiles = 1;
4277 /* Create a dummy input file, so that we can pass
4278 the help option on to the various sub-processes. */
4279 infiles[0].language = "c";
4280 infiles[0].name = "help-dummy";
4283 switches[n_switches].part1 = 0;
4284 infiles[n_infiles].name = 0;
4287 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4288 and place that in the environment. */
4290 static void
4291 set_collect_gcc_options (void)
4293 int i;
4294 int first_time;
4296 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4297 the compiler. */
4298 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4299 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4301 first_time = TRUE;
4302 for (i = 0; (int) i < n_switches; i++)
4304 const char *const *args;
4305 const char *p, *q;
4306 if (!first_time)
4307 obstack_grow (&collect_obstack, " ", 1);
4309 first_time = FALSE;
4311 /* Ignore elided switches. */
4312 if ((switches[i].live_cond & SWITCH_IGNORE) != 0)
4313 continue;
4315 obstack_grow (&collect_obstack, "'-", 2);
4316 q = switches[i].part1;
4317 while ((p = strchr (q, '\'')))
4319 obstack_grow (&collect_obstack, q, p - q);
4320 obstack_grow (&collect_obstack, "'\\''", 4);
4321 q = ++p;
4323 obstack_grow (&collect_obstack, q, strlen (q));
4324 obstack_grow (&collect_obstack, "'", 1);
4326 for (args = switches[i].args; args && *args; args++)
4328 obstack_grow (&collect_obstack, " '", 2);
4329 q = *args;
4330 while ((p = strchr (q, '\'')))
4332 obstack_grow (&collect_obstack, q, p - q);
4333 obstack_grow (&collect_obstack, "'\\''", 4);
4334 q = ++p;
4336 obstack_grow (&collect_obstack, q, strlen (q));
4337 obstack_grow (&collect_obstack, "'", 1);
4340 obstack_grow (&collect_obstack, "\0", 1);
4341 xputenv (XOBFINISH (&collect_obstack, char *));
4344 /* Process a spec string, accumulating and running commands. */
4346 /* These variables describe the input file name.
4347 input_file_number is the index on outfiles of this file,
4348 so that the output file name can be stored for later use by %o.
4349 input_basename is the start of the part of the input file
4350 sans all directory names, and basename_length is the number
4351 of characters starting there excluding the suffix .c or whatever. */
4353 static const char *input_filename;
4354 static int input_file_number;
4355 size_t input_filename_length;
4356 static int basename_length;
4357 static int suffixed_basename_length;
4358 static const char *input_basename;
4359 static const char *input_suffix;
4360 #ifndef HOST_LACKS_INODE_NUMBERS
4361 static struct stat input_stat;
4362 #endif
4363 static int input_stat_set;
4365 /* The compiler used to process the current input file. */
4366 static struct compiler *input_file_compiler;
4368 /* These are variables used within do_spec and do_spec_1. */
4370 /* Nonzero if an arg has been started and not yet terminated
4371 (with space, tab or newline). */
4372 static int arg_going;
4374 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4375 is a temporary file name. */
4376 static int delete_this_arg;
4378 /* Nonzero means %w has been seen; the next arg to be terminated
4379 is the output file name of this compilation. */
4380 static int this_is_output_file;
4382 /* Nonzero means %s has been seen; the next arg to be terminated
4383 is the name of a library file and we should try the standard
4384 search dirs for it. */
4385 static int this_is_library_file;
4387 /* Nonzero means that the input of this command is coming from a pipe. */
4388 static int input_from_pipe;
4390 /* Nonnull means substitute this for any suffix when outputting a switches
4391 arguments. */
4392 static const char *suffix_subst;
4394 /* If there is an argument being accumulated, terminate it and store it. */
4396 static void
4397 end_going_arg (void)
4399 if (arg_going)
4401 const char *string;
4403 obstack_1grow (&obstack, 0);
4404 string = XOBFINISH (&obstack, const char *);
4405 if (this_is_library_file)
4406 string = find_file (string);
4407 store_arg (string, delete_this_arg, this_is_output_file);
4408 if (this_is_output_file)
4409 outfiles[input_file_number] = string;
4410 arg_going = 0;
4414 /* Process the spec SPEC and run the commands specified therein.
4415 Returns 0 if the spec is successfully processed; -1 if failed. */
4418 do_spec (const char *spec)
4420 int value;
4422 value = do_spec_2 (spec);
4424 /* Force out any unfinished command.
4425 If -pipe, this forces out the last command if it ended in `|'. */
4426 if (value == 0)
4428 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4429 argbuf_index--;
4431 set_collect_gcc_options ();
4433 if (argbuf_index > 0)
4434 value = execute ();
4437 return value;
4440 static int
4441 do_spec_2 (const char *spec)
4443 int result;
4445 clear_args ();
4446 arg_going = 0;
4447 delete_this_arg = 0;
4448 this_is_output_file = 0;
4449 this_is_library_file = 0;
4450 input_from_pipe = 0;
4451 suffix_subst = NULL;
4453 result = do_spec_1 (spec, 0, NULL);
4455 end_going_arg ();
4457 return result;
4461 /* Process the given spec string and add any new options to the end
4462 of the switches/n_switches array. */
4464 static void
4465 do_option_spec (const char *name, const char *spec)
4467 unsigned int i, value_count, value_len;
4468 const char *p, *q, *value;
4469 char *tmp_spec, *tmp_spec_p;
4471 if (configure_default_options[0].name == NULL)
4472 return;
4474 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4475 if (strcmp (configure_default_options[i].name, name) == 0)
4476 break;
4477 if (i == ARRAY_SIZE (configure_default_options))
4478 return;
4480 value = configure_default_options[i].value;
4481 value_len = strlen (value);
4483 /* Compute the size of the final spec. */
4484 value_count = 0;
4485 p = spec;
4486 while ((p = strstr (p, "%(VALUE)")) != NULL)
4488 p ++;
4489 value_count ++;
4492 /* Replace each %(VALUE) by the specified value. */
4493 tmp_spec = alloca (strlen (spec) + 1
4494 + value_count * (value_len - strlen ("%(VALUE)")));
4495 tmp_spec_p = tmp_spec;
4496 q = spec;
4497 while ((p = strstr (q, "%(VALUE)")) != NULL)
4499 memcpy (tmp_spec_p, q, p - q);
4500 tmp_spec_p = tmp_spec_p + (p - q);
4501 memcpy (tmp_spec_p, value, value_len);
4502 tmp_spec_p += value_len;
4503 q = p + strlen ("%(VALUE)");
4505 strcpy (tmp_spec_p, q);
4507 do_self_spec (tmp_spec);
4510 /* Process the given spec string and add any new options to the end
4511 of the switches/n_switches array. */
4513 static void
4514 do_self_spec (const char *spec)
4516 do_spec_2 (spec);
4517 do_spec_1 (" ", 0, NULL);
4519 if (argbuf_index > 0)
4521 int i, first;
4523 first = n_switches;
4524 n_switches += argbuf_index;
4525 switches = xrealloc (switches,
4526 sizeof (struct switchstr) * (n_switches + 1));
4528 switches[n_switches] = switches[first];
4529 for (i = 0; i < argbuf_index; i++)
4531 struct switchstr *sw;
4533 /* Each switch should start with '-'. */
4534 if (argbuf[i][0] != '-')
4535 fatal ("switch '%s' does not start with '-'", argbuf[i]);
4537 sw = &switches[i + first];
4538 sw->part1 = &argbuf[i][1];
4539 sw->args = 0;
4540 sw->live_cond = 0;
4541 sw->validated = 0;
4542 sw->ordering = 0;
4547 /* Callback for processing %D and %I specs. */
4549 struct spec_path_info {
4550 const char *option;
4551 const char *append;
4552 size_t append_len;
4553 bool omit_relative;
4554 bool separate_options;
4557 static void *
4558 spec_path (char *path, void *data)
4560 struct spec_path_info *info = data;
4561 size_t len = 0;
4562 char save = 0;
4564 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4565 return NULL;
4567 if (info->append_len != 0)
4569 len = strlen (path);
4570 memcpy (path + len, info->append, info->append_len + 1);
4573 if (!is_directory (path, true))
4574 return NULL;
4576 do_spec_1 (info->option, 1, NULL);
4577 if (info->separate_options)
4578 do_spec_1 (" ", 0, NULL);
4580 if (info->append_len == 0)
4582 len = strlen (path);
4583 save = path[len - 1];
4584 if (IS_DIR_SEPARATOR (path[len - 1]))
4585 path[len - 1] = '\0';
4588 do_spec_1 (path, 1, NULL);
4589 do_spec_1 (" ", 0, NULL);
4591 /* Must not damage the original path. */
4592 if (info->append_len == 0)
4593 path[len - 1] = save;
4595 return NULL;
4598 /* Process the sub-spec SPEC as a portion of a larger spec.
4599 This is like processing a whole spec except that we do
4600 not initialize at the beginning and we do not supply a
4601 newline by default at the end.
4602 INSWITCH nonzero means don't process %-sequences in SPEC;
4603 in this case, % is treated as an ordinary character.
4604 This is used while substituting switches.
4605 INSWITCH nonzero also causes SPC not to terminate an argument.
4607 Value is zero unless a line was finished
4608 and the command on that line reported an error. */
4610 static int
4611 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4613 const char *p = spec;
4614 int c;
4615 int i;
4616 int value;
4618 while ((c = *p++))
4619 /* If substituting a switch, treat all chars like letters.
4620 Otherwise, NL, SPC, TAB and % are special. */
4621 switch (inswitch ? 'a' : c)
4623 case '\n':
4624 end_going_arg ();
4626 if (argbuf_index > 0 && !strcmp (argbuf[argbuf_index - 1], "|"))
4628 /* A `|' before the newline means use a pipe here,
4629 but only if -pipe was specified.
4630 Otherwise, execute now and don't pass the `|' as an arg. */
4631 if (use_pipes)
4633 input_from_pipe = 1;
4634 break;
4636 else
4637 argbuf_index--;
4640 set_collect_gcc_options ();
4642 if (argbuf_index > 0)
4644 value = execute ();
4645 if (value)
4646 return value;
4648 /* Reinitialize for a new command, and for a new argument. */
4649 clear_args ();
4650 arg_going = 0;
4651 delete_this_arg = 0;
4652 this_is_output_file = 0;
4653 this_is_library_file = 0;
4654 input_from_pipe = 0;
4655 break;
4657 case '|':
4658 end_going_arg ();
4660 /* Use pipe */
4661 obstack_1grow (&obstack, c);
4662 arg_going = 1;
4663 break;
4665 case '\t':
4666 case ' ':
4667 end_going_arg ();
4669 /* Reinitialize for a new argument. */
4670 delete_this_arg = 0;
4671 this_is_output_file = 0;
4672 this_is_library_file = 0;
4673 break;
4675 case '%':
4676 switch (c = *p++)
4678 case 0:
4679 fatal ("spec '%s' invalid", spec);
4681 case 'b':
4682 obstack_grow (&obstack, input_basename, basename_length);
4683 arg_going = 1;
4684 break;
4686 case 'B':
4687 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4688 arg_going = 1;
4689 break;
4691 case 'd':
4692 delete_this_arg = 2;
4693 break;
4695 /* Dump out the directories specified with LIBRARY_PATH,
4696 followed by the absolute directories
4697 that we search for startfiles. */
4698 case 'D':
4700 struct spec_path_info info;
4702 info.option = "-L";
4703 info.append_len = 0;
4704 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4705 /* Used on systems which record the specified -L dirs
4706 and use them to search for dynamic linking.
4707 Relative directories always come from -B,
4708 and it is better not to use them for searching
4709 at run time. In particular, stage1 loses. */
4710 info.omit_relative = true;
4711 #else
4712 info.omit_relative = false;
4713 #endif
4714 info.separate_options = false;
4716 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
4718 break;
4720 case 'e':
4721 /* %efoo means report an error with `foo' as error message
4722 and don't execute any more commands for this file. */
4724 const char *q = p;
4725 char *buf;
4726 while (*p != 0 && *p != '\n')
4727 p++;
4728 buf = alloca (p - q + 1);
4729 strncpy (buf, q, p - q);
4730 buf[p - q] = 0;
4731 error ("%s", buf);
4732 return -1;
4734 break;
4735 case 'n':
4736 /* %nfoo means report a notice with `foo' on stderr. */
4738 const char *q = p;
4739 char *buf;
4740 while (*p != 0 && *p != '\n')
4741 p++;
4742 buf = alloca (p - q + 1);
4743 strncpy (buf, q, p - q);
4744 buf[p - q] = 0;
4745 notice ("%s\n", buf);
4746 if (*p)
4747 p++;
4749 break;
4751 case 'j':
4753 struct stat st;
4755 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4756 defined, and it is not a directory, and it is
4757 writable, use it. Otherwise, treat this like any
4758 other temporary file. */
4760 if ((!save_temps_flag)
4761 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4762 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4764 obstack_grow (&obstack, HOST_BIT_BUCKET,
4765 strlen (HOST_BIT_BUCKET));
4766 delete_this_arg = 0;
4767 arg_going = 1;
4768 break;
4771 goto create_temp_file;
4772 case '|':
4773 if (use_pipes)
4775 obstack_1grow (&obstack, '-');
4776 delete_this_arg = 0;
4777 arg_going = 1;
4779 /* consume suffix */
4780 while (*p == '.' || ISALNUM ((unsigned char) *p))
4781 p++;
4782 if (p[0] == '%' && p[1] == 'O')
4783 p += 2;
4785 break;
4787 goto create_temp_file;
4788 case 'm':
4789 if (use_pipes)
4791 /* consume suffix */
4792 while (*p == '.' || ISALNUM ((unsigned char) *p))
4793 p++;
4794 if (p[0] == '%' && p[1] == 'O')
4795 p += 2;
4797 break;
4799 goto create_temp_file;
4800 case 'g':
4801 case 'u':
4802 case 'U':
4803 create_temp_file:
4805 struct temp_name *t;
4806 int suffix_length;
4807 const char *suffix = p;
4808 char *saved_suffix = NULL;
4810 while (*p == '.' || ISALNUM ((unsigned char) *p))
4811 p++;
4812 suffix_length = p - suffix;
4813 if (p[0] == '%' && p[1] == 'O')
4815 p += 2;
4816 /* We don't support extra suffix characters after %O. */
4817 if (*p == '.' || ISALNUM ((unsigned char) *p))
4818 fatal ("spec '%s' has invalid '%%0%c'", spec, *p);
4819 if (suffix_length == 0)
4820 suffix = TARGET_OBJECT_SUFFIX;
4821 else
4823 saved_suffix
4824 = XNEWVEC (char, suffix_length
4825 + strlen (TARGET_OBJECT_SUFFIX));
4826 strncpy (saved_suffix, suffix, suffix_length);
4827 strcpy (saved_suffix + suffix_length,
4828 TARGET_OBJECT_SUFFIX);
4830 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4833 /* If the input_filename has the same suffix specified
4834 for the %g, %u, or %U, and -save-temps is specified,
4835 we could end up using that file as an intermediate
4836 thus clobbering the user's source file (.e.g.,
4837 gcc -save-temps foo.s would clobber foo.s with the
4838 output of cpp0). So check for this condition and
4839 generate a temp file as the intermediate. */
4841 if (save_temps_flag)
4843 char *tmp;
4845 temp_filename_length = basename_length + suffix_length;
4846 tmp = alloca (temp_filename_length + 1);
4847 strncpy (tmp, input_basename, basename_length);
4848 strncpy (tmp + basename_length, suffix, suffix_length);
4849 tmp[temp_filename_length] = '\0';
4850 temp_filename = tmp;
4851 if (strcmp (temp_filename, input_filename) != 0)
4853 #ifndef HOST_LACKS_INODE_NUMBERS
4854 struct stat st_temp;
4856 /* Note, set_input() resets input_stat_set to 0. */
4857 if (input_stat_set == 0)
4859 input_stat_set = stat (input_filename, &input_stat);
4860 if (input_stat_set >= 0)
4861 input_stat_set = 1;
4864 /* If we have the stat for the input_filename
4865 and we can do the stat for the temp_filename
4866 then the they could still refer to the same
4867 file if st_dev/st_ino's are the same. */
4868 if (input_stat_set != 1
4869 || stat (temp_filename, &st_temp) < 0
4870 || input_stat.st_dev != st_temp.st_dev
4871 || input_stat.st_ino != st_temp.st_ino)
4872 #else
4873 /* Just compare canonical pathnames. */
4874 char* input_realname = lrealpath (input_filename);
4875 char* temp_realname = lrealpath (temp_filename);
4876 bool files_differ = strcmp (input_realname, temp_realname);
4877 free (input_realname);
4878 free (temp_realname);
4879 if (files_differ)
4880 #endif
4882 temp_filename = save_string (temp_filename,
4883 temp_filename_length + 1);
4884 obstack_grow (&obstack, temp_filename,
4885 temp_filename_length);
4886 arg_going = 1;
4887 delete_this_arg = 0;
4888 break;
4893 /* See if we already have an association of %g/%u/%U and
4894 suffix. */
4895 for (t = temp_names; t; t = t->next)
4896 if (t->length == suffix_length
4897 && strncmp (t->suffix, suffix, suffix_length) == 0
4898 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4899 break;
4901 /* Make a new association if needed. %u and %j
4902 require one. */
4903 if (t == 0 || c == 'u' || c == 'j')
4905 if (t == 0)
4907 t = xmalloc (sizeof (struct temp_name));
4908 t->next = temp_names;
4909 temp_names = t;
4911 t->length = suffix_length;
4912 if (saved_suffix)
4914 t->suffix = saved_suffix;
4915 saved_suffix = NULL;
4917 else
4918 t->suffix = save_string (suffix, suffix_length);
4919 t->unique = (c == 'u' || c == 'U' || c == 'j');
4920 temp_filename = make_temp_file (t->suffix);
4921 temp_filename_length = strlen (temp_filename);
4922 t->filename = temp_filename;
4923 t->filename_length = temp_filename_length;
4926 if (saved_suffix)
4927 free (saved_suffix);
4929 obstack_grow (&obstack, t->filename, t->filename_length);
4930 delete_this_arg = 1;
4932 arg_going = 1;
4933 break;
4935 case 'i':
4936 if (combine_inputs)
4938 for (i = 0; (int) i < n_infiles; i++)
4939 if ((!infiles[i].language) || (infiles[i].language[0] != '*'))
4940 if (infiles[i].incompiler == input_file_compiler)
4942 store_arg (infiles[i].name, 0, 0);
4943 infiles[i].compiled = true;
4946 else
4948 obstack_grow (&obstack, input_filename, input_filename_length);
4949 arg_going = 1;
4951 break;
4953 case 'I':
4955 struct spec_path_info info;
4957 if (multilib_dir)
4959 do_spec_1 ("-imultilib", 1, NULL);
4960 /* Make this a separate argument. */
4961 do_spec_1 (" ", 0, NULL);
4962 do_spec_1 (multilib_dir, 1, NULL);
4963 do_spec_1 (" ", 0, NULL);
4966 if (gcc_exec_prefix)
4968 do_spec_1 ("-iprefix", 1, NULL);
4969 /* Make this a separate argument. */
4970 do_spec_1 (" ", 0, NULL);
4971 do_spec_1 (gcc_exec_prefix, 1, NULL);
4972 do_spec_1 (" ", 0, NULL);
4975 if (target_system_root_changed ||
4976 (target_system_root && target_sysroot_hdrs_suffix))
4978 do_spec_1 ("-isysroot", 1, NULL);
4979 /* Make this a separate argument. */
4980 do_spec_1 (" ", 0, NULL);
4981 do_spec_1 (target_system_root, 1, NULL);
4982 if (target_sysroot_hdrs_suffix)
4983 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
4984 do_spec_1 (" ", 0, NULL);
4987 info.option = "-isystem";
4988 info.append = "include";
4989 info.append_len = strlen (info.append);
4990 info.omit_relative = false;
4991 info.separate_options = true;
4993 for_each_path (&include_prefixes, false, info.append_len,
4994 spec_path, &info);
4996 info.append = "include-fixed";
4997 if (*sysroot_hdrs_suffix_spec)
4998 info.append = concat (info.append, dir_separator_str,
4999 multilib_dir, NULL);
5000 info.append_len = strlen (info.append);
5001 for_each_path (&include_prefixes, false, info.append_len,
5002 spec_path, &info);
5004 break;
5006 case 'o':
5008 int max = n_infiles;
5009 max += lang_specific_extra_outfiles;
5011 if (HAVE_GNU_LD && at_file_supplied)
5013 /* We are going to expand `%o' to `@FILE', where FILE
5014 is a newly-created temporary filename. The filenames
5015 that would usually be expanded in place of %o will be
5016 written to the temporary file. */
5018 char *temp_file = make_temp_file ("");
5019 char *at_argument;
5020 char **argv;
5021 int n_files, j, status;
5022 FILE *f;
5024 at_argument = concat ("@", temp_file, NULL);
5025 store_arg (at_argument, 0, 0);
5027 /* Convert OUTFILES into a form suitable for writeargv. */
5029 /* Determine how many are non-NULL. */
5030 for (n_files = 0, i = 0; i < max; i++)
5031 n_files += outfiles[i] != NULL;
5033 argv = alloca (sizeof (char *) * (n_files + 1));
5035 /* Copy the strings over. */
5036 for (i = 0, j = 0; i < max; i++)
5037 if (outfiles[i])
5039 argv[j] = CONST_CAST (char *, outfiles[i]);
5040 j++;
5042 argv[j] = NULL;
5044 f = fopen (temp_file, "w");
5046 if (f == NULL)
5047 fatal ("could not open temporary response file %s",
5048 temp_file);
5050 status = writeargv (argv, f);
5052 if (status)
5053 fatal ("could not write to temporary response file %s",
5054 temp_file);
5056 status = fclose (f);
5058 if (EOF == status)
5059 fatal ("could not close temporary response file %s",
5060 temp_file);
5062 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
5064 else
5065 for (i = 0; i < max; i++)
5066 if (outfiles[i])
5067 store_arg (outfiles[i], 0, 0);
5068 break;
5071 case 'O':
5072 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5073 arg_going = 1;
5074 break;
5076 case 's':
5077 this_is_library_file = 1;
5078 break;
5080 case 'V':
5081 outfiles[input_file_number] = NULL;
5082 break;
5084 case 'w':
5085 this_is_output_file = 1;
5086 break;
5088 case 'W':
5090 int cur_index = argbuf_index;
5091 /* Handle the {...} following the %W. */
5092 if (*p != '{')
5093 fatal ("spec '%s' has invalid '%%W%c", spec, *p);
5094 p = handle_braces (p + 1);
5095 if (p == 0)
5096 return -1;
5097 end_going_arg ();
5098 /* If any args were output, mark the last one for deletion
5099 on failure. */
5100 if (argbuf_index != cur_index)
5101 record_temp_file (argbuf[argbuf_index - 1], 0, 1);
5102 break;
5105 /* %x{OPTION} records OPTION for %X to output. */
5106 case 'x':
5108 const char *p1 = p;
5109 char *string;
5111 /* Skip past the option value and make a copy. */
5112 if (*p != '{')
5113 fatal ("spec '%s' has invalid '%%x%c'", spec, *p);
5114 while (*p++ != '}')
5116 string = save_string (p1 + 1, p - p1 - 2);
5118 /* See if we already recorded this option. */
5119 for (i = 0; i < n_linker_options; i++)
5120 if (! strcmp (string, linker_options[i]))
5122 free (string);
5123 return 0;
5126 /* This option is new; add it. */
5127 add_linker_option (string, strlen (string));
5129 break;
5131 /* Dump out the options accumulated previously using %x. */
5132 case 'X':
5133 for (i = 0; i < n_linker_options; i++)
5135 do_spec_1 (linker_options[i], 1, NULL);
5136 /* Make each accumulated option a separate argument. */
5137 do_spec_1 (" ", 0, NULL);
5139 break;
5141 /* Dump out the options accumulated previously using -Wa,. */
5142 case 'Y':
5143 for (i = 0; i < n_assembler_options; i++)
5145 do_spec_1 (assembler_options[i], 1, NULL);
5146 /* Make each accumulated option a separate argument. */
5147 do_spec_1 (" ", 0, NULL);
5149 break;
5151 /* Dump out the options accumulated previously using -Wp,. */
5152 case 'Z':
5153 for (i = 0; i < n_preprocessor_options; i++)
5155 do_spec_1 (preprocessor_options[i], 1, NULL);
5156 /* Make each accumulated option a separate argument. */
5157 do_spec_1 (" ", 0, NULL);
5159 break;
5161 /* Here are digits and numbers that just process
5162 a certain constant string as a spec. */
5164 case '1':
5165 value = do_spec_1 (cc1_spec, 0, NULL);
5166 if (value != 0)
5167 return value;
5168 break;
5170 case '2':
5171 value = do_spec_1 (cc1plus_spec, 0, NULL);
5172 if (value != 0)
5173 return value;
5174 break;
5176 case 'a':
5177 value = do_spec_1 (asm_spec, 0, NULL);
5178 if (value != 0)
5179 return value;
5180 break;
5182 case 'A':
5183 value = do_spec_1 (asm_final_spec, 0, NULL);
5184 if (value != 0)
5185 return value;
5186 break;
5188 case 'C':
5190 const char *const spec
5191 = (input_file_compiler->cpp_spec
5192 ? input_file_compiler->cpp_spec
5193 : cpp_spec);
5194 value = do_spec_1 (spec, 0, NULL);
5195 if (value != 0)
5196 return value;
5198 break;
5200 case 'E':
5201 value = do_spec_1 (endfile_spec, 0, NULL);
5202 if (value != 0)
5203 return value;
5204 break;
5206 case 'l':
5207 value = do_spec_1 (link_spec, 0, NULL);
5208 if (value != 0)
5209 return value;
5210 break;
5212 case 'L':
5213 value = do_spec_1 (lib_spec, 0, NULL);
5214 if (value != 0)
5215 return value;
5216 break;
5218 case 'G':
5219 value = do_spec_1 (libgcc_spec, 0, NULL);
5220 if (value != 0)
5221 return value;
5222 break;
5224 case 'R':
5225 /* We assume there is a directory
5226 separator at the end of this string. */
5227 if (target_system_root)
5229 obstack_grow (&obstack, target_system_root,
5230 strlen (target_system_root));
5231 if (target_sysroot_suffix)
5232 obstack_grow (&obstack, target_sysroot_suffix,
5233 strlen (target_sysroot_suffix));
5235 break;
5237 case 'S':
5238 value = do_spec_1 (startfile_spec, 0, NULL);
5239 if (value != 0)
5240 return value;
5241 break;
5243 /* Here we define characters other than letters and digits. */
5245 case '{':
5246 p = handle_braces (p);
5247 if (p == 0)
5248 return -1;
5249 break;
5251 case ':':
5252 p = handle_spec_function (p);
5253 if (p == 0)
5254 return -1;
5255 break;
5257 case '%':
5258 obstack_1grow (&obstack, '%');
5259 break;
5261 case '.':
5263 unsigned len = 0;
5265 while (p[len] && p[len] != ' ' && p[len] != '%')
5266 len++;
5267 suffix_subst = save_string (p - 1, len + 1);
5268 p += len;
5270 break;
5272 /* Henceforth ignore the option(s) matching the pattern
5273 after the %<. */
5274 case '<':
5276 unsigned len = 0;
5277 int have_wildcard = 0;
5278 int i;
5280 while (p[len] && p[len] != ' ' && p[len] != '\t')
5281 len++;
5283 if (p[len-1] == '*')
5284 have_wildcard = 1;
5286 for (i = 0; i < n_switches; i++)
5287 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5288 && (have_wildcard || switches[i].part1[len] == '\0'))
5290 switches[i].live_cond |= SWITCH_IGNORE;
5291 switches[i].validated = 1;
5294 p += len;
5296 break;
5298 case '*':
5299 if (soft_matched_part)
5301 do_spec_1 (soft_matched_part, 1, NULL);
5302 do_spec_1 (" ", 0, NULL);
5304 else
5305 /* Catch the case where a spec string contains something like
5306 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5307 hand side of the :. */
5308 error ("spec failure: '%%*' has not been initialized by pattern match");
5309 break;
5311 /* Process a string found as the value of a spec given by name.
5312 This feature allows individual machine descriptions
5313 to add and use their own specs.
5314 %[...] modifies -D options the way %P does;
5315 %(...) uses the spec unmodified. */
5316 case '[':
5317 error ("warning: use of obsolete %%[ operator in specs");
5318 case '(':
5320 const char *name = p;
5321 struct spec_list *sl;
5322 int len;
5324 /* The string after the S/P is the name of a spec that is to be
5325 processed. */
5326 while (*p && *p != ')' && *p != ']')
5327 p++;
5329 /* See if it's in the list. */
5330 for (len = p - name, sl = specs; sl; sl = sl->next)
5331 if (sl->name_len == len && !strncmp (sl->name, name, len))
5333 name = *(sl->ptr_spec);
5334 #ifdef DEBUG_SPECS
5335 notice ("Processing spec %c%s%c, which is '%s'\n",
5336 c, sl->name, (c == '(') ? ')' : ']', name);
5337 #endif
5338 break;
5341 if (sl)
5343 if (c == '(')
5345 value = do_spec_1 (name, 0, NULL);
5346 if (value != 0)
5347 return value;
5349 else
5351 char *x = alloca (strlen (name) * 2 + 1);
5352 char *buf = x;
5353 const char *y = name;
5354 int flag = 0;
5356 /* Copy all of NAME into BUF, but put __ after
5357 every -D and at the end of each arg. */
5358 while (1)
5360 if (! strncmp (y, "-D", 2))
5362 *x++ = '-';
5363 *x++ = 'D';
5364 *x++ = '_';
5365 *x++ = '_';
5366 y += 2;
5367 flag = 1;
5368 continue;
5370 else if (flag
5371 && (*y == ' ' || *y == '\t' || *y == '='
5372 || *y == '}' || *y == 0))
5374 *x++ = '_';
5375 *x++ = '_';
5376 flag = 0;
5378 if (*y == 0)
5379 break;
5380 else
5381 *x++ = *y++;
5383 *x = 0;
5385 value = do_spec_1 (buf, 0, NULL);
5386 if (value != 0)
5387 return value;
5391 /* Discard the closing paren or bracket. */
5392 if (*p)
5393 p++;
5395 break;
5397 default:
5398 error ("spec failure: unrecognized spec option '%c'", c);
5399 break;
5401 break;
5403 case '\\':
5404 /* Backslash: treat next character as ordinary. */
5405 c = *p++;
5407 /* Fall through. */
5408 default:
5409 /* Ordinary character: put it into the current argument. */
5410 obstack_1grow (&obstack, c);
5411 arg_going = 1;
5414 /* End of string. If we are processing a spec function, we need to
5415 end any pending argument. */
5416 if (processing_spec_function)
5417 end_going_arg ();
5419 return 0;
5422 /* Look up a spec function. */
5424 static const struct spec_function *
5425 lookup_spec_function (const char *name)
5427 const struct spec_function *sf;
5429 for (sf = static_spec_functions; sf->name != NULL; sf++)
5430 if (strcmp (sf->name, name) == 0)
5431 return sf;
5433 return NULL;
5436 /* Evaluate a spec function. */
5438 static const char *
5439 eval_spec_function (const char *func, const char *args)
5441 const struct spec_function *sf;
5442 const char *funcval;
5444 /* Saved spec processing context. */
5445 int save_argbuf_index;
5446 int save_argbuf_length;
5447 const char **save_argbuf;
5449 int save_arg_going;
5450 int save_delete_this_arg;
5451 int save_this_is_output_file;
5452 int save_this_is_library_file;
5453 int save_input_from_pipe;
5454 const char *save_suffix_subst;
5457 sf = lookup_spec_function (func);
5458 if (sf == NULL)
5459 fatal ("unknown spec function '%s'", func);
5461 /* Push the spec processing context. */
5462 save_argbuf_index = argbuf_index;
5463 save_argbuf_length = argbuf_length;
5464 save_argbuf = argbuf;
5466 save_arg_going = arg_going;
5467 save_delete_this_arg = delete_this_arg;
5468 save_this_is_output_file = this_is_output_file;
5469 save_this_is_library_file = this_is_library_file;
5470 save_input_from_pipe = input_from_pipe;
5471 save_suffix_subst = suffix_subst;
5473 /* Create a new spec processing context, and build the function
5474 arguments. */
5476 alloc_args ();
5477 if (do_spec_2 (args) < 0)
5478 fatal ("error in args to spec function '%s'", func);
5480 /* argbuf_index is an index for the next argument to be inserted, and
5481 so contains the count of the args already inserted. */
5483 funcval = (*sf->func) (argbuf_index, argbuf);
5485 /* Pop the spec processing context. */
5486 argbuf_index = save_argbuf_index;
5487 argbuf_length = save_argbuf_length;
5488 free (argbuf);
5489 argbuf = save_argbuf;
5491 arg_going = save_arg_going;
5492 delete_this_arg = save_delete_this_arg;
5493 this_is_output_file = save_this_is_output_file;
5494 this_is_library_file = save_this_is_library_file;
5495 input_from_pipe = save_input_from_pipe;
5496 suffix_subst = save_suffix_subst;
5498 return funcval;
5501 /* Handle a spec function call of the form:
5503 %:function(args)
5505 ARGS is processed as a spec in a separate context and split into an
5506 argument vector in the normal fashion. The function returns a string
5507 containing a spec which we then process in the caller's context, or
5508 NULL if no processing is required. */
5510 static const char *
5511 handle_spec_function (const char *p)
5513 char *func, *args;
5514 const char *endp, *funcval;
5515 int count;
5517 processing_spec_function++;
5519 /* Get the function name. */
5520 for (endp = p; *endp != '\0'; endp++)
5522 if (*endp == '(') /* ) */
5523 break;
5524 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5525 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5526 fatal ("malformed spec function name");
5528 if (*endp != '(') /* ) */
5529 fatal ("no arguments for spec function");
5530 func = save_string (p, endp - p);
5531 p = ++endp;
5533 /* Get the arguments. */
5534 for (count = 0; *endp != '\0'; endp++)
5536 /* ( */
5537 if (*endp == ')')
5539 if (count == 0)
5540 break;
5541 count--;
5543 else if (*endp == '(') /* ) */
5544 count++;
5546 /* ( */
5547 if (*endp != ')')
5548 fatal ("malformed spec function arguments");
5549 args = save_string (p, endp - p);
5550 p = ++endp;
5552 /* p now points to just past the end of the spec function expression. */
5554 funcval = eval_spec_function (func, args);
5555 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5556 p = NULL;
5558 free (func);
5559 free (args);
5561 processing_spec_function--;
5563 return p;
5566 /* Inline subroutine of handle_braces. Returns true if the current
5567 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5568 static inline bool
5569 input_suffix_matches (const char *atom, const char *end_atom)
5571 return (input_suffix
5572 && !strncmp (input_suffix, atom, end_atom - atom)
5573 && input_suffix[end_atom - atom] == '\0');
5576 /* Subroutine of handle_braces. Returns true if the current
5577 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
5578 static bool
5579 input_spec_matches (const char *atom, const char *end_atom)
5581 return (input_file_compiler
5582 && input_file_compiler->suffix
5583 && input_file_compiler->suffix[0] != '\0'
5584 && !strncmp (input_file_compiler->suffix + 1, atom,
5585 end_atom - atom)
5586 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
5589 /* Subroutine of handle_braces. Returns true if a switch
5590 matching the atom bracketed by ATOM and END_ATOM appeared on the
5591 command line. */
5592 static bool
5593 switch_matches (const char *atom, const char *end_atom, int starred)
5595 int i;
5596 int len = end_atom - atom;
5597 int plen = starred ? len : -1;
5599 for (i = 0; i < n_switches; i++)
5600 if (!strncmp (switches[i].part1, atom, len)
5601 && (starred || switches[i].part1[len] == '\0')
5602 && check_live_switch (i, plen))
5603 return true;
5605 return false;
5608 /* Inline subroutine of handle_braces. Mark all of the switches which
5609 match ATOM (extends to END_ATOM; STARRED indicates whether there
5610 was a star after the atom) for later processing. */
5611 static inline void
5612 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5614 int i;
5615 int len = end_atom - atom;
5616 int plen = starred ? len : -1;
5618 for (i = 0; i < n_switches; i++)
5619 if (!strncmp (switches[i].part1, atom, len)
5620 && (starred || switches[i].part1[len] == '\0')
5621 && check_live_switch (i, plen))
5622 switches[i].ordering = 1;
5625 /* Inline subroutine of handle_braces. Process all the currently
5626 marked switches through give_switch, and clear the marks. */
5627 static inline void
5628 process_marked_switches (void)
5630 int i;
5632 for (i = 0; i < n_switches; i++)
5633 if (switches[i].ordering == 1)
5635 switches[i].ordering = 0;
5636 give_switch (i, 0);
5640 /* Handle a %{ ... } construct. P points just inside the leading {.
5641 Returns a pointer one past the end of the brace block, or 0
5642 if we call do_spec_1 and that returns -1. */
5644 static const char *
5645 handle_braces (const char *p)
5647 const char *atom, *end_atom;
5648 const char *d_atom = NULL, *d_end_atom = NULL;
5649 const char *orig = p;
5651 bool a_is_suffix;
5652 bool a_is_spectype;
5653 bool a_is_starred;
5654 bool a_is_negated;
5655 bool a_matched;
5657 bool a_must_be_last = false;
5658 bool ordered_set = false;
5659 bool disjunct_set = false;
5660 bool disj_matched = false;
5661 bool disj_starred = true;
5662 bool n_way_choice = false;
5663 bool n_way_matched = false;
5665 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5669 if (a_must_be_last)
5670 goto invalid;
5672 /* Scan one "atom" (S in the description above of %{}, possibly
5673 with '!', '.', '@', ',', or '*' modifiers). */
5674 a_matched = false;
5675 a_is_suffix = false;
5676 a_is_starred = false;
5677 a_is_negated = false;
5678 a_is_spectype = false;
5680 SKIP_WHITE();
5681 if (*p == '!')
5682 p++, a_is_negated = true;
5684 SKIP_WHITE();
5685 if (*p == '.')
5686 p++, a_is_suffix = true;
5687 else if (*p == ',')
5688 p++, a_is_spectype = true;
5690 atom = p;
5691 while (ISIDNUM(*p) || *p == '-' || *p == '+' || *p == '='
5692 || *p == ',' || *p == '.' || *p == '@')
5693 p++;
5694 end_atom = p;
5696 if (*p == '*')
5697 p++, a_is_starred = 1;
5699 SKIP_WHITE();
5700 switch (*p)
5702 case '&': case '}':
5703 /* Substitute the switch(es) indicated by the current atom. */
5704 ordered_set = true;
5705 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5706 || a_is_spectype || atom == end_atom)
5707 goto invalid;
5709 mark_matching_switches (atom, end_atom, a_is_starred);
5711 if (*p == '}')
5712 process_marked_switches ();
5713 break;
5715 case '|': case ':':
5716 /* Substitute some text if the current atom appears as a switch
5717 or suffix. */
5718 disjunct_set = true;
5719 if (ordered_set)
5720 goto invalid;
5722 if (atom == end_atom)
5724 if (!n_way_choice || disj_matched || *p == '|'
5725 || a_is_negated || a_is_suffix || a_is_spectype
5726 || a_is_starred)
5727 goto invalid;
5729 /* An empty term may appear as the last choice of an
5730 N-way choice set; it means "otherwise". */
5731 a_must_be_last = true;
5732 disj_matched = !n_way_matched;
5733 disj_starred = false;
5735 else
5737 if ((a_is_suffix || a_is_spectype) && a_is_starred)
5738 goto invalid;
5740 if (!a_is_starred)
5741 disj_starred = false;
5743 /* Don't bother testing this atom if we already have a
5744 match. */
5745 if (!disj_matched && !n_way_matched)
5747 if (a_is_suffix)
5748 a_matched = input_suffix_matches (atom, end_atom);
5749 else if (a_is_spectype)
5750 a_matched = input_spec_matches (atom, end_atom);
5751 else
5752 a_matched = switch_matches (atom, end_atom, a_is_starred);
5754 if (a_matched != a_is_negated)
5756 disj_matched = true;
5757 d_atom = atom;
5758 d_end_atom = end_atom;
5763 if (*p == ':')
5765 /* Found the body, that is, the text to substitute if the
5766 current disjunction matches. */
5767 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5768 disj_matched && !n_way_matched);
5769 if (p == 0)
5770 return 0;
5772 /* If we have an N-way choice, reset state for the next
5773 disjunction. */
5774 if (*p == ';')
5776 n_way_choice = true;
5777 n_way_matched |= disj_matched;
5778 disj_matched = false;
5779 disj_starred = true;
5780 d_atom = d_end_atom = NULL;
5783 break;
5785 default:
5786 goto invalid;
5789 while (*p++ != '}');
5791 return p;
5793 invalid:
5794 fatal ("braced spec '%s' is invalid at '%c'", orig, *p);
5796 #undef SKIP_WHITE
5799 /* Subroutine of handle_braces. Scan and process a brace substitution body
5800 (X in the description of %{} syntax). P points one past the colon;
5801 ATOM and END_ATOM bracket the first atom which was found to be true
5802 (present) in the current disjunction; STARRED indicates whether all
5803 the atoms in the current disjunction were starred (for syntax validation);
5804 MATCHED indicates whether the disjunction matched or not, and therefore
5805 whether or not the body is to be processed through do_spec_1 or just
5806 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5807 returns -1. */
5809 static const char *
5810 process_brace_body (const char *p, const char *atom, const char *end_atom,
5811 int starred, int matched)
5813 const char *body, *end_body;
5814 unsigned int nesting_level;
5815 bool have_subst = false;
5817 /* Locate the closing } or ;, honoring nested braces.
5818 Trim trailing whitespace. */
5819 body = p;
5820 nesting_level = 1;
5821 for (;;)
5823 if (*p == '{')
5824 nesting_level++;
5825 else if (*p == '}')
5827 if (!--nesting_level)
5828 break;
5830 else if (*p == ';' && nesting_level == 1)
5831 break;
5832 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5833 have_subst = true;
5834 else if (*p == '\0')
5835 goto invalid;
5836 p++;
5839 end_body = p;
5840 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5841 end_body--;
5843 if (have_subst && !starred)
5844 goto invalid;
5846 if (matched)
5848 /* Copy the substitution body to permanent storage and execute it.
5849 If have_subst is false, this is a simple matter of running the
5850 body through do_spec_1... */
5851 char *string = save_string (body, end_body - body);
5852 if (!have_subst)
5854 if (do_spec_1 (string, 0, NULL) < 0)
5855 return 0;
5857 else
5859 /* ... but if have_subst is true, we have to process the
5860 body once for each matching switch, with %* set to the
5861 variant part of the switch. */
5862 unsigned int hard_match_len = end_atom - atom;
5863 int i;
5865 for (i = 0; i < n_switches; i++)
5866 if (!strncmp (switches[i].part1, atom, hard_match_len)
5867 && check_live_switch (i, hard_match_len))
5869 if (do_spec_1 (string, 0,
5870 &switches[i].part1[hard_match_len]) < 0)
5871 return 0;
5872 /* Pass any arguments this switch has. */
5873 give_switch (i, 1);
5874 suffix_subst = NULL;
5879 return p;
5881 invalid:
5882 fatal ("braced spec body '%s' is invalid", body);
5885 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5886 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5887 spec, or -1 if either exact match or %* is used.
5889 A -O switch is obsoleted by a later -O switch. A -f, -m, or -W switch
5890 whose value does not begin with "no-" is obsoleted by the same value
5891 with the "no-", similarly for a switch with the "no-" prefix. */
5893 static int
5894 check_live_switch (int switchnum, int prefix_length)
5896 const char *name = switches[switchnum].part1;
5897 int i;
5899 /* In the common case of {<at-most-one-letter>*}, a negating
5900 switch would always match, so ignore that case. We will just
5901 send the conflicting switches to the compiler phase. */
5902 if (prefix_length >= 0 && prefix_length <= 1)
5903 return 1;
5905 /* If we already processed this switch and determined if it was
5906 live or not, return our past determination. */
5907 if (switches[switchnum].live_cond != 0)
5908 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
5909 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0);
5911 /* Now search for duplicate in a manner that depends on the name. */
5912 switch (*name)
5914 case 'O':
5915 for (i = switchnum + 1; i < n_switches; i++)
5916 if (switches[i].part1[0] == 'O')
5918 switches[switchnum].validated = 1;
5919 switches[switchnum].live_cond = SWITCH_FALSE;
5920 return 0;
5922 break;
5924 case 'W': case 'f': case 'm':
5925 if (! strncmp (name + 1, "no-", 3))
5927 /* We have Xno-YYY, search for XYYY. */
5928 for (i = switchnum + 1; i < n_switches; i++)
5929 if (switches[i].part1[0] == name[0]
5930 && ! strcmp (&switches[i].part1[1], &name[4]))
5932 switches[switchnum].validated = 1;
5933 switches[switchnum].live_cond = SWITCH_FALSE;
5934 return 0;
5937 else
5939 /* We have XYYY, search for Xno-YYY. */
5940 for (i = switchnum + 1; i < n_switches; i++)
5941 if (switches[i].part1[0] == name[0]
5942 && switches[i].part1[1] == 'n'
5943 && switches[i].part1[2] == 'o'
5944 && switches[i].part1[3] == '-'
5945 && !strcmp (&switches[i].part1[4], &name[1]))
5947 switches[switchnum].validated = 1;
5948 switches[switchnum].live_cond = SWITCH_FALSE;
5949 return 0;
5952 break;
5955 /* Otherwise the switch is live. */
5956 switches[switchnum].live_cond |= SWITCH_LIVE;
5957 return 1;
5960 /* Pass a switch to the current accumulating command
5961 in the same form that we received it.
5962 SWITCHNUM identifies the switch; it is an index into
5963 the vector of switches gcc received, which is `switches'.
5964 This cannot fail since it never finishes a command line.
5966 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
5968 static void
5969 give_switch (int switchnum, int omit_first_word)
5971 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
5972 return;
5974 if (!omit_first_word)
5976 do_spec_1 ("-", 0, NULL);
5977 do_spec_1 (switches[switchnum].part1, 1, NULL);
5980 if (switches[switchnum].args != 0)
5982 const char **p;
5983 for (p = switches[switchnum].args; *p; p++)
5985 const char *arg = *p;
5987 do_spec_1 (" ", 0, NULL);
5988 if (suffix_subst)
5990 unsigned length = strlen (arg);
5991 int dot = 0;
5993 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
5994 if (arg[length] == '.')
5996 (CONST_CAST(char *, arg))[length] = 0;
5997 dot = 1;
5998 break;
6000 do_spec_1 (arg, 1, NULL);
6001 if (dot)
6002 (CONST_CAST(char *, arg))[length] = '.';
6003 do_spec_1 (suffix_subst, 1, NULL);
6005 else
6006 do_spec_1 (arg, 1, NULL);
6010 do_spec_1 (" ", 0, NULL);
6011 switches[switchnum].validated = 1;
6014 /* Search for a file named NAME trying various prefixes including the
6015 user's -B prefix and some standard ones.
6016 Return the absolute file name found. If nothing is found, return NAME. */
6018 static const char *
6019 find_file (const char *name)
6021 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
6022 return newname ? newname : name;
6025 /* Determine whether a directory exists. If LINKER, return 0 for
6026 certain fixed names not needed by the linker. */
6028 static int
6029 is_directory (const char *path1, bool linker)
6031 int len1;
6032 char *path;
6033 char *cp;
6034 struct stat st;
6036 /* Ensure the string ends with "/.". The resulting path will be a
6037 directory even if the given path is a symbolic link. */
6038 len1 = strlen (path1);
6039 path = alloca (3 + len1);
6040 memcpy (path, path1, len1);
6041 cp = path + len1;
6042 if (!IS_DIR_SEPARATOR (cp[-1]))
6043 *cp++ = DIR_SEPARATOR;
6044 *cp++ = '.';
6045 *cp = '\0';
6047 /* Exclude directories that the linker is known to search. */
6048 if (linker
6049 && IS_DIR_SEPARATOR (path[0])
6050 && ((cp - path == 6
6051 && strncmp (path + 1, "lib", 3) == 0)
6052 || (cp - path == 10
6053 && strncmp (path + 1, "usr", 3) == 0
6054 && IS_DIR_SEPARATOR (path[4])
6055 && strncmp (path + 5, "lib", 3) == 0)))
6056 return 0;
6058 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
6061 /* Set up the various global variables to indicate that we're processing
6062 the input file named FILENAME. */
6064 void
6065 set_input (const char *filename)
6067 const char *p;
6069 input_filename = filename;
6070 input_filename_length = strlen (input_filename);
6072 input_basename = input_filename;
6073 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
6074 /* Skip drive name so 'x:foo' is handled properly. */
6075 if (input_basename[1] == ':')
6076 input_basename += 2;
6077 #endif
6078 for (p = input_basename; *p; p++)
6079 if (IS_DIR_SEPARATOR (*p))
6080 input_basename = p + 1;
6082 /* Find a suffix starting with the last period,
6083 and set basename_length to exclude that suffix. */
6084 basename_length = strlen (input_basename);
6085 suffixed_basename_length = basename_length;
6086 p = input_basename + basename_length;
6087 while (p != input_basename && *p != '.')
6088 --p;
6089 if (*p == '.' && p != input_basename)
6091 basename_length = p - input_basename;
6092 input_suffix = p + 1;
6094 else
6095 input_suffix = "";
6097 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6098 we will need to do a stat on the input_filename. The
6099 INPUT_STAT_SET signals that the stat is needed. */
6100 input_stat_set = 0;
6103 /* On fatal signals, delete all the temporary files. */
6105 static void
6106 fatal_error (int signum)
6108 signal (signum, SIG_DFL);
6109 delete_failure_queue ();
6110 delete_temp_files ();
6111 /* Get the same signal again, this time not handled,
6112 so its normal effect occurs. */
6113 kill (getpid (), signum);
6116 extern int main (int, char **);
6119 main (int argc, char **argv)
6121 size_t i;
6122 int value;
6123 int linker_was_run = 0;
6124 int lang_n_infiles = 0;
6125 int num_linker_inputs = 0;
6126 char *explicit_link_files;
6127 char *specs_file;
6128 const char *p;
6129 struct user_specs *uptr;
6130 char **old_argv = argv;
6132 /* Initialize here, not in definition. The IRIX 6 O32 cc sometimes chokes
6133 on ?: in file-scope variable initializations. */
6134 asm_debug = ASM_DEBUG_SPEC;
6136 p = argv[0] + strlen (argv[0]);
6137 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
6138 --p;
6139 programname = p;
6141 xmalloc_set_program_name (programname);
6143 expandargv (&argc, &argv);
6145 /* Determine if any expansions were made. */
6146 if (argv != old_argv)
6147 at_file_supplied = true;
6149 prune_options (&argc, &argv);
6151 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6152 /* Perform host dependent initialization when needed. */
6153 GCC_DRIVER_HOST_INITIALIZATION;
6154 #endif
6156 /* Unlock the stdio streams. */
6157 unlock_std_streams ();
6159 gcc_init_libintl ();
6161 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6162 signal (SIGINT, fatal_error);
6163 #ifdef SIGHUP
6164 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6165 signal (SIGHUP, fatal_error);
6166 #endif
6167 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6168 signal (SIGTERM, fatal_error);
6169 #ifdef SIGPIPE
6170 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6171 signal (SIGPIPE, fatal_error);
6172 #endif
6173 #ifdef SIGCHLD
6174 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6175 receive the signal. A different setting is inheritable */
6176 signal (SIGCHLD, SIG_DFL);
6177 #endif
6179 /* Allocate the argument vector. */
6180 alloc_args ();
6182 obstack_init (&obstack);
6184 /* Build multilib_select, et. al from the separate lines that make up each
6185 multilib selection. */
6187 const char *const *q = multilib_raw;
6188 int need_space;
6190 obstack_init (&multilib_obstack);
6191 while ((p = *q++) != (char *) 0)
6192 obstack_grow (&multilib_obstack, p, strlen (p));
6194 obstack_1grow (&multilib_obstack, 0);
6195 multilib_select = XOBFINISH (&multilib_obstack, const char *);
6197 q = multilib_matches_raw;
6198 while ((p = *q++) != (char *) 0)
6199 obstack_grow (&multilib_obstack, p, strlen (p));
6201 obstack_1grow (&multilib_obstack, 0);
6202 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
6204 q = multilib_exclusions_raw;
6205 while ((p = *q++) != (char *) 0)
6206 obstack_grow (&multilib_obstack, p, strlen (p));
6208 obstack_1grow (&multilib_obstack, 0);
6209 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
6211 need_space = FALSE;
6212 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6214 if (need_space)
6215 obstack_1grow (&multilib_obstack, ' ');
6216 obstack_grow (&multilib_obstack,
6217 multilib_defaults_raw[i],
6218 strlen (multilib_defaults_raw[i]));
6219 need_space = TRUE;
6222 obstack_1grow (&multilib_obstack, 0);
6223 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
6226 /* Set up to remember the pathname of gcc and any options
6227 needed for collect. We use argv[0] instead of programname because
6228 we need the complete pathname. */
6229 obstack_init (&collect_obstack);
6230 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
6231 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
6232 xputenv (XOBFINISH (&collect_obstack, char *));
6234 #ifdef INIT_ENVIRONMENT
6235 /* Set up any other necessary machine specific environment variables. */
6236 xputenv (INIT_ENVIRONMENT);
6237 #endif
6239 /* Make a table of what switches there are (switches, n_switches).
6240 Make a table of specified input files (infiles, n_infiles).
6241 Decode switches that are handled locally. */
6243 process_command (argc, (const char **) argv);
6245 /* Initialize the vector of specs to just the default.
6246 This means one element containing 0s, as a terminator. */
6248 compilers = xmalloc (sizeof default_compilers);
6249 memcpy (compilers, default_compilers, sizeof default_compilers);
6250 n_compilers = n_default_compilers;
6252 /* Read specs from a file if there is one. */
6254 machine_suffix = concat (spec_machine, dir_separator_str,
6255 spec_version, dir_separator_str, NULL);
6256 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6258 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
6259 /* Read the specs file unless it is a default one. */
6260 if (specs_file != 0 && strcmp (specs_file, "specs"))
6261 read_specs (specs_file, TRUE);
6262 else
6263 init_spec ();
6265 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6266 for any override of as, ld and libraries. */
6267 specs_file = alloca (strlen (standard_exec_prefix)
6268 + strlen (just_machine_suffix) + sizeof ("specs"));
6270 strcpy (specs_file, standard_exec_prefix);
6271 strcat (specs_file, just_machine_suffix);
6272 strcat (specs_file, "specs");
6273 if (access (specs_file, R_OK) == 0)
6274 read_specs (specs_file, TRUE);
6276 /* Process any configure-time defaults specified for the command line
6277 options, via OPTION_DEFAULT_SPECS. */
6278 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6279 do_option_spec (option_default_specs[i].name,
6280 option_default_specs[i].spec);
6282 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6283 of the command line. */
6285 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6286 do_self_spec (driver_self_specs[i]);
6288 /* If not cross-compiling, look for executables in the standard
6289 places. */
6290 if (*cross_compile == '0')
6292 if (*md_exec_prefix)
6294 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6295 PREFIX_PRIORITY_LAST, 0, 0);
6299 /* Process sysroot_suffix_spec. */
6300 if (*sysroot_suffix_spec != 0
6301 && do_spec_2 (sysroot_suffix_spec) == 0)
6303 if (argbuf_index > 1)
6304 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
6305 else if (argbuf_index == 1)
6306 target_sysroot_suffix = xstrdup (argbuf[argbuf_index -1]);
6309 #ifdef HAVE_LD_SYSROOT
6310 /* Pass the --sysroot option to the linker, if it supports that. If
6311 there is a sysroot_suffix_spec, it has already been processed by
6312 this point, so target_system_root really is the system root we
6313 should be using. */
6314 if (target_system_root)
6316 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
6317 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
6318 set_spec ("link", XOBFINISH (&obstack, const char *));
6320 #endif
6322 /* Process sysroot_hdrs_suffix_spec. */
6323 if (*sysroot_hdrs_suffix_spec != 0
6324 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6326 if (argbuf_index > 1)
6327 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
6328 else if (argbuf_index == 1)
6329 target_sysroot_hdrs_suffix = xstrdup (argbuf[argbuf_index -1]);
6332 /* Look for startfiles in the standard places. */
6333 if (*startfile_prefix_spec != 0
6334 && do_spec_2 (startfile_prefix_spec) == 0
6335 && do_spec_1 (" ", 0, NULL) == 0)
6337 int ndx;
6338 for (ndx = 0; ndx < argbuf_index; ndx++)
6339 add_sysrooted_prefix (&startfile_prefixes, argbuf[ndx], "BINUTILS",
6340 PREFIX_PRIORITY_LAST, 0, 1);
6342 /* We should eventually get rid of all these and stick to
6343 startfile_prefix_spec exclusively. */
6344 else if (*cross_compile == '0' || target_system_root)
6346 if (*md_startfile_prefix)
6347 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6348 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6350 if (*md_startfile_prefix_1)
6351 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6352 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6354 /* If standard_startfile_prefix is relative, base it on
6355 standard_exec_prefix. This lets us move the installed tree
6356 as a unit. If GCC_EXEC_PREFIX is defined, base
6357 standard_startfile_prefix on that as well.
6359 If the prefix is relative, only search it for native compilers;
6360 otherwise we will search a directory containing host libraries. */
6361 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6362 add_sysrooted_prefix (&startfile_prefixes,
6363 standard_startfile_prefix, "BINUTILS",
6364 PREFIX_PRIORITY_LAST, 0, 1);
6365 else if (*cross_compile == '0')
6367 add_prefix (&startfile_prefixes,
6368 concat (gcc_exec_prefix
6369 ? gcc_exec_prefix : standard_exec_prefix,
6370 machine_suffix,
6371 standard_startfile_prefix, NULL),
6372 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6375 /* Sysrooted prefixes are relocated because target_system_root is
6376 also relocated by gcc_exec_prefix. */
6377 if (*standard_startfile_prefix_1)
6378 add_sysrooted_prefix (&startfile_prefixes,
6379 standard_startfile_prefix_1, "BINUTILS",
6380 PREFIX_PRIORITY_LAST, 0, 1);
6381 if (*standard_startfile_prefix_2)
6382 add_sysrooted_prefix (&startfile_prefixes,
6383 standard_startfile_prefix_2, "BINUTILS",
6384 PREFIX_PRIORITY_LAST, 0, 1);
6387 /* Process any user specified specs in the order given on the command
6388 line. */
6389 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6391 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6392 R_OK, true);
6393 read_specs (filename ? filename : uptr->filename, FALSE);
6396 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6397 if (gcc_exec_prefix)
6398 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6399 spec_version, dir_separator_str, NULL);
6401 /* Now we have the specs.
6402 Set the `valid' bits for switches that match anything in any spec. */
6404 validate_all_switches ();
6406 /* Now that we have the switches and the specs, set
6407 the subdirectory based on the options. */
6408 set_multilib_dir ();
6410 /* Warn about any switches that no pass was interested in. */
6412 for (i = 0; (int) i < n_switches; i++)
6413 if (! switches[i].validated)
6414 error ("unrecognized option '-%s'", switches[i].part1);
6416 /* Obey some of the options. */
6418 if (print_search_dirs)
6420 printf (_("install: %s%s\n"),
6421 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
6422 gcc_exec_prefix ? "" : machine_suffix);
6423 printf (_("programs: %s\n"),
6424 build_search_list (&exec_prefixes, "", false, false));
6425 printf (_("libraries: %s\n"),
6426 build_search_list (&startfile_prefixes, "", false, true));
6427 return (0);
6430 if (print_file_name)
6432 printf ("%s\n", find_file (print_file_name));
6433 return (0);
6436 if (print_prog_name)
6438 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6439 printf ("%s\n", (newname ? newname : print_prog_name));
6440 return (0);
6443 if (print_multi_lib)
6445 print_multilib_info ();
6446 return (0);
6449 if (print_multi_directory)
6451 if (multilib_dir == NULL)
6452 printf (".\n");
6453 else
6454 printf ("%s\n", multilib_dir);
6455 return (0);
6458 if (print_multi_os_directory)
6460 if (multilib_os_dir == NULL)
6461 printf (".\n");
6462 else
6463 printf ("%s\n", multilib_os_dir);
6464 return (0);
6467 if (print_sysroot_headers_suffix)
6469 if (*sysroot_hdrs_suffix_spec)
6471 printf("%s\n", (target_sysroot_hdrs_suffix
6472 ? target_sysroot_hdrs_suffix
6473 : ""));
6474 return (0);
6476 else
6477 /* The error status indicates that only one set of fixed
6478 headers should be built. */
6479 fatal ("not configured with sysroot headers suffix");
6482 if (print_help_list)
6484 display_help ();
6486 if (! verbose_flag)
6488 printf (_("\nFor bug reporting instructions, please see:\n"));
6489 printf ("%s.\n", bug_report_url);
6491 return (0);
6494 /* We do not exit here. Instead we have created a fake input file
6495 called 'help-dummy' which needs to be compiled, and we pass this
6496 on the various sub-processes, along with the --help switch. */
6499 if (verbose_flag)
6501 int n;
6502 const char *thrmod;
6504 notice ("Target: %s\n", spec_machine);
6505 notice ("Configured with: %s\n", configuration_arguments);
6507 #ifdef THREAD_MODEL_SPEC
6508 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6509 but there's no point in doing all this processing just to get
6510 thread_model back. */
6511 obstack_init (&obstack);
6512 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6513 obstack_1grow (&obstack, '\0');
6514 thrmod = XOBFINISH (&obstack, const char *);
6515 #else
6516 thrmod = thread_model;
6517 #endif
6519 notice ("Thread model: %s\n", thrmod);
6521 /* compiler_version is truncated at the first space when initialized
6522 from version string, so truncate version_string at the first space
6523 before comparing. */
6524 for (n = 0; version_string[n]; n++)
6525 if (version_string[n] == ' ')
6526 break;
6528 if (! strncmp (version_string, compiler_version, n)
6529 && compiler_version[n] == 0)
6530 notice ("gcc version %s %s\n", version_string, pkgversion_string);
6531 else
6532 notice ("gcc driver version %s %sexecuting gcc version %s\n",
6533 version_string, pkgversion_string, compiler_version);
6535 if (n_infiles == 0)
6536 return (0);
6539 if (n_infiles == added_libraries)
6540 fatal ("no input files");
6542 /* Make a place to record the compiler output file names
6543 that correspond to the input files. */
6545 i = n_infiles;
6546 i += lang_specific_extra_outfiles;
6547 outfiles = XCNEWVEC (const char *, i);
6549 /* Record which files were specified explicitly as link input. */
6551 explicit_link_files = XCNEWVEC (char, n_infiles);
6553 if (combine_flag)
6554 combine_inputs = true;
6555 else
6556 combine_inputs = false;
6558 for (i = 0; (int) i < n_infiles; i++)
6560 const char *name = infiles[i].name;
6561 struct compiler *compiler = lookup_compiler (name,
6562 strlen (name),
6563 infiles[i].language);
6565 if (compiler && !(compiler->combinable))
6566 combine_inputs = false;
6568 if (lang_n_infiles > 0 && compiler != input_file_compiler
6569 && infiles[i].language && infiles[i].language[0] != '*')
6570 infiles[i].incompiler = compiler;
6571 else if (compiler)
6573 lang_n_infiles++;
6574 input_file_compiler = compiler;
6575 infiles[i].incompiler = compiler;
6577 else
6579 /* Since there is no compiler for this input file, assume it is a
6580 linker file. */
6581 explicit_link_files[i] = 1;
6582 infiles[i].incompiler = NULL;
6584 infiles[i].compiled = false;
6585 infiles[i].preprocessed = false;
6588 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
6589 fatal ("cannot specify -o with -c or -S with multiple files");
6591 if (combine_flag && save_temps_flag)
6593 bool save_combine_inputs = combine_inputs;
6594 /* Must do a separate pre-processing pass for C & Objective-C files, to
6595 obtain individual .i files. */
6597 combine_inputs = false;
6598 for (i = 0; (int) i < n_infiles; i++)
6600 int this_file_error = 0;
6602 input_file_number = i;
6603 set_input (infiles[i].name);
6604 if (infiles[i].incompiler
6605 && (infiles[i].incompiler)->needs_preprocessing)
6606 input_file_compiler = infiles[i].incompiler;
6607 else
6608 continue;
6610 if (input_file_compiler)
6612 if (input_file_compiler->spec[0] == '#')
6614 error ("%s: %s compiler not installed on this system",
6615 input_filename, &input_file_compiler->spec[1]);
6616 this_file_error = 1;
6618 else
6620 value = do_spec (input_file_compiler->spec);
6621 infiles[i].preprocessed = true;
6622 if (!have_o_argbuf_index)
6623 fatal ("spec '%s' is invalid", input_file_compiler->spec);
6624 infiles[i].name = argbuf[have_o_argbuf_index];
6625 infiles[i].incompiler
6626 = lookup_compiler (infiles[i].name,
6627 strlen (infiles[i].name),
6628 infiles[i].language);
6630 if (value < 0)
6631 this_file_error = 1;
6635 if (this_file_error)
6637 delete_failure_queue ();
6638 error_count++;
6639 break;
6641 clear_failure_queue ();
6643 combine_inputs = save_combine_inputs;
6646 for (i = 0; (int) i < n_infiles; i++)
6648 int this_file_error = 0;
6650 /* Tell do_spec what to substitute for %i. */
6652 input_file_number = i;
6653 set_input (infiles[i].name);
6655 if (infiles[i].compiled)
6656 continue;
6658 /* Use the same thing in %o, unless cp->spec says otherwise. */
6660 outfiles[i] = input_filename;
6662 /* Figure out which compiler from the file's suffix. */
6664 if (! combine_inputs)
6665 input_file_compiler
6666 = lookup_compiler (infiles[i].name, input_filename_length,
6667 infiles[i].language);
6668 else
6669 input_file_compiler = infiles[i].incompiler;
6671 if (input_file_compiler)
6673 /* Ok, we found an applicable compiler. Run its spec. */
6675 if (input_file_compiler->spec[0] == '#')
6677 error ("%s: %s compiler not installed on this system",
6678 input_filename, &input_file_compiler->spec[1]);
6679 this_file_error = 1;
6681 else
6683 value = do_spec (input_file_compiler->spec);
6684 infiles[i].compiled = true;
6685 if (value < 0)
6686 this_file_error = 1;
6690 /* If this file's name does not contain a recognized suffix,
6691 record it as explicit linker input. */
6693 else
6694 explicit_link_files[i] = 1;
6696 /* Clear the delete-on-failure queue, deleting the files in it
6697 if this compilation failed. */
6699 if (this_file_error)
6701 delete_failure_queue ();
6702 error_count++;
6704 /* If this compilation succeeded, don't delete those files later. */
6705 clear_failure_queue ();
6708 /* Reset the input file name to the first compile/object file name, for use
6709 with %b in LINK_SPEC. We use the first input file that we can find
6710 a compiler to compile it instead of using infiles.language since for
6711 languages other than C we use aliases that we then lookup later. */
6712 if (n_infiles > 0)
6714 int i;
6716 for (i = 0; i < n_infiles ; i++)
6717 if (infiles[i].language && infiles[i].language[0] != '*')
6719 set_input (infiles[i].name);
6720 break;
6724 if (error_count == 0)
6726 /* Make sure INPUT_FILE_NUMBER points to first available open
6727 slot. */
6728 input_file_number = n_infiles;
6729 if (lang_specific_pre_link ())
6730 error_count++;
6733 /* Determine if there are any linker input files. */
6734 num_linker_inputs = 0;
6735 for (i = 0; (int) i < n_infiles; i++)
6736 if (explicit_link_files[i] || outfiles[i] != NULL)
6737 num_linker_inputs++;
6739 /* Run ld to link all the compiler output files. */
6741 if (num_linker_inputs > 0 && error_count == 0 && print_subprocess_help < 2)
6743 int tmp = execution_count;
6745 /* We'll use ld if we can't find collect2. */
6746 if (! strcmp (linker_name_spec, "collect2"))
6748 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
6749 if (s == NULL)
6750 linker_name_spec = "ld";
6752 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
6753 for collect. */
6754 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
6755 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
6757 if (print_subprocess_help == 1)
6759 printf (_("\nLinker options\n==============\n\n"));
6760 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
6761 " to the linker.\n\n"));
6762 fflush (stdout);
6764 value = do_spec (link_command_spec);
6765 if (value < 0)
6766 error_count = 1;
6767 linker_was_run = (tmp != execution_count);
6770 /* If options said don't run linker,
6771 complain about input files to be given to the linker. */
6773 if (! linker_was_run && error_count == 0)
6774 for (i = 0; (int) i < n_infiles; i++)
6775 if (explicit_link_files[i]
6776 && !(infiles[i].language && infiles[i].language[0] == '*'))
6777 error ("%s: linker input file unused because linking not done",
6778 outfiles[i]);
6780 /* Delete some or all of the temporary files we made. */
6782 if (error_count)
6783 delete_failure_queue ();
6784 delete_temp_files ();
6786 if (print_help_list)
6788 printf (("\nFor bug reporting instructions, please see:\n"));
6789 printf ("%s\n", bug_report_url);
6792 return (signal_count != 0 ? 2
6793 : error_count > 0 ? (pass_exit_codes ? greatest_status : 1)
6794 : 0);
6797 /* Find the proper compilation spec for the file name NAME,
6798 whose length is LENGTH. LANGUAGE is the specified language,
6799 or 0 if this file is to be passed to the linker. */
6801 static struct compiler *
6802 lookup_compiler (const char *name, size_t length, const char *language)
6804 struct compiler *cp;
6806 /* If this was specified by the user to be a linker input, indicate that. */
6807 if (language != 0 && language[0] == '*')
6808 return 0;
6810 /* Otherwise, look for the language, if one is spec'd. */
6811 if (language != 0)
6813 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6814 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
6815 return cp;
6817 error ("language %s not recognized", language);
6818 return 0;
6821 /* Look for a suffix. */
6822 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6824 if (/* The suffix `-' matches only the file name `-'. */
6825 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6826 || (strlen (cp->suffix) < length
6827 /* See if the suffix matches the end of NAME. */
6828 && !strcmp (cp->suffix,
6829 name + length - strlen (cp->suffix))
6831 break;
6834 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
6835 /* Look again, but case-insensitively this time. */
6836 if (cp < compilers)
6837 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
6839 if (/* The suffix `-' matches only the file name `-'. */
6840 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
6841 || (strlen (cp->suffix) < length
6842 /* See if the suffix matches the end of NAME. */
6843 && ((!strcmp (cp->suffix,
6844 name + length - strlen (cp->suffix))
6845 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
6846 && !strcasecmp (cp->suffix,
6847 name + length - strlen (cp->suffix)))
6849 break;
6851 #endif
6853 if (cp >= compilers)
6855 if (cp->spec[0] != '@')
6856 /* A non-alias entry: return it. */
6857 return cp;
6859 /* An alias entry maps a suffix to a language.
6860 Search for the language; pass 0 for NAME and LENGTH
6861 to avoid infinite recursion if language not found. */
6862 return lookup_compiler (NULL, 0, cp->spec + 1);
6864 return 0;
6867 static char *
6868 save_string (const char *s, int len)
6870 char *result = XNEWVEC (char, len + 1);
6872 memcpy (result, s, len);
6873 result[len] = 0;
6874 return result;
6877 void
6878 pfatal_with_name (const char *name)
6880 perror_with_name (name);
6881 delete_temp_files ();
6882 exit (1);
6885 static void
6886 perror_with_name (const char *name)
6888 error ("%s: %s", name, xstrerror (errno));
6891 /* Output an error message and exit. */
6893 void
6894 fancy_abort (const char *file, int line, const char *func)
6896 fatal_ice ("internal gcc abort in %s, at %s:%d", func, file, line);
6899 /* Output an error message and exit. */
6901 void
6902 fatal_ice (const char *cmsgid, ...)
6904 va_list ap;
6906 va_start (ap, cmsgid);
6908 fprintf (stderr, "%s: ", programname);
6909 vfprintf (stderr, _(cmsgid), ap);
6910 va_end (ap);
6911 fprintf (stderr, "\n");
6912 delete_temp_files ();
6913 exit (pass_exit_codes ? ICE_EXIT_CODE : 1);
6916 void
6917 fatal (const char *cmsgid, ...)
6919 va_list ap;
6921 va_start (ap, cmsgid);
6923 fprintf (stderr, "%s: ", programname);
6924 vfprintf (stderr, _(cmsgid), ap);
6925 va_end (ap);
6926 fprintf (stderr, "\n");
6927 delete_temp_files ();
6928 exit (1);
6931 /* The argument is actually c-format, not gcc-internal-format,
6932 but because functions with identical names are used through
6933 the rest of the compiler with gcc-internal-format, we just
6934 need to hope all users of these functions use the common
6935 subset between c-format and gcc-internal-format. */
6937 void
6938 error (const char *gmsgid, ...)
6940 va_list ap;
6942 va_start (ap, gmsgid);
6943 fprintf (stderr, "%s: ", programname);
6944 vfprintf (stderr, _(gmsgid), ap);
6945 va_end (ap);
6947 fprintf (stderr, "\n");
6950 static void
6951 notice (const char *cmsgid, ...)
6953 va_list ap;
6955 va_start (ap, cmsgid);
6956 vfprintf (stderr, _(cmsgid), ap);
6957 va_end (ap);
6960 static inline void
6961 validate_switches_from_spec (const char *spec)
6963 const char *p = spec;
6964 char c;
6965 while ((c = *p++))
6966 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
6967 /* We have a switch spec. */
6968 p = validate_switches (p + 1);
6971 static void
6972 validate_all_switches (void)
6974 struct compiler *comp;
6975 struct spec_list *spec;
6977 for (comp = compilers; comp->spec; comp++)
6978 validate_switches_from_spec (comp->spec);
6980 /* Look through the linked list of specs read from the specs file. */
6981 for (spec = specs; spec; spec = spec->next)
6982 validate_switches_from_spec (*spec->ptr_spec);
6984 validate_switches_from_spec (link_command_spec);
6987 /* Look at the switch-name that comes after START
6988 and mark as valid all supplied switches that match it. */
6990 static const char *
6991 validate_switches (const char *start)
6993 const char *p = start;
6994 const char *atom;
6995 size_t len;
6996 int i;
6997 bool suffix = false;
6998 bool starred = false;
7000 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
7002 next_member:
7003 SKIP_WHITE ();
7005 if (*p == '!')
7006 p++;
7008 SKIP_WHITE ();
7009 if (*p == '.' || *p == ',')
7010 suffix = true, p++;
7012 atom = p;
7013 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
7014 || *p == ',' || *p == '.' || *p == '@')
7015 p++;
7016 len = p - atom;
7018 if (*p == '*')
7019 starred = true, p++;
7021 SKIP_WHITE ();
7023 if (!suffix)
7025 /* Mark all matching switches as valid. */
7026 for (i = 0; i < n_switches; i++)
7027 if (!strncmp (switches[i].part1, atom, len)
7028 && (starred || switches[i].part1[len] == 0))
7029 switches[i].validated = 1;
7032 if (*p) p++;
7033 if (*p && (p[-1] == '|' || p[-1] == '&'))
7034 goto next_member;
7036 if (*p && p[-1] == ':')
7038 while (*p && *p != ';' && *p != '}')
7040 if (*p == '%')
7042 p++;
7043 if (*p == '{' || *p == '<')
7044 p = validate_switches (p+1);
7045 else if (p[0] == 'W' && p[1] == '{')
7046 p = validate_switches (p+2);
7048 else
7049 p++;
7052 if (*p) p++;
7053 if (*p && p[-1] == ';')
7054 goto next_member;
7057 return p;
7058 #undef SKIP_WHITE
7061 struct mdswitchstr
7063 const char *str;
7064 int len;
7067 static struct mdswitchstr *mdswitches;
7068 static int n_mdswitches;
7070 /* Check whether a particular argument was used. The first time we
7071 canonicalize the switches to keep only the ones we care about. */
7073 static int
7074 used_arg (const char *p, int len)
7076 struct mswitchstr
7078 const char *str;
7079 const char *replace;
7080 int len;
7081 int rep_len;
7084 static struct mswitchstr *mswitches;
7085 static int n_mswitches;
7086 int i, j;
7088 if (!mswitches)
7090 struct mswitchstr *matches;
7091 const char *q;
7092 int cnt = 0;
7094 /* Break multilib_matches into the component strings of string
7095 and replacement string. */
7096 for (q = multilib_matches; *q != '\0'; q++)
7097 if (*q == ';')
7098 cnt++;
7100 matches = alloca ((sizeof (struct mswitchstr)) * cnt);
7101 i = 0;
7102 q = multilib_matches;
7103 while (*q != '\0')
7105 matches[i].str = q;
7106 while (*q != ' ')
7108 if (*q == '\0')
7110 invalid_matches:
7111 fatal ("multilib spec '%s' is invalid", multilib_matches);
7113 q++;
7115 matches[i].len = q - matches[i].str;
7117 matches[i].replace = ++q;
7118 while (*q != ';' && *q != '\0')
7120 if (*q == ' ')
7121 goto invalid_matches;
7122 q++;
7124 matches[i].rep_len = q - matches[i].replace;
7125 i++;
7126 if (*q == ';')
7127 q++;
7130 /* Now build a list of the replacement string for switches that we care
7131 about. Make sure we allocate at least one entry. This prevents
7132 xmalloc from calling fatal, and prevents us from re-executing this
7133 block of code. */
7134 mswitches
7135 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
7136 for (i = 0; i < n_switches; i++)
7137 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
7139 int xlen = strlen (switches[i].part1);
7140 for (j = 0; j < cnt; j++)
7141 if (xlen == matches[j].len
7142 && ! strncmp (switches[i].part1, matches[j].str, xlen))
7144 mswitches[n_mswitches].str = matches[j].replace;
7145 mswitches[n_mswitches].len = matches[j].rep_len;
7146 mswitches[n_mswitches].replace = (char *) 0;
7147 mswitches[n_mswitches].rep_len = 0;
7148 n_mswitches++;
7149 break;
7153 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
7154 on the command line nor any options mutually incompatible with
7155 them. */
7156 for (i = 0; i < n_mdswitches; i++)
7158 const char *r;
7160 for (q = multilib_options; *q != '\0'; q++)
7162 while (*q == ' ')
7163 q++;
7165 r = q;
7166 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
7167 || strchr (" /", q[mdswitches[i].len]) == NULL)
7169 while (*q != ' ' && *q != '/' && *q != '\0')
7170 q++;
7171 if (*q != '/')
7172 break;
7173 q++;
7176 if (*q != ' ' && *q != '\0')
7178 while (*r != ' ' && *r != '\0')
7180 q = r;
7181 while (*q != ' ' && *q != '/' && *q != '\0')
7182 q++;
7184 if (used_arg (r, q - r))
7185 break;
7187 if (*q != '/')
7189 mswitches[n_mswitches].str = mdswitches[i].str;
7190 mswitches[n_mswitches].len = mdswitches[i].len;
7191 mswitches[n_mswitches].replace = (char *) 0;
7192 mswitches[n_mswitches].rep_len = 0;
7193 n_mswitches++;
7194 break;
7197 r = q + 1;
7199 break;
7205 for (i = 0; i < n_mswitches; i++)
7206 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7207 return 1;
7209 return 0;
7212 static int
7213 default_arg (const char *p, int len)
7215 int i;
7217 for (i = 0; i < n_mdswitches; i++)
7218 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7219 return 1;
7221 return 0;
7224 /* Work out the subdirectory to use based on the options. The format of
7225 multilib_select is a list of elements. Each element is a subdirectory
7226 name followed by a list of options followed by a semicolon. The format
7227 of multilib_exclusions is the same, but without the preceding
7228 directory. First gcc will check the exclusions, if none of the options
7229 beginning with an exclamation point are present, and all of the other
7230 options are present, then we will ignore this completely. Passing
7231 that, gcc will consider each multilib_select in turn using the same
7232 rules for matching the options. If a match is found, that subdirectory
7233 will be used. */
7235 static void
7236 set_multilib_dir (void)
7238 const char *p;
7239 unsigned int this_path_len;
7240 const char *this_path, *this_arg;
7241 const char *start, *end;
7242 int not_arg;
7243 int ok, ndfltok, first;
7245 n_mdswitches = 0;
7246 start = multilib_defaults;
7247 while (*start == ' ' || *start == '\t')
7248 start++;
7249 while (*start != '\0')
7251 n_mdswitches++;
7252 while (*start != ' ' && *start != '\t' && *start != '\0')
7253 start++;
7254 while (*start == ' ' || *start == '\t')
7255 start++;
7258 if (n_mdswitches)
7260 int i = 0;
7262 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
7263 for (start = multilib_defaults; *start != '\0'; start = end + 1)
7265 while (*start == ' ' || *start == '\t')
7266 start++;
7268 if (*start == '\0')
7269 break;
7271 for (end = start + 1;
7272 *end != ' ' && *end != '\t' && *end != '\0'; end++)
7275 obstack_grow (&multilib_obstack, start, end - start);
7276 obstack_1grow (&multilib_obstack, 0);
7277 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
7278 mdswitches[i++].len = end - start;
7280 if (*end == '\0')
7281 break;
7285 p = multilib_exclusions;
7286 while (*p != '\0')
7288 /* Ignore newlines. */
7289 if (*p == '\n')
7291 ++p;
7292 continue;
7295 /* Check the arguments. */
7296 ok = 1;
7297 while (*p != ';')
7299 if (*p == '\0')
7301 invalid_exclusions:
7302 fatal ("multilib exclusions '%s' is invalid",
7303 multilib_exclusions);
7306 if (! ok)
7308 ++p;
7309 continue;
7312 this_arg = p;
7313 while (*p != ' ' && *p != ';')
7315 if (*p == '\0')
7316 goto invalid_exclusions;
7317 ++p;
7320 if (*this_arg != '!')
7321 not_arg = 0;
7322 else
7324 not_arg = 1;
7325 ++this_arg;
7328 ok = used_arg (this_arg, p - this_arg);
7329 if (not_arg)
7330 ok = ! ok;
7332 if (*p == ' ')
7333 ++p;
7336 if (ok)
7337 return;
7339 ++p;
7342 first = 1;
7343 p = multilib_select;
7344 while (*p != '\0')
7346 /* Ignore newlines. */
7347 if (*p == '\n')
7349 ++p;
7350 continue;
7353 /* Get the initial path. */
7354 this_path = p;
7355 while (*p != ' ')
7357 if (*p == '\0')
7359 invalid_select:
7360 fatal ("multilib select '%s' is invalid",
7361 multilib_select);
7363 ++p;
7365 this_path_len = p - this_path;
7367 /* Check the arguments. */
7368 ok = 1;
7369 ndfltok = 1;
7370 ++p;
7371 while (*p != ';')
7373 if (*p == '\0')
7374 goto invalid_select;
7376 if (! ok)
7378 ++p;
7379 continue;
7382 this_arg = p;
7383 while (*p != ' ' && *p != ';')
7385 if (*p == '\0')
7386 goto invalid_select;
7387 ++p;
7390 if (*this_arg != '!')
7391 not_arg = 0;
7392 else
7394 not_arg = 1;
7395 ++this_arg;
7398 /* If this is a default argument, we can just ignore it.
7399 This is true even if this_arg begins with '!'. Beginning
7400 with '!' does not mean that this argument is necessarily
7401 inappropriate for this library: it merely means that
7402 there is a more specific library which uses this
7403 argument. If this argument is a default, we need not
7404 consider that more specific library. */
7405 ok = used_arg (this_arg, p - this_arg);
7406 if (not_arg)
7407 ok = ! ok;
7409 if (! ok)
7410 ndfltok = 0;
7412 if (default_arg (this_arg, p - this_arg))
7413 ok = 1;
7415 if (*p == ' ')
7416 ++p;
7419 if (ok && first)
7421 if (this_path_len != 1
7422 || this_path[0] != '.')
7424 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
7425 char *q;
7427 strncpy (new_multilib_dir, this_path, this_path_len);
7428 new_multilib_dir[this_path_len] = '\0';
7429 q = strchr (new_multilib_dir, ':');
7430 if (q != NULL)
7431 *q = '\0';
7432 multilib_dir = new_multilib_dir;
7434 first = 0;
7437 if (ndfltok)
7439 const char *q = this_path, *end = this_path + this_path_len;
7441 while (q < end && *q != ':')
7442 q++;
7443 if (q < end)
7445 char *new_multilib_os_dir = XNEWVEC (char, end - q);
7446 memcpy (new_multilib_os_dir, q + 1, end - q - 1);
7447 new_multilib_os_dir[end - q - 1] = '\0';
7448 multilib_os_dir = new_multilib_os_dir;
7449 break;
7453 ++p;
7456 if (multilib_dir == NULL && multilib_os_dir != NULL
7457 && strcmp (multilib_os_dir, ".") == 0)
7459 free (CONST_CAST (char *, multilib_os_dir));
7460 multilib_os_dir = NULL;
7462 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7463 multilib_os_dir = multilib_dir;
7466 /* Print out the multiple library subdirectory selection
7467 information. This prints out a series of lines. Each line looks
7468 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7469 required. Only the desired options are printed out, the negative
7470 matches. The options are print without a leading dash. There are
7471 no spaces to make it easy to use the information in the shell.
7472 Each subdirectory is printed only once. This assumes the ordering
7473 generated by the genmultilib script. Also, we leave out ones that match
7474 the exclusions. */
7476 static void
7477 print_multilib_info (void)
7479 const char *p = multilib_select;
7480 const char *last_path = 0, *this_path;
7481 int skip;
7482 unsigned int last_path_len = 0;
7484 while (*p != '\0')
7486 skip = 0;
7487 /* Ignore newlines. */
7488 if (*p == '\n')
7490 ++p;
7491 continue;
7494 /* Get the initial path. */
7495 this_path = p;
7496 while (*p != ' ')
7498 if (*p == '\0')
7500 invalid_select:
7501 fatal ("multilib select '%s' is invalid", multilib_select);
7504 ++p;
7507 /* When --disable-multilib was used but target defines
7508 MULTILIB_OSDIRNAMES, entries starting with .: are there just
7509 to find multilib_os_dir, so skip them from output. */
7510 if (this_path[0] == '.' && this_path[1] == ':')
7511 skip = 1;
7513 /* Check for matches with the multilib_exclusions. We don't bother
7514 with the '!' in either list. If any of the exclusion rules match
7515 all of its options with the select rule, we skip it. */
7517 const char *e = multilib_exclusions;
7518 const char *this_arg;
7520 while (*e != '\0')
7522 int m = 1;
7523 /* Ignore newlines. */
7524 if (*e == '\n')
7526 ++e;
7527 continue;
7530 /* Check the arguments. */
7531 while (*e != ';')
7533 const char *q;
7534 int mp = 0;
7536 if (*e == '\0')
7538 invalid_exclusion:
7539 fatal ("multilib exclusion '%s' is invalid",
7540 multilib_exclusions);
7543 if (! m)
7545 ++e;
7546 continue;
7549 this_arg = e;
7551 while (*e != ' ' && *e != ';')
7553 if (*e == '\0')
7554 goto invalid_exclusion;
7555 ++e;
7558 q = p + 1;
7559 while (*q != ';')
7561 const char *arg;
7562 int len = e - this_arg;
7564 if (*q == '\0')
7565 goto invalid_select;
7567 arg = q;
7569 while (*q != ' ' && *q != ';')
7571 if (*q == '\0')
7572 goto invalid_select;
7573 ++q;
7576 if (! strncmp (arg, this_arg,
7577 (len < q - arg) ? q - arg : len)
7578 || default_arg (this_arg, e - this_arg))
7580 mp = 1;
7581 break;
7584 if (*q == ' ')
7585 ++q;
7588 if (! mp)
7589 m = 0;
7591 if (*e == ' ')
7592 ++e;
7595 if (m)
7597 skip = 1;
7598 break;
7601 if (*e != '\0')
7602 ++e;
7606 if (! skip)
7608 /* If this is a duplicate, skip it. */
7609 skip = (last_path != 0
7610 && (unsigned int) (p - this_path) == last_path_len
7611 && ! strncmp (last_path, this_path, last_path_len));
7613 last_path = this_path;
7614 last_path_len = p - this_path;
7617 /* If this directory requires any default arguments, we can skip
7618 it. We will already have printed a directory identical to
7619 this one which does not require that default argument. */
7620 if (! skip)
7622 const char *q;
7624 q = p + 1;
7625 while (*q != ';')
7627 const char *arg;
7629 if (*q == '\0')
7630 goto invalid_select;
7632 if (*q == '!')
7633 arg = NULL;
7634 else
7635 arg = q;
7637 while (*q != ' ' && *q != ';')
7639 if (*q == '\0')
7640 goto invalid_select;
7641 ++q;
7644 if (arg != NULL
7645 && default_arg (arg, q - arg))
7647 skip = 1;
7648 break;
7651 if (*q == ' ')
7652 ++q;
7656 if (! skip)
7658 const char *p1;
7660 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
7661 putchar (*p1);
7662 putchar (';');
7665 ++p;
7666 while (*p != ';')
7668 int use_arg;
7670 if (*p == '\0')
7671 goto invalid_select;
7673 if (skip)
7675 ++p;
7676 continue;
7679 use_arg = *p != '!';
7681 if (use_arg)
7682 putchar ('@');
7684 while (*p != ' ' && *p != ';')
7686 if (*p == '\0')
7687 goto invalid_select;
7688 if (use_arg)
7689 putchar (*p);
7690 ++p;
7693 if (*p == ' ')
7694 ++p;
7697 if (! skip)
7699 /* If there are extra options, print them now. */
7700 if (multilib_extra && *multilib_extra)
7702 int print_at = TRUE;
7703 const char *q;
7705 for (q = multilib_extra; *q != '\0'; q++)
7707 if (*q == ' ')
7708 print_at = TRUE;
7709 else
7711 if (print_at)
7712 putchar ('@');
7713 putchar (*q);
7714 print_at = FALSE;
7719 putchar ('\n');
7722 ++p;
7726 /* getenv built-in spec function.
7728 Returns the value of the environment variable given by its first
7729 argument, concatenated with the second argument. If the
7730 environment variable is not defined, a fatal error is issued. */
7732 static const char *
7733 getenv_spec_function (int argc, const char **argv)
7735 char *value;
7736 char *result;
7737 char *ptr;
7738 size_t len;
7740 if (argc != 2)
7741 return NULL;
7743 value = getenv (argv[0]);
7744 if (!value)
7745 fatal ("environment variable \"%s\" not defined", argv[0]);
7747 /* We have to escape every character of the environment variable so
7748 they are not interpretted as active spec characters. A
7749 particulaly painful case is when we are reading a variable
7750 holding a windows path complete with \ separators. */
7751 len = strlen (value) * 2 + strlen (argv[1]) + 1;
7752 result = xmalloc (len);
7753 for (ptr = result; *value; ptr += 2)
7755 ptr[0] = '\\';
7756 ptr[1] = *value++;
7759 strcpy (ptr, argv[1]);
7761 return result;
7764 /* if-exists built-in spec function.
7766 Checks to see if the file specified by the absolute pathname in
7767 ARGS exists. Returns that pathname if found.
7769 The usual use for this function is to check for a library file
7770 (whose name has been expanded with %s). */
7772 static const char *
7773 if_exists_spec_function (int argc, const char **argv)
7775 /* Must have only one argument. */
7776 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7777 return argv[0];
7779 return NULL;
7782 /* if-exists-else built-in spec function.
7784 This is like if-exists, but takes an additional argument which
7785 is returned if the first argument does not exist. */
7787 static const char *
7788 if_exists_else_spec_function (int argc, const char **argv)
7790 /* Must have exactly two arguments. */
7791 if (argc != 2)
7792 return NULL;
7794 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7795 return argv[0];
7797 return argv[1];
7800 /* replace-outfile built-in spec function.
7802 This looks for the first argument in the outfiles array's name and
7803 replaces it with the second argument. */
7805 static const char *
7806 replace_outfile_spec_function (int argc, const char **argv)
7808 int i;
7809 /* Must have exactly two arguments. */
7810 if (argc != 2)
7811 abort ();
7813 for (i = 0; i < n_infiles; i++)
7815 if (outfiles[i] && !strcmp (outfiles[i], argv[0]))
7816 outfiles[i] = xstrdup (argv[1]);
7818 return NULL;
7821 /* Given two version numbers, compares the two numbers.
7822 A version number must match the regular expression
7823 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
7825 static int
7826 compare_version_strings (const char *v1, const char *v2)
7828 int rresult;
7829 regex_t r;
7831 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
7832 REG_EXTENDED | REG_NOSUB) != 0)
7833 abort ();
7834 rresult = regexec (&r, v1, 0, NULL, 0);
7835 if (rresult == REG_NOMATCH)
7836 fatal ("invalid version number `%s'", v1);
7837 else if (rresult != 0)
7838 abort ();
7839 rresult = regexec (&r, v2, 0, NULL, 0);
7840 if (rresult == REG_NOMATCH)
7841 fatal ("invalid version number `%s'", v2);
7842 else if (rresult != 0)
7843 abort ();
7845 return strverscmp (v1, v2);
7849 /* version_compare built-in spec function.
7851 This takes an argument of the following form:
7853 <comparison-op> <arg1> [<arg2>] <switch> <result>
7855 and produces "result" if the comparison evaluates to true,
7856 and nothing if it doesn't.
7858 The supported <comparison-op> values are:
7860 >= true if switch is a later (or same) version than arg1
7861 !> opposite of >=
7862 < true if switch is an earlier version than arg1
7863 !< opposite of <
7864 >< true if switch is arg1 or later, and earlier than arg2
7865 <> true if switch is earlier than arg1 or is arg2 or later
7867 If the switch is not present, the condition is false unless
7868 the first character of the <comparison-op> is '!'.
7870 For example,
7871 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
7872 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
7874 static const char *
7875 version_compare_spec_function (int argc, const char **argv)
7877 int comp1, comp2;
7878 size_t switch_len;
7879 const char *switch_value = NULL;
7880 int nargs = 1, i;
7881 bool result;
7883 if (argc < 3)
7884 fatal ("too few arguments to %%:version-compare");
7885 if (argv[0][0] == '\0')
7886 abort ();
7887 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
7888 nargs = 2;
7889 if (argc != nargs + 3)
7890 fatal ("too many arguments to %%:version-compare");
7892 switch_len = strlen (argv[nargs + 1]);
7893 for (i = 0; i < n_switches; i++)
7894 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
7895 && check_live_switch (i, switch_len))
7896 switch_value = switches[i].part1 + switch_len;
7898 if (switch_value == NULL)
7899 comp1 = comp2 = -1;
7900 else
7902 comp1 = compare_version_strings (switch_value, argv[1]);
7903 if (nargs == 2)
7904 comp2 = compare_version_strings (switch_value, argv[2]);
7905 else
7906 comp2 = -1; /* This value unused. */
7909 switch (argv[0][0] << 8 | argv[0][1])
7911 case '>' << 8 | '=':
7912 result = comp1 >= 0;
7913 break;
7914 case '!' << 8 | '<':
7915 result = comp1 >= 0 || switch_value == NULL;
7916 break;
7917 case '<' << 8:
7918 result = comp1 < 0;
7919 break;
7920 case '!' << 8 | '>':
7921 result = comp1 < 0 || switch_value == NULL;
7922 break;
7923 case '>' << 8 | '<':
7924 result = comp1 >= 0 && comp2 < 0;
7925 break;
7926 case '<' << 8 | '>':
7927 result = comp1 < 0 || comp2 >= 0;
7928 break;
7930 default:
7931 fatal ("unknown operator '%s' in %%:version-compare", argv[0]);
7933 if (! result)
7934 return NULL;
7936 return argv[nargs + 2];
7939 /* %:include builtin spec function. This differs from %include in that it
7940 can be nested inside a spec, and thus be conditionalized. It takes
7941 one argument, the filename, and looks for it in the startfile path.
7942 The result is always NULL, i.e. an empty expansion. */
7944 static const char *
7945 include_spec_function (int argc, const char **argv)
7947 char *file;
7949 if (argc != 1)
7950 abort ();
7952 file = find_a_file (&startfile_prefixes, argv[0], R_OK, 0);
7953 read_specs (file ? file : argv[0], FALSE);
7955 return NULL;
7958 /* %:print-asm-header spec function. Print a banner to say that the
7959 following output is from the assembler. */
7961 static const char *
7962 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
7963 const char **argv ATTRIBUTE_UNUSED)
7965 printf (_("Assembler options\n=================\n\n"));
7966 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
7967 fflush (stdout);
7968 return NULL;