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