OSDN Git Service

2011-08-18 Tobias Burnus <burnus@net-b.de>
[pf3gnuchains/gcc-fork.git] / gcc / collect2.c
1 /* Collect static initialization info into data structures that can be
2    traversed by C++ initialization and finalization routines.
3    Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998,
4    1999, 2000, 2001, 2002, 2003, 2004, 2005, 2007, 2008, 2009, 2010, 2011
5    Free Software Foundation, Inc.
6    Contributed by Chris Smith (csmith@convex.com).
7    Heavily modified by Michael Meissner (meissner@cygnus.com),
8    Per Bothner (bothner@cygnus.com), and John Gilmore (gnu@cygnus.com).
9
10 This file is part of GCC.
11
12 GCC is free software; you can redistribute it and/or modify it under
13 the terms of the GNU General Public License as published by the Free
14 Software Foundation; either version 3, or (at your option) any later
15 version.
16
17 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
18 WARRANTY; without even the implied warranty of MERCHANTABILITY or
19 FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
20 for more details.
21
22 You should have received a copy of the GNU General Public License
23 along with GCC; see the file COPYING3.  If not see
24 <http://www.gnu.org/licenses/>.  */
25
26
27 /* Build tables of static constructors and destructors and run ld.  */
28
29 #include "config.h"
30 #include "system.h"
31 #include "coretypes.h"
32 #include "tm.h"
33 #include "filenames.h"
34
35 /* TARGET_64BIT may be defined to use driver specific functionality. */
36 #undef TARGET_64BIT
37 #define TARGET_64BIT TARGET_64BIT_DEFAULT
38
39 #ifndef LIBRARY_PATH_ENV
40 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
41 #endif
42
43 #define COLLECT
44
45 #include "collect2.h"
46 #include "collect2-aix.h"
47 #include "diagnostic.h"
48 #include "demangle.h"
49 #include "obstack.h"
50 #include "intl.h"
51 #include "version.h"
52 \f
53 /* On certain systems, we have code that works by scanning the object file
54    directly.  But this code uses system-specific header files and library
55    functions, so turn it off in a cross-compiler.  Likewise, the names of
56    the utilities are not correct for a cross-compiler; we have to hope that
57    cross-versions are in the proper directories.  */
58
59 #ifdef CROSS_DIRECTORY_STRUCTURE
60 #ifndef CROSS_AIX_SUPPORT
61 #undef OBJECT_FORMAT_COFF
62 #endif
63 #undef MD_EXEC_PREFIX
64 #undef REAL_LD_FILE_NAME
65 #undef REAL_NM_FILE_NAME
66 #undef REAL_STRIP_FILE_NAME
67 #endif
68
69 /* If we cannot use a special method, use the ordinary one:
70    run nm to find what symbols are present.
71    In a cross-compiler, this means you need a cross nm,
72    but that is not quite as unpleasant as special headers.  */
73
74 #if !defined (OBJECT_FORMAT_COFF)
75 #define OBJECT_FORMAT_NONE
76 #endif
77
78 #ifdef OBJECT_FORMAT_COFF
79
80 #ifndef CROSS_DIRECTORY_STRUCTURE
81 #include <a.out.h>
82 #include <ar.h>
83
84 #ifdef UMAX
85 #include <sgs.h>
86 #endif
87
88 /* Many versions of ldfcn.h define these.  */
89 #ifdef FREAD
90 #undef FREAD
91 #undef FWRITE
92 #endif
93
94 #include <ldfcn.h>
95 #endif
96
97 /* Some systems have an ISCOFF macro, but others do not.  In some cases
98    the macro may be wrong.  MY_ISCOFF is defined in tm.h files for machines
99    that either do not have an ISCOFF macro in /usr/include or for those
100    where it is wrong.  */
101
102 #ifndef MY_ISCOFF
103 #define MY_ISCOFF(X) ISCOFF (X)
104 #endif
105
106 #endif /* OBJECT_FORMAT_COFF */
107
108 #ifdef OBJECT_FORMAT_NONE
109
110 /* Default flags to pass to nm.  */
111 #ifndef NM_FLAGS
112 #define NM_FLAGS "-n"
113 #endif
114
115 #endif /* OBJECT_FORMAT_NONE */
116
117 /* Some systems use __main in a way incompatible with its use in gcc, in these
118    cases use the macros NAME__MAIN to give a quoted symbol and SYMBOL__MAIN to
119    give the same symbol without quotes for an alternative entry point.  */
120 #ifndef NAME__MAIN
121 #define NAME__MAIN "__main"
122 #endif
123
124 /* This must match tree.h.  */
125 #define DEFAULT_INIT_PRIORITY 65535
126
127 #ifndef COLLECT_SHARED_INIT_FUNC
128 #define COLLECT_SHARED_INIT_FUNC(STREAM, FUNC) \
129   fprintf ((STREAM), "void _GLOBAL__DI() {\n\t%s();\n}\n", (FUNC))
130 #endif
131 #ifndef COLLECT_SHARED_FINI_FUNC
132 #define COLLECT_SHARED_FINI_FUNC(STREAM, FUNC) \
133   fprintf ((STREAM), "void _GLOBAL__DD() {\n\t%s();\n}\n", (FUNC))
134 #endif
135
136 #ifdef LDD_SUFFIX
137 #define SCAN_LIBRARIES
138 #endif
139
140 #ifndef SHLIB_SUFFIX
141 #define SHLIB_SUFFIX ".so"
142 #endif
143
144 #ifdef USE_COLLECT2
145 int do_collecting = 1;
146 #else
147 int do_collecting = 0;
148 #endif
149
150 /* Cook up an always defined indication of whether we proceed the
151    "EXPORT_LIST" way.  */
152
153 #ifdef COLLECT_EXPORT_LIST
154 #define DO_COLLECT_EXPORT_LIST 1
155 #else
156 #define DO_COLLECT_EXPORT_LIST 0
157 #endif
158
159 /* Nonzero if we should suppress the automatic demangling of identifiers
160    in linker error messages.  Set from COLLECT_NO_DEMANGLE.  */
161 int no_demangle;
162 \f
163 /* Linked lists of constructor and destructor names.  */
164
165 struct id
166 {
167   struct id *next;
168   int sequence;
169   char name[1];
170 };
171
172 struct head
173 {
174   struct id *first;
175   struct id *last;
176   int number;
177 };
178
179 bool vflag;                             /* true if -v or --version */ 
180 static int rflag;                       /* true if -r */
181 static int strip_flag;                  /* true if -s */
182 #ifdef COLLECT_EXPORT_LIST
183 static int export_flag;                 /* true if -bE */
184 static int aix64_flag;                  /* true if -b64 */
185 static int aixrtl_flag;                 /* true if -brtl */
186 #endif
187
188 enum lto_mode_d {
189   LTO_MODE_NONE,                        /* Not doing LTO.  */
190   LTO_MODE_LTO,                         /* Normal LTO.  */
191   LTO_MODE_WHOPR                        /* WHOPR.  */
192 };
193
194 /* Current LTO mode.  */
195 static enum lto_mode_d lto_mode = LTO_MODE_NONE;
196
197 bool debug;                             /* true if -debug */
198 bool helpflag;                  /* true if --help */
199
200 static int shared_obj;                  /* true if -shared */
201
202 static const char *c_file;              /* <xxx>.c for constructor/destructor list.  */
203 static const char *o_file;              /* <xxx>.o for constructor/destructor list.  */
204 #ifdef COLLECT_EXPORT_LIST
205 static const char *export_file;         /* <xxx>.x for AIX export list.  */
206 #endif
207 static char **lto_o_files;              /* Output files for LTO.  */
208 const char *ldout;                      /* File for ld stdout.  */
209 const char *lderrout;                   /* File for ld stderr.  */
210 static const char *output_file;         /* Output file for ld.  */
211 static const char *nm_file_name;        /* pathname of nm */
212 #ifdef LDD_SUFFIX
213 static const char *ldd_file_name;       /* pathname of ldd (or equivalent) */
214 #endif
215 static const char *strip_file_name;             /* pathname of strip */
216 const char *c_file_name;                /* pathname of gcc */
217 static char *initname, *fininame;       /* names of init and fini funcs */
218
219 static struct head constructors;        /* list of constructors found */
220 static struct head destructors;         /* list of destructors found */
221 #ifdef COLLECT_EXPORT_LIST
222 static struct head exports;             /* list of exported symbols */
223 #endif
224 static struct head frame_tables;        /* list of frame unwind info tables */
225
226 static bool at_file_supplied;           /* Whether to use @file arguments */
227 static char *response_file;             /* Name of any current response file */
228
229 struct obstack temporary_obstack;
230 char * temporary_firstobj;
231
232 /* A string that must be prepended to a target OS path in order to find
233    it on the host system.  */
234 #ifdef TARGET_SYSTEM_ROOT
235 static const char *target_system_root = TARGET_SYSTEM_ROOT;
236 #else
237 static const char *target_system_root = "";
238 #endif
239
240 /* Structure to hold all the directories in which to search for files to
241    execute.  */
242
243 struct prefix_list
244 {
245   const char *prefix;         /* String to prepend to the path.  */
246   struct prefix_list *next;   /* Next in linked list.  */
247 };
248
249 struct path_prefix
250 {
251   struct prefix_list *plist;  /* List of prefixes to try */
252   int max_len;                /* Max length of a prefix in PLIST */
253   const char *name;           /* Name of this list (used in config stuff) */
254 };
255
256 #ifdef COLLECT_EXPORT_LIST
257 /* Lists to keep libraries to be scanned for global constructors/destructors.  */
258 static struct head libs;                    /* list of libraries */
259 static struct path_prefix cmdline_lib_dirs; /* directories specified with -L */
260 static struct path_prefix libpath_lib_dirs; /* directories in LIBPATH */
261 static struct path_prefix *libpaths[3] = {&cmdline_lib_dirs,
262                                           &libpath_lib_dirs, NULL};
263 #endif
264
265 /* List of names of object files containing LTO information.
266    These are a subset of the object file names appearing on the
267    command line, and must be identical, in the sense of pointer
268    equality, with the names passed to maybe_run_lto_and_relink().  */
269
270 struct lto_object
271 {
272   const char *name;             /* Name of object file.  */
273   struct lto_object *next;      /* Next in linked list.  */
274 };
275
276 struct lto_object_list
277 {
278   struct lto_object *first;     /* First list element.  */
279   struct lto_object *last;      /* Last list element.  */
280 };
281
282 static struct lto_object_list lto_objects;
283
284 /* Special kinds of symbols that a name may denote.  */
285
286 typedef enum {
287   SYM_REGULAR = 0,  /* nothing special  */
288
289   SYM_CTOR = 1,  /* constructor */
290   SYM_DTOR = 2,  /* destructor  */
291   SYM_INIT = 3,  /* shared object routine that calls all the ctors  */
292   SYM_FINI = 4,  /* shared object routine that calls all the dtors  */
293   SYM_DWEH = 5   /* DWARF exception handling table  */
294 } symkind;
295
296 static symkind is_ctor_dtor (const char *);
297
298 static void handler (int);
299 static char *find_a_file (struct path_prefix *, const char *);
300 static void add_prefix (struct path_prefix *, const char *);
301 static void prefix_from_env (const char *, struct path_prefix *);
302 static void prefix_from_string (const char *, struct path_prefix *);
303 static void do_wait (const char *, struct pex_obj *);
304 static void fork_execute (const char *, char **);
305 static void maybe_unlink (const char *);
306 static void maybe_unlink_list (char **);
307 static void add_to_list (struct head *, const char *);
308 static int extract_init_priority (const char *);
309 static void sort_ids (struct head *);
310 static void write_list (FILE *, const char *, struct id *);
311 #ifdef COLLECT_EXPORT_LIST
312 static void dump_list (FILE *, const char *, struct id *);
313 #endif
314 #if 0
315 static void dump_prefix_list (FILE *, const char *, struct prefix_list *);
316 #endif
317 static void write_list_with_asm (FILE *, const char *, struct id *);
318 static void write_c_file (FILE *, const char *);
319 static void write_c_file_stat (FILE *, const char *);
320 #ifndef LD_INIT_SWITCH
321 static void write_c_file_glob (FILE *, const char *);
322 #endif
323 #ifdef SCAN_LIBRARIES
324 static void scan_libraries (const char *);
325 #endif
326 #if LINK_ELIMINATE_DUPLICATE_LDIRECTORIES
327 static int is_in_args (const char *, const char **, const char **);
328 #endif
329 #ifdef COLLECT_EXPORT_LIST
330 #if 0
331 static int is_in_list (const char *, struct id *);
332 #endif
333 static void write_aix_file (FILE *, struct id *);
334 static char *resolve_lib_name (const char *);
335 #endif
336 static char *extract_string (const char **);
337 static void post_ld_pass (bool);
338 static void process_args (int *argcp, char **argv);
339
340 /* Enumerations describing which pass this is for scanning the
341    program file ...  */
342
343 typedef enum {
344   PASS_FIRST,                           /* without constructors */
345   PASS_OBJ,                             /* individual objects */
346   PASS_LIB,                             /* looking for shared libraries */
347   PASS_SECOND,                          /* with constructors linked in */
348   PASS_LTOINFO                          /* looking for objects with LTO info */
349 } scanpass;
350
351 /* ... and which kinds of symbols are to be considered.  */
352
353 enum scanfilter_masks {
354   SCAN_NOTHING = 0,
355
356   SCAN_CTOR = 1 << SYM_CTOR,
357   SCAN_DTOR = 1 << SYM_DTOR,
358   SCAN_INIT = 1 << SYM_INIT,
359   SCAN_FINI = 1 << SYM_FINI,
360   SCAN_DWEH = 1 << SYM_DWEH,
361   SCAN_ALL  = ~0
362 };
363
364 /* This type is used for parameters and variables which hold
365    combinations of the flags in enum scanfilter_masks.  */
366 typedef int scanfilter;
367
368 /* Scan the name list of the loaded program for the symbols g++ uses for
369    static constructors and destructors.
370
371    The SCANPASS argument tells which collect processing pass this is for and
372    the SCANFILTER argument tells which kinds of symbols to consider in this
373    pass.  Symbols of a special kind not in the filter mask are considered as
374    regular ones.
375
376    The constructor table begins at __CTOR_LIST__ and contains a count of the
377    number of pointers (or -1 if the constructors are built in a separate
378    section by the linker), followed by the pointers to the constructor
379    functions, terminated with a null pointer.  The destructor table has the
380    same format, and begins at __DTOR_LIST__.  */
381
382 static void scan_prog_file (const char *, scanpass, scanfilter);
383
384 \f
385 /* Delete tempfiles and exit function.  */
386
387 void
388 collect_exit (int status)
389 {
390   if (c_file != 0 && c_file[0])
391     maybe_unlink (c_file);
392
393   if (o_file != 0 && o_file[0])
394     maybe_unlink (o_file);
395
396 #ifdef COLLECT_EXPORT_LIST
397   if (export_file != 0 && export_file[0])
398     maybe_unlink (export_file);
399 #endif
400
401   if (lto_o_files)
402     maybe_unlink_list (lto_o_files);
403
404   if (ldout != 0 && ldout[0])
405     {
406       dump_file (ldout, stdout);
407       maybe_unlink (ldout);
408     }
409
410   if (lderrout != 0 && lderrout[0])
411     {
412       dump_file (lderrout, stderr);
413       maybe_unlink (lderrout);
414     }
415
416   if (status != 0 && output_file != 0 && output_file[0])
417     maybe_unlink (output_file);
418
419   if (response_file)
420     maybe_unlink (response_file);
421
422   exit (status);
423 }
424
425 \f
426 /* Notify user of a non-error.  */
427 void
428 notice (const char *cmsgid, ...)
429 {
430   va_list ap;
431
432   va_start (ap, cmsgid);
433   vfprintf (stderr, _(cmsgid), ap);
434   va_end (ap);
435 }
436
437 /* Notify user of a non-error, without translating the format string.  */
438 void
439 notice_translated (const char *cmsgid, ...)
440 {
441   va_list ap;
442
443   va_start (ap, cmsgid);
444   vfprintf (stderr, cmsgid, ap);
445   va_end (ap);
446 }
447 \f
448 static void
449 handler (int signo)
450 {
451   if (c_file != 0 && c_file[0])
452     maybe_unlink (c_file);
453
454   if (o_file != 0 && o_file[0])
455     maybe_unlink (o_file);
456
457   if (ldout != 0 && ldout[0])
458     maybe_unlink (ldout);
459
460   if (lderrout != 0 && lderrout[0])
461     maybe_unlink (lderrout);
462
463 #ifdef COLLECT_EXPORT_LIST
464   if (export_file != 0 && export_file[0])
465     maybe_unlink (export_file);
466 #endif
467
468   if (lto_o_files)
469     maybe_unlink_list (lto_o_files);
470
471   if (response_file)
472     maybe_unlink (response_file);
473
474   signal (signo, SIG_DFL);
475   raise (signo);
476 }
477
478 \f
479 int
480 file_exists (const char *name)
481 {
482   return access (name, R_OK) == 0;
483 }
484
485 /* Parse a reasonable subset of shell quoting syntax.  */
486
487 static char *
488 extract_string (const char **pp)
489 {
490   const char *p = *pp;
491   int backquote = 0;
492   int inside = 0;
493
494   for (;;)
495     {
496       char c = *p;
497       if (c == '\0')
498         break;
499       ++p;
500       if (backquote)
501         obstack_1grow (&temporary_obstack, c);
502       else if (! inside && c == ' ')
503         break;
504       else if (! inside && c == '\\')
505         backquote = 1;
506       else if (c == '\'')
507         inside = !inside;
508       else
509         obstack_1grow (&temporary_obstack, c);
510     }
511
512   obstack_1grow (&temporary_obstack, '\0');
513   *pp = p;
514   return XOBFINISH (&temporary_obstack, char *);
515 }
516 \f
517 void
518 dump_file (const char *name, FILE *to)
519 {
520   FILE *stream = fopen (name, "r");
521
522   if (stream == 0)
523     return;
524   while (1)
525     {
526       int c;
527       while (c = getc (stream),
528              c != EOF && (ISIDNUM (c) || c == '$' || c == '.'))
529         obstack_1grow (&temporary_obstack, c);
530       if (obstack_object_size (&temporary_obstack) > 0)
531         {
532           const char *word, *p;
533           char *result;
534           obstack_1grow (&temporary_obstack, '\0');
535           word = XOBFINISH (&temporary_obstack, const char *);
536
537           if (*word == '.')
538             ++word, putc ('.', to);
539           p = word;
540           if (!strncmp (p, USER_LABEL_PREFIX, strlen (USER_LABEL_PREFIX)))
541             p += strlen (USER_LABEL_PREFIX);
542
543 #ifdef HAVE_LD_DEMANGLE
544           result = 0;
545 #else
546           if (no_demangle)
547             result = 0;
548           else
549             result = cplus_demangle (p, DMGL_PARAMS | DMGL_ANSI | DMGL_VERBOSE);
550 #endif
551
552           if (result)
553             {
554               int diff;
555               fputs (result, to);
556
557               diff = strlen (word) - strlen (result);
558               while (diff > 0 && c == ' ')
559                 --diff, putc (' ', to);
560               if (diff < 0 && c == ' ')
561                 {
562                   while (diff < 0 && c == ' ')
563                     ++diff, c = getc (stream);
564                   if (!ISSPACE (c))
565                     {
566                       /* Make sure we output at least one space, or
567                          the demangled symbol name will run into
568                          whatever text follows.  */
569                       putc (' ', to);
570                     }
571                 }
572
573               free (result);
574             }
575           else
576             fputs (word, to);
577
578           fflush (to);
579           obstack_free (&temporary_obstack, temporary_firstobj);
580         }
581       if (c == EOF)
582         break;
583       putc (c, to);
584     }
585   fclose (stream);
586 }
587 \f
588 /* Return the kind of symbol denoted by name S.  */
589
590 static symkind
591 is_ctor_dtor (const char *s)
592 {
593   struct names { const char *const name; const int len; symkind ret;
594     const int two_underscores; };
595
596   const struct names *p;
597   int ch;
598   const char *orig_s = s;
599
600   static const struct names special[] = {
601 #ifndef NO_DOLLAR_IN_LABEL
602     { "GLOBAL__I$", sizeof ("GLOBAL__I$")-1, SYM_CTOR, 0 },
603     { "GLOBAL__D$", sizeof ("GLOBAL__D$")-1, SYM_DTOR, 0 },
604 #else
605 #ifndef NO_DOT_IN_LABEL
606     { "GLOBAL__I.", sizeof ("GLOBAL__I.")-1, SYM_CTOR, 0 },
607     { "GLOBAL__D.", sizeof ("GLOBAL__D.")-1, SYM_DTOR, 0 },
608 #endif /* NO_DOT_IN_LABEL */
609 #endif /* NO_DOLLAR_IN_LABEL */
610     { "GLOBAL__I_", sizeof ("GLOBAL__I_")-1, SYM_CTOR, 0 },
611     { "GLOBAL__D_", sizeof ("GLOBAL__D_")-1, SYM_DTOR, 0 },
612     { "GLOBAL__F_", sizeof ("GLOBAL__F_")-1, SYM_DWEH, 0 },
613     { "GLOBAL__FI_", sizeof ("GLOBAL__FI_")-1, SYM_INIT, 0 },
614     { "GLOBAL__FD_", sizeof ("GLOBAL__FD_")-1, SYM_FINI, 0 },
615     { NULL, 0, SYM_REGULAR, 0 }
616   };
617
618   while ((ch = *s) == '_')
619     ++s;
620
621   if (s == orig_s)
622     return SYM_REGULAR;
623
624   for (p = &special[0]; p->len > 0; p++)
625     {
626       if (ch == p->name[0]
627           && (!p->two_underscores || ((s - orig_s) >= 2))
628           && strncmp(s, p->name, p->len) == 0)
629         {
630           return p->ret;
631         }
632     }
633   return SYM_REGULAR;
634 }
635 \f
636 /* We maintain two prefix lists: one from COMPILER_PATH environment variable
637    and one from the PATH variable.  */
638
639 static struct path_prefix cpath, path;
640
641 #ifdef CROSS_DIRECTORY_STRUCTURE
642 /* This is the name of the target machine.  We use it to form the name
643    of the files to execute.  */
644
645 static const char *const target_machine = TARGET_MACHINE;
646 #endif
647
648 /* Search for NAME using prefix list PPREFIX.  We only look for executable
649    files.
650
651    Return 0 if not found, otherwise return its name, allocated with malloc.  */
652
653 static char *
654 find_a_file (struct path_prefix *pprefix, const char *name)
655 {
656   char *temp;
657   struct prefix_list *pl;
658   int len = pprefix->max_len + strlen (name) + 1;
659
660   if (debug)
661     fprintf (stderr, "Looking for '%s'\n", name);
662
663 #ifdef HOST_EXECUTABLE_SUFFIX
664   len += strlen (HOST_EXECUTABLE_SUFFIX);
665 #endif
666
667   temp = XNEWVEC (char, len);
668
669   /* Determine the filename to execute (special case for absolute paths).  */
670
671   if (IS_ABSOLUTE_PATH (name))
672     {
673       if (access (name, X_OK) == 0)
674         {
675           strcpy (temp, name);
676
677           if (debug)
678             fprintf (stderr, "  - found: absolute path\n");
679
680           return temp;
681         }
682
683 #ifdef HOST_EXECUTABLE_SUFFIX
684         /* Some systems have a suffix for executable files.
685            So try appending that.  */
686       strcpy (temp, name);
687         strcat (temp, HOST_EXECUTABLE_SUFFIX);
688
689         if (access (temp, X_OK) == 0)
690           return temp;
691 #endif
692
693       if (debug)
694         fprintf (stderr, "  - failed to locate using absolute path\n");
695     }
696   else
697     for (pl = pprefix->plist; pl; pl = pl->next)
698       {
699         struct stat st;
700
701         strcpy (temp, pl->prefix);
702         strcat (temp, name);
703
704         if (stat (temp, &st) >= 0
705             && ! S_ISDIR (st.st_mode)
706             && access (temp, X_OK) == 0)
707           return temp;
708
709 #ifdef HOST_EXECUTABLE_SUFFIX
710         /* Some systems have a suffix for executable files.
711            So try appending that.  */
712         strcat (temp, HOST_EXECUTABLE_SUFFIX);
713
714         if (stat (temp, &st) >= 0
715             && ! S_ISDIR (st.st_mode)
716             && access (temp, X_OK) == 0)
717           return temp;
718 #endif
719       }
720
721   if (debug && pprefix->plist == NULL)
722     fprintf (stderr, "  - failed: no entries in prefix list\n");
723
724   free (temp);
725   return 0;
726 }
727
728 /* Add an entry for PREFIX to prefix list PPREFIX.  */
729
730 static void
731 add_prefix (struct path_prefix *pprefix, const char *prefix)
732 {
733   struct prefix_list *pl, **prev;
734   int len;
735
736   if (pprefix->plist)
737     {
738       for (pl = pprefix->plist; pl->next; pl = pl->next)
739         ;
740       prev = &pl->next;
741     }
742   else
743     prev = &pprefix->plist;
744
745   /* Keep track of the longest prefix.  */
746
747   len = strlen (prefix);
748   if (len > pprefix->max_len)
749     pprefix->max_len = len;
750
751   pl = XNEW (struct prefix_list);
752   pl->prefix = xstrdup (prefix);
753
754   if (*prev)
755     pl->next = *prev;
756   else
757     pl->next = (struct prefix_list *) 0;
758   *prev = pl;
759 }
760 \f
761 /* Take the value of the environment variable ENV, break it into a path, and
762    add of the entries to PPREFIX.  */
763
764 static void
765 prefix_from_env (const char *env, struct path_prefix *pprefix)
766 {
767   const char *p;
768   p = getenv (env);
769
770   if (p)
771     prefix_from_string (p, pprefix);
772 }
773
774 static void
775 prefix_from_string (const char *p, struct path_prefix *pprefix)
776 {
777   const char *startp, *endp;
778   char *nstore = XNEWVEC (char, strlen (p) + 3);
779
780   if (debug)
781     fprintf (stderr, "Convert string '%s' into prefixes, separator = '%c'\n", p, PATH_SEPARATOR);
782
783   startp = endp = p;
784   while (1)
785     {
786       if (*endp == PATH_SEPARATOR || *endp == 0)
787         {
788           strncpy (nstore, startp, endp-startp);
789           if (endp == startp)
790             {
791               strcpy (nstore, "./");
792             }
793           else if (! IS_DIR_SEPARATOR (endp[-1]))
794             {
795               nstore[endp-startp] = DIR_SEPARATOR;
796               nstore[endp-startp+1] = 0;
797             }
798           else
799             nstore[endp-startp] = 0;
800
801           if (debug)
802             fprintf (stderr, "  - add prefix: %s\n", nstore);
803
804           add_prefix (pprefix, nstore);
805           if (*endp == 0)
806             break;
807           endp = startp = endp + 1;
808         }
809       else
810         endp++;
811     }
812   free (nstore);
813 }
814
815 #ifdef OBJECT_FORMAT_NONE
816
817 /* Add an entry for the object file NAME to object file list LIST.
818    New entries are added at the end of the list. The original pointer
819    value of NAME is preserved, i.e., no string copy is performed.  */
820
821 static void
822 add_lto_object (struct lto_object_list *list, const char *name)
823 {
824   struct lto_object *n = XNEW (struct lto_object);
825   n->name = name;
826   n->next = NULL;
827
828   if (list->last)
829     list->last->next = n;
830   else
831     list->first = n;
832
833   list->last = n;
834 }
835 #endif /* OBJECT_FORMAT_NONE */
836
837
838 /* Perform a link-time recompilation and relink if any of the object
839    files contain LTO info.  The linker command line LTO_LD_ARGV
840    represents the linker command that would produce a final executable
841    without the use of LTO. OBJECT_LST is a vector of object file names
842    appearing in LTO_LD_ARGV that are to be considerd for link-time
843    recompilation, where OBJECT is a pointer to the last valid element.
844    (This awkward convention avoids an impedance mismatch with the
845    usage of similarly-named variables in main().)  The elements of
846    OBJECT_LST must be identical, i.e., pointer equal, to the
847    corresponding arguments in LTO_LD_ARGV.
848
849    Upon entry, at least one linker run has been performed without the
850    use of any LTO info that might be present.  Any recompilations
851    necessary for template instantiations have been performed, and
852    initializer/finalizer tables have been created if needed and
853    included in the linker command line LTO_LD_ARGV. If any of the
854    object files contain LTO info, we run the LTO back end on all such
855    files, and perform the final link with the LTO back end output
856    substituted for the LTO-optimized files.  In some cases, a final
857    link with all link-time generated code has already been performed,
858    so there is no need to relink if no LTO info is found.  In other
859    cases, our caller has not produced the final executable, and is
860    relying on us to perform the required link whether LTO info is
861    present or not.  In that case, the FORCE argument should be true.
862    Note that the linker command line argument LTO_LD_ARGV passed into
863    this function may be modified in place.  */
864
865 static void
866 maybe_run_lto_and_relink (char **lto_ld_argv, char **object_lst,
867                           const char **object, bool force)
868 {
869   const char **object_file = CONST_CAST2 (const char **, char **, object_lst);
870
871   int num_lto_c_args = 1;    /* Allow space for the terminating NULL.  */
872
873   while (object_file < object)
874   {
875     /* If file contains LTO info, add it to the list of LTO objects.  */
876     scan_prog_file (*object_file++, PASS_LTOINFO, SCAN_ALL);
877
878     /* Increment the argument count by the number of object file arguments
879        we will add.  An upper bound suffices, so just count all of the
880        object files regardless of whether they contain LTO info.  */
881     num_lto_c_args++;
882   }
883
884   if (lto_objects.first)
885     {
886       char **lto_c_argv;
887       const char **lto_c_ptr;
888       char **p;
889       char **lto_o_ptr;
890       struct lto_object *list;
891       char *lto_wrapper = getenv ("COLLECT_LTO_WRAPPER");
892       struct pex_obj *pex;
893       const char *prog = "lto-wrapper";
894       int lto_ld_argv_size = 0;
895       char **out_lto_ld_argv;
896       int out_lto_ld_argv_size;
897       size_t num_files;
898
899       if (!lto_wrapper)
900         fatal_error ("COLLECT_LTO_WRAPPER must be set");
901
902       num_lto_c_args++;
903
904       /* There is at least one object file containing LTO info,
905          so we need to run the LTO back end and relink.
906
907          To do so we build updated ld arguments with first
908          LTO object replaced by all partitions and other LTO
909          objects removed.  */
910
911       lto_c_argv = (char **) xcalloc (sizeof (char *), num_lto_c_args);
912       lto_c_ptr = CONST_CAST2 (const char **, char **, lto_c_argv);
913
914       *lto_c_ptr++ = lto_wrapper;
915
916       /* Add LTO objects to the wrapper command line.  */
917       for (list = lto_objects.first; list; list = list->next)
918         *lto_c_ptr++ = list->name;
919
920       *lto_c_ptr = NULL;
921
922       /* Run the LTO back end.  */
923       pex = collect_execute (prog, lto_c_argv, NULL, NULL, PEX_SEARCH);
924       {
925         int c;
926         FILE *stream;
927         size_t i;
928         char *start, *end;
929
930         stream = pex_read_output (pex, 0);
931         gcc_assert (stream);
932
933         num_files = 0;
934         while ((c = getc (stream)) != EOF)
935           {
936             obstack_1grow (&temporary_obstack, c);
937             if (c == '\n')
938               ++num_files;
939           }
940
941         lto_o_files = XNEWVEC (char *, num_files + 1);
942         lto_o_files[num_files] = NULL;
943         start = XOBFINISH (&temporary_obstack, char *);
944         for (i = 0; i < num_files; ++i)
945           {
946             end = start;
947             while (*end != '\n')
948               ++end;
949             *end = '\0';
950
951             lto_o_files[i] = xstrdup (start);
952
953             start = end + 1;
954           }
955
956         obstack_free (&temporary_obstack, temporary_firstobj);
957       }
958       do_wait (prog, pex);
959       pex = NULL;
960
961       /* Compute memory needed for new LD arguments.  At most number of original arguemtns
962          plus number of partitions.  */
963       for (lto_ld_argv_size = 0; lto_ld_argv[lto_ld_argv_size]; lto_ld_argv_size++)
964         ;
965       out_lto_ld_argv = XCNEWVEC(char *, num_files + lto_ld_argv_size + 1);
966       out_lto_ld_argv_size = 0;
967
968       /* After running the LTO back end, we will relink, substituting
969          the LTO output for the object files that we submitted to the
970          LTO. Here, we modify the linker command line for the relink.  */
971
972       /* Copy all arguments until we find first LTO file.  */
973       p = lto_ld_argv;
974       while (*p != NULL)
975         {
976           for (list = lto_objects.first; list; list = list->next)
977             if (*p == list->name) /* Note test for pointer equality!  */
978               break;
979           if (list)
980             break;
981           out_lto_ld_argv[out_lto_ld_argv_size++] = *p++;
982         }
983
984       /* Now insert all LTO partitions.  */
985       lto_o_ptr = lto_o_files;
986       while (*lto_o_ptr)
987         out_lto_ld_argv[out_lto_ld_argv_size++] = *lto_o_ptr++;
988
989       /* ... and copy the rest.  */
990       while (*p != NULL)
991         {
992           for (list = lto_objects.first; list; list = list->next)
993             if (*p == list->name) /* Note test for pointer equality!  */
994               break;
995           if (!list)
996             out_lto_ld_argv[out_lto_ld_argv_size++] = *p;
997           p++;
998         }
999       out_lto_ld_argv[out_lto_ld_argv_size++] = 0;
1000
1001       /* Run the linker again, this time replacing the object files
1002          optimized by the LTO with the temporary file generated by the LTO.  */
1003       fork_execute ("ld", out_lto_ld_argv);
1004       post_ld_pass (true);
1005       free (lto_ld_argv);
1006
1007       maybe_unlink_list (lto_o_files);
1008     }
1009   else if (force)
1010     {
1011       /* Our caller is relying on us to do the link
1012          even though there is no LTO back end work to be done.  */
1013       fork_execute ("ld", lto_ld_argv);
1014       post_ld_pass (false);
1015     }
1016 }
1017 \f
1018 /* Main program.  */
1019
1020 int
1021 main (int argc, char **argv)
1022 {
1023   static const char *const ld_suffix    = "ld";
1024   static const char *const plugin_ld_suffix = PLUGIN_LD;
1025   static const char *const real_ld_suffix = "real-ld";
1026   static const char *const collect_ld_suffix = "collect-ld";
1027   static const char *const nm_suffix    = "nm";
1028   static const char *const gnm_suffix   = "gnm";
1029 #ifdef LDD_SUFFIX
1030   static const char *const ldd_suffix   = LDD_SUFFIX;
1031 #endif
1032   static const char *const strip_suffix = "strip";
1033   static const char *const gstrip_suffix = "gstrip";
1034
1035 #ifdef CROSS_DIRECTORY_STRUCTURE
1036   /* If we look for a program in the compiler directories, we just use
1037      the short name, since these directories are already system-specific.
1038      But it we look for a program in the system directories, we need to
1039      qualify the program name with the target machine.  */
1040
1041   const char *const full_ld_suffix =
1042     concat(target_machine, "-", ld_suffix, NULL);
1043   const char *const full_plugin_ld_suffix =
1044     concat(target_machine, "-", plugin_ld_suffix, NULL);
1045   const char *const full_nm_suffix =
1046     concat (target_machine, "-", nm_suffix, NULL);
1047   const char *const full_gnm_suffix =
1048     concat (target_machine, "-", gnm_suffix, NULL);
1049 #ifdef LDD_SUFFIX
1050   const char *const full_ldd_suffix =
1051     concat (target_machine, "-", ldd_suffix, NULL);
1052 #endif
1053   const char *const full_strip_suffix =
1054     concat (target_machine, "-", strip_suffix, NULL);
1055   const char *const full_gstrip_suffix =
1056     concat (target_machine, "-", gstrip_suffix, NULL);
1057 #else
1058   const char *const full_ld_suffix      = ld_suffix;
1059   const char *const full_plugin_ld_suffix = plugin_ld_suffix;
1060   const char *const full_nm_suffix      = nm_suffix;
1061   const char *const full_gnm_suffix     = gnm_suffix;
1062 #ifdef LDD_SUFFIX
1063   const char *const full_ldd_suffix     = ldd_suffix;
1064 #endif
1065   const char *const full_strip_suffix   = strip_suffix;
1066   const char *const full_gstrip_suffix  = gstrip_suffix;
1067 #endif /* CROSS_DIRECTORY_STRUCTURE */
1068
1069   const char *arg;
1070   FILE *outf;
1071 #ifdef COLLECT_EXPORT_LIST
1072   FILE *exportf;
1073 #endif
1074   const char *ld_file_name;
1075   const char *p;
1076   char **c_argv;
1077   const char **c_ptr;
1078   char **ld1_argv;
1079   const char **ld1;
1080   bool use_plugin = false;
1081
1082   /* The kinds of symbols we will have to consider when scanning the
1083      outcome of a first pass link.  This is ALL to start with, then might
1084      be adjusted before getting to the first pass link per se, typically on
1085      AIX where we perform an early scan of objects and libraries to fetch
1086      the list of global ctors/dtors and make sure they are not garbage
1087      collected.  */
1088   scanfilter ld1_filter = SCAN_ALL;
1089
1090   char **ld2_argv;
1091   const char **ld2;
1092   char **object_lst;
1093   const char **object;
1094   int first_file;
1095   int num_c_args;
1096   char **old_argv;
1097
1098   p = argv[0] + strlen (argv[0]);
1099   while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
1100     --p;
1101   progname = p;
1102
1103   xmalloc_set_program_name (progname);
1104
1105   old_argv = argv;
1106   expandargv (&argc, &argv);
1107   if (argv != old_argv)
1108     at_file_supplied = 1;
1109
1110   process_args (&argc, argv);
1111
1112   num_c_args = argc + 9;
1113
1114 #ifndef HAVE_LD_DEMANGLE
1115   no_demangle = !! getenv ("COLLECT_NO_DEMANGLE");
1116
1117   /* Suppress demangling by the real linker, which may be broken.  */
1118   putenv (xstrdup ("COLLECT_NO_DEMANGLE=1"));
1119 #endif
1120
1121 #if defined (COLLECT2_HOST_INITIALIZATION)
1122   /* Perform system dependent initialization, if necessary.  */
1123   COLLECT2_HOST_INITIALIZATION;
1124 #endif
1125
1126 #ifdef SIGCHLD
1127   /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
1128      receive the signal.  A different setting is inheritable */
1129   signal (SIGCHLD, SIG_DFL);
1130 #endif
1131
1132   /* Unlock the stdio streams.  */
1133   unlock_std_streams ();
1134
1135   gcc_init_libintl ();
1136
1137   diagnostic_initialize (global_dc, 0);
1138
1139   /* Do not invoke xcalloc before this point, since locale needs to be
1140      set first, in case a diagnostic is issued.  */
1141
1142   ld1_argv = XCNEWVEC (char *, argc + 4);
1143   ld1 = CONST_CAST2 (const char **, char **, ld1_argv);
1144   ld2_argv = XCNEWVEC (char *, argc + 11);
1145   ld2 = CONST_CAST2 (const char **, char **, ld2_argv);
1146   object_lst = XCNEWVEC (char *, argc);
1147   object = CONST_CAST2 (const char **, char **, object_lst);
1148
1149 #ifdef DEBUG
1150   debug = 1;
1151 #endif
1152
1153   /* Parse command line early for instances of -debug.  This allows
1154      the debug flag to be set before functions like find_a_file()
1155      are called.  We also look for the -flto or -flto-partition=none flag to know
1156      what LTO mode we are in.  */
1157   {
1158     int i;
1159     bool no_partition = false;
1160
1161     for (i = 1; argv[i] != NULL; i ++)
1162       {
1163         if (! strcmp (argv[i], "-debug"))
1164           debug = true;
1165         else if (! strcmp (argv[i], "-flto-partition=none"))
1166           no_partition = true;
1167         else if ((! strncmp (argv[i], "-flto=", 6)
1168                   || ! strcmp (argv[i], "-flto")) && ! use_plugin)
1169           lto_mode = LTO_MODE_WHOPR;
1170         else if (!strncmp (argv[i], "-fno-lto", 8))
1171           lto_mode = LTO_MODE_NONE;
1172         else if (! strcmp (argv[i], "-plugin"))
1173           {
1174             use_plugin = true;
1175             lto_mode = LTO_MODE_NONE;
1176           }
1177 #ifdef COLLECT_EXPORT_LIST
1178         /* since -brtl, -bexport, -b64 are not position dependent
1179            also check for them here */
1180         if ((argv[i][0] == '-') && (argv[i][1] == 'b'))
1181           {
1182             arg = argv[i];
1183             /* We want to disable automatic exports on AIX when user
1184                explicitly puts an export list in command line */
1185             if (arg[2] == 'E' || strncmp (&arg[2], "export", 6) == 0)
1186               export_flag = 1;
1187             else if (arg[2] == '6' && arg[3] == '4')
1188               aix64_flag = 1;
1189             else if (arg[2] == 'r' && arg[3] == 't' && arg[4] == 'l')
1190               aixrtl_flag = 1;
1191           }
1192 #endif
1193       }
1194     vflag = debug;
1195     if (no_partition && lto_mode == LTO_MODE_WHOPR)
1196       lto_mode = LTO_MODE_LTO;
1197   }
1198
1199 #ifndef DEFAULT_A_OUT_NAME
1200   output_file = "a.out";
1201 #else
1202   output_file = DEFAULT_A_OUT_NAME;
1203 #endif
1204
1205   obstack_begin (&temporary_obstack, 0);
1206   temporary_firstobj = (char *) obstack_alloc (&temporary_obstack, 0);
1207
1208 #ifndef HAVE_LD_DEMANGLE
1209   current_demangling_style = auto_demangling;
1210 #endif
1211   p = getenv ("COLLECT_GCC_OPTIONS");
1212   while (p && *p)
1213     {
1214       const char *q = extract_string (&p);
1215       if (*q == '-' && (q[1] == 'm' || q[1] == 'f'))
1216         num_c_args++;
1217     }
1218   obstack_free (&temporary_obstack, temporary_firstobj);
1219
1220   /* -fno-profile-arcs -fno-test-coverage -fno-branch-probabilities
1221      -fno-exceptions -w -fno-whole-program */
1222   num_c_args += 6;
1223
1224   c_argv = XCNEWVEC (char *, num_c_args);
1225   c_ptr = CONST_CAST2 (const char **, char **, c_argv);
1226
1227   if (argc < 2)
1228     fatal_error ("no arguments");
1229
1230 #ifdef SIGQUIT
1231   if (signal (SIGQUIT, SIG_IGN) != SIG_IGN)
1232     signal (SIGQUIT, handler);
1233 #endif
1234   if (signal (SIGINT, SIG_IGN) != SIG_IGN)
1235     signal (SIGINT, handler);
1236 #ifdef SIGALRM
1237   if (signal (SIGALRM, SIG_IGN) != SIG_IGN)
1238     signal (SIGALRM, handler);
1239 #endif
1240 #ifdef SIGHUP
1241   if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
1242     signal (SIGHUP, handler);
1243 #endif
1244   if (signal (SIGSEGV, SIG_IGN) != SIG_IGN)
1245     signal (SIGSEGV, handler);
1246 #ifdef SIGBUS
1247   if (signal (SIGBUS, SIG_IGN) != SIG_IGN)
1248     signal (SIGBUS, handler);
1249 #endif
1250
1251   /* Extract COMPILER_PATH and PATH into our prefix list.  */
1252   prefix_from_env ("COMPILER_PATH", &cpath);
1253   prefix_from_env ("PATH", &path);
1254
1255   /* Try to discover a valid linker/nm/strip to use.  */
1256
1257   /* Maybe we know the right file to use (if not cross).  */
1258   ld_file_name = 0;
1259 #ifdef DEFAULT_LINKER
1260   if (access (DEFAULT_LINKER, X_OK) == 0)
1261     ld_file_name = DEFAULT_LINKER;
1262   if (ld_file_name == 0)
1263 #endif
1264 #ifdef REAL_LD_FILE_NAME
1265   ld_file_name = find_a_file (&path, REAL_LD_FILE_NAME);
1266   if (ld_file_name == 0)
1267 #endif
1268   /* Search the (target-specific) compiler dirs for ld'.  */
1269   ld_file_name = find_a_file (&cpath, real_ld_suffix);
1270   /* Likewise for `collect-ld'.  */
1271   if (ld_file_name == 0)
1272     ld_file_name = find_a_file (&cpath, collect_ld_suffix);
1273   /* Search the compiler directories for `ld'.  We have protection against
1274      recursive calls in find_a_file.  */
1275   if (ld_file_name == 0)
1276     ld_file_name = find_a_file (&cpath,
1277                                 use_plugin
1278                                 ? plugin_ld_suffix
1279                                 : ld_suffix);
1280   /* Search the ordinary system bin directories
1281      for `ld' (if native linking) or `TARGET-ld' (if cross).  */
1282   if (ld_file_name == 0)
1283     ld_file_name = find_a_file (&path,
1284                                 use_plugin
1285                                 ? full_plugin_ld_suffix
1286                                 : full_ld_suffix);
1287
1288 #ifdef REAL_NM_FILE_NAME
1289   nm_file_name = find_a_file (&path, REAL_NM_FILE_NAME);
1290   if (nm_file_name == 0)
1291 #endif
1292   nm_file_name = find_a_file (&cpath, gnm_suffix);
1293   if (nm_file_name == 0)
1294     nm_file_name = find_a_file (&path, full_gnm_suffix);
1295   if (nm_file_name == 0)
1296     nm_file_name = find_a_file (&cpath, nm_suffix);
1297   if (nm_file_name == 0)
1298     nm_file_name = find_a_file (&path, full_nm_suffix);
1299
1300 #ifdef LDD_SUFFIX
1301   ldd_file_name = find_a_file (&cpath, ldd_suffix);
1302   if (ldd_file_name == 0)
1303     ldd_file_name = find_a_file (&path, full_ldd_suffix);
1304 #endif
1305
1306 #ifdef REAL_STRIP_FILE_NAME
1307   strip_file_name = find_a_file (&path, REAL_STRIP_FILE_NAME);
1308   if (strip_file_name == 0)
1309 #endif
1310   strip_file_name = find_a_file (&cpath, gstrip_suffix);
1311   if (strip_file_name == 0)
1312     strip_file_name = find_a_file (&path, full_gstrip_suffix);
1313   if (strip_file_name == 0)
1314     strip_file_name = find_a_file (&cpath, strip_suffix);
1315   if (strip_file_name == 0)
1316     strip_file_name = find_a_file (&path, full_strip_suffix);
1317
1318   /* Determine the full path name of the C compiler to use.  */
1319   c_file_name = getenv ("COLLECT_GCC");
1320   if (c_file_name == 0)
1321     {
1322 #ifdef CROSS_DIRECTORY_STRUCTURE
1323       c_file_name = concat (target_machine, "-gcc", NULL);
1324 #else
1325       c_file_name = "gcc";
1326 #endif
1327     }
1328
1329   p = find_a_file (&cpath, c_file_name);
1330
1331   /* Here it should be safe to use the system search path since we should have
1332      already qualified the name of the compiler when it is needed.  */
1333   if (p == 0)
1334     p = find_a_file (&path, c_file_name);
1335
1336   if (p)
1337     c_file_name = p;
1338
1339   *ld1++ = *ld2++ = ld_file_name;
1340
1341   /* Make temp file names.  */
1342   c_file = make_temp_file (".c");
1343   o_file = make_temp_file (".o");
1344 #ifdef COLLECT_EXPORT_LIST
1345   export_file = make_temp_file (".x");
1346 #endif
1347   ldout = make_temp_file (".ld");
1348   lderrout = make_temp_file (".le");
1349   *c_ptr++ = c_file_name;
1350   *c_ptr++ = "-x";
1351   *c_ptr++ = "c";
1352   *c_ptr++ = "-c";
1353   *c_ptr++ = "-o";
1354   *c_ptr++ = o_file;
1355
1356 #ifdef COLLECT_EXPORT_LIST
1357   /* Generate a list of directories from LIBPATH.  */
1358   prefix_from_env ("LIBPATH", &libpath_lib_dirs);
1359   /* Add to this list also two standard directories where
1360      AIX loader always searches for libraries.  */
1361   add_prefix (&libpath_lib_dirs, "/lib");
1362   add_prefix (&libpath_lib_dirs, "/usr/lib");
1363 #endif
1364
1365   /* Get any options that the upper GCC wants to pass to the sub-GCC.
1366
1367      AIX support needs to know if -shared has been specified before
1368      parsing commandline arguments.  */
1369
1370   p = getenv ("COLLECT_GCC_OPTIONS");
1371   while (p && *p)
1372     {
1373       const char *q = extract_string (&p);
1374       if (*q == '-' && (q[1] == 'm' || q[1] == 'f'))
1375         *c_ptr++ = xstrdup (q);
1376       if (strcmp (q, "-EL") == 0 || strcmp (q, "-EB") == 0)
1377         *c_ptr++ = xstrdup (q);
1378       if (strcmp (q, "-shared") == 0)
1379         shared_obj = 1;
1380       if (*q == '-' && q[1] == 'B')
1381         {
1382           *c_ptr++ = xstrdup (q);
1383           if (q[2] == 0)
1384             {
1385               q = extract_string (&p);
1386               *c_ptr++ = xstrdup (q);
1387             }
1388         }
1389     }
1390   obstack_free (&temporary_obstack, temporary_firstobj);
1391   *c_ptr++ = "-fno-profile-arcs";
1392   *c_ptr++ = "-fno-test-coverage";
1393   *c_ptr++ = "-fno-branch-probabilities";
1394   *c_ptr++ = "-fno-exceptions";
1395   *c_ptr++ = "-w";
1396   *c_ptr++ = "-fno-whole-program";
1397
1398   /* !!! When GCC calls collect2,
1399      it does not know whether it is calling collect2 or ld.
1400      So collect2 cannot meaningfully understand any options
1401      except those ld understands.
1402      If you propose to make GCC pass some other option,
1403      just imagine what will happen if ld is really ld!!!  */
1404
1405   /* Parse arguments.  Remember output file spec, pass the rest to ld.  */
1406   /* After the first file, put in the c++ rt0.  */
1407
1408   first_file = 1;
1409   while ((arg = *++argv) != (char *) 0)
1410     {
1411       *ld1++ = *ld2++ = arg;
1412
1413       if (arg[0] == '-')
1414         {
1415           switch (arg[1])
1416             {
1417             case 'd':
1418               if (!strcmp (arg, "-debug"))
1419                 {
1420                   /* Already parsed.  */
1421                   ld1--;
1422                   ld2--;
1423                 }
1424               if (!strcmp (arg, "-dynamic-linker") && argv[1])
1425                 {
1426                   ++argv;
1427                   *ld1++ = *ld2++ = *argv;
1428                 }
1429               break;
1430
1431             case 'f':
1432               if (strncmp (arg, "-flto", 5) == 0)
1433                 {
1434 #ifdef ENABLE_LTO
1435                   /* Do not pass LTO flag to the linker. */
1436                   ld1--;
1437                   ld2--;
1438 #else
1439                   error ("LTO support has not been enabled in this "
1440                          "configuration");
1441 #endif
1442                 }
1443               break;
1444
1445             case 'l':
1446               if (first_file)
1447                 {
1448                   /* place o_file BEFORE this argument! */
1449                   first_file = 0;
1450                   ld2--;
1451                   *ld2++ = o_file;
1452                   *ld2++ = arg;
1453                 }
1454 #ifdef COLLECT_EXPORT_LIST
1455               {
1456                 /* Resolving full library name.  */
1457                 const char *s = resolve_lib_name (arg+2);
1458
1459                 /* Saving a full library name.  */
1460                 add_to_list (&libs, s);
1461               }
1462 #endif
1463               break;
1464
1465 #ifdef COLLECT_EXPORT_LIST
1466             /* Saving directories where to search for libraries.  */
1467             case 'L':
1468               add_prefix (&cmdline_lib_dirs, arg+2);
1469               break;
1470 #else
1471 #if LINK_ELIMINATE_DUPLICATE_LDIRECTORIES
1472             case 'L':
1473               if (is_in_args (arg,
1474                               CONST_CAST2 (const char **, char **, ld1_argv),
1475                               ld1 - 1))
1476                 --ld1;
1477               break;
1478 #endif /* LINK_ELIMINATE_DUPLICATE_LDIRECTORIES */
1479 #endif
1480
1481             case 'o':
1482               if (arg[2] == '\0')
1483                 output_file = *ld1++ = *ld2++ = *++argv;
1484               else
1485                 output_file = &arg[2];
1486               break;
1487
1488             case 'r':
1489               if (arg[2] == '\0')
1490                 rflag = 1;
1491               break;
1492
1493             case 's':
1494               if (arg[2] == '\0' && do_collecting)
1495                 {
1496                   /* We must strip after the nm run, otherwise C++ linking
1497                      will not work.  Thus we strip in the second ld run, or
1498                      else with strip if there is no second ld run.  */
1499                   strip_flag = 1;
1500                   ld1--;
1501                 }
1502               break;
1503
1504             case 'v':
1505               if (arg[2] == '\0')
1506                 vflag = true;
1507               break;
1508
1509             case '-':
1510               if (strcmp (arg, "--no-demangle") == 0)
1511                 {
1512 #ifndef HAVE_LD_DEMANGLE
1513                   no_demangle = 1;
1514                   ld1--;
1515                   ld2--;
1516 #endif
1517                 }
1518               else if (strncmp (arg, "--demangle", 10) == 0)
1519                 {
1520 #ifndef HAVE_LD_DEMANGLE
1521                   no_demangle = 0;
1522                   if (arg[10] == '=')
1523                     {
1524                       enum demangling_styles style
1525                         = cplus_demangle_name_to_style (arg+11);
1526                       if (style == unknown_demangling)
1527                         error ("unknown demangling style '%s'", arg+11);
1528                       else
1529                         current_demangling_style = style;
1530                     }
1531                   ld1--;
1532                   ld2--;
1533 #endif
1534                 }
1535               else if (strncmp (arg, "--sysroot=", 10) == 0)
1536                 target_system_root = arg + 10;
1537               else if (strcmp (arg, "--version") == 0)
1538                 vflag = true;
1539               else if (strcmp (arg, "--help") == 0)
1540                 helpflag = true;
1541               break;
1542             }
1543         }
1544       else if ((p = strrchr (arg, '.')) != (char *) 0
1545                && (strcmp (p, ".o") == 0 || strcmp (p, ".a") == 0
1546                    || strcmp (p, ".so") == 0 || strcmp (p, ".lo") == 0
1547                    || strcmp (p, ".obj") == 0))
1548         {
1549           if (first_file)
1550             {
1551               first_file = 0;
1552               if (p[1] == 'o')
1553                 *ld2++ = o_file;
1554               else
1555                 {
1556                   /* place o_file BEFORE this argument! */
1557                   ld2--;
1558                   *ld2++ = o_file;
1559                   *ld2++ = arg;
1560                 }
1561             }
1562           if (p[1] == 'o' || p[1] == 'l')
1563             *object++ = arg;
1564 #ifdef COLLECT_EXPORT_LIST
1565           /* libraries can be specified directly, i.e. without -l flag.  */
1566           else
1567             {
1568               /* Saving a full library name.  */
1569               add_to_list (&libs, arg);
1570             }
1571 #endif
1572         }
1573     }
1574
1575 #ifdef COLLECT_EXPORT_LIST
1576   /* This is added only for debugging purposes.  */
1577   if (debug)
1578     {
1579       fprintf (stderr, "List of libraries:\n");
1580       dump_list (stderr, "\t", libs.first);
1581     }
1582
1583   /* The AIX linker will discard static constructors in object files if
1584      nothing else in the file is referenced, so look at them first.  Unless
1585      we are building a shared object, ignore the eh frame tables, as we
1586      would otherwise reference them all, hence drag all the corresponding
1587      objects even if nothing else is referenced.  */
1588   {
1589     const char **export_object_lst
1590       = CONST_CAST2 (const char **, char **, object_lst);
1591
1592     struct id *list = libs.first;
1593
1594     /* Compute the filter to use from the current one, do scan, then adjust
1595        the "current" filter to remove what we just included here.  This will
1596        control whether we need a first pass link later on or not, and what
1597        will remain to be scanned there.  */
1598
1599     scanfilter this_filter = ld1_filter;
1600 #if HAVE_AS_REF
1601     if (!shared_obj)
1602       this_filter &= ~SCAN_DWEH;
1603 #endif
1604
1605     while (export_object_lst < object)
1606       scan_prog_file (*export_object_lst++, PASS_OBJ, this_filter);
1607
1608     for (; list; list = list->next)
1609       scan_prog_file (list->name, PASS_FIRST, this_filter);
1610
1611     ld1_filter = ld1_filter & ~this_filter;
1612   }
1613
1614   if (exports.first)
1615     {
1616       char *buf = concat ("-bE:", export_file, NULL);
1617
1618       *ld1++ = buf;
1619       *ld2++ = buf;
1620
1621       exportf = fopen (export_file, "w");
1622       if (exportf == (FILE *) 0)
1623         fatal_error ("fopen %s: %m", export_file);
1624       write_aix_file (exportf, exports.first);
1625       if (fclose (exportf))
1626         fatal_error ("fclose %s: %m", export_file);
1627     }
1628 #endif
1629
1630   *c_ptr++ = c_file;
1631   *c_ptr = *ld1 = *object = (char *) 0;
1632
1633   if (vflag)
1634     notice ("collect2 version %s\n", version_string);
1635
1636   if (helpflag)
1637     {
1638       printf ("Usage: collect2 [options]\n");
1639       printf (" Wrap linker and generate constructor code if needed.\n");
1640       printf (" Options:\n");
1641       printf ("  -debug          Enable debug output\n");
1642       printf ("  --help          Display this information\n");
1643       printf ("  -v, --version   Display this program's version number\n");
1644       printf ("\n");
1645       printf ("Overview: http://gcc.gnu.org/onlinedocs/gccint/Collect2.html\n");
1646       printf ("Report bugs: %s\n", bug_report_url);
1647       printf ("\n");
1648     }
1649
1650   if (debug)
1651     {
1652       const char *ptr;
1653       fprintf (stderr, "ld_file_name        = %s\n",
1654                (ld_file_name ? ld_file_name : "not found"));
1655       fprintf (stderr, "c_file_name         = %s\n",
1656                (c_file_name ? c_file_name : "not found"));
1657       fprintf (stderr, "nm_file_name        = %s\n",
1658                (nm_file_name ? nm_file_name : "not found"));
1659 #ifdef LDD_SUFFIX
1660       fprintf (stderr, "ldd_file_name       = %s\n",
1661                (ldd_file_name ? ldd_file_name : "not found"));
1662 #endif
1663       fprintf (stderr, "strip_file_name     = %s\n",
1664                (strip_file_name ? strip_file_name : "not found"));
1665       fprintf (stderr, "c_file              = %s\n",
1666                (c_file ? c_file : "not found"));
1667       fprintf (stderr, "o_file              = %s\n",
1668                (o_file ? o_file : "not found"));
1669
1670       ptr = getenv ("COLLECT_GCC_OPTIONS");
1671       if (ptr)
1672         fprintf (stderr, "COLLECT_GCC_OPTIONS = %s\n", ptr);
1673
1674       ptr = getenv ("COLLECT_GCC");
1675       if (ptr)
1676         fprintf (stderr, "COLLECT_GCC         = %s\n", ptr);
1677
1678       ptr = getenv ("COMPILER_PATH");
1679       if (ptr)
1680         fprintf (stderr, "COMPILER_PATH       = %s\n", ptr);
1681
1682       ptr = getenv (LIBRARY_PATH_ENV);
1683       if (ptr)
1684         fprintf (stderr, "%-20s= %s\n", LIBRARY_PATH_ENV, ptr);
1685
1686       fprintf (stderr, "\n");
1687     }
1688
1689   /* Load the program, searching all libraries and attempting to provide
1690      undefined symbols from repository information.
1691
1692      If -r or they will be run via some other method, do not build the
1693      constructor or destructor list, just return now.  */
1694   {
1695     bool early_exit
1696       = rflag || (! DO_COLLECT_EXPORT_LIST && ! do_collecting);
1697
1698     /* Perform the first pass link now, if we're about to exit or if we need
1699        to scan for things we haven't collected yet before pursuing further.
1700
1701        On AIX, the latter typically includes nothing for shared objects or
1702        frame tables for an executable, out of what the required early scan on
1703        objects and libraries has performed above.  In the !shared_obj case, we
1704        expect the relevant tables to be dragged together with their associated
1705        functions from precise cross reference insertions by the compiler.  */
1706
1707     if (early_exit || ld1_filter != SCAN_NOTHING)
1708       do_tlink (ld1_argv, object_lst);
1709
1710     if (early_exit)
1711       {
1712 #ifdef COLLECT_EXPORT_LIST
1713         /* Make sure we delete the export file we may have created.  */
1714         if (export_file != 0 && export_file[0])
1715           maybe_unlink (export_file);
1716 #endif
1717         if (lto_mode != LTO_MODE_NONE)
1718           maybe_run_lto_and_relink (ld1_argv, object_lst, object, false);
1719         else
1720           post_ld_pass (false);
1721
1722         maybe_unlink (c_file);
1723         maybe_unlink (o_file);
1724         return 0;
1725       }
1726   }
1727
1728   /* Unless we have done it all already, examine the namelist and search for
1729      static constructors and destructors to call.  Write the constructor and
1730      destructor tables to a .s file and reload.  */
1731
1732   if (ld1_filter != SCAN_NOTHING)
1733     scan_prog_file (output_file, PASS_FIRST, ld1_filter);
1734
1735 #ifdef SCAN_LIBRARIES
1736   scan_libraries (output_file);
1737 #endif
1738
1739   if (debug)
1740     {
1741       notice_translated (ngettext ("%d constructor found\n",
1742                                    "%d constructors found\n",
1743                                    constructors.number),
1744                          constructors.number);
1745       notice_translated (ngettext ("%d destructor found\n",
1746                                    "%d destructors found\n",
1747                                    destructors.number),
1748                          destructors.number);
1749       notice_translated (ngettext("%d frame table found\n",
1750                                   "%d frame tables found\n",
1751                                   frame_tables.number),
1752                          frame_tables.number);
1753     }
1754
1755   /* If the scan exposed nothing of special interest, there's no need to
1756      generate the glue code and relink so return now.  */
1757
1758   if (constructors.number == 0 && destructors.number == 0
1759       && frame_tables.number == 0
1760 #if defined (SCAN_LIBRARIES) || defined (COLLECT_EXPORT_LIST)
1761       /* If we will be running these functions ourselves, we want to emit
1762          stubs into the shared library so that we do not have to relink
1763          dependent programs when we add static objects.  */
1764       && ! shared_obj
1765 #endif
1766       )
1767     {
1768       /* Do tlink without additional code generation now if we didn't
1769          do it earlier for scanning purposes.  */
1770       if (ld1_filter == SCAN_NOTHING)
1771         do_tlink (ld1_argv, object_lst);
1772
1773       if (lto_mode)
1774         maybe_run_lto_and_relink (ld1_argv, object_lst, object, false);
1775
1776       /* Strip now if it was requested on the command line.  */
1777       if (strip_flag)
1778         {
1779           char **real_strip_argv = XCNEWVEC (char *, 3);
1780           const char ** strip_argv = CONST_CAST2 (const char **, char **,
1781                                                   real_strip_argv);
1782
1783           strip_argv[0] = strip_file_name;
1784           strip_argv[1] = output_file;
1785           strip_argv[2] = (char *) 0;
1786           fork_execute ("strip", real_strip_argv);
1787         }
1788
1789 #ifdef COLLECT_EXPORT_LIST
1790       maybe_unlink (export_file);
1791 #endif
1792       post_ld_pass (false);
1793
1794       maybe_unlink (c_file);
1795       maybe_unlink (o_file);
1796       return 0;
1797     }
1798
1799   /* Sort ctor and dtor lists by priority.  */
1800   sort_ids (&constructors);
1801   sort_ids (&destructors);
1802
1803   maybe_unlink(output_file);
1804   outf = fopen (c_file, "w");
1805   if (outf == (FILE *) 0)
1806     fatal_error ("fopen %s: %m", c_file);
1807
1808   write_c_file (outf, c_file);
1809
1810   if (fclose (outf))
1811     fatal_error ("fclose %s: %m", c_file);
1812
1813   /* Tell the linker that we have initializer and finalizer functions.  */
1814 #ifdef LD_INIT_SWITCH
1815 #ifdef COLLECT_EXPORT_LIST
1816   *ld2++ = concat (LD_INIT_SWITCH, ":", initname, ":", fininame, NULL);
1817 #else
1818   *ld2++ = LD_INIT_SWITCH;
1819   *ld2++ = initname;
1820   *ld2++ = LD_FINI_SWITCH;
1821   *ld2++ = fininame;
1822 #endif
1823 #endif
1824
1825 #ifdef COLLECT_EXPORT_LIST
1826   if (shared_obj)
1827     {
1828       /* If we did not add export flag to link arguments before, add it to
1829          second link phase now.  No new exports should have been added.  */
1830       if (! exports.first)
1831         *ld2++ = concat ("-bE:", export_file, NULL);
1832
1833 #ifndef LD_INIT_SWITCH
1834       add_to_list (&exports, initname);
1835       add_to_list (&exports, fininame);
1836       add_to_list (&exports, "_GLOBAL__DI");
1837       add_to_list (&exports, "_GLOBAL__DD");
1838 #endif
1839       exportf = fopen (export_file, "w");
1840       if (exportf == (FILE *) 0)
1841         fatal_error ("fopen %s: %m", export_file);
1842       write_aix_file (exportf, exports.first);
1843       if (fclose (exportf))
1844         fatal_error ("fclose %s: %m", export_file);
1845     }
1846 #endif
1847
1848   /* End of arguments to second link phase.  */
1849   *ld2 = (char*) 0;
1850
1851   if (debug)
1852     {
1853       fprintf (stderr, "\n========== output_file = %s, c_file = %s\n",
1854                output_file, c_file);
1855       write_c_file (stderr, "stderr");
1856       fprintf (stderr, "========== end of c_file\n\n");
1857 #ifdef COLLECT_EXPORT_LIST
1858       fprintf (stderr, "\n========== export_file = %s\n", export_file);
1859       write_aix_file (stderr, exports.first);
1860       fprintf (stderr, "========== end of export_file\n\n");
1861 #endif
1862     }
1863
1864   /* Assemble the constructor and destructor tables.
1865      Link the tables in with the rest of the program.  */
1866
1867   fork_execute ("gcc",  c_argv);
1868 #ifdef COLLECT_EXPORT_LIST
1869   /* On AIX we must call tlink because of possible templates resolution.  */
1870   do_tlink (ld2_argv, object_lst);
1871
1872   if (lto_mode)
1873     maybe_run_lto_and_relink (ld2_argv, object_lst, object, false);
1874 #else
1875   /* Otherwise, simply call ld because tlink is already done.  */
1876   if (lto_mode)
1877     maybe_run_lto_and_relink (ld2_argv, object_lst, object, true);
1878   else
1879     {
1880       fork_execute ("ld", ld2_argv);
1881       post_ld_pass (false);
1882     }
1883
1884   /* Let scan_prog_file do any final mods (OSF/rose needs this for
1885      constructors/destructors in shared libraries.  */
1886   scan_prog_file (output_file, PASS_SECOND, SCAN_ALL);
1887 #endif
1888
1889   maybe_unlink (c_file);
1890   maybe_unlink (o_file);
1891
1892 #ifdef COLLECT_EXPORT_LIST
1893   maybe_unlink (export_file);
1894 #endif
1895
1896   return 0;
1897 }
1898
1899 \f
1900 /* Wait for a process to finish, and exit if a nonzero status is found.  */
1901
1902 int
1903 collect_wait (const char *prog, struct pex_obj *pex)
1904 {
1905   int status;
1906
1907   if (!pex_get_status (pex, 1, &status))
1908     fatal_error ("can't get program status: %m");
1909   pex_free (pex);
1910
1911   if (status)
1912     {
1913       if (WIFSIGNALED (status))
1914         {
1915           int sig = WTERMSIG (status);
1916           error ("%s terminated with signal %d [%s]%s",
1917                  prog, sig, strsignal(sig),
1918                  WCOREDUMP(status) ? ", core dumped" : "");
1919           collect_exit (FATAL_EXIT_CODE);
1920         }
1921
1922       if (WIFEXITED (status))
1923         return WEXITSTATUS (status);
1924     }
1925   return 0;
1926 }
1927
1928 static void
1929 do_wait (const char *prog, struct pex_obj *pex)
1930 {
1931   int ret = collect_wait (prog, pex);
1932   if (ret != 0)
1933     {
1934       error ("%s returned %d exit status", prog, ret);
1935       collect_exit (ret);
1936     }
1937
1938   if (response_file)
1939     {
1940       unlink (response_file);
1941       response_file = NULL;
1942     }
1943 }
1944
1945 \f
1946 /* Execute a program, and wait for the reply.  */
1947
1948 struct pex_obj *
1949 collect_execute (const char *prog, char **argv, const char *outname,
1950                  const char *errname, int flags)
1951 {
1952   struct pex_obj *pex;
1953   const char *errmsg;
1954   int err;
1955   char *response_arg = NULL;
1956   char *response_argv[3] ATTRIBUTE_UNUSED;
1957
1958   if (HAVE_GNU_LD && at_file_supplied && argv[0] != NULL)
1959     {
1960       /* If using @file arguments, create a temporary file and put the
1961          contents of argv into it.  Then change argv to an array corresponding
1962          to a single argument @FILE, where FILE is the temporary filename.  */
1963
1964       char **current_argv = argv + 1;
1965       char *argv0 = argv[0];
1966       int status;
1967       FILE *f;
1968
1969       /* Note: we assume argv contains at least one element; this is
1970          checked above.  */
1971
1972       response_file = make_temp_file ("");
1973
1974       f = fopen (response_file, "w");
1975
1976       if (f == NULL)
1977         fatal_error ("could not open response file %s", response_file);
1978
1979       status = writeargv (current_argv, f);
1980
1981       if (status)
1982         fatal_error ("could not write to response file %s", response_file);
1983
1984       status = fclose (f);
1985
1986       if (EOF == status)
1987         fatal_error ("could not close response file %s", response_file);
1988
1989       response_arg = concat ("@", response_file, NULL);
1990       response_argv[0] = argv0;
1991       response_argv[1] = response_arg;
1992       response_argv[2] = NULL;
1993
1994       argv = response_argv;
1995     }
1996
1997   if (vflag || debug)
1998     {
1999       char **p_argv;
2000       const char *str;
2001
2002       if (argv[0])
2003         fprintf (stderr, "%s", argv[0]);
2004       else
2005         notice ("[cannot find %s]", prog);
2006
2007       for (p_argv = &argv[1]; (str = *p_argv) != (char *) 0; p_argv++)
2008         fprintf (stderr, " %s", str);
2009
2010       fprintf (stderr, "\n");
2011     }
2012
2013   fflush (stdout);
2014   fflush (stderr);
2015
2016   /* If we cannot find a program we need, complain error.  Do this here
2017      since we might not end up needing something that we could not find.  */
2018
2019   if (argv[0] == 0)
2020     fatal_error ("cannot find '%s'", prog);
2021
2022   pex = pex_init (0, "collect2", NULL);
2023   if (pex == NULL)
2024     fatal_error ("pex_init failed: %m");
2025
2026   errmsg = pex_run (pex, flags, argv[0], argv, outname,
2027                     errname, &err);
2028   if (errmsg != NULL)
2029     {
2030       if (err != 0)
2031         {
2032           errno = err;
2033           fatal_error ("%s: %m", _(errmsg));
2034         }
2035       else
2036         fatal_error (errmsg);
2037     }
2038
2039   free (response_arg);
2040
2041   return pex;
2042 }
2043
2044 static void
2045 fork_execute (const char *prog, char **argv)
2046 {
2047   struct pex_obj *pex;
2048
2049   pex = collect_execute (prog, argv, NULL, NULL, PEX_LAST | PEX_SEARCH);
2050   do_wait (prog, pex);
2051 }
2052 \f
2053 /* Unlink a file unless we are debugging.  */
2054
2055 static void
2056 maybe_unlink (const char *file)
2057 {
2058   if (!debug)
2059     unlink_if_ordinary (file);
2060   else
2061     notice ("[Leaving %s]\n", file);
2062 }
2063
2064 /* Call maybe_unlink on the NULL-terminated list, FILE_LIST.  */
2065
2066 static void
2067 maybe_unlink_list (char **file_list)
2068 {
2069   char **tmp = file_list;
2070
2071   while (*tmp)
2072     maybe_unlink (*(tmp++));
2073 }
2074
2075 \f
2076 static long sequence_number = 0;
2077
2078 /* Add a name to a linked list.  */
2079
2080 static void
2081 add_to_list (struct head *head_ptr, const char *name)
2082 {
2083   struct id *newid
2084     = (struct id *) xcalloc (sizeof (struct id) + strlen (name), 1);
2085   struct id *p;
2086   strcpy (newid->name, name);
2087
2088   if (head_ptr->first)
2089     head_ptr->last->next = newid;
2090   else
2091     head_ptr->first = newid;
2092
2093   /* Check for duplicate symbols.  */
2094   for (p = head_ptr->first;
2095        strcmp (name, p->name) != 0;
2096        p = p->next)
2097     ;
2098   if (p != newid)
2099     {
2100       head_ptr->last->next = 0;
2101       free (newid);
2102       return;
2103     }
2104
2105   newid->sequence = ++sequence_number;
2106   head_ptr->last = newid;
2107   head_ptr->number++;
2108 }
2109
2110 /* Grab the init priority number from an init function name that
2111    looks like "_GLOBAL_.I.12345.foo".  */
2112
2113 static int
2114 extract_init_priority (const char *name)
2115 {
2116   int pos = 0, pri;
2117
2118   while (name[pos] == '_')
2119     ++pos;
2120   pos += 10; /* strlen ("GLOBAL__X_") */
2121
2122   /* Extract init_p number from ctor/dtor name.  */
2123   pri = atoi (name + pos);
2124   return pri ? pri : DEFAULT_INIT_PRIORITY;
2125 }
2126
2127 /* Insertion sort the ids from ctor/dtor list HEAD_PTR in descending order.
2128    ctors will be run from right to left, dtors from left to right.  */
2129
2130 static void
2131 sort_ids (struct head *head_ptr)
2132 {
2133   /* id holds the current element to insert.  id_next holds the next
2134      element to insert.  id_ptr iterates through the already sorted elements
2135      looking for the place to insert id.  */
2136   struct id *id, *id_next, **id_ptr;
2137
2138   id = head_ptr->first;
2139
2140   /* We don't have any sorted elements yet.  */
2141   head_ptr->first = NULL;
2142
2143   for (; id; id = id_next)
2144     {
2145       id_next = id->next;
2146       id->sequence = extract_init_priority (id->name);
2147
2148       for (id_ptr = &(head_ptr->first); ; id_ptr = &((*id_ptr)->next))
2149         if (*id_ptr == NULL
2150             /* If the sequence numbers are the same, we put the id from the
2151                file later on the command line later in the list.  */
2152             || id->sequence > (*id_ptr)->sequence
2153             /* Hack: do lexical compare, too.
2154             || (id->sequence == (*id_ptr)->sequence
2155                 && strcmp (id->name, (*id_ptr)->name) > 0) */
2156             )
2157           {
2158             id->next = *id_ptr;
2159             *id_ptr = id;
2160             break;
2161           }
2162     }
2163
2164   /* Now set the sequence numbers properly so write_c_file works.  */
2165   for (id = head_ptr->first; id; id = id->next)
2166     id->sequence = ++sequence_number;
2167 }
2168
2169 /* Write: `prefix', the names on list LIST, `suffix'.  */
2170
2171 static void
2172 write_list (FILE *stream, const char *prefix, struct id *list)
2173 {
2174   while (list)
2175     {
2176       fprintf (stream, "%sx%d,\n", prefix, list->sequence);
2177       list = list->next;
2178     }
2179 }
2180
2181 #if LINK_ELIMINATE_DUPLICATE_LDIRECTORIES
2182 /* Given a STRING, return nonzero if it occurs in the list in range
2183    [ARGS_BEGIN,ARGS_END).  */
2184
2185 static int
2186 is_in_args (const char *string, const char **args_begin,
2187             const char **args_end)
2188 {
2189   const char **args_pointer;
2190   for (args_pointer = args_begin; args_pointer != args_end; ++args_pointer)
2191     if (strcmp (string, *args_pointer) == 0)
2192       return 1;
2193   return 0;
2194 }
2195 #endif /* LINK_ELIMINATE_DUPLICATE_LDIRECTORIES */
2196
2197 #ifdef COLLECT_EXPORT_LIST
2198 /* This function is really used only on AIX, but may be useful.  */
2199 #if 0
2200 static int
2201 is_in_list (const char *prefix, struct id *list)
2202 {
2203   while (list)
2204     {
2205       if (!strcmp (prefix, list->name)) return 1;
2206       list = list->next;
2207     }
2208     return 0;
2209 }
2210 #endif
2211 #endif /* COLLECT_EXPORT_LIST */
2212
2213 /* Added for debugging purpose.  */
2214 #ifdef COLLECT_EXPORT_LIST
2215 static void
2216 dump_list (FILE *stream, const char *prefix, struct id *list)
2217 {
2218   while (list)
2219     {
2220       fprintf (stream, "%s%s,\n", prefix, list->name);
2221       list = list->next;
2222     }
2223 }
2224 #endif
2225
2226 #if 0
2227 static void
2228 dump_prefix_list (FILE *stream, const char *prefix, struct prefix_list *list)
2229 {
2230   while (list)
2231     {
2232       fprintf (stream, "%s%s,\n", prefix, list->prefix);
2233       list = list->next;
2234     }
2235 }
2236 #endif
2237
2238 static void
2239 write_list_with_asm (FILE *stream, const char *prefix, struct id *list)
2240 {
2241   while (list)
2242     {
2243       fprintf (stream, "%sx%d __asm__ (\"%s\");\n",
2244                prefix, list->sequence, list->name);
2245       list = list->next;
2246     }
2247 }
2248
2249 /* Write out the constructor and destructor tables statically (for a shared
2250    object), along with the functions to execute them.  */
2251
2252 static void
2253 write_c_file_stat (FILE *stream, const char *name ATTRIBUTE_UNUSED)
2254 {
2255   const char *p, *q;
2256   char *prefix, *r;
2257   int frames = (frame_tables.number > 0);
2258
2259   /* Figure out name of output_file, stripping off .so version.  */
2260   q = p = lbasename (output_file);
2261
2262   while (q)
2263     {
2264       q = strchr (q,'.');
2265       if (q == 0)
2266         {
2267           q = p + strlen (p);
2268           break;
2269         }
2270       else
2271         {
2272           if (filename_ncmp (q, SHLIB_SUFFIX, strlen (SHLIB_SUFFIX)) == 0)
2273             {
2274               q += strlen (SHLIB_SUFFIX);
2275               break;
2276             }
2277           else
2278             q++;
2279         }
2280     }
2281   /* q points to null at end of the string (or . of the .so version) */
2282   prefix = XNEWVEC (char, q - p + 1);
2283   strncpy (prefix, p, q - p);
2284   prefix[q - p] = 0;
2285   for (r = prefix; *r; r++)
2286     if (!ISALNUM ((unsigned char)*r))
2287       *r = '_';
2288   if (debug)
2289     notice ("\nwrite_c_file - output name is %s, prefix is %s\n",
2290             output_file, prefix);
2291
2292   initname = concat ("_GLOBAL__FI_", prefix, NULL);
2293   fininame = concat ("_GLOBAL__FD_", prefix, NULL);
2294
2295   free (prefix);
2296
2297   /* Write the tables as C code.  */
2298
2299   fprintf (stream, "static int count;\n");
2300   fprintf (stream, "typedef void entry_pt();\n");
2301   write_list_with_asm (stream, "extern entry_pt ", constructors.first);
2302
2303   if (frames)
2304     {
2305       write_list_with_asm (stream, "extern void *", frame_tables.first);
2306
2307       fprintf (stream, "\tstatic void *frame_table[] = {\n");
2308       write_list (stream, "\t\t&", frame_tables.first);
2309       fprintf (stream, "\t0\n};\n");
2310
2311       /* This must match what's in frame.h.  */
2312       fprintf (stream, "struct object {\n");
2313       fprintf (stream, "  void *pc_begin;\n");
2314       fprintf (stream, "  void *pc_end;\n");
2315       fprintf (stream, "  void *fde_begin;\n");
2316       fprintf (stream, "  void *fde_array;\n");
2317       fprintf (stream, "  __SIZE_TYPE__ count;\n");
2318       fprintf (stream, "  struct object *next;\n");
2319       fprintf (stream, "};\n");
2320
2321       fprintf (stream, "extern void __register_frame_info_table (void *, struct object *);\n");
2322       fprintf (stream, "extern void *__deregister_frame_info (void *);\n");
2323
2324       fprintf (stream, "static void reg_frame () {\n");
2325       fprintf (stream, "\tstatic struct object ob;\n");
2326       fprintf (stream, "\t__register_frame_info_table (frame_table, &ob);\n");
2327       fprintf (stream, "\t}\n");
2328
2329       fprintf (stream, "static void dereg_frame () {\n");
2330       fprintf (stream, "\t__deregister_frame_info (frame_table);\n");
2331       fprintf (stream, "\t}\n");
2332     }
2333
2334   fprintf (stream, "void %s() {\n", initname);
2335   if (constructors.number > 0 || frames)
2336     {
2337       fprintf (stream, "\tstatic entry_pt *ctors[] = {\n");
2338       write_list (stream, "\t\t", constructors.first);
2339       if (frames)
2340         fprintf (stream, "\treg_frame,\n");
2341       fprintf (stream, "\t};\n");
2342       fprintf (stream, "\tentry_pt **p;\n");
2343       fprintf (stream, "\tif (count++ != 0) return;\n");
2344       fprintf (stream, "\tp = ctors + %d;\n", constructors.number + frames);
2345       fprintf (stream, "\twhile (p > ctors) (*--p)();\n");
2346     }
2347   else
2348     fprintf (stream, "\t++count;\n");
2349   fprintf (stream, "}\n");
2350   write_list_with_asm (stream, "extern entry_pt ", destructors.first);
2351   fprintf (stream, "void %s() {\n", fininame);
2352   if (destructors.number > 0 || frames)
2353     {
2354       fprintf (stream, "\tstatic entry_pt *dtors[] = {\n");
2355       write_list (stream, "\t\t", destructors.first);
2356       if (frames)
2357         fprintf (stream, "\tdereg_frame,\n");
2358       fprintf (stream, "\t};\n");
2359       fprintf (stream, "\tentry_pt **p;\n");
2360       fprintf (stream, "\tif (--count != 0) return;\n");
2361       fprintf (stream, "\tp = dtors;\n");
2362       fprintf (stream, "\twhile (p < dtors + %d) (*p++)();\n",
2363                destructors.number + frames);
2364     }
2365   fprintf (stream, "}\n");
2366
2367   if (shared_obj)
2368     {
2369       COLLECT_SHARED_INIT_FUNC(stream, initname);
2370       COLLECT_SHARED_FINI_FUNC(stream, fininame);
2371     }
2372 }
2373
2374 /* Write the constructor/destructor tables.  */
2375
2376 #ifndef LD_INIT_SWITCH
2377 static void
2378 write_c_file_glob (FILE *stream, const char *name ATTRIBUTE_UNUSED)
2379 {
2380   /* Write the tables as C code.  */
2381
2382   int frames = (frame_tables.number > 0);
2383
2384   fprintf (stream, "typedef void entry_pt();\n\n");
2385
2386   write_list_with_asm (stream, "extern entry_pt ", constructors.first);
2387
2388   if (frames)
2389     {
2390       write_list_with_asm (stream, "extern void *", frame_tables.first);
2391
2392       fprintf (stream, "\tstatic void *frame_table[] = {\n");
2393       write_list (stream, "\t\t&", frame_tables.first);
2394       fprintf (stream, "\t0\n};\n");
2395
2396       /* This must match what's in frame.h.  */
2397       fprintf (stream, "struct object {\n");
2398       fprintf (stream, "  void *pc_begin;\n");
2399       fprintf (stream, "  void *pc_end;\n");
2400       fprintf (stream, "  void *fde_begin;\n");
2401       fprintf (stream, "  void *fde_array;\n");
2402       fprintf (stream, "  __SIZE_TYPE__ count;\n");
2403       fprintf (stream, "  struct object *next;\n");
2404       fprintf (stream, "};\n");
2405
2406       fprintf (stream, "extern void __register_frame_info_table (void *, struct object *);\n");
2407       fprintf (stream, "extern void *__deregister_frame_info (void *);\n");
2408
2409       fprintf (stream, "static void reg_frame () {\n");
2410       fprintf (stream, "\tstatic struct object ob;\n");
2411       fprintf (stream, "\t__register_frame_info_table (frame_table, &ob);\n");
2412       fprintf (stream, "\t}\n");
2413
2414       fprintf (stream, "static void dereg_frame () {\n");
2415       fprintf (stream, "\t__deregister_frame_info (frame_table);\n");
2416       fprintf (stream, "\t}\n");
2417     }
2418
2419   fprintf (stream, "\nentry_pt * __CTOR_LIST__[] = {\n");
2420   fprintf (stream, "\t(entry_pt *) %d,\n", constructors.number + frames);
2421   write_list (stream, "\t", constructors.first);
2422   if (frames)
2423     fprintf (stream, "\treg_frame,\n");
2424   fprintf (stream, "\t0\n};\n\n");
2425
2426   write_list_with_asm (stream, "extern entry_pt ", destructors.first);
2427
2428   fprintf (stream, "\nentry_pt * __DTOR_LIST__[] = {\n");
2429   fprintf (stream, "\t(entry_pt *) %d,\n", destructors.number + frames);
2430   write_list (stream, "\t", destructors.first);
2431   if (frames)
2432     fprintf (stream, "\tdereg_frame,\n");
2433   fprintf (stream, "\t0\n};\n\n");
2434
2435   fprintf (stream, "extern entry_pt %s;\n", NAME__MAIN);
2436   fprintf (stream, "entry_pt *__main_reference = %s;\n\n", NAME__MAIN);
2437 }
2438 #endif /* ! LD_INIT_SWITCH */
2439
2440 static void
2441 write_c_file (FILE *stream, const char *name)
2442 {
2443 #ifndef LD_INIT_SWITCH
2444   if (! shared_obj)
2445     write_c_file_glob (stream, name);
2446   else
2447 #endif
2448     write_c_file_stat (stream, name);
2449 }
2450
2451 #ifdef COLLECT_EXPORT_LIST
2452 static void
2453 write_aix_file (FILE *stream, struct id *list)
2454 {
2455   for (; list; list = list->next)
2456     {
2457       fputs (list->name, stream);
2458       putc ('\n', stream);
2459     }
2460 }
2461 #endif
2462 \f
2463 #ifdef OBJECT_FORMAT_NONE
2464
2465 /* Check to make sure the file is an LTO object file.  */
2466
2467 static bool
2468 maybe_lto_object_file (const char *prog_name)
2469 {
2470   FILE *f;
2471   unsigned char buf[4];
2472   int i;
2473
2474   static unsigned char elfmagic[4] = { 0x7f, 'E', 'L', 'F' };
2475   static unsigned char coffmagic[2] = { 0x4c, 0x01 };
2476   static unsigned char coffmagic_x64[2] = { 0x64, 0x86 };
2477   static unsigned char machomagic[4][4] = {
2478     { 0xcf, 0xfa, 0xed, 0xfe },
2479     { 0xce, 0xfa, 0xed, 0xfe },
2480     { 0xfe, 0xed, 0xfa, 0xcf },
2481     { 0xfe, 0xed, 0xfa, 0xce }
2482   };
2483
2484   f = fopen (prog_name, "rb");
2485   if (f == NULL)
2486     return false;
2487   if (fread (buf, sizeof (buf), 1, f) != 1)
2488     buf[0] = 0;
2489   fclose (f);
2490
2491   if (memcmp (buf, elfmagic, sizeof (elfmagic)) == 0
2492       || memcmp (buf, coffmagic, sizeof (coffmagic)) == 0
2493       || memcmp (buf, coffmagic_x64, sizeof (coffmagic_x64)) == 0)
2494     return true;
2495   for (i = 0; i < 4; i++)
2496     if (memcmp (buf, machomagic[i], sizeof (machomagic[i])) == 0)
2497       return true;
2498
2499   return false;
2500 }
2501
2502 /* Generic version to scan the name list of the loaded program for
2503    the symbols g++ uses for static constructors and destructors.  */
2504
2505 static void
2506 scan_prog_file (const char *prog_name, scanpass which_pass,
2507                 scanfilter filter)
2508 {
2509   void (*int_handler) (int);
2510 #ifdef SIGQUIT
2511   void (*quit_handler) (int);
2512 #endif
2513   char *real_nm_argv[4];
2514   const char **nm_argv = CONST_CAST2 (const char **, char**, real_nm_argv);
2515   int argc = 0;
2516   struct pex_obj *pex;
2517   const char *errmsg;
2518   int err;
2519   char *p, buf[1024];
2520   FILE *inf;
2521   int found_lto = 0;
2522
2523   if (which_pass == PASS_SECOND)
2524     return;
2525
2526   /* LTO objects must be in a known format.  This check prevents
2527      us from accepting an archive containing LTO objects, which
2528      gcc cannnot currently handle.  */
2529   if (which_pass == PASS_LTOINFO && !maybe_lto_object_file (prog_name))
2530     return;
2531
2532   /* If we do not have an `nm', complain.  */
2533   if (nm_file_name == 0)
2534     fatal_error ("cannot find 'nm'");
2535
2536   nm_argv[argc++] = nm_file_name;
2537   if (NM_FLAGS[0] != '\0')
2538     nm_argv[argc++] = NM_FLAGS;
2539
2540   nm_argv[argc++] = prog_name;
2541   nm_argv[argc++] = (char *) 0;
2542
2543   /* Trace if needed.  */
2544   if (vflag)
2545     {
2546       const char **p_argv;
2547       const char *str;
2548
2549       for (p_argv = &nm_argv[0]; (str = *p_argv) != (char *) 0; p_argv++)
2550         fprintf (stderr, " %s", str);
2551
2552       fprintf (stderr, "\n");
2553     }
2554
2555   fflush (stdout);
2556   fflush (stderr);
2557
2558   pex = pex_init (PEX_USE_PIPES, "collect2", NULL);
2559   if (pex == NULL)
2560     fatal_error ("pex_init failed: %m");
2561
2562   errmsg = pex_run (pex, 0, nm_file_name, real_nm_argv, NULL, HOST_BIT_BUCKET,
2563                     &err);
2564   if (errmsg != NULL)
2565     {
2566       if (err != 0)
2567         {
2568           errno = err;
2569           fatal_error ("%s: %m", _(errmsg));
2570         }
2571       else
2572         fatal_error (errmsg);
2573     }
2574
2575   int_handler  = (void (*) (int)) signal (SIGINT,  SIG_IGN);
2576 #ifdef SIGQUIT
2577   quit_handler = (void (*) (int)) signal (SIGQUIT, SIG_IGN);
2578 #endif
2579
2580   inf = pex_read_output (pex, 0);
2581   if (inf == NULL)
2582     fatal_error ("can't open nm output: %m");
2583
2584   if (debug)
2585     {
2586       if (which_pass == PASS_LTOINFO)
2587         fprintf (stderr, "\nnm output with LTO info marker symbol.\n");
2588       else
2589         fprintf (stderr, "\nnm output with constructors/destructors.\n");
2590     }
2591
2592   /* Read each line of nm output.  */
2593   while (fgets (buf, sizeof buf, inf) != (char *) 0)
2594     {
2595       int ch, ch2;
2596       char *name, *end;
2597
2598       if (debug)
2599         fprintf (stderr, "\t%s\n", buf);
2600
2601       if (which_pass == PASS_LTOINFO)
2602         {
2603           if (found_lto)
2604             continue;
2605
2606           /* Look for the LTO info marker symbol, and add filename to
2607              the LTO objects list if found.  */
2608           for (p = buf; (ch = *p) != '\0' && ch != '\n'; p++)
2609             if (ch == ' '  && p[1] == '_' && p[2] == '_'
2610                 && (strncmp (p + (p[3] == '_' ? 2 : 1), "__gnu_lto_v1", 12) == 0)
2611                 && ISSPACE (p[p[3] == '_' ? 14 : 13]))
2612               {
2613                 add_lto_object (&lto_objects, prog_name);
2614
2615                 /* We need to read all the input, so we can't just
2616                    return here.  But we can avoid useless work.  */
2617                 found_lto = 1;
2618
2619                 break;
2620               }
2621
2622           continue;
2623         }
2624
2625       /* If it contains a constructor or destructor name, add the name
2626          to the appropriate list unless this is a kind of symbol we're
2627          not supposed to even consider.  */
2628
2629       for (p = buf; (ch = *p) != '\0' && ch != '\n' && ch != '_'; p++)
2630         if (ch == ' ' && p[1] == 'U' && p[2] == ' ')
2631           break;
2632
2633       if (ch != '_')
2634         continue;
2635
2636       name = p;
2637       /* Find the end of the symbol name.
2638          Do not include `|', because Encore nm can tack that on the end.  */
2639       for (end = p; (ch2 = *end) != '\0' && !ISSPACE (ch2) && ch2 != '|';
2640            end++)
2641         continue;
2642
2643
2644       *end = '\0';
2645       switch (is_ctor_dtor (name))
2646         {
2647         case SYM_CTOR:
2648           if (! (filter & SCAN_CTOR))
2649             break;
2650           if (which_pass != PASS_LIB)
2651             add_to_list (&constructors, name);
2652           break;
2653
2654         case SYM_DTOR:
2655           if (! (filter & SCAN_DTOR))
2656             break;
2657           if (which_pass != PASS_LIB)
2658             add_to_list (&destructors, name);
2659           break;
2660
2661         case SYM_INIT:
2662           if (! (filter & SCAN_INIT))
2663             break;
2664           if (which_pass != PASS_LIB)
2665             fatal_error ("init function found in object %s", prog_name);
2666 #ifndef LD_INIT_SWITCH
2667           add_to_list (&constructors, name);
2668 #endif
2669           break;
2670
2671         case SYM_FINI:
2672           if (! (filter & SCAN_FINI))
2673             break;
2674           if (which_pass != PASS_LIB)
2675             fatal_error ("fini function found in object %s", prog_name);
2676 #ifndef LD_FINI_SWITCH
2677           add_to_list (&destructors, name);
2678 #endif
2679           break;
2680
2681         case SYM_DWEH:
2682           if (! (filter & SCAN_DWEH))
2683             break;
2684           if (which_pass != PASS_LIB)
2685             add_to_list (&frame_tables, name);
2686           break;
2687
2688         default:                /* not a constructor or destructor */
2689           continue;
2690         }
2691     }
2692
2693   if (debug)
2694     fprintf (stderr, "\n");
2695
2696   do_wait (nm_file_name, pex);
2697
2698   signal (SIGINT,  int_handler);
2699 #ifdef SIGQUIT
2700   signal (SIGQUIT, quit_handler);
2701 #endif
2702 }
2703
2704 #ifdef LDD_SUFFIX
2705
2706 /* Use the List Dynamic Dependencies program to find shared libraries that
2707    the output file depends upon and their initialization/finalization
2708    routines, if any.  */
2709
2710 static void
2711 scan_libraries (const char *prog_name)
2712 {
2713   static struct head libraries;         /* list of shared libraries found */
2714   struct id *list;
2715   void (*int_handler) (int);
2716 #ifdef SIGQUIT
2717   void (*quit_handler) (int);
2718 #endif
2719   char *real_ldd_argv[4];
2720   const char **ldd_argv = CONST_CAST2 (const char **, char **, real_ldd_argv);
2721   int argc = 0;
2722   struct pex_obj *pex;
2723   const char *errmsg;
2724   int err;
2725   char buf[1024];
2726   FILE *inf;
2727
2728   /* If we do not have an `ldd', complain.  */
2729   if (ldd_file_name == 0)
2730     {
2731       error ("cannot find 'ldd'");
2732       return;
2733     }
2734
2735   ldd_argv[argc++] = ldd_file_name;
2736   ldd_argv[argc++] = prog_name;
2737   ldd_argv[argc++] = (char *) 0;
2738
2739   /* Trace if needed.  */
2740   if (vflag)
2741     {
2742       const char **p_argv;
2743       const char *str;
2744
2745       for (p_argv = &ldd_argv[0]; (str = *p_argv) != (char *) 0; p_argv++)
2746         fprintf (stderr, " %s", str);
2747
2748       fprintf (stderr, "\n");
2749     }
2750
2751   fflush (stdout);
2752   fflush (stderr);
2753
2754   pex = pex_init (PEX_USE_PIPES, "collect2", NULL);
2755   if (pex == NULL)
2756     fatal_error ("pex_init failed: %m");
2757
2758   errmsg = pex_run (pex, 0, ldd_file_name, real_ldd_argv, NULL, NULL, &err);
2759   if (errmsg != NULL)
2760     {
2761       if (err != 0)
2762         {
2763           errno = err;
2764           fatal_error ("%s: %m", _(errmsg));
2765         }
2766       else
2767         fatal_error (errmsg);
2768     }
2769
2770   int_handler  = (void (*) (int)) signal (SIGINT,  SIG_IGN);
2771 #ifdef SIGQUIT
2772   quit_handler = (void (*) (int)) signal (SIGQUIT, SIG_IGN);
2773 #endif
2774
2775   inf = pex_read_output (pex, 0);
2776   if (inf == NULL)
2777     fatal_error ("can't open ldd output: %m");
2778
2779   if (debug)
2780     notice ("\nldd output with constructors/destructors.\n");
2781
2782   /* Read each line of ldd output.  */
2783   while (fgets (buf, sizeof buf, inf) != (char *) 0)
2784     {
2785       int ch2;
2786       char *name, *end, *p = buf;
2787
2788       /* Extract names of libraries and add to list.  */
2789       PARSE_LDD_OUTPUT (p);
2790       if (p == 0)
2791         continue;
2792
2793       name = p;
2794       if (strncmp (name, "not found", sizeof ("not found") - 1) == 0)
2795         fatal_error ("dynamic dependency %s not found", buf);
2796
2797       /* Find the end of the symbol name.  */
2798       for (end = p;
2799            (ch2 = *end) != '\0' && ch2 != '\n' && !ISSPACE (ch2) && ch2 != '|';
2800            end++)
2801         continue;
2802       *end = '\0';
2803
2804       if (access (name, R_OK) == 0)
2805         add_to_list (&libraries, name);
2806       else
2807         fatal_error ("unable to open dynamic dependency '%s'", buf);
2808
2809       if (debug)
2810         fprintf (stderr, "\t%s\n", buf);
2811     }
2812   if (debug)
2813     fprintf (stderr, "\n");
2814
2815   do_wait (ldd_file_name, pex);
2816
2817   signal (SIGINT,  int_handler);
2818 #ifdef SIGQUIT
2819   signal (SIGQUIT, quit_handler);
2820 #endif
2821
2822   /* Now iterate through the library list adding their symbols to
2823      the list.  */
2824   for (list = libraries.first; list; list = list->next)
2825     scan_prog_file (list->name, PASS_LIB, SCAN_ALL);
2826 }
2827
2828 #endif /* LDD_SUFFIX */
2829
2830 #endif /* OBJECT_FORMAT_NONE */
2831
2832 \f
2833 /*
2834  * COFF specific stuff.
2835  */
2836
2837 #ifdef OBJECT_FORMAT_COFF
2838
2839 #if defined (EXTENDED_COFF)
2840
2841 #   define GCC_SYMBOLS(X)       (SYMHEADER(X).isymMax + SYMHEADER(X).iextMax)
2842 #   define GCC_SYMENT           SYMR
2843 #   define GCC_OK_SYMBOL(X)     ((X).st == stProc || (X).st == stGlobal)
2844 #   define GCC_SYMINC(X)        (1)
2845 #   define GCC_SYMZERO(X)       (SYMHEADER(X).isymMax)
2846 #   define GCC_CHECK_HDR(X)     (PSYMTAB(X) != 0)
2847
2848 #else
2849
2850 #   define GCC_SYMBOLS(X)       (HEADER(ldptr).f_nsyms)
2851 #   define GCC_SYMENT           SYMENT
2852 #   if defined (C_WEAKEXT)
2853 #     define GCC_OK_SYMBOL(X) \
2854        (((X).n_sclass == C_EXT || (X).n_sclass == C_WEAKEXT) && \
2855         ((X).n_scnum > N_UNDEF) && \
2856         (aix64_flag \
2857          || (((X).n_type & N_TMASK) == (DT_NON << N_BTSHFT) \
2858              || ((X).n_type & N_TMASK) == (DT_FCN << N_BTSHFT))))
2859 #     define GCC_UNDEF_SYMBOL(X) \
2860        (((X).n_sclass == C_EXT || (X).n_sclass == C_WEAKEXT) && \
2861         ((X).n_scnum == N_UNDEF))
2862 #   else
2863 #     define GCC_OK_SYMBOL(X) \
2864        (((X).n_sclass == C_EXT) && \
2865         ((X).n_scnum > N_UNDEF) && \
2866         (aix64_flag \
2867          || (((X).n_type & N_TMASK) == (DT_NON << N_BTSHFT) \
2868              || ((X).n_type & N_TMASK) == (DT_FCN << N_BTSHFT))))
2869 #     define GCC_UNDEF_SYMBOL(X) \
2870        (((X).n_sclass == C_EXT) && ((X).n_scnum == N_UNDEF))
2871 #   endif
2872 #   define GCC_SYMINC(X)        ((X).n_numaux+1)
2873 #   define GCC_SYMZERO(X)       0
2874
2875 /* 0757 = U803XTOCMAGIC (AIX 4.3) and 0767 = U64_TOCMAGIC (AIX V5) */
2876 #if TARGET_AIX_VERSION >= 51
2877 #   define GCC_CHECK_HDR(X) \
2878      ((HEADER (X).f_magic == U802TOCMAGIC && ! aix64_flag) \
2879       || (HEADER (X).f_magic == 0767 && aix64_flag))
2880 #else
2881 #   define GCC_CHECK_HDR(X) \
2882      ((HEADER (X).f_magic == U802TOCMAGIC && ! aix64_flag) \
2883       || (HEADER (X).f_magic == 0757 && aix64_flag))
2884 #endif
2885
2886 #endif
2887
2888 #ifdef COLLECT_EXPORT_LIST
2889 /* Array of standard AIX libraries which should not
2890    be scanned for ctors/dtors.  */
2891 static const char *const aix_std_libs[] = {
2892   "/unix",
2893   "/lib/libc.a",
2894   "/lib/libm.a",
2895   "/lib/libc_r.a",
2896   "/lib/libm_r.a",
2897   "/usr/lib/libc.a",
2898   "/usr/lib/libm.a",
2899   "/usr/lib/libc_r.a",
2900   "/usr/lib/libm_r.a",
2901   "/usr/lib/threads/libc.a",
2902   "/usr/ccs/lib/libc.a",
2903   "/usr/ccs/lib/libm.a",
2904   "/usr/ccs/lib/libc_r.a",
2905   "/usr/ccs/lib/libm_r.a",
2906   NULL
2907 };
2908
2909 /* This function checks the filename and returns 1
2910    if this name matches the location of a standard AIX library.  */
2911 static int ignore_library (const char *);
2912 static int
2913 ignore_library (const char *name)
2914 {
2915   const char *const *p;
2916   size_t length;
2917
2918   if (target_system_root[0] != '\0')
2919     {
2920       length = strlen (target_system_root);
2921       if (strncmp (name, target_system_root, length) != 0)
2922         return 0;
2923       name += length;
2924     }
2925   for (p = &aix_std_libs[0]; *p != NULL; ++p)
2926     if (strcmp (name, *p) == 0)
2927       return 1;
2928   return 0;
2929 }
2930 #endif /* COLLECT_EXPORT_LIST */
2931
2932 #if defined (HAVE_DECL_LDGETNAME) && !HAVE_DECL_LDGETNAME
2933 extern char *ldgetname (LDFILE *, GCC_SYMENT *);
2934 #endif
2935
2936 /* COFF version to scan the name list of the loaded program for
2937    the symbols g++ uses for static constructors and destructors.  */
2938
2939 static void
2940 scan_prog_file (const char *prog_name, scanpass which_pass,
2941                 scanfilter filter)
2942 {
2943   LDFILE *ldptr = NULL;
2944   int sym_index, sym_count;
2945   int is_shared = 0;
2946
2947   if (which_pass != PASS_FIRST && which_pass != PASS_OBJ)
2948     return;
2949
2950 #ifdef COLLECT_EXPORT_LIST
2951   /* We do not need scanning for some standard C libraries.  */
2952   if (which_pass == PASS_FIRST && ignore_library (prog_name))
2953     return;
2954
2955   /* On AIX we have a loop, because there is not much difference
2956      between an object and an archive. This trick allows us to
2957      eliminate scan_libraries() function.  */
2958   do
2959     {
2960 #endif
2961       /* Some platforms (e.g. OSF4) declare ldopen as taking a
2962          non-const char * filename parameter, even though it will not
2963          modify that string.  So we must cast away const-ness here,
2964          using CONST_CAST to prevent complaints from -Wcast-qual.  */
2965       if ((ldptr = ldopen (CONST_CAST (char *, prog_name), ldptr)) != NULL)
2966         {
2967           if (! MY_ISCOFF (HEADER (ldptr).f_magic))
2968             fatal_error ("%s: not a COFF file", prog_name);
2969
2970           if (GCC_CHECK_HDR (ldptr))
2971             {
2972               sym_count = GCC_SYMBOLS (ldptr);
2973               sym_index = GCC_SYMZERO (ldptr);
2974
2975 #ifdef COLLECT_EXPORT_LIST
2976               /* Is current archive member a shared object?  */
2977               is_shared = HEADER (ldptr).f_flags & F_SHROBJ;
2978 #endif
2979
2980               while (sym_index < sym_count)
2981                 {
2982                   GCC_SYMENT symbol;
2983
2984                   if (ldtbread (ldptr, sym_index, &symbol) <= 0)
2985                     break;
2986                   sym_index += GCC_SYMINC (symbol);
2987
2988                   if (GCC_OK_SYMBOL (symbol))
2989                     {
2990                       char *name;
2991
2992                       if ((name = ldgetname (ldptr, &symbol)) == NULL)
2993                         continue;               /* Should never happen.  */
2994
2995 #ifdef XCOFF_DEBUGGING_INFO
2996                       /* All AIX function names have a duplicate entry
2997                          beginning with a dot.  */
2998                       if (*name == '.')
2999                         ++name;
3000 #endif
3001
3002                       switch (is_ctor_dtor (name))
3003                         {
3004                         case SYM_CTOR:
3005                           if (! (filter & SCAN_CTOR))
3006                             break;
3007                           if (! is_shared)
3008                             add_to_list (&constructors, name);
3009 #if defined (COLLECT_EXPORT_LIST) && !defined (LD_INIT_SWITCH)
3010                           if (which_pass == PASS_OBJ)
3011                             add_to_list (&exports, name);
3012 #endif
3013                           break;
3014
3015                         case SYM_DTOR:
3016                           if (! (filter & SCAN_DTOR))
3017                             break;
3018                           if (! is_shared)
3019                             add_to_list (&destructors, name);
3020 #if defined (COLLECT_EXPORT_LIST) && !defined (LD_INIT_SWITCH)
3021                           if (which_pass == PASS_OBJ)
3022                             add_to_list (&exports, name);
3023 #endif
3024                           break;
3025
3026 #ifdef COLLECT_EXPORT_LIST
3027                         case SYM_INIT:
3028                           if (! (filter & SCAN_INIT))
3029                             break;
3030 #ifndef LD_INIT_SWITCH
3031                           if (is_shared)
3032                             add_to_list (&constructors, name);
3033 #endif
3034                           break;
3035
3036                         case SYM_FINI:
3037                           if (! (filter & SCAN_FINI))
3038                             break;
3039 #ifndef LD_INIT_SWITCH
3040                           if (is_shared)
3041                             add_to_list (&destructors, name);
3042 #endif
3043                           break;
3044 #endif
3045
3046                         case SYM_DWEH:
3047                           if (! (filter & SCAN_DWEH))
3048                             break;
3049                           if (! is_shared)
3050                             add_to_list (&frame_tables, name);
3051 #if defined (COLLECT_EXPORT_LIST) && !defined (LD_INIT_SWITCH)
3052                           if (which_pass == PASS_OBJ)
3053                             add_to_list (&exports, name);
3054 #endif
3055                           break;
3056
3057                         default:        /* not a constructor or destructor */
3058 #ifdef COLLECT_EXPORT_LIST
3059                           /* Explicitly export all global symbols when
3060                              building a shared object on AIX, but do not
3061                              re-export symbols from another shared object
3062                              and do not export symbols if the user
3063                              provides an explicit export list.  */
3064                           if (shared_obj && !is_shared
3065                               && which_pass == PASS_OBJ && !export_flag)
3066                             add_to_list (&exports, name);
3067 #endif
3068                           continue;
3069                         }
3070
3071                       if (debug)
3072 #if !defined(EXTENDED_COFF)
3073                         fprintf (stderr, "\tsec=%d class=%d type=%s%o %s\n",
3074                                  symbol.n_scnum, symbol.n_sclass,
3075                                  (symbol.n_type ? "0" : ""), symbol.n_type,
3076                                  name);
3077 #else
3078                         fprintf (stderr,
3079                                  "\tiss = %5d, value = %5ld, index = %5d, name = %s\n",
3080                                  symbol.iss, (long) symbol.value, symbol.index, name);
3081 #endif
3082                     }
3083                 }
3084             }
3085 #ifdef COLLECT_EXPORT_LIST
3086           else
3087             {
3088               /* If archive contains both 32-bit and 64-bit objects,
3089                  we want to skip objects in other mode so mismatch normal.  */
3090               if (debug)
3091                 fprintf (stderr, "%s : magic=%o aix64=%d mismatch\n",
3092                          prog_name, HEADER (ldptr).f_magic, aix64_flag);
3093             }
3094 #endif
3095         }
3096       else
3097         {
3098           fatal_error ("%s: cannot open as COFF file", prog_name);
3099         }
3100 #ifdef COLLECT_EXPORT_LIST
3101       /* On AIX loop continues while there are more members in archive.  */
3102     }
3103   while (ldclose (ldptr) == FAILURE);
3104 #else
3105   /* Otherwise we simply close ldptr.  */
3106   (void) ldclose(ldptr);
3107 #endif
3108 }
3109 #endif /* OBJECT_FORMAT_COFF */
3110
3111 #ifdef COLLECT_EXPORT_LIST
3112 /* Given a library name without "lib" prefix, this function
3113    returns a full library name including a path.  */
3114 static char *
3115 resolve_lib_name (const char *name)
3116 {
3117   char *lib_buf;
3118   int i, j, l = 0;
3119   /* Library extensions for AIX dynamic linking.  */
3120   const char * const libexts[2] = {"a", "so"};
3121
3122   for (i = 0; libpaths[i]; i++)
3123     if (libpaths[i]->max_len > l)
3124       l = libpaths[i]->max_len;
3125
3126   lib_buf = XNEWVEC (char, l + strlen(name) + 10);
3127
3128   for (i = 0; libpaths[i]; i++)
3129     {
3130       struct prefix_list *list = libpaths[i]->plist;
3131       for (; list; list = list->next)
3132         {
3133           /* The following lines are needed because path_prefix list
3134              may contain directories both with trailing DIR_SEPARATOR and
3135              without it.  */
3136           const char *p = "";
3137           if (!IS_DIR_SEPARATOR (list->prefix[strlen(list->prefix)-1]))
3138             p = "/";
3139           for (j = 0; j < 2; j++)
3140             {
3141               sprintf (lib_buf, "%s%slib%s.%s",
3142                        list->prefix, p, name,
3143                        libexts[(j + aixrtl_flag) % 2]);
3144               if (debug) fprintf (stderr, "searching for: %s\n", lib_buf);
3145               if (file_exists (lib_buf))
3146                 {
3147                   if (debug) fprintf (stderr, "found: %s\n", lib_buf);
3148                   return (lib_buf);
3149                 }
3150             }
3151         }
3152     }
3153   if (debug)
3154     fprintf (stderr, "not found\n");
3155   else
3156     fatal_error ("library lib%s not found", name);
3157   return (NULL);
3158 }
3159 #endif /* COLLECT_EXPORT_LIST */
3160
3161 #ifdef COLLECT_RUN_DSYMUTIL
3162 static int flag_dsym = false;
3163 static int flag_idsym = false;
3164
3165 static void
3166 process_args (int *argcp, char **argv) {
3167   int i, j;
3168   int argc = *argcp;
3169   for (i=0; i<argc; ++i)
3170     {
3171       if (strcmp (argv[i], "-dsym") == 0)
3172         {
3173           flag_dsym = true;
3174           /* Remove the flag, as we handle all processing for it.  */
3175           j = i;
3176           do
3177             argv[j] = argv[j+1];
3178           while (++j < argc);
3179           --i;
3180           argc = --(*argcp);
3181         }
3182       else if (strcmp (argv[i], "-idsym") == 0)
3183         {
3184           flag_idsym = true;
3185           /* Remove the flag, as we handle all processing for it.  */
3186           j = i;
3187           do
3188             argv[j] = argv[j+1];
3189           while (++j < argc);
3190           --i;
3191           argc = --(*argcp);
3192         }
3193     }
3194 }
3195
3196 static void
3197 do_dsymutil (const char *output_file) {
3198   const char *dsymutil = DSYMUTIL + 1;
3199   struct pex_obj *pex;
3200   char **real_argv = XCNEWVEC (char *, 3);
3201   const char ** argv = CONST_CAST2 (const char **, char **,
3202                                     real_argv);
3203
3204   argv[0] = dsymutil;
3205   argv[1] = output_file;
3206   argv[2] = (char *) 0;
3207
3208   pex = collect_execute (dsymutil, real_argv, NULL, NULL, PEX_LAST | PEX_SEARCH);
3209   do_wait (dsymutil, pex);
3210 }
3211
3212 static void
3213 post_ld_pass (bool temp_file) {
3214   if (!(temp_file && flag_idsym) && !flag_dsym)
3215     return;
3216       
3217   do_dsymutil (output_file);
3218 }
3219 #else
3220 static void
3221 process_args (int *argcp ATTRIBUTE_UNUSED, char **argv ATTRIBUTE_UNUSED) { }
3222 static void post_ld_pass (bool temp_file ATTRIBUTE_UNUSED) { }
3223 #endif