Daily bump.
[official-gcc.git] / gcc / collect2.c
blob5b31f608754e675de98bebb291d7a71b8725f613
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
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).
10 This file is part of GCC.
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.
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.
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/>. */
27 /* Build tables of static constructors and destructors and run ld. */
29 #include "config.h"
30 #include "system.h"
31 #include "coretypes.h"
32 #include "tm.h"
33 #include "filenames.h"
35 /* TARGET_64BIT may be defined to use driver specific functionality. */
36 #undef TARGET_64BIT
37 #define TARGET_64BIT TARGET_64BIT_DEFAULT
39 #ifndef LIBRARY_PATH_ENV
40 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
41 #endif
43 #define COLLECT
45 #include "collect2.h"
46 #include "collect2-aix.h"
47 #include "demangle.h"
48 #include "obstack.h"
49 #include "intl.h"
50 #include "version.h"
52 /* On certain systems, we have code that works by scanning the object file
53 directly. But this code uses system-specific header files and library
54 functions, so turn it off in a cross-compiler. Likewise, the names of
55 the utilities are not correct for a cross-compiler; we have to hope that
56 cross-versions are in the proper directories. */
58 #ifdef CROSS_DIRECTORY_STRUCTURE
59 #ifndef CROSS_AIX_SUPPORT
60 #undef OBJECT_FORMAT_COFF
61 #endif
62 #undef MD_EXEC_PREFIX
63 #undef REAL_LD_FILE_NAME
64 #undef REAL_NM_FILE_NAME
65 #undef REAL_STRIP_FILE_NAME
66 #endif
68 /* If we cannot use a special method, use the ordinary one:
69 run nm to find what symbols are present.
70 In a cross-compiler, this means you need a cross nm,
71 but that is not quite as unpleasant as special headers. */
73 #if !defined (OBJECT_FORMAT_COFF)
74 #define OBJECT_FORMAT_NONE
75 #endif
77 #ifdef OBJECT_FORMAT_COFF
79 #ifndef CROSS_DIRECTORY_STRUCTURE
80 #include <a.out.h>
81 #include <ar.h>
83 #ifdef UMAX
84 #include <sgs.h>
85 #endif
87 /* Many versions of ldfcn.h define these. */
88 #ifdef FREAD
89 #undef FREAD
90 #undef FWRITE
91 #endif
93 #include <ldfcn.h>
94 #endif
96 /* Some systems have an ISCOFF macro, but others do not. In some cases
97 the macro may be wrong. MY_ISCOFF is defined in tm.h files for machines
98 that either do not have an ISCOFF macro in /usr/include or for those
99 where it is wrong. */
101 #ifndef MY_ISCOFF
102 #define MY_ISCOFF(X) ISCOFF (X)
103 #endif
105 #endif /* OBJECT_FORMAT_COFF */
107 #ifdef OBJECT_FORMAT_NONE
109 /* Default flags to pass to nm. */
110 #ifndef NM_FLAGS
111 #define NM_FLAGS "-n"
112 #endif
114 #endif /* OBJECT_FORMAT_NONE */
116 /* Some systems use __main in a way incompatible with its use in gcc, in these
117 cases use the macros NAME__MAIN to give a quoted symbol and SYMBOL__MAIN to
118 give the same symbol without quotes for an alternative entry point. */
119 #ifndef NAME__MAIN
120 #define NAME__MAIN "__main"
121 #endif
123 /* This must match tree.h. */
124 #define DEFAULT_INIT_PRIORITY 65535
126 #ifndef COLLECT_SHARED_INIT_FUNC
127 #define COLLECT_SHARED_INIT_FUNC(STREAM, FUNC) \
128 fprintf ((STREAM), "void _GLOBAL__DI() {\n\t%s();\n}\n", (FUNC))
129 #endif
130 #ifndef COLLECT_SHARED_FINI_FUNC
131 #define COLLECT_SHARED_FINI_FUNC(STREAM, FUNC) \
132 fprintf ((STREAM), "void _GLOBAL__DD() {\n\t%s();\n}\n", (FUNC))
133 #endif
135 #ifdef LDD_SUFFIX
136 #define SCAN_LIBRARIES
137 #endif
139 #ifndef SHLIB_SUFFIX
140 #define SHLIB_SUFFIX ".so"
141 #endif
143 #ifdef USE_COLLECT2
144 int do_collecting = 1;
145 #else
146 int do_collecting = 0;
147 #endif
149 /* Cook up an always defined indication of whether we proceed the
150 "EXPORT_LIST" way. */
152 #ifdef COLLECT_EXPORT_LIST
153 #define DO_COLLECT_EXPORT_LIST 1
154 #else
155 #define DO_COLLECT_EXPORT_LIST 0
156 #endif
158 /* Nonzero if we should suppress the automatic demangling of identifiers
159 in linker error messages. Set from COLLECT_NO_DEMANGLE. */
160 int no_demangle;
162 /* Linked lists of constructor and destructor names. */
164 struct id
166 struct id *next;
167 int sequence;
168 char name[1];
171 struct head
173 struct id *first;
174 struct id *last;
175 int number;
178 bool vflag; /* true if -v or --version */
179 static int rflag; /* true if -r */
180 static int strip_flag; /* true if -s */
181 static const char *demangle_flag;
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
188 enum lto_mode_d {
189 LTO_MODE_NONE, /* Not doing LTO. */
190 LTO_MODE_LTO, /* Normal LTO. */
191 LTO_MODE_WHOPR /* WHOPR. */
194 /* Current LTO mode. */
195 static enum lto_mode_d lto_mode = LTO_MODE_NONE;
197 bool debug; /* true if -debug */
198 bool helpflag; /* true if --help */
200 static int shared_obj; /* true if -shared */
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 */
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 */
226 static bool at_file_supplied; /* Whether to use @file arguments */
227 static char *response_file; /* Name of any current response file */
229 struct obstack temporary_obstack;
230 char * temporary_firstobj;
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
240 /* Structure to hold all the directories in which to search for files to
241 execute. */
243 struct prefix_list
245 const char *prefix; /* String to prepend to the path. */
246 struct prefix_list *next; /* Next in linked list. */
249 struct path_prefix
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) */
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
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(). */
270 struct lto_object
272 const char *name; /* Name of object file. */
273 struct lto_object *next; /* Next in linked list. */
276 struct lto_object_list
278 struct lto_object *first; /* First list element. */
279 struct lto_object *last; /* Last list element. */
282 static struct lto_object_list lto_objects;
284 /* Special kinds of symbols that a name may denote. */
286 typedef enum {
287 SYM_REGULAR = 0, /* nothing special */
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;
296 static symkind is_ctor_dtor (const char *);
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);
340 /* Enumerations describing which pass this is for scanning the
341 program file ... */
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;
351 /* ... and which kinds of symbols are to be considered. */
353 enum scanfilter_masks {
354 SCAN_NOTHING = 0,
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
364 /* This type is used for parameters and variables which hold
365 combinations of the flags in enum scanfilter_masks. */
366 typedef int scanfilter;
368 /* Scan the name list of the loaded program for the symbols g++ uses for
369 static constructors and destructors.
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.
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__. */
382 static void scan_prog_file (const char *, scanpass, scanfilter);
385 /* Delete tempfiles and exit function. */
387 void
388 collect_exit (int status)
390 if (c_file != 0 && c_file[0])
391 maybe_unlink (c_file);
393 if (o_file != 0 && o_file[0])
394 maybe_unlink (o_file);
396 #ifdef COLLECT_EXPORT_LIST
397 if (export_file != 0 && export_file[0])
398 maybe_unlink (export_file);
399 #endif
401 if (lto_o_files)
402 maybe_unlink_list (lto_o_files);
404 if (ldout != 0 && ldout[0])
406 dump_file (ldout, stdout);
407 maybe_unlink (ldout);
410 if (lderrout != 0 && lderrout[0])
412 dump_file (lderrout, stderr);
413 maybe_unlink (lderrout);
416 if (status != 0 && output_file != 0 && output_file[0])
417 maybe_unlink (output_file);
419 if (response_file)
420 maybe_unlink (response_file);
422 exit (status);
426 /* Notify user of a non-error. */
427 void
428 notice (const char *cmsgid, ...)
430 va_list ap;
432 va_start (ap, cmsgid);
433 vfprintf (stderr, _(cmsgid), ap);
434 va_end (ap);
437 /* Notify user of a non-error, without translating the format string. */
438 void
439 notice_translated (const char *cmsgid, ...)
441 va_list ap;
443 va_start (ap, cmsgid);
444 vfprintf (stderr, cmsgid, ap);
445 va_end (ap);
448 /* Die when sys call fails. */
450 void
451 fatal_perror (const char * cmsgid, ...)
453 int e = errno;
454 va_list ap;
456 va_start (ap, cmsgid);
457 fprintf (stderr, "collect2: ");
458 vfprintf (stderr, _(cmsgid), ap);
459 fprintf (stderr, ": %s\n", xstrerror (e));
460 va_end (ap);
462 collect_exit (FATAL_EXIT_CODE);
465 /* Just die. */
467 void
468 fatal (const char * cmsgid, ...)
470 va_list ap;
472 va_start (ap, cmsgid);
473 fprintf (stderr, "collect2: ");
474 vfprintf (stderr, _(cmsgid), ap);
475 fprintf (stderr, "\n");
476 va_end (ap);
478 collect_exit (FATAL_EXIT_CODE);
481 /* Write error message. */
483 void
484 error (const char * gmsgid, ...)
486 va_list ap;
488 va_start (ap, gmsgid);
489 fprintf (stderr, "collect2: ");
490 vfprintf (stderr, _(gmsgid), ap);
491 fprintf (stderr, "\n");
492 va_end(ap);
495 /* In case obstack is linked in, and abort is defined to fancy_abort,
496 provide a default entry. */
498 void
499 fancy_abort (const char *file, int line, const char *func)
501 fatal ("internal gcc abort in %s, at %s:%d", func, file, line);
504 static void
505 handler (int signo)
507 if (c_file != 0 && c_file[0])
508 maybe_unlink (c_file);
510 if (o_file != 0 && o_file[0])
511 maybe_unlink (o_file);
513 if (ldout != 0 && ldout[0])
514 maybe_unlink (ldout);
516 if (lderrout != 0 && lderrout[0])
517 maybe_unlink (lderrout);
519 #ifdef COLLECT_EXPORT_LIST
520 if (export_file != 0 && export_file[0])
521 maybe_unlink (export_file);
522 #endif
524 if (lto_o_files)
525 maybe_unlink_list (lto_o_files);
527 if (response_file)
528 maybe_unlink (response_file);
530 signal (signo, SIG_DFL);
531 raise (signo);
536 file_exists (const char *name)
538 return access (name, R_OK) == 0;
541 /* Parse a reasonable subset of shell quoting syntax. */
543 static char *
544 extract_string (const char **pp)
546 const char *p = *pp;
547 int backquote = 0;
548 int inside = 0;
550 for (;;)
552 char c = *p;
553 if (c == '\0')
554 break;
555 ++p;
556 if (backquote)
557 obstack_1grow (&temporary_obstack, c);
558 else if (! inside && c == ' ')
559 break;
560 else if (! inside && c == '\\')
561 backquote = 1;
562 else if (c == '\'')
563 inside = !inside;
564 else
565 obstack_1grow (&temporary_obstack, c);
568 obstack_1grow (&temporary_obstack, '\0');
569 *pp = p;
570 return XOBFINISH (&temporary_obstack, char *);
573 void
574 dump_file (const char *name, FILE *to)
576 FILE *stream = fopen (name, "r");
578 if (stream == 0)
579 return;
580 while (1)
582 int c;
583 while (c = getc (stream),
584 c != EOF && (ISIDNUM (c) || c == '$' || c == '.'))
585 obstack_1grow (&temporary_obstack, c);
586 if (obstack_object_size (&temporary_obstack) > 0)
588 const char *word, *p;
589 char *result;
590 obstack_1grow (&temporary_obstack, '\0');
591 word = XOBFINISH (&temporary_obstack, const char *);
593 if (*word == '.')
594 ++word, putc ('.', to);
595 p = word;
596 if (!strncmp (p, USER_LABEL_PREFIX, strlen (USER_LABEL_PREFIX)))
597 p += strlen (USER_LABEL_PREFIX);
599 #ifdef HAVE_LD_DEMANGLE
600 result = 0;
601 #else
602 if (no_demangle)
603 result = 0;
604 else
605 result = cplus_demangle (p, DMGL_PARAMS | DMGL_ANSI | DMGL_VERBOSE);
606 #endif
608 if (result)
610 int diff;
611 fputs (result, to);
613 diff = strlen (word) - strlen (result);
614 while (diff > 0 && c == ' ')
615 --diff, putc (' ', to);
616 if (diff < 0 && c == ' ')
618 while (diff < 0 && c == ' ')
619 ++diff, c = getc (stream);
620 if (!ISSPACE (c))
622 /* Make sure we output at least one space, or
623 the demangled symbol name will run into
624 whatever text follows. */
625 putc (' ', to);
629 free (result);
631 else
632 fputs (word, to);
634 fflush (to);
635 obstack_free (&temporary_obstack, temporary_firstobj);
637 if (c == EOF)
638 break;
639 putc (c, to);
641 fclose (stream);
644 /* Return the kind of symbol denoted by name S. */
646 static symkind
647 is_ctor_dtor (const char *s)
649 struct names { const char *const name; const int len; symkind ret;
650 const int two_underscores; };
652 const struct names *p;
653 int ch;
654 const char *orig_s = s;
656 static const struct names special[] = {
657 #ifndef NO_DOLLAR_IN_LABEL
658 { "GLOBAL__I$", sizeof ("GLOBAL__I$")-1, SYM_CTOR, 0 },
659 { "GLOBAL__D$", sizeof ("GLOBAL__D$")-1, SYM_DTOR, 0 },
660 #else
661 #ifndef NO_DOT_IN_LABEL
662 { "GLOBAL__I.", sizeof ("GLOBAL__I.")-1, SYM_CTOR, 0 },
663 { "GLOBAL__D.", sizeof ("GLOBAL__D.")-1, SYM_DTOR, 0 },
664 #endif /* NO_DOT_IN_LABEL */
665 #endif /* NO_DOLLAR_IN_LABEL */
666 { "GLOBAL__I_", sizeof ("GLOBAL__I_")-1, SYM_CTOR, 0 },
667 { "GLOBAL__D_", sizeof ("GLOBAL__D_")-1, SYM_DTOR, 0 },
668 { "GLOBAL__F_", sizeof ("GLOBAL__F_")-1, SYM_DWEH, 0 },
669 { "GLOBAL__FI_", sizeof ("GLOBAL__FI_")-1, SYM_INIT, 0 },
670 { "GLOBAL__FD_", sizeof ("GLOBAL__FD_")-1, SYM_FINI, 0 },
671 { NULL, 0, SYM_REGULAR, 0 }
674 while ((ch = *s) == '_')
675 ++s;
677 if (s == orig_s)
678 return SYM_REGULAR;
680 for (p = &special[0]; p->len > 0; p++)
682 if (ch == p->name[0]
683 && (!p->two_underscores || ((s - orig_s) >= 2))
684 && strncmp(s, p->name, p->len) == 0)
686 return p->ret;
689 return SYM_REGULAR;
692 /* We maintain two prefix lists: one from COMPILER_PATH environment variable
693 and one from the PATH variable. */
695 static struct path_prefix cpath, path;
697 #ifdef CROSS_DIRECTORY_STRUCTURE
698 /* This is the name of the target machine. We use it to form the name
699 of the files to execute. */
701 static const char *const target_machine = TARGET_MACHINE;
702 #endif
704 /* Search for NAME using prefix list PPREFIX. We only look for executable
705 files.
707 Return 0 if not found, otherwise return its name, allocated with malloc. */
709 static char *
710 find_a_file (struct path_prefix *pprefix, const char *name)
712 char *temp;
713 struct prefix_list *pl;
714 int len = pprefix->max_len + strlen (name) + 1;
716 if (debug)
717 fprintf (stderr, "Looking for '%s'\n", name);
719 #ifdef HOST_EXECUTABLE_SUFFIX
720 len += strlen (HOST_EXECUTABLE_SUFFIX);
721 #endif
723 temp = XNEWVEC (char, len);
725 /* Determine the filename to execute (special case for absolute paths). */
727 if (IS_ABSOLUTE_PATH (name))
729 if (access (name, X_OK) == 0)
731 strcpy (temp, name);
733 if (debug)
734 fprintf (stderr, " - found: absolute path\n");
736 return temp;
739 #ifdef HOST_EXECUTABLE_SUFFIX
740 /* Some systems have a suffix for executable files.
741 So try appending that. */
742 strcpy (temp, name);
743 strcat (temp, HOST_EXECUTABLE_SUFFIX);
745 if (access (temp, X_OK) == 0)
746 return temp;
747 #endif
749 if (debug)
750 fprintf (stderr, " - failed to locate using absolute path\n");
752 else
753 for (pl = pprefix->plist; pl; pl = pl->next)
755 struct stat st;
757 strcpy (temp, pl->prefix);
758 strcat (temp, name);
760 if (stat (temp, &st) >= 0
761 && ! S_ISDIR (st.st_mode)
762 && access (temp, X_OK) == 0)
763 return temp;
765 #ifdef HOST_EXECUTABLE_SUFFIX
766 /* Some systems have a suffix for executable files.
767 So try appending that. */
768 strcat (temp, HOST_EXECUTABLE_SUFFIX);
770 if (stat (temp, &st) >= 0
771 && ! S_ISDIR (st.st_mode)
772 && access (temp, X_OK) == 0)
773 return temp;
774 #endif
777 if (debug && pprefix->plist == NULL)
778 fprintf (stderr, " - failed: no entries in prefix list\n");
780 free (temp);
781 return 0;
784 /* Add an entry for PREFIX to prefix list PPREFIX. */
786 static void
787 add_prefix (struct path_prefix *pprefix, const char *prefix)
789 struct prefix_list *pl, **prev;
790 int len;
792 if (pprefix->plist)
794 for (pl = pprefix->plist; pl->next; pl = pl->next)
796 prev = &pl->next;
798 else
799 prev = &pprefix->plist;
801 /* Keep track of the longest prefix. */
803 len = strlen (prefix);
804 if (len > pprefix->max_len)
805 pprefix->max_len = len;
807 pl = XNEW (struct prefix_list);
808 pl->prefix = xstrdup (prefix);
810 if (*prev)
811 pl->next = *prev;
812 else
813 pl->next = (struct prefix_list *) 0;
814 *prev = pl;
817 /* Take the value of the environment variable ENV, break it into a path, and
818 add of the entries to PPREFIX. */
820 static void
821 prefix_from_env (const char *env, struct path_prefix *pprefix)
823 const char *p;
824 p = getenv (env);
826 if (p)
827 prefix_from_string (p, pprefix);
830 static void
831 prefix_from_string (const char *p, struct path_prefix *pprefix)
833 const char *startp, *endp;
834 char *nstore = XNEWVEC (char, strlen (p) + 3);
836 if (debug)
837 fprintf (stderr, "Convert string '%s' into prefixes, separator = '%c'\n", p, PATH_SEPARATOR);
839 startp = endp = p;
840 while (1)
842 if (*endp == PATH_SEPARATOR || *endp == 0)
844 strncpy (nstore, startp, endp-startp);
845 if (endp == startp)
847 strcpy (nstore, "./");
849 else if (! IS_DIR_SEPARATOR (endp[-1]))
851 nstore[endp-startp] = DIR_SEPARATOR;
852 nstore[endp-startp+1] = 0;
854 else
855 nstore[endp-startp] = 0;
857 if (debug)
858 fprintf (stderr, " - add prefix: %s\n", nstore);
860 add_prefix (pprefix, nstore);
861 if (*endp == 0)
862 break;
863 endp = startp = endp + 1;
865 else
866 endp++;
868 free (nstore);
871 #ifdef OBJECT_FORMAT_NONE
873 /* Add an entry for the object file NAME to object file list LIST.
874 New entries are added at the end of the list. The original pointer
875 value of NAME is preserved, i.e., no string copy is performed. */
877 static void
878 add_lto_object (struct lto_object_list *list, const char *name)
880 struct lto_object *n = XNEW (struct lto_object);
881 n->name = name;
882 n->next = NULL;
884 if (list->last)
885 list->last->next = n;
886 else
887 list->first = n;
889 list->last = n;
891 #endif /* OBJECT_FORMAT_NONE */
894 /* Perform a link-time recompilation and relink if any of the object
895 files contain LTO info. The linker command line LTO_LD_ARGV
896 represents the linker command that would produce a final executable
897 without the use of LTO. OBJECT_LST is a vector of object file names
898 appearing in LTO_LD_ARGV that are to be considerd for link-time
899 recompilation, where OBJECT is a pointer to the last valid element.
900 (This awkward convention avoids an impedance mismatch with the
901 usage of similarly-named variables in main().) The elements of
902 OBJECT_LST must be identical, i.e., pointer equal, to the
903 corresponding arguments in LTO_LD_ARGV.
905 Upon entry, at least one linker run has been performed without the
906 use of any LTO info that might be present. Any recompilations
907 necessary for template instantiations have been performed, and
908 initializer/finalizer tables have been created if needed and
909 included in the linker command line LTO_LD_ARGV. If any of the
910 object files contain LTO info, we run the LTO back end on all such
911 files, and perform the final link with the LTO back end output
912 substituted for the LTO-optimized files. In some cases, a final
913 link with all link-time generated code has already been performed,
914 so there is no need to relink if no LTO info is found. In other
915 cases, our caller has not produced the final executable, and is
916 relying on us to perform the required link whether LTO info is
917 present or not. In that case, the FORCE argument should be true.
918 Note that the linker command line argument LTO_LD_ARGV passed into
919 this function may be modified in place. */
921 static void
922 maybe_run_lto_and_relink (char **lto_ld_argv, char **object_lst,
923 const char **object, bool force)
925 const char **object_file = CONST_CAST2 (const char **, char **, object_lst);
927 int num_lto_c_args = 1; /* Allow space for the terminating NULL. */
929 while (object_file < object)
931 /* If file contains LTO info, add it to the list of LTO objects. */
932 scan_prog_file (*object_file++, PASS_LTOINFO, SCAN_ALL);
934 /* Increment the argument count by the number of object file arguments
935 we will add. An upper bound suffices, so just count all of the
936 object files regardless of whether they contain LTO info. */
937 num_lto_c_args++;
940 if (lto_objects.first)
942 char **lto_c_argv;
943 const char **lto_c_ptr;
944 char **p;
945 char **lto_o_ptr;
946 struct lto_object *list;
947 char *lto_wrapper = getenv ("COLLECT_LTO_WRAPPER");
948 struct pex_obj *pex;
949 const char *prog = "lto-wrapper";
950 int lto_ld_argv_size = 0;
951 char **out_lto_ld_argv;
952 int out_lto_ld_argv_size;
953 size_t num_files;
955 if (!lto_wrapper)
956 fatal ("COLLECT_LTO_WRAPPER must be set");
958 num_lto_c_args++;
960 /* There is at least one object file containing LTO info,
961 so we need to run the LTO back end and relink.
963 To do so we build updated ld arguments with first
964 LTO object replaced by all partitions and other LTO
965 objects removed. */
967 lto_c_argv = (char **) xcalloc (sizeof (char *), num_lto_c_args);
968 lto_c_ptr = CONST_CAST2 (const char **, char **, lto_c_argv);
970 *lto_c_ptr++ = lto_wrapper;
972 /* Add LTO objects to the wrapper command line. */
973 for (list = lto_objects.first; list; list = list->next)
974 *lto_c_ptr++ = list->name;
976 *lto_c_ptr = NULL;
978 /* Run the LTO back end. */
979 pex = collect_execute (prog, lto_c_argv, NULL, NULL, PEX_SEARCH);
981 int c;
982 FILE *stream;
983 size_t i;
984 char *start, *end;
986 stream = pex_read_output (pex, 0);
987 gcc_assert (stream);
989 num_files = 0;
990 while ((c = getc (stream)) != EOF)
992 obstack_1grow (&temporary_obstack, c);
993 if (c == '\n')
994 ++num_files;
997 lto_o_files = XNEWVEC (char *, num_files + 1);
998 lto_o_files[num_files] = NULL;
999 start = XOBFINISH (&temporary_obstack, char *);
1000 for (i = 0; i < num_files; ++i)
1002 end = start;
1003 while (*end != '\n')
1004 ++end;
1005 *end = '\0';
1007 lto_o_files[i] = xstrdup (start);
1009 start = end + 1;
1012 obstack_free (&temporary_obstack, temporary_firstobj);
1014 do_wait (prog, pex);
1015 pex = NULL;
1017 /* Compute memory needed for new LD arguments. At most number of original arguemtns
1018 plus number of partitions. */
1019 for (lto_ld_argv_size = 0; lto_ld_argv[lto_ld_argv_size]; lto_ld_argv_size++)
1021 out_lto_ld_argv = XCNEWVEC(char *, num_files + lto_ld_argv_size + 1);
1022 out_lto_ld_argv_size = 0;
1024 /* After running the LTO back end, we will relink, substituting
1025 the LTO output for the object files that we submitted to the
1026 LTO. Here, we modify the linker command line for the relink. */
1028 /* Copy all arguments until we find first LTO file. */
1029 p = lto_ld_argv;
1030 while (*p != NULL)
1032 for (list = lto_objects.first; list; list = list->next)
1033 if (*p == list->name) /* Note test for pointer equality! */
1034 break;
1035 if (list)
1036 break;
1037 out_lto_ld_argv[out_lto_ld_argv_size++] = *p++;
1040 /* Now insert all LTO partitions. */
1041 lto_o_ptr = lto_o_files;
1042 while (*lto_o_ptr)
1043 out_lto_ld_argv[out_lto_ld_argv_size++] = *lto_o_ptr++;
1045 /* ... and copy the rest. */
1046 while (*p != NULL)
1048 for (list = lto_objects.first; list; list = list->next)
1049 if (*p == list->name) /* Note test for pointer equality! */
1050 break;
1051 if (!list)
1052 out_lto_ld_argv[out_lto_ld_argv_size++] = *p;
1053 p++;
1055 out_lto_ld_argv[out_lto_ld_argv_size++] = 0;
1057 /* Run the linker again, this time replacing the object files
1058 optimized by the LTO with the temporary file generated by the LTO. */
1059 fork_execute ("ld", out_lto_ld_argv);
1060 post_ld_pass (true);
1061 free (lto_ld_argv);
1063 maybe_unlink_list (lto_o_files);
1065 else if (force)
1067 /* Our caller is relying on us to do the link
1068 even though there is no LTO back end work to be done. */
1069 fork_execute ("ld", lto_ld_argv);
1070 post_ld_pass (false);
1074 /* Main program. */
1077 main (int argc, char **argv)
1079 static const char *const ld_suffix = "ld";
1080 static const char *const plugin_ld_suffix = PLUGIN_LD;
1081 static const char *const real_ld_suffix = "real-ld";
1082 static const char *const collect_ld_suffix = "collect-ld";
1083 static const char *const nm_suffix = "nm";
1084 static const char *const gnm_suffix = "gnm";
1085 #ifdef LDD_SUFFIX
1086 static const char *const ldd_suffix = LDD_SUFFIX;
1087 #endif
1088 static const char *const strip_suffix = "strip";
1089 static const char *const gstrip_suffix = "gstrip";
1091 #ifdef CROSS_DIRECTORY_STRUCTURE
1092 /* If we look for a program in the compiler directories, we just use
1093 the short name, since these directories are already system-specific.
1094 But it we look for a program in the system directories, we need to
1095 qualify the program name with the target machine. */
1097 const char *const full_ld_suffix =
1098 concat(target_machine, "-", ld_suffix, NULL);
1099 const char *const full_plugin_ld_suffix =
1100 concat(target_machine, "-", plugin_ld_suffix, NULL);
1101 const char *const full_nm_suffix =
1102 concat (target_machine, "-", nm_suffix, NULL);
1103 const char *const full_gnm_suffix =
1104 concat (target_machine, "-", gnm_suffix, NULL);
1105 #ifdef LDD_SUFFIX
1106 const char *const full_ldd_suffix =
1107 concat (target_machine, "-", ldd_suffix, NULL);
1108 #endif
1109 const char *const full_strip_suffix =
1110 concat (target_machine, "-", strip_suffix, NULL);
1111 const char *const full_gstrip_suffix =
1112 concat (target_machine, "-", gstrip_suffix, NULL);
1113 #else
1114 const char *const full_ld_suffix = ld_suffix;
1115 const char *const full_plugin_ld_suffix = plugin_ld_suffix;
1116 const char *const full_nm_suffix = nm_suffix;
1117 const char *const full_gnm_suffix = gnm_suffix;
1118 #ifdef LDD_SUFFIX
1119 const char *const full_ldd_suffix = ldd_suffix;
1120 #endif
1121 const char *const full_strip_suffix = strip_suffix;
1122 const char *const full_gstrip_suffix = gstrip_suffix;
1123 #endif /* CROSS_DIRECTORY_STRUCTURE */
1125 const char *arg;
1126 FILE *outf;
1127 #ifdef COLLECT_EXPORT_LIST
1128 FILE *exportf;
1129 #endif
1130 const char *ld_file_name;
1131 const char *p;
1132 char **c_argv;
1133 const char **c_ptr;
1134 char **ld1_argv;
1135 const char **ld1;
1136 bool use_plugin = false;
1138 /* The kinds of symbols we will have to consider when scanning the
1139 outcome of a first pass link. This is ALL to start with, then might
1140 be adjusted before getting to the first pass link per se, typically on
1141 AIX where we perform an early scan of objects and libraries to fetch
1142 the list of global ctors/dtors and make sure they are not garbage
1143 collected. */
1144 scanfilter ld1_filter = SCAN_ALL;
1146 char **ld2_argv;
1147 const char **ld2;
1148 char **object_lst;
1149 const char **object;
1150 int first_file;
1151 int num_c_args;
1152 char **old_argv;
1154 old_argv = argv;
1155 expandargv (&argc, &argv);
1156 if (argv != old_argv)
1157 at_file_supplied = 1;
1159 process_args (&argc, argv);
1161 num_c_args = argc + 9;
1163 no_demangle = !! getenv ("COLLECT_NO_DEMANGLE");
1165 /* Suppress demangling by the real linker, which may be broken. */
1166 putenv (xstrdup ("COLLECT_NO_DEMANGLE="));
1168 #if defined (COLLECT2_HOST_INITIALIZATION)
1169 /* Perform system dependent initialization, if necessary. */
1170 COLLECT2_HOST_INITIALIZATION;
1171 #endif
1173 #ifdef SIGCHLD
1174 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
1175 receive the signal. A different setting is inheritable */
1176 signal (SIGCHLD, SIG_DFL);
1177 #endif
1179 /* Unlock the stdio streams. */
1180 unlock_std_streams ();
1182 gcc_init_libintl ();
1184 /* Do not invoke xcalloc before this point, since locale needs to be
1185 set first, in case a diagnostic is issued. */
1187 ld1_argv = XCNEWVEC (char *, argc + 4);
1188 ld1 = CONST_CAST2 (const char **, char **, ld1_argv);
1189 ld2_argv = XCNEWVEC (char *, argc + 11);
1190 ld2 = CONST_CAST2 (const char **, char **, ld2_argv);
1191 object_lst = XCNEWVEC (char *, argc);
1192 object = CONST_CAST2 (const char **, char **, object_lst);
1194 #ifdef DEBUG
1195 debug = 1;
1196 #endif
1198 /* Parse command line early for instances of -debug. This allows
1199 the debug flag to be set before functions like find_a_file()
1200 are called. We also look for the -flto or -flto-partition=none flag to know
1201 what LTO mode we are in. */
1203 int i;
1204 bool no_partition = false;
1206 for (i = 1; argv[i] != NULL; i ++)
1208 if (! strcmp (argv[i], "-debug"))
1209 debug = true;
1210 else if (! strcmp (argv[i], "-flto-partition=none"))
1211 no_partition = true;
1212 else if ((! strncmp (argv[i], "-flto=", 6)
1213 || ! strcmp (argv[i], "-flto")) && ! use_plugin)
1214 lto_mode = LTO_MODE_WHOPR;
1215 else if (!strncmp (argv[i], "-fno-lto", 8))
1216 lto_mode = LTO_MODE_NONE;
1217 else if (! strcmp (argv[i], "-plugin"))
1219 use_plugin = true;
1220 lto_mode = LTO_MODE_NONE;
1222 #ifdef COLLECT_EXPORT_LIST
1223 /* since -brtl, -bexport, -b64 are not position dependent
1224 also check for them here */
1225 if ((argv[i][0] == '-') && (argv[i][1] == 'b'))
1227 arg = argv[i];
1228 /* We want to disable automatic exports on AIX when user
1229 explicitly puts an export list in command line */
1230 if (arg[2] == 'E' || strncmp (&arg[2], "export", 6) == 0)
1231 export_flag = 1;
1232 else if (arg[2] == '6' && arg[3] == '4')
1233 aix64_flag = 1;
1234 else if (arg[2] == 'r' && arg[3] == 't' && arg[4] == 'l')
1235 aixrtl_flag = 1;
1237 #endif
1239 vflag = debug;
1240 if (no_partition && lto_mode == LTO_MODE_WHOPR)
1241 lto_mode = LTO_MODE_LTO;
1244 #ifndef DEFAULT_A_OUT_NAME
1245 output_file = "a.out";
1246 #else
1247 output_file = DEFAULT_A_OUT_NAME;
1248 #endif
1250 obstack_begin (&temporary_obstack, 0);
1251 temporary_firstobj = (char *) obstack_alloc (&temporary_obstack, 0);
1253 #ifndef HAVE_LD_DEMANGLE
1254 current_demangling_style = auto_demangling;
1255 #endif
1256 p = getenv ("COLLECT_GCC_OPTIONS");
1257 while (p && *p)
1259 const char *q = extract_string (&p);
1260 if (*q == '-' && (q[1] == 'm' || q[1] == 'f'))
1261 num_c_args++;
1263 obstack_free (&temporary_obstack, temporary_firstobj);
1265 /* -fno-profile-arcs -fno-test-coverage -fno-branch-probabilities
1266 -fno-exceptions -w -fno-whole-program */
1267 num_c_args += 6;
1269 c_argv = XCNEWVEC (char *, num_c_args);
1270 c_ptr = CONST_CAST2 (const char **, char **, c_argv);
1272 if (argc < 2)
1273 fatal ("no arguments");
1275 #ifdef SIGQUIT
1276 if (signal (SIGQUIT, SIG_IGN) != SIG_IGN)
1277 signal (SIGQUIT, handler);
1278 #endif
1279 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
1280 signal (SIGINT, handler);
1281 #ifdef SIGALRM
1282 if (signal (SIGALRM, SIG_IGN) != SIG_IGN)
1283 signal (SIGALRM, handler);
1284 #endif
1285 #ifdef SIGHUP
1286 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
1287 signal (SIGHUP, handler);
1288 #endif
1289 if (signal (SIGSEGV, SIG_IGN) != SIG_IGN)
1290 signal (SIGSEGV, handler);
1291 #ifdef SIGBUS
1292 if (signal (SIGBUS, SIG_IGN) != SIG_IGN)
1293 signal (SIGBUS, handler);
1294 #endif
1296 /* Extract COMPILER_PATH and PATH into our prefix list. */
1297 prefix_from_env ("COMPILER_PATH", &cpath);
1298 prefix_from_env ("PATH", &path);
1300 /* Try to discover a valid linker/nm/strip to use. */
1302 /* Maybe we know the right file to use (if not cross). */
1303 ld_file_name = 0;
1304 #ifdef DEFAULT_LINKER
1305 if (access (DEFAULT_LINKER, X_OK) == 0)
1306 ld_file_name = DEFAULT_LINKER;
1307 if (ld_file_name == 0)
1308 #endif
1309 #ifdef REAL_LD_FILE_NAME
1310 ld_file_name = find_a_file (&path, REAL_LD_FILE_NAME);
1311 if (ld_file_name == 0)
1312 #endif
1313 /* Search the (target-specific) compiler dirs for ld'. */
1314 ld_file_name = find_a_file (&cpath, real_ld_suffix);
1315 /* Likewise for `collect-ld'. */
1316 if (ld_file_name == 0)
1317 ld_file_name = find_a_file (&cpath, collect_ld_suffix);
1318 /* Search the compiler directories for `ld'. We have protection against
1319 recursive calls in find_a_file. */
1320 if (ld_file_name == 0)
1321 ld_file_name = find_a_file (&cpath,
1322 use_plugin
1323 ? plugin_ld_suffix
1324 : ld_suffix);
1325 /* Search the ordinary system bin directories
1326 for `ld' (if native linking) or `TARGET-ld' (if cross). */
1327 if (ld_file_name == 0)
1328 ld_file_name = find_a_file (&path,
1329 use_plugin
1330 ? full_plugin_ld_suffix
1331 : full_ld_suffix);
1333 #ifdef REAL_NM_FILE_NAME
1334 nm_file_name = find_a_file (&path, REAL_NM_FILE_NAME);
1335 if (nm_file_name == 0)
1336 #endif
1337 nm_file_name = find_a_file (&cpath, gnm_suffix);
1338 if (nm_file_name == 0)
1339 nm_file_name = find_a_file (&path, full_gnm_suffix);
1340 if (nm_file_name == 0)
1341 nm_file_name = find_a_file (&cpath, nm_suffix);
1342 if (nm_file_name == 0)
1343 nm_file_name = find_a_file (&path, full_nm_suffix);
1345 #ifdef LDD_SUFFIX
1346 ldd_file_name = find_a_file (&cpath, ldd_suffix);
1347 if (ldd_file_name == 0)
1348 ldd_file_name = find_a_file (&path, full_ldd_suffix);
1349 #endif
1351 #ifdef REAL_STRIP_FILE_NAME
1352 strip_file_name = find_a_file (&path, REAL_STRIP_FILE_NAME);
1353 if (strip_file_name == 0)
1354 #endif
1355 strip_file_name = find_a_file (&cpath, gstrip_suffix);
1356 if (strip_file_name == 0)
1357 strip_file_name = find_a_file (&path, full_gstrip_suffix);
1358 if (strip_file_name == 0)
1359 strip_file_name = find_a_file (&cpath, strip_suffix);
1360 if (strip_file_name == 0)
1361 strip_file_name = find_a_file (&path, full_strip_suffix);
1363 /* Determine the full path name of the C compiler to use. */
1364 c_file_name = getenv ("COLLECT_GCC");
1365 if (c_file_name == 0)
1367 #ifdef CROSS_DIRECTORY_STRUCTURE
1368 c_file_name = concat (target_machine, "-gcc", NULL);
1369 #else
1370 c_file_name = "gcc";
1371 #endif
1374 p = find_a_file (&cpath, c_file_name);
1376 /* Here it should be safe to use the system search path since we should have
1377 already qualified the name of the compiler when it is needed. */
1378 if (p == 0)
1379 p = find_a_file (&path, c_file_name);
1381 if (p)
1382 c_file_name = p;
1384 *ld1++ = *ld2++ = ld_file_name;
1386 /* Make temp file names. */
1387 c_file = make_temp_file (".c");
1388 o_file = make_temp_file (".o");
1389 #ifdef COLLECT_EXPORT_LIST
1390 export_file = make_temp_file (".x");
1391 #endif
1392 ldout = make_temp_file (".ld");
1393 lderrout = make_temp_file (".le");
1394 *c_ptr++ = c_file_name;
1395 *c_ptr++ = "-x";
1396 *c_ptr++ = "c";
1397 *c_ptr++ = "-c";
1398 *c_ptr++ = "-o";
1399 *c_ptr++ = o_file;
1401 #ifdef COLLECT_EXPORT_LIST
1402 /* Generate a list of directories from LIBPATH. */
1403 prefix_from_env ("LIBPATH", &libpath_lib_dirs);
1404 /* Add to this list also two standard directories where
1405 AIX loader always searches for libraries. */
1406 add_prefix (&libpath_lib_dirs, "/lib");
1407 add_prefix (&libpath_lib_dirs, "/usr/lib");
1408 #endif
1410 /* Get any options that the upper GCC wants to pass to the sub-GCC.
1412 AIX support needs to know if -shared has been specified before
1413 parsing commandline arguments. */
1415 p = getenv ("COLLECT_GCC_OPTIONS");
1416 while (p && *p)
1418 const char *q = extract_string (&p);
1419 if (*q == '-' && (q[1] == 'm' || q[1] == 'f'))
1420 *c_ptr++ = xstrdup (q);
1421 if (strcmp (q, "-EL") == 0 || strcmp (q, "-EB") == 0)
1422 *c_ptr++ = xstrdup (q);
1423 if (strcmp (q, "-shared") == 0)
1424 shared_obj = 1;
1425 if (*q == '-' && q[1] == 'B')
1427 *c_ptr++ = xstrdup (q);
1428 if (q[2] == 0)
1430 q = extract_string (&p);
1431 *c_ptr++ = xstrdup (q);
1435 obstack_free (&temporary_obstack, temporary_firstobj);
1436 *c_ptr++ = "-fno-profile-arcs";
1437 *c_ptr++ = "-fno-test-coverage";
1438 *c_ptr++ = "-fno-branch-probabilities";
1439 *c_ptr++ = "-fno-exceptions";
1440 *c_ptr++ = "-w";
1441 *c_ptr++ = "-fno-whole-program";
1443 /* !!! When GCC calls collect2,
1444 it does not know whether it is calling collect2 or ld.
1445 So collect2 cannot meaningfully understand any options
1446 except those ld understands.
1447 If you propose to make GCC pass some other option,
1448 just imagine what will happen if ld is really ld!!! */
1450 /* Parse arguments. Remember output file spec, pass the rest to ld. */
1451 /* After the first file, put in the c++ rt0. */
1453 first_file = 1;
1454 #ifdef HAVE_LD_DEMANGLE
1455 if (!demangle_flag && !no_demangle)
1456 demangle_flag = "--demangle";
1457 if (demangle_flag)
1458 *ld1++ = *ld2++ = demangle_flag;
1459 #endif
1460 while ((arg = *++argv) != (char *) 0)
1462 *ld1++ = *ld2++ = arg;
1464 if (arg[0] == '-')
1466 switch (arg[1])
1468 case 'd':
1469 if (!strcmp (arg, "-debug"))
1471 /* Already parsed. */
1472 ld1--;
1473 ld2--;
1475 if (!strcmp (arg, "-dynamic-linker") && argv[1])
1477 ++argv;
1478 *ld1++ = *ld2++ = *argv;
1480 break;
1482 case 'f':
1483 if (strncmp (arg, "-flto", 5) == 0)
1485 #ifdef ENABLE_LTO
1486 /* Do not pass LTO flag to the linker. */
1487 ld1--;
1488 ld2--;
1489 #else
1490 error ("LTO support has not been enabled in this "
1491 "configuration");
1492 #endif
1494 break;
1496 case 'l':
1497 if (first_file)
1499 /* place o_file BEFORE this argument! */
1500 first_file = 0;
1501 ld2--;
1502 *ld2++ = o_file;
1503 *ld2++ = arg;
1505 #ifdef COLLECT_EXPORT_LIST
1507 /* Resolving full library name. */
1508 const char *s = resolve_lib_name (arg+2);
1510 /* Saving a full library name. */
1511 add_to_list (&libs, s);
1513 #endif
1514 break;
1516 #ifdef COLLECT_EXPORT_LIST
1517 /* Saving directories where to search for libraries. */
1518 case 'L':
1519 add_prefix (&cmdline_lib_dirs, arg+2);
1520 break;
1521 #else
1522 #if LINK_ELIMINATE_DUPLICATE_LDIRECTORIES
1523 case 'L':
1524 if (is_in_args (arg,
1525 CONST_CAST2 (const char **, char **, ld1_argv),
1526 ld1 - 1))
1527 --ld1;
1528 break;
1529 #endif /* LINK_ELIMINATE_DUPLICATE_LDIRECTORIES */
1530 #endif
1532 case 'o':
1533 if (arg[2] == '\0')
1534 output_file = *ld1++ = *ld2++ = *++argv;
1535 else
1536 output_file = &arg[2];
1537 break;
1539 case 'r':
1540 if (arg[2] == '\0')
1541 rflag = 1;
1542 break;
1544 case 's':
1545 if (arg[2] == '\0' && do_collecting)
1547 /* We must strip after the nm run, otherwise C++ linking
1548 will not work. Thus we strip in the second ld run, or
1549 else with strip if there is no second ld run. */
1550 strip_flag = 1;
1551 ld1--;
1553 break;
1555 case 'v':
1556 if (arg[2] == '\0')
1557 vflag = true;
1558 break;
1560 case '-':
1561 if (strcmp (arg, "--no-demangle") == 0)
1563 demangle_flag = arg;
1564 no_demangle = 1;
1565 ld1--;
1566 ld2--;
1568 else if (strncmp (arg, "--demangle", 10) == 0)
1570 demangle_flag = arg;
1571 no_demangle = 0;
1572 #ifndef HAVE_LD_DEMANGLE
1573 if (arg[10] == '=')
1575 enum demangling_styles style
1576 = cplus_demangle_name_to_style (arg+11);
1577 if (style == unknown_demangling)
1578 error ("unknown demangling style '%s'", arg+11);
1579 else
1580 current_demangling_style = style;
1582 #endif
1583 ld1--;
1584 ld2--;
1586 else if (strncmp (arg, "--sysroot=", 10) == 0)
1587 target_system_root = arg + 10;
1588 else if (strcmp (arg, "--version") == 0)
1589 vflag = true;
1590 else if (strcmp (arg, "--help") == 0)
1591 helpflag = true;
1592 break;
1595 else if ((p = strrchr (arg, '.')) != (char *) 0
1596 && (strcmp (p, ".o") == 0 || strcmp (p, ".a") == 0
1597 || strcmp (p, ".so") == 0 || strcmp (p, ".lo") == 0
1598 || strcmp (p, ".obj") == 0))
1600 if (first_file)
1602 first_file = 0;
1603 if (p[1] == 'o')
1604 *ld2++ = o_file;
1605 else
1607 /* place o_file BEFORE this argument! */
1608 ld2--;
1609 *ld2++ = o_file;
1610 *ld2++ = arg;
1613 if (p[1] == 'o' || p[1] == 'l')
1614 *object++ = arg;
1615 #ifdef COLLECT_EXPORT_LIST
1616 /* libraries can be specified directly, i.e. without -l flag. */
1617 else
1619 /* Saving a full library name. */
1620 add_to_list (&libs, arg);
1622 #endif
1626 #ifdef COLLECT_EXPORT_LIST
1627 /* This is added only for debugging purposes. */
1628 if (debug)
1630 fprintf (stderr, "List of libraries:\n");
1631 dump_list (stderr, "\t", libs.first);
1634 /* The AIX linker will discard static constructors in object files if
1635 nothing else in the file is referenced, so look at them first. Unless
1636 we are building a shared object, ignore the eh frame tables, as we
1637 would otherwise reference them all, hence drag all the corresponding
1638 objects even if nothing else is referenced. */
1640 const char **export_object_lst
1641 = CONST_CAST2 (const char **, char **, object_lst);
1643 struct id *list = libs.first;
1645 /* Compute the filter to use from the current one, do scan, then adjust
1646 the "current" filter to remove what we just included here. This will
1647 control whether we need a first pass link later on or not, and what
1648 will remain to be scanned there. */
1650 scanfilter this_filter = ld1_filter;
1651 #if HAVE_AS_REF
1652 if (!shared_obj)
1653 this_filter &= ~SCAN_DWEH;
1654 #endif
1656 while (export_object_lst < object)
1657 scan_prog_file (*export_object_lst++, PASS_OBJ, this_filter);
1659 for (; list; list = list->next)
1660 scan_prog_file (list->name, PASS_FIRST, this_filter);
1662 ld1_filter = ld1_filter & ~this_filter;
1665 if (exports.first)
1667 char *buf = concat ("-bE:", export_file, NULL);
1669 *ld1++ = buf;
1670 *ld2++ = buf;
1672 exportf = fopen (export_file, "w");
1673 if (exportf == (FILE *) 0)
1674 fatal_perror ("fopen %s", export_file);
1675 write_aix_file (exportf, exports.first);
1676 if (fclose (exportf))
1677 fatal_perror ("fclose %s", export_file);
1679 #endif
1681 *c_ptr++ = c_file;
1682 *c_ptr = *ld1 = *object = (char *) 0;
1684 if (vflag)
1686 notice ("collect2 version %s", version_string);
1687 #ifdef TARGET_VERSION
1688 TARGET_VERSION;
1689 #endif
1690 fprintf (stderr, "\n");
1693 if (helpflag)
1695 printf ("Usage: collect2 [options]\n");
1696 printf (" Wrap linker and generate constructor code if needed.\n");
1697 printf (" Options:\n");
1698 printf (" -debug Enable debug output\n");
1699 printf (" --help Display this information\n");
1700 printf (" -v, --version Display this program's version number\n");
1701 printf ("\n");
1702 printf ("Overview: http://gcc.gnu.org/onlinedocs/gccint/Collect2.html\n");
1703 printf ("Report bugs: %s\n", bug_report_url);
1704 printf ("\n");
1707 if (debug)
1709 const char *ptr;
1710 fprintf (stderr, "ld_file_name = %s\n",
1711 (ld_file_name ? ld_file_name : "not found"));
1712 fprintf (stderr, "c_file_name = %s\n",
1713 (c_file_name ? c_file_name : "not found"));
1714 fprintf (stderr, "nm_file_name = %s\n",
1715 (nm_file_name ? nm_file_name : "not found"));
1716 #ifdef LDD_SUFFIX
1717 fprintf (stderr, "ldd_file_name = %s\n",
1718 (ldd_file_name ? ldd_file_name : "not found"));
1719 #endif
1720 fprintf (stderr, "strip_file_name = %s\n",
1721 (strip_file_name ? strip_file_name : "not found"));
1722 fprintf (stderr, "c_file = %s\n",
1723 (c_file ? c_file : "not found"));
1724 fprintf (stderr, "o_file = %s\n",
1725 (o_file ? o_file : "not found"));
1727 ptr = getenv ("COLLECT_GCC_OPTIONS");
1728 if (ptr)
1729 fprintf (stderr, "COLLECT_GCC_OPTIONS = %s\n", ptr);
1731 ptr = getenv ("COLLECT_GCC");
1732 if (ptr)
1733 fprintf (stderr, "COLLECT_GCC = %s\n", ptr);
1735 ptr = getenv ("COMPILER_PATH");
1736 if (ptr)
1737 fprintf (stderr, "COMPILER_PATH = %s\n", ptr);
1739 ptr = getenv (LIBRARY_PATH_ENV);
1740 if (ptr)
1741 fprintf (stderr, "%-20s= %s\n", LIBRARY_PATH_ENV, ptr);
1743 fprintf (stderr, "\n");
1746 /* Load the program, searching all libraries and attempting to provide
1747 undefined symbols from repository information.
1749 If -r or they will be run via some other method, do not build the
1750 constructor or destructor list, just return now. */
1752 bool early_exit
1753 = rflag || (! DO_COLLECT_EXPORT_LIST && ! do_collecting);
1755 /* Perform the first pass link now, if we're about to exit or if we need
1756 to scan for things we haven't collected yet before pursuing further.
1758 On AIX, the latter typically includes nothing for shared objects or
1759 frame tables for an executable, out of what the required early scan on
1760 objects and libraries has performed above. In the !shared_obj case, we
1761 expect the relevant tables to be dragged together with their associated
1762 functions from precise cross reference insertions by the compiler. */
1764 if (early_exit || ld1_filter != SCAN_NOTHING)
1765 do_tlink (ld1_argv, object_lst);
1767 if (early_exit)
1769 #ifdef COLLECT_EXPORT_LIST
1770 /* Make sure we delete the export file we may have created. */
1771 if (export_file != 0 && export_file[0])
1772 maybe_unlink (export_file);
1773 #endif
1774 if (lto_mode != LTO_MODE_NONE)
1775 maybe_run_lto_and_relink (ld1_argv, object_lst, object, false);
1776 else
1777 post_ld_pass (false);
1779 maybe_unlink (c_file);
1780 maybe_unlink (o_file);
1781 return 0;
1785 /* Unless we have done it all already, examine the namelist and search for
1786 static constructors and destructors to call. Write the constructor and
1787 destructor tables to a .s file and reload. */
1789 if (ld1_filter != SCAN_NOTHING)
1790 scan_prog_file (output_file, PASS_FIRST, ld1_filter);
1792 #ifdef SCAN_LIBRARIES
1793 scan_libraries (output_file);
1794 #endif
1796 if (debug)
1798 notice_translated (ngettext ("%d constructor found\n",
1799 "%d constructors found\n",
1800 constructors.number),
1801 constructors.number);
1802 notice_translated (ngettext ("%d destructor found\n",
1803 "%d destructors found\n",
1804 destructors.number),
1805 destructors.number);
1806 notice_translated (ngettext("%d frame table found\n",
1807 "%d frame tables found\n",
1808 frame_tables.number),
1809 frame_tables.number);
1812 /* If the scan exposed nothing of special interest, there's no need to
1813 generate the glue code and relink so return now. */
1815 if (constructors.number == 0 && destructors.number == 0
1816 && frame_tables.number == 0
1817 #if defined (SCAN_LIBRARIES) || defined (COLLECT_EXPORT_LIST)
1818 /* If we will be running these functions ourselves, we want to emit
1819 stubs into the shared library so that we do not have to relink
1820 dependent programs when we add static objects. */
1821 && ! shared_obj
1822 #endif
1825 /* Do tlink without additional code generation now if we didn't
1826 do it earlier for scanning purposes. */
1827 if (ld1_filter == SCAN_NOTHING)
1828 do_tlink (ld1_argv, object_lst);
1830 if (lto_mode)
1831 maybe_run_lto_and_relink (ld1_argv, object_lst, object, false);
1833 /* Strip now if it was requested on the command line. */
1834 if (strip_flag)
1836 char **real_strip_argv = XCNEWVEC (char *, 3);
1837 const char ** strip_argv = CONST_CAST2 (const char **, char **,
1838 real_strip_argv);
1840 strip_argv[0] = strip_file_name;
1841 strip_argv[1] = output_file;
1842 strip_argv[2] = (char *) 0;
1843 fork_execute ("strip", real_strip_argv);
1846 #ifdef COLLECT_EXPORT_LIST
1847 maybe_unlink (export_file);
1848 #endif
1849 post_ld_pass (false);
1851 maybe_unlink (c_file);
1852 maybe_unlink (o_file);
1853 return 0;
1856 /* Sort ctor and dtor lists by priority. */
1857 sort_ids (&constructors);
1858 sort_ids (&destructors);
1860 maybe_unlink(output_file);
1861 outf = fopen (c_file, "w");
1862 if (outf == (FILE *) 0)
1863 fatal_perror ("fopen %s", c_file);
1865 write_c_file (outf, c_file);
1867 if (fclose (outf))
1868 fatal_perror ("fclose %s", c_file);
1870 /* Tell the linker that we have initializer and finalizer functions. */
1871 #ifdef LD_INIT_SWITCH
1872 #ifdef COLLECT_EXPORT_LIST
1873 *ld2++ = concat (LD_INIT_SWITCH, ":", initname, ":", fininame, NULL);
1874 #else
1875 *ld2++ = LD_INIT_SWITCH;
1876 *ld2++ = initname;
1877 *ld2++ = LD_FINI_SWITCH;
1878 *ld2++ = fininame;
1879 #endif
1880 #endif
1882 #ifdef COLLECT_EXPORT_LIST
1883 if (shared_obj)
1885 /* If we did not add export flag to link arguments before, add it to
1886 second link phase now. No new exports should have been added. */
1887 if (! exports.first)
1888 *ld2++ = concat ("-bE:", export_file, NULL);
1890 #ifndef LD_INIT_SWITCH
1891 add_to_list (&exports, initname);
1892 add_to_list (&exports, fininame);
1893 add_to_list (&exports, "_GLOBAL__DI");
1894 add_to_list (&exports, "_GLOBAL__DD");
1895 #endif
1896 exportf = fopen (export_file, "w");
1897 if (exportf == (FILE *) 0)
1898 fatal_perror ("fopen %s", export_file);
1899 write_aix_file (exportf, exports.first);
1900 if (fclose (exportf))
1901 fatal_perror ("fclose %s", export_file);
1903 #endif
1905 /* End of arguments to second link phase. */
1906 *ld2 = (char*) 0;
1908 if (debug)
1910 fprintf (stderr, "\n========== output_file = %s, c_file = %s\n",
1911 output_file, c_file);
1912 write_c_file (stderr, "stderr");
1913 fprintf (stderr, "========== end of c_file\n\n");
1914 #ifdef COLLECT_EXPORT_LIST
1915 fprintf (stderr, "\n========== export_file = %s\n", export_file);
1916 write_aix_file (stderr, exports.first);
1917 fprintf (stderr, "========== end of export_file\n\n");
1918 #endif
1921 /* Assemble the constructor and destructor tables.
1922 Link the tables in with the rest of the program. */
1924 fork_execute ("gcc", c_argv);
1925 #ifdef COLLECT_EXPORT_LIST
1926 /* On AIX we must call tlink because of possible templates resolution. */
1927 do_tlink (ld2_argv, object_lst);
1929 if (lto_mode)
1930 maybe_run_lto_and_relink (ld2_argv, object_lst, object, false);
1931 #else
1932 /* Otherwise, simply call ld because tlink is already done. */
1933 if (lto_mode)
1934 maybe_run_lto_and_relink (ld2_argv, object_lst, object, true);
1935 else
1937 fork_execute ("ld", ld2_argv);
1938 post_ld_pass (false);
1941 /* Let scan_prog_file do any final mods (OSF/rose needs this for
1942 constructors/destructors in shared libraries. */
1943 scan_prog_file (output_file, PASS_SECOND, SCAN_ALL);
1944 #endif
1946 maybe_unlink (c_file);
1947 maybe_unlink (o_file);
1949 #ifdef COLLECT_EXPORT_LIST
1950 maybe_unlink (export_file);
1951 #endif
1953 return 0;
1957 /* Wait for a process to finish, and exit if a nonzero status is found. */
1960 collect_wait (const char *prog, struct pex_obj *pex)
1962 int status;
1964 if (!pex_get_status (pex, 1, &status))
1965 fatal_perror ("can't get program status");
1966 pex_free (pex);
1968 if (status)
1970 if (WIFSIGNALED (status))
1972 int sig = WTERMSIG (status);
1973 error ("%s terminated with signal %d [%s]%s",
1974 prog, sig, strsignal(sig),
1975 WCOREDUMP(status) ? ", core dumped" : "");
1976 collect_exit (FATAL_EXIT_CODE);
1979 if (WIFEXITED (status))
1980 return WEXITSTATUS (status);
1982 return 0;
1985 static void
1986 do_wait (const char *prog, struct pex_obj *pex)
1988 int ret = collect_wait (prog, pex);
1989 if (ret != 0)
1991 error ("%s returned %d exit status", prog, ret);
1992 collect_exit (ret);
1995 if (response_file)
1997 unlink (response_file);
1998 response_file = NULL;
2003 /* Execute a program, and wait for the reply. */
2005 struct pex_obj *
2006 collect_execute (const char *prog, char **argv, const char *outname,
2007 const char *errname, int flags)
2009 struct pex_obj *pex;
2010 const char *errmsg;
2011 int err;
2012 char *response_arg = NULL;
2013 char *response_argv[3] ATTRIBUTE_UNUSED;
2015 if (HAVE_GNU_LD && at_file_supplied && argv[0] != NULL)
2017 /* If using @file arguments, create a temporary file and put the
2018 contents of argv into it. Then change argv to an array corresponding
2019 to a single argument @FILE, where FILE is the temporary filename. */
2021 char **current_argv = argv + 1;
2022 char *argv0 = argv[0];
2023 int status;
2024 FILE *f;
2026 /* Note: we assume argv contains at least one element; this is
2027 checked above. */
2029 response_file = make_temp_file ("");
2031 f = fopen (response_file, "w");
2033 if (f == NULL)
2034 fatal ("could not open response file %s", response_file);
2036 status = writeargv (current_argv, f);
2038 if (status)
2039 fatal ("could not write to response file %s", response_file);
2041 status = fclose (f);
2043 if (EOF == status)
2044 fatal ("could not close response file %s", response_file);
2046 response_arg = concat ("@", response_file, NULL);
2047 response_argv[0] = argv0;
2048 response_argv[1] = response_arg;
2049 response_argv[2] = NULL;
2051 argv = response_argv;
2054 if (vflag || debug)
2056 char **p_argv;
2057 const char *str;
2059 if (argv[0])
2060 fprintf (stderr, "%s", argv[0]);
2061 else
2062 notice ("[cannot find %s]", prog);
2064 for (p_argv = &argv[1]; (str = *p_argv) != (char *) 0; p_argv++)
2065 fprintf (stderr, " %s", str);
2067 fprintf (stderr, "\n");
2070 fflush (stdout);
2071 fflush (stderr);
2073 /* If we cannot find a program we need, complain error. Do this here
2074 since we might not end up needing something that we could not find. */
2076 if (argv[0] == 0)
2077 fatal ("cannot find '%s'", prog);
2079 pex = pex_init (0, "collect2", NULL);
2080 if (pex == NULL)
2081 fatal_perror ("pex_init failed");
2083 errmsg = pex_run (pex, flags, argv[0], argv, outname,
2084 errname, &err);
2085 if (errmsg != NULL)
2087 if (err != 0)
2089 errno = err;
2090 fatal_perror (errmsg);
2092 else
2093 fatal (errmsg);
2096 if (response_arg)
2097 free (response_arg);
2099 return pex;
2102 static void
2103 fork_execute (const char *prog, char **argv)
2105 struct pex_obj *pex;
2107 pex = collect_execute (prog, argv, NULL, NULL, PEX_LAST | PEX_SEARCH);
2108 do_wait (prog, pex);
2111 /* Unlink a file unless we are debugging. */
2113 static void
2114 maybe_unlink (const char *file)
2116 if (!debug)
2117 unlink_if_ordinary (file);
2118 else
2119 notice ("[Leaving %s]\n", file);
2122 /* Call maybe_unlink on the NULL-terminated list, FILE_LIST. */
2124 static void
2125 maybe_unlink_list (char **file_list)
2127 char **tmp = file_list;
2129 while (*tmp)
2130 maybe_unlink (*(tmp++));
2134 static long sequence_number = 0;
2136 /* Add a name to a linked list. */
2138 static void
2139 add_to_list (struct head *head_ptr, const char *name)
2141 struct id *newid
2142 = (struct id *) xcalloc (sizeof (struct id) + strlen (name), 1);
2143 struct id *p;
2144 strcpy (newid->name, name);
2146 if (head_ptr->first)
2147 head_ptr->last->next = newid;
2148 else
2149 head_ptr->first = newid;
2151 /* Check for duplicate symbols. */
2152 for (p = head_ptr->first;
2153 strcmp (name, p->name) != 0;
2154 p = p->next)
2156 if (p != newid)
2158 head_ptr->last->next = 0;
2159 free (newid);
2160 return;
2163 newid->sequence = ++sequence_number;
2164 head_ptr->last = newid;
2165 head_ptr->number++;
2168 /* Grab the init priority number from an init function name that
2169 looks like "_GLOBAL_.I.12345.foo". */
2171 static int
2172 extract_init_priority (const char *name)
2174 int pos = 0, pri;
2176 while (name[pos] == '_')
2177 ++pos;
2178 pos += 10; /* strlen ("GLOBAL__X_") */
2180 /* Extract init_p number from ctor/dtor name. */
2181 pri = atoi (name + pos);
2182 return pri ? pri : DEFAULT_INIT_PRIORITY;
2185 /* Insertion sort the ids from ctor/dtor list HEAD_PTR in descending order.
2186 ctors will be run from right to left, dtors from left to right. */
2188 static void
2189 sort_ids (struct head *head_ptr)
2191 /* id holds the current element to insert. id_next holds the next
2192 element to insert. id_ptr iterates through the already sorted elements
2193 looking for the place to insert id. */
2194 struct id *id, *id_next, **id_ptr;
2196 id = head_ptr->first;
2198 /* We don't have any sorted elements yet. */
2199 head_ptr->first = NULL;
2201 for (; id; id = id_next)
2203 id_next = id->next;
2204 id->sequence = extract_init_priority (id->name);
2206 for (id_ptr = &(head_ptr->first); ; id_ptr = &((*id_ptr)->next))
2207 if (*id_ptr == NULL
2208 /* If the sequence numbers are the same, we put the id from the
2209 file later on the command line later in the list. */
2210 || id->sequence > (*id_ptr)->sequence
2211 /* Hack: do lexical compare, too.
2212 || (id->sequence == (*id_ptr)->sequence
2213 && strcmp (id->name, (*id_ptr)->name) > 0) */
2216 id->next = *id_ptr;
2217 *id_ptr = id;
2218 break;
2222 /* Now set the sequence numbers properly so write_c_file works. */
2223 for (id = head_ptr->first; id; id = id->next)
2224 id->sequence = ++sequence_number;
2227 /* Write: `prefix', the names on list LIST, `suffix'. */
2229 static void
2230 write_list (FILE *stream, const char *prefix, struct id *list)
2232 while (list)
2234 fprintf (stream, "%sx%d,\n", prefix, list->sequence);
2235 list = list->next;
2239 #if LINK_ELIMINATE_DUPLICATE_LDIRECTORIES
2240 /* Given a STRING, return nonzero if it occurs in the list in range
2241 [ARGS_BEGIN,ARGS_END). */
2243 static int
2244 is_in_args (const char *string, const char **args_begin,
2245 const char **args_end)
2247 const char **args_pointer;
2248 for (args_pointer = args_begin; args_pointer != args_end; ++args_pointer)
2249 if (strcmp (string, *args_pointer) == 0)
2250 return 1;
2251 return 0;
2253 #endif /* LINK_ELIMINATE_DUPLICATE_LDIRECTORIES */
2255 #ifdef COLLECT_EXPORT_LIST
2256 /* This function is really used only on AIX, but may be useful. */
2257 #if 0
2258 static int
2259 is_in_list (const char *prefix, struct id *list)
2261 while (list)
2263 if (!strcmp (prefix, list->name)) return 1;
2264 list = list->next;
2266 return 0;
2268 #endif
2269 #endif /* COLLECT_EXPORT_LIST */
2271 /* Added for debugging purpose. */
2272 #ifdef COLLECT_EXPORT_LIST
2273 static void
2274 dump_list (FILE *stream, const char *prefix, struct id *list)
2276 while (list)
2278 fprintf (stream, "%s%s,\n", prefix, list->name);
2279 list = list->next;
2282 #endif
2284 #if 0
2285 static void
2286 dump_prefix_list (FILE *stream, const char *prefix, struct prefix_list *list)
2288 while (list)
2290 fprintf (stream, "%s%s,\n", prefix, list->prefix);
2291 list = list->next;
2294 #endif
2296 static void
2297 write_list_with_asm (FILE *stream, const char *prefix, struct id *list)
2299 while (list)
2301 fprintf (stream, "%sx%d __asm__ (\"%s\");\n",
2302 prefix, list->sequence, list->name);
2303 list = list->next;
2307 /* Write out the constructor and destructor tables statically (for a shared
2308 object), along with the functions to execute them. */
2310 static void
2311 write_c_file_stat (FILE *stream, const char *name ATTRIBUTE_UNUSED)
2313 const char *p, *q;
2314 char *prefix, *r;
2315 int frames = (frame_tables.number > 0);
2317 /* Figure out name of output_file, stripping off .so version. */
2318 q = p = lbasename (output_file);
2320 while (q)
2322 q = strchr (q,'.');
2323 if (q == 0)
2325 q = p + strlen (p);
2326 break;
2328 else
2330 if (filename_ncmp (q, SHLIB_SUFFIX, strlen (SHLIB_SUFFIX)) == 0)
2332 q += strlen (SHLIB_SUFFIX);
2333 break;
2335 else
2336 q++;
2339 /* q points to null at end of the string (or . of the .so version) */
2340 prefix = XNEWVEC (char, q - p + 1);
2341 strncpy (prefix, p, q - p);
2342 prefix[q - p] = 0;
2343 for (r = prefix; *r; r++)
2344 if (!ISALNUM ((unsigned char)*r))
2345 *r = '_';
2346 if (debug)
2347 notice ("\nwrite_c_file - output name is %s, prefix is %s\n",
2348 output_file, prefix);
2350 initname = concat ("_GLOBAL__FI_", prefix, NULL);
2351 fininame = concat ("_GLOBAL__FD_", prefix, NULL);
2353 free (prefix);
2355 /* Write the tables as C code. */
2357 fprintf (stream, "static int count;\n");
2358 fprintf (stream, "typedef void entry_pt();\n");
2359 write_list_with_asm (stream, "extern entry_pt ", constructors.first);
2361 if (frames)
2363 write_list_with_asm (stream, "extern void *", frame_tables.first);
2365 fprintf (stream, "\tstatic void *frame_table[] = {\n");
2366 write_list (stream, "\t\t&", frame_tables.first);
2367 fprintf (stream, "\t0\n};\n");
2369 /* This must match what's in frame.h. */
2370 fprintf (stream, "struct object {\n");
2371 fprintf (stream, " void *pc_begin;\n");
2372 fprintf (stream, " void *pc_end;\n");
2373 fprintf (stream, " void *fde_begin;\n");
2374 fprintf (stream, " void *fde_array;\n");
2375 fprintf (stream, " __SIZE_TYPE__ count;\n");
2376 fprintf (stream, " struct object *next;\n");
2377 fprintf (stream, "};\n");
2379 fprintf (stream, "extern void __register_frame_info_table (void *, struct object *);\n");
2380 fprintf (stream, "extern void *__deregister_frame_info (void *);\n");
2382 fprintf (stream, "static void reg_frame () {\n");
2383 fprintf (stream, "\tstatic struct object ob;\n");
2384 fprintf (stream, "\t__register_frame_info_table (frame_table, &ob);\n");
2385 fprintf (stream, "\t}\n");
2387 fprintf (stream, "static void dereg_frame () {\n");
2388 fprintf (stream, "\t__deregister_frame_info (frame_table);\n");
2389 fprintf (stream, "\t}\n");
2392 fprintf (stream, "void %s() {\n", initname);
2393 if (constructors.number > 0 || frames)
2395 fprintf (stream, "\tstatic entry_pt *ctors[] = {\n");
2396 write_list (stream, "\t\t", constructors.first);
2397 if (frames)
2398 fprintf (stream, "\treg_frame,\n");
2399 fprintf (stream, "\t};\n");
2400 fprintf (stream, "\tentry_pt **p;\n");
2401 fprintf (stream, "\tif (count++ != 0) return;\n");
2402 fprintf (stream, "\tp = ctors + %d;\n", constructors.number + frames);
2403 fprintf (stream, "\twhile (p > ctors) (*--p)();\n");
2405 else
2406 fprintf (stream, "\t++count;\n");
2407 fprintf (stream, "}\n");
2408 write_list_with_asm (stream, "extern entry_pt ", destructors.first);
2409 fprintf (stream, "void %s() {\n", fininame);
2410 if (destructors.number > 0 || frames)
2412 fprintf (stream, "\tstatic entry_pt *dtors[] = {\n");
2413 write_list (stream, "\t\t", destructors.first);
2414 if (frames)
2415 fprintf (stream, "\tdereg_frame,\n");
2416 fprintf (stream, "\t};\n");
2417 fprintf (stream, "\tentry_pt **p;\n");
2418 fprintf (stream, "\tif (--count != 0) return;\n");
2419 fprintf (stream, "\tp = dtors;\n");
2420 fprintf (stream, "\twhile (p < dtors + %d) (*p++)();\n",
2421 destructors.number + frames);
2423 fprintf (stream, "}\n");
2425 if (shared_obj)
2427 COLLECT_SHARED_INIT_FUNC(stream, initname);
2428 COLLECT_SHARED_FINI_FUNC(stream, fininame);
2432 /* Write the constructor/destructor tables. */
2434 #ifndef LD_INIT_SWITCH
2435 static void
2436 write_c_file_glob (FILE *stream, const char *name ATTRIBUTE_UNUSED)
2438 /* Write the tables as C code. */
2440 int frames = (frame_tables.number > 0);
2442 fprintf (stream, "typedef void entry_pt();\n\n");
2444 write_list_with_asm (stream, "extern entry_pt ", constructors.first);
2446 if (frames)
2448 write_list_with_asm (stream, "extern void *", frame_tables.first);
2450 fprintf (stream, "\tstatic void *frame_table[] = {\n");
2451 write_list (stream, "\t\t&", frame_tables.first);
2452 fprintf (stream, "\t0\n};\n");
2454 /* This must match what's in frame.h. */
2455 fprintf (stream, "struct object {\n");
2456 fprintf (stream, " void *pc_begin;\n");
2457 fprintf (stream, " void *pc_end;\n");
2458 fprintf (stream, " void *fde_begin;\n");
2459 fprintf (stream, " void *fde_array;\n");
2460 fprintf (stream, " __SIZE_TYPE__ count;\n");
2461 fprintf (stream, " struct object *next;\n");
2462 fprintf (stream, "};\n");
2464 fprintf (stream, "extern void __register_frame_info_table (void *, struct object *);\n");
2465 fprintf (stream, "extern void *__deregister_frame_info (void *);\n");
2467 fprintf (stream, "static void reg_frame () {\n");
2468 fprintf (stream, "\tstatic struct object ob;\n");
2469 fprintf (stream, "\t__register_frame_info_table (frame_table, &ob);\n");
2470 fprintf (stream, "\t}\n");
2472 fprintf (stream, "static void dereg_frame () {\n");
2473 fprintf (stream, "\t__deregister_frame_info (frame_table);\n");
2474 fprintf (stream, "\t}\n");
2477 fprintf (stream, "\nentry_pt * __CTOR_LIST__[] = {\n");
2478 fprintf (stream, "\t(entry_pt *) %d,\n", constructors.number + frames);
2479 write_list (stream, "\t", constructors.first);
2480 if (frames)
2481 fprintf (stream, "\treg_frame,\n");
2482 fprintf (stream, "\t0\n};\n\n");
2484 write_list_with_asm (stream, "extern entry_pt ", destructors.first);
2486 fprintf (stream, "\nentry_pt * __DTOR_LIST__[] = {\n");
2487 fprintf (stream, "\t(entry_pt *) %d,\n", destructors.number + frames);
2488 write_list (stream, "\t", destructors.first);
2489 if (frames)
2490 fprintf (stream, "\tdereg_frame,\n");
2491 fprintf (stream, "\t0\n};\n\n");
2493 fprintf (stream, "extern entry_pt %s;\n", NAME__MAIN);
2494 fprintf (stream, "entry_pt *__main_reference = %s;\n\n", NAME__MAIN);
2496 #endif /* ! LD_INIT_SWITCH */
2498 static void
2499 write_c_file (FILE *stream, const char *name)
2501 #ifndef LD_INIT_SWITCH
2502 if (! shared_obj)
2503 write_c_file_glob (stream, name);
2504 else
2505 #endif
2506 write_c_file_stat (stream, name);
2509 #ifdef COLLECT_EXPORT_LIST
2510 static void
2511 write_aix_file (FILE *stream, struct id *list)
2513 for (; list; list = list->next)
2515 fputs (list->name, stream);
2516 putc ('\n', stream);
2519 #endif
2521 #ifdef OBJECT_FORMAT_NONE
2523 /* Check to make sure the file is an LTO object file. */
2525 static bool
2526 maybe_lto_object_file (const char *prog_name)
2528 FILE *f;
2529 unsigned char buf[4];
2530 int i;
2532 static unsigned char elfmagic[4] = { 0x7f, 'E', 'L', 'F' };
2533 static unsigned char coffmagic[2] = { 0x4c, 0x01 };
2534 static unsigned char coffmagic_x64[2] = { 0x64, 0x86 };
2535 static unsigned char machomagic[4][4] = {
2536 { 0xcf, 0xfa, 0xed, 0xfe },
2537 { 0xce, 0xfa, 0xed, 0xfe },
2538 { 0xfe, 0xed, 0xfa, 0xcf },
2539 { 0xfe, 0xed, 0xfa, 0xce }
2542 f = fopen (prog_name, "rb");
2543 if (f == NULL)
2544 return false;
2545 if (fread (buf, sizeof (buf), 1, f) != 1)
2546 buf[0] = 0;
2547 fclose (f);
2549 if (memcmp (buf, elfmagic, sizeof (elfmagic)) == 0
2550 || memcmp (buf, coffmagic, sizeof (coffmagic)) == 0
2551 || memcmp (buf, coffmagic_x64, sizeof (coffmagic_x64)) == 0)
2552 return true;
2553 for (i = 0; i < 4; i++)
2554 if (memcmp (buf, machomagic[i], sizeof (machomagic[i])) == 0)
2555 return true;
2557 return false;
2560 /* Generic version to scan the name list of the loaded program for
2561 the symbols g++ uses for static constructors and destructors. */
2563 static void
2564 scan_prog_file (const char *prog_name, scanpass which_pass,
2565 scanfilter filter)
2567 void (*int_handler) (int);
2568 #ifdef SIGQUIT
2569 void (*quit_handler) (int);
2570 #endif
2571 char *real_nm_argv[4];
2572 const char **nm_argv = CONST_CAST2 (const char **, char**, real_nm_argv);
2573 int argc = 0;
2574 struct pex_obj *pex;
2575 const char *errmsg;
2576 int err;
2577 char *p, buf[1024];
2578 FILE *inf;
2579 int found_lto = 0;
2581 if (which_pass == PASS_SECOND)
2582 return;
2584 /* LTO objects must be in a known format. This check prevents
2585 us from accepting an archive containing LTO objects, which
2586 gcc cannnot currently handle. */
2587 if (which_pass == PASS_LTOINFO && !maybe_lto_object_file (prog_name))
2588 return;
2590 /* If we do not have an `nm', complain. */
2591 if (nm_file_name == 0)
2592 fatal ("cannot find 'nm'");
2594 nm_argv[argc++] = nm_file_name;
2595 if (NM_FLAGS[0] != '\0')
2596 nm_argv[argc++] = NM_FLAGS;
2598 nm_argv[argc++] = prog_name;
2599 nm_argv[argc++] = (char *) 0;
2601 /* Trace if needed. */
2602 if (vflag)
2604 const char **p_argv;
2605 const char *str;
2607 for (p_argv = &nm_argv[0]; (str = *p_argv) != (char *) 0; p_argv++)
2608 fprintf (stderr, " %s", str);
2610 fprintf (stderr, "\n");
2613 fflush (stdout);
2614 fflush (stderr);
2616 pex = pex_init (PEX_USE_PIPES, "collect2", NULL);
2617 if (pex == NULL)
2618 fatal_perror ("pex_init failed");
2620 errmsg = pex_run (pex, 0, nm_file_name, real_nm_argv, NULL, HOST_BIT_BUCKET,
2621 &err);
2622 if (errmsg != NULL)
2624 if (err != 0)
2626 errno = err;
2627 fatal_perror (errmsg);
2629 else
2630 fatal (errmsg);
2633 int_handler = (void (*) (int)) signal (SIGINT, SIG_IGN);
2634 #ifdef SIGQUIT
2635 quit_handler = (void (*) (int)) signal (SIGQUIT, SIG_IGN);
2636 #endif
2638 inf = pex_read_output (pex, 0);
2639 if (inf == NULL)
2640 fatal_perror ("can't open nm output");
2642 if (debug)
2644 if (which_pass == PASS_LTOINFO)
2645 fprintf (stderr, "\nnm output with LTO info marker symbol.\n");
2646 else
2647 fprintf (stderr, "\nnm output with constructors/destructors.\n");
2650 /* Read each line of nm output. */
2651 while (fgets (buf, sizeof buf, inf) != (char *) 0)
2653 int ch, ch2;
2654 char *name, *end;
2656 if (debug)
2657 fprintf (stderr, "\t%s\n", buf);
2659 if (which_pass == PASS_LTOINFO)
2661 if (found_lto)
2662 continue;
2664 /* Look for the LTO info marker symbol, and add filename to
2665 the LTO objects list if found. */
2666 for (p = buf; (ch = *p) != '\0' && ch != '\n'; p++)
2667 if (ch == ' ' && p[1] == '_' && p[2] == '_'
2668 && (strncmp (p + (p[3] == '_' ? 2 : 1), "__gnu_lto_v1", 12) == 0)
2669 && ISSPACE (p[p[3] == '_' ? 14 : 13]))
2671 add_lto_object (&lto_objects, prog_name);
2673 /* We need to read all the input, so we can't just
2674 return here. But we can avoid useless work. */
2675 found_lto = 1;
2677 break;
2680 continue;
2683 /* If it contains a constructor or destructor name, add the name
2684 to the appropriate list unless this is a kind of symbol we're
2685 not supposed to even consider. */
2687 for (p = buf; (ch = *p) != '\0' && ch != '\n' && ch != '_'; p++)
2688 if (ch == ' ' && p[1] == 'U' && p[2] == ' ')
2689 break;
2691 if (ch != '_')
2692 continue;
2694 name = p;
2695 /* Find the end of the symbol name.
2696 Do not include `|', because Encore nm can tack that on the end. */
2697 for (end = p; (ch2 = *end) != '\0' && !ISSPACE (ch2) && ch2 != '|';
2698 end++)
2699 continue;
2702 *end = '\0';
2703 switch (is_ctor_dtor (name))
2705 case SYM_CTOR:
2706 if (! (filter & SCAN_CTOR))
2707 break;
2708 if (which_pass != PASS_LIB)
2709 add_to_list (&constructors, name);
2710 break;
2712 case SYM_DTOR:
2713 if (! (filter & SCAN_DTOR))
2714 break;
2715 if (which_pass != PASS_LIB)
2716 add_to_list (&destructors, name);
2717 break;
2719 case SYM_INIT:
2720 if (! (filter & SCAN_INIT))
2721 break;
2722 if (which_pass != PASS_LIB)
2723 fatal ("init function found in object %s", prog_name);
2724 #ifndef LD_INIT_SWITCH
2725 add_to_list (&constructors, name);
2726 #endif
2727 break;
2729 case SYM_FINI:
2730 if (! (filter & SCAN_FINI))
2731 break;
2732 if (which_pass != PASS_LIB)
2733 fatal ("fini function found in object %s", prog_name);
2734 #ifndef LD_FINI_SWITCH
2735 add_to_list (&destructors, name);
2736 #endif
2737 break;
2739 case SYM_DWEH:
2740 if (! (filter & SCAN_DWEH))
2741 break;
2742 if (which_pass != PASS_LIB)
2743 add_to_list (&frame_tables, name);
2744 break;
2746 default: /* not a constructor or destructor */
2747 continue;
2751 if (debug)
2752 fprintf (stderr, "\n");
2754 do_wait (nm_file_name, pex);
2756 signal (SIGINT, int_handler);
2757 #ifdef SIGQUIT
2758 signal (SIGQUIT, quit_handler);
2759 #endif
2762 #ifdef LDD_SUFFIX
2764 /* Use the List Dynamic Dependencies program to find shared libraries that
2765 the output file depends upon and their initialization/finalization
2766 routines, if any. */
2768 static void
2769 scan_libraries (const char *prog_name)
2771 static struct head libraries; /* list of shared libraries found */
2772 struct id *list;
2773 void (*int_handler) (int);
2774 #ifdef SIGQUIT
2775 void (*quit_handler) (int);
2776 #endif
2777 char *real_ldd_argv[4];
2778 const char **ldd_argv = CONST_CAST2 (const char **, char **, real_ldd_argv);
2779 int argc = 0;
2780 struct pex_obj *pex;
2781 const char *errmsg;
2782 int err;
2783 char buf[1024];
2784 FILE *inf;
2786 /* If we do not have an `ldd', complain. */
2787 if (ldd_file_name == 0)
2789 error ("cannot find 'ldd'");
2790 return;
2793 ldd_argv[argc++] = ldd_file_name;
2794 ldd_argv[argc++] = prog_name;
2795 ldd_argv[argc++] = (char *) 0;
2797 /* Trace if needed. */
2798 if (vflag)
2800 const char **p_argv;
2801 const char *str;
2803 for (p_argv = &ldd_argv[0]; (str = *p_argv) != (char *) 0; p_argv++)
2804 fprintf (stderr, " %s", str);
2806 fprintf (stderr, "\n");
2809 fflush (stdout);
2810 fflush (stderr);
2812 pex = pex_init (PEX_USE_PIPES, "collect2", NULL);
2813 if (pex == NULL)
2814 fatal_perror ("pex_init failed");
2816 errmsg = pex_run (pex, 0, ldd_file_name, real_ldd_argv, NULL, NULL, &err);
2817 if (errmsg != NULL)
2819 if (err != 0)
2821 errno = err;
2822 fatal_perror (errmsg);
2824 else
2825 fatal (errmsg);
2828 int_handler = (void (*) (int)) signal (SIGINT, SIG_IGN);
2829 #ifdef SIGQUIT
2830 quit_handler = (void (*) (int)) signal (SIGQUIT, SIG_IGN);
2831 #endif
2833 inf = pex_read_output (pex, 0);
2834 if (inf == NULL)
2835 fatal_perror ("can't open ldd output");
2837 if (debug)
2838 notice ("\nldd output with constructors/destructors.\n");
2840 /* Read each line of ldd output. */
2841 while (fgets (buf, sizeof buf, inf) != (char *) 0)
2843 int ch2;
2844 char *name, *end, *p = buf;
2846 /* Extract names of libraries and add to list. */
2847 PARSE_LDD_OUTPUT (p);
2848 if (p == 0)
2849 continue;
2851 name = p;
2852 if (strncmp (name, "not found", sizeof ("not found") - 1) == 0)
2853 fatal ("dynamic dependency %s not found", buf);
2855 /* Find the end of the symbol name. */
2856 for (end = p;
2857 (ch2 = *end) != '\0' && ch2 != '\n' && !ISSPACE (ch2) && ch2 != '|';
2858 end++)
2859 continue;
2860 *end = '\0';
2862 if (access (name, R_OK) == 0)
2863 add_to_list (&libraries, name);
2864 else
2865 fatal ("unable to open dynamic dependency '%s'", buf);
2867 if (debug)
2868 fprintf (stderr, "\t%s\n", buf);
2870 if (debug)
2871 fprintf (stderr, "\n");
2873 do_wait (ldd_file_name, pex);
2875 signal (SIGINT, int_handler);
2876 #ifdef SIGQUIT
2877 signal (SIGQUIT, quit_handler);
2878 #endif
2880 /* Now iterate through the library list adding their symbols to
2881 the list. */
2882 for (list = libraries.first; list; list = list->next)
2883 scan_prog_file (list->name, PASS_LIB, SCAN_ALL);
2886 #endif /* LDD_SUFFIX */
2888 #endif /* OBJECT_FORMAT_NONE */
2892 * COFF specific stuff.
2895 #ifdef OBJECT_FORMAT_COFF
2897 #if defined (EXTENDED_COFF)
2899 # define GCC_SYMBOLS(X) (SYMHEADER(X).isymMax + SYMHEADER(X).iextMax)
2900 # define GCC_SYMENT SYMR
2901 # define GCC_OK_SYMBOL(X) ((X).st == stProc || (X).st == stGlobal)
2902 # define GCC_SYMINC(X) (1)
2903 # define GCC_SYMZERO(X) (SYMHEADER(X).isymMax)
2904 # define GCC_CHECK_HDR(X) (PSYMTAB(X) != 0)
2906 #else
2908 # define GCC_SYMBOLS(X) (HEADER(ldptr).f_nsyms)
2909 # define GCC_SYMENT SYMENT
2910 # if defined (C_WEAKEXT)
2911 # define GCC_OK_SYMBOL(X) \
2912 (((X).n_sclass == C_EXT || (X).n_sclass == C_WEAKEXT) && \
2913 ((X).n_scnum > N_UNDEF) && \
2914 (aix64_flag \
2915 || (((X).n_type & N_TMASK) == (DT_NON << N_BTSHFT) \
2916 || ((X).n_type & N_TMASK) == (DT_FCN << N_BTSHFT))))
2917 # define GCC_UNDEF_SYMBOL(X) \
2918 (((X).n_sclass == C_EXT || (X).n_sclass == C_WEAKEXT) && \
2919 ((X).n_scnum == N_UNDEF))
2920 # else
2921 # define GCC_OK_SYMBOL(X) \
2922 (((X).n_sclass == C_EXT) && \
2923 ((X).n_scnum > N_UNDEF) && \
2924 (aix64_flag \
2925 || (((X).n_type & N_TMASK) == (DT_NON << N_BTSHFT) \
2926 || ((X).n_type & N_TMASK) == (DT_FCN << N_BTSHFT))))
2927 # define GCC_UNDEF_SYMBOL(X) \
2928 (((X).n_sclass == C_EXT) && ((X).n_scnum == N_UNDEF))
2929 # endif
2930 # define GCC_SYMINC(X) ((X).n_numaux+1)
2931 # define GCC_SYMZERO(X) 0
2933 /* 0757 = U803XTOCMAGIC (AIX 4.3) and 0767 = U64_TOCMAGIC (AIX V5) */
2934 #if TARGET_AIX_VERSION >= 51
2935 # define GCC_CHECK_HDR(X) \
2936 ((HEADER (X).f_magic == U802TOCMAGIC && ! aix64_flag) \
2937 || (HEADER (X).f_magic == 0767 && aix64_flag))
2938 #else
2939 # define GCC_CHECK_HDR(X) \
2940 ((HEADER (X).f_magic == U802TOCMAGIC && ! aix64_flag) \
2941 || (HEADER (X).f_magic == 0757 && aix64_flag))
2942 #endif
2944 #endif
2946 #ifdef COLLECT_EXPORT_LIST
2947 /* Array of standard AIX libraries which should not
2948 be scanned for ctors/dtors. */
2949 static const char *const aix_std_libs[] = {
2950 "/unix",
2951 "/lib/libc.a",
2952 "/lib/libm.a",
2953 "/lib/libc_r.a",
2954 "/lib/libm_r.a",
2955 "/usr/lib/libc.a",
2956 "/usr/lib/libm.a",
2957 "/usr/lib/libc_r.a",
2958 "/usr/lib/libm_r.a",
2959 "/usr/lib/threads/libc.a",
2960 "/usr/ccs/lib/libc.a",
2961 "/usr/ccs/lib/libm.a",
2962 "/usr/ccs/lib/libc_r.a",
2963 "/usr/ccs/lib/libm_r.a",
2964 NULL
2967 /* This function checks the filename and returns 1
2968 if this name matches the location of a standard AIX library. */
2969 static int ignore_library (const char *);
2970 static int
2971 ignore_library (const char *name)
2973 const char *const *p;
2974 size_t length;
2976 if (target_system_root[0] != '\0')
2978 length = strlen (target_system_root);
2979 if (strncmp (name, target_system_root, length) != 0)
2980 return 0;
2981 name += length;
2983 for (p = &aix_std_libs[0]; *p != NULL; ++p)
2984 if (strcmp (name, *p) == 0)
2985 return 1;
2986 return 0;
2988 #endif /* COLLECT_EXPORT_LIST */
2990 #if defined (HAVE_DECL_LDGETNAME) && !HAVE_DECL_LDGETNAME
2991 extern char *ldgetname (LDFILE *, GCC_SYMENT *);
2992 #endif
2994 /* COFF version to scan the name list of the loaded program for
2995 the symbols g++ uses for static constructors and destructors. */
2997 static void
2998 scan_prog_file (const char *prog_name, scanpass which_pass,
2999 scanfilter filter)
3001 LDFILE *ldptr = NULL;
3002 int sym_index, sym_count;
3003 int is_shared = 0;
3005 if (which_pass != PASS_FIRST && which_pass != PASS_OBJ)
3006 return;
3008 #ifdef COLLECT_EXPORT_LIST
3009 /* We do not need scanning for some standard C libraries. */
3010 if (which_pass == PASS_FIRST && ignore_library (prog_name))
3011 return;
3013 /* On AIX we have a loop, because there is not much difference
3014 between an object and an archive. This trick allows us to
3015 eliminate scan_libraries() function. */
3018 #endif
3019 /* Some platforms (e.g. OSF4) declare ldopen as taking a
3020 non-const char * filename parameter, even though it will not
3021 modify that string. So we must cast away const-ness here,
3022 using CONST_CAST to prevent complaints from -Wcast-qual. */
3023 if ((ldptr = ldopen (CONST_CAST (char *, prog_name), ldptr)) != NULL)
3025 if (! MY_ISCOFF (HEADER (ldptr).f_magic))
3026 fatal ("%s: not a COFF file", prog_name);
3028 if (GCC_CHECK_HDR (ldptr))
3030 sym_count = GCC_SYMBOLS (ldptr);
3031 sym_index = GCC_SYMZERO (ldptr);
3033 #ifdef COLLECT_EXPORT_LIST
3034 /* Is current archive member a shared object? */
3035 is_shared = HEADER (ldptr).f_flags & F_SHROBJ;
3036 #endif
3038 while (sym_index < sym_count)
3040 GCC_SYMENT symbol;
3042 if (ldtbread (ldptr, sym_index, &symbol) <= 0)
3043 break;
3044 sym_index += GCC_SYMINC (symbol);
3046 if (GCC_OK_SYMBOL (symbol))
3048 char *name;
3050 if ((name = ldgetname (ldptr, &symbol)) == NULL)
3051 continue; /* Should never happen. */
3053 #ifdef XCOFF_DEBUGGING_INFO
3054 /* All AIX function names have a duplicate entry
3055 beginning with a dot. */
3056 if (*name == '.')
3057 ++name;
3058 #endif
3060 switch (is_ctor_dtor (name))
3062 case SYM_CTOR:
3063 if (! (filter & SCAN_CTOR))
3064 break;
3065 if (! is_shared)
3066 add_to_list (&constructors, name);
3067 #if defined (COLLECT_EXPORT_LIST) && !defined (LD_INIT_SWITCH)
3068 if (which_pass == PASS_OBJ)
3069 add_to_list (&exports, name);
3070 #endif
3071 break;
3073 case SYM_DTOR:
3074 if (! (filter & SCAN_DTOR))
3075 break;
3076 if (! is_shared)
3077 add_to_list (&destructors, name);
3078 #if defined (COLLECT_EXPORT_LIST) && !defined (LD_INIT_SWITCH)
3079 if (which_pass == PASS_OBJ)
3080 add_to_list (&exports, name);
3081 #endif
3082 break;
3084 #ifdef COLLECT_EXPORT_LIST
3085 case SYM_INIT:
3086 if (! (filter & SCAN_INIT))
3087 break;
3088 #ifndef LD_INIT_SWITCH
3089 if (is_shared)
3090 add_to_list (&constructors, name);
3091 #endif
3092 break;
3094 case SYM_FINI:
3095 if (! (filter & SCAN_FINI))
3096 break;
3097 #ifndef LD_INIT_SWITCH
3098 if (is_shared)
3099 add_to_list (&destructors, name);
3100 #endif
3101 break;
3102 #endif
3104 case SYM_DWEH:
3105 if (! (filter & SCAN_DWEH))
3106 break;
3107 if (! is_shared)
3108 add_to_list (&frame_tables, name);
3109 #if defined (COLLECT_EXPORT_LIST) && !defined (LD_INIT_SWITCH)
3110 if (which_pass == PASS_OBJ)
3111 add_to_list (&exports, name);
3112 #endif
3113 break;
3115 default: /* not a constructor or destructor */
3116 #ifdef COLLECT_EXPORT_LIST
3117 /* Explicitly export all global symbols when
3118 building a shared object on AIX, but do not
3119 re-export symbols from another shared object
3120 and do not export symbols if the user
3121 provides an explicit export list. */
3122 if (shared_obj && !is_shared
3123 && which_pass == PASS_OBJ && !export_flag)
3124 add_to_list (&exports, name);
3125 #endif
3126 continue;
3129 if (debug)
3130 #if !defined(EXTENDED_COFF)
3131 fprintf (stderr, "\tsec=%d class=%d type=%s%o %s\n",
3132 symbol.n_scnum, symbol.n_sclass,
3133 (symbol.n_type ? "0" : ""), symbol.n_type,
3134 name);
3135 #else
3136 fprintf (stderr,
3137 "\tiss = %5d, value = %5ld, index = %5d, name = %s\n",
3138 symbol.iss, (long) symbol.value, symbol.index, name);
3139 #endif
3143 #ifdef COLLECT_EXPORT_LIST
3144 else
3146 /* If archive contains both 32-bit and 64-bit objects,
3147 we want to skip objects in other mode so mismatch normal. */
3148 if (debug)
3149 fprintf (stderr, "%s : magic=%o aix64=%d mismatch\n",
3150 prog_name, HEADER (ldptr).f_magic, aix64_flag);
3152 #endif
3154 else
3156 fatal ("%s: cannot open as COFF file", prog_name);
3158 #ifdef COLLECT_EXPORT_LIST
3159 /* On AIX loop continues while there are more members in archive. */
3161 while (ldclose (ldptr) == FAILURE);
3162 #else
3163 /* Otherwise we simply close ldptr. */
3164 (void) ldclose(ldptr);
3165 #endif
3167 #endif /* OBJECT_FORMAT_COFF */
3169 #ifdef COLLECT_EXPORT_LIST
3170 /* Given a library name without "lib" prefix, this function
3171 returns a full library name including a path. */
3172 static char *
3173 resolve_lib_name (const char *name)
3175 char *lib_buf;
3176 int i, j, l = 0;
3177 /* Library extensions for AIX dynamic linking. */
3178 const char * const libexts[2] = {"a", "so"};
3180 for (i = 0; libpaths[i]; i++)
3181 if (libpaths[i]->max_len > l)
3182 l = libpaths[i]->max_len;
3184 lib_buf = XNEWVEC (char, l + strlen(name) + 10);
3186 for (i = 0; libpaths[i]; i++)
3188 struct prefix_list *list = libpaths[i]->plist;
3189 for (; list; list = list->next)
3191 /* The following lines are needed because path_prefix list
3192 may contain directories both with trailing DIR_SEPARATOR and
3193 without it. */
3194 const char *p = "";
3195 if (!IS_DIR_SEPARATOR (list->prefix[strlen(list->prefix)-1]))
3196 p = "/";
3197 for (j = 0; j < 2; j++)
3199 sprintf (lib_buf, "%s%slib%s.%s",
3200 list->prefix, p, name,
3201 libexts[(j + aixrtl_flag) % 2]);
3202 if (debug) fprintf (stderr, "searching for: %s\n", lib_buf);
3203 if (file_exists (lib_buf))
3205 if (debug) fprintf (stderr, "found: %s\n", lib_buf);
3206 return (lib_buf);
3211 if (debug)
3212 fprintf (stderr, "not found\n");
3213 else
3214 fatal ("library lib%s not found", name);
3215 return (NULL);
3217 #endif /* COLLECT_EXPORT_LIST */
3219 #ifdef COLLECT_RUN_DSYMUTIL
3220 static int flag_dsym = false;
3221 static int flag_idsym = false;
3223 static void
3224 process_args (int *argcp, char **argv) {
3225 int i, j;
3226 int argc = *argcp;
3227 for (i=0; i<argc; ++i)
3229 if (strcmp (argv[i], "-dsym") == 0)
3231 flag_dsym = true;
3232 /* Remove the flag, as we handle all processing for it. */
3233 j = i;
3235 argv[j] = argv[j+1];
3236 while (++j < argc);
3237 --i;
3238 argc = --(*argcp);
3240 else if (strcmp (argv[i], "-idsym") == 0)
3242 flag_idsym = true;
3243 /* Remove the flag, as we handle all processing for it. */
3244 j = i;
3246 argv[j] = argv[j+1];
3247 while (++j < argc);
3248 --i;
3249 argc = --(*argcp);
3254 static void
3255 do_dsymutil (const char *output_file) {
3256 const char *dsymutil = DSYMUTIL + 1;
3257 struct pex_obj *pex;
3258 char **real_argv = XCNEWVEC (char *, 3);
3259 const char ** argv = CONST_CAST2 (const char **, char **,
3260 real_argv);
3262 argv[0] = dsymutil;
3263 argv[1] = output_file;
3264 argv[2] = (char *) 0;
3266 pex = collect_execute (dsymutil, real_argv, NULL, NULL, PEX_LAST | PEX_SEARCH);
3267 do_wait (dsymutil, pex);
3270 static void
3271 post_ld_pass (bool temp_file) {
3272 if (!(temp_file && flag_idsym) && !flag_dsym)
3273 return;
3275 do_dsymutil (output_file);
3277 #else
3278 static void
3279 process_args (int *argcp ATTRIBUTE_UNUSED, char **argv ATTRIBUTE_UNUSED) { }
3280 static void post_ld_pass (bool temp_file ATTRIBUTE_UNUSED) { }
3281 #endif