2013-11-29 Richard Biener <rguenther@suse.de>
[official-gcc.git] / gcc / collect2.c
blob95f817d307ac345ef79efb6b839c39fc29124d62
1 /* Collect static initialization info into data structures that can be
2 traversed by C++ initialization and finalization routines.
3 Copyright (C) 1992-2013 Free Software Foundation, Inc.
4 Contributed by Chris Smith (csmith@convex.com).
5 Heavily modified by Michael Meissner (meissner@cygnus.com),
6 Per Bothner (bothner@cygnus.com), and John Gilmore (gnu@cygnus.com).
8 This file is part of GCC.
10 GCC is free software; you can redistribute it and/or modify it under
11 the terms of the GNU General Public License as published by the Free
12 Software Foundation; either version 3, or (at your option) any later
13 version.
15 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
16 WARRANTY; without even the implied warranty of MERCHANTABILITY or
17 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
18 for more details.
20 You should have received a copy of the GNU General Public License
21 along with GCC; see the file COPYING3. If not see
22 <http://www.gnu.org/licenses/>. */
25 /* Build tables of static constructors and destructors and run ld. */
27 #include "config.h"
28 #include "system.h"
29 #include "coretypes.h"
30 #include "tm.h"
31 #include "filenames.h"
32 #include "file-find.h"
34 /* TARGET_64BIT may be defined to use driver specific functionality. */
35 #undef TARGET_64BIT
36 #define TARGET_64BIT TARGET_64BIT_DEFAULT
38 #ifndef LIBRARY_PATH_ENV
39 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
40 #endif
42 #define COLLECT
44 #include "collect2.h"
45 #include "collect2-aix.h"
46 #include "diagnostic.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 #ifdef COLLECT_EXPORT_LIST
182 static int export_flag; /* true if -bE */
183 static int aix64_flag; /* true if -b64 */
184 static int aixrtl_flag; /* true if -brtl */
185 static int aixlazy_flag; /* true if -blazy */
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 */
220 #ifdef TARGET_AIX_VERSION
221 static char *aix_shared_initname;
222 static char *aix_shared_fininame; /* init/fini names as per the scheme
223 described in config/rs6000/aix.h */
224 #endif
226 static struct head constructors; /* list of constructors found */
227 static struct head destructors; /* list of destructors found */
228 #ifdef COLLECT_EXPORT_LIST
229 static struct head exports; /* list of exported symbols */
230 #endif
231 static struct head frame_tables; /* list of frame unwind info tables */
233 static bool at_file_supplied; /* Whether to use @file arguments */
234 static char *response_file; /* Name of any current response file */
236 struct obstack temporary_obstack;
237 char * temporary_firstobj;
239 /* A string that must be prepended to a target OS path in order to find
240 it on the host system. */
241 #ifdef TARGET_SYSTEM_ROOT
242 static const char *target_system_root = TARGET_SYSTEM_ROOT;
243 #else
244 static const char *target_system_root = "";
245 #endif
247 /* Whether we may unlink the output file, which should be set as soon as we
248 know we have successfully produced it. This is typically useful to prevent
249 blindly attempting to unlink a read-only output that the target linker
250 would leave untouched. */
251 bool may_unlink_output_file = false;
253 #ifdef COLLECT_EXPORT_LIST
254 /* Lists to keep libraries to be scanned for global constructors/destructors. */
255 static struct head libs; /* list of libraries */
256 static struct path_prefix cmdline_lib_dirs; /* directories specified with -L */
257 static struct path_prefix libpath_lib_dirs; /* directories in LIBPATH */
258 static struct path_prefix *libpaths[3] = {&cmdline_lib_dirs,
259 &libpath_lib_dirs, NULL};
260 #endif
262 /* List of names of object files containing LTO information.
263 These are a subset of the object file names appearing on the
264 command line, and must be identical, in the sense of pointer
265 equality, with the names passed to maybe_run_lto_and_relink(). */
267 struct lto_object
269 const char *name; /* Name of object file. */
270 struct lto_object *next; /* Next in linked list. */
273 struct lto_object_list
275 struct lto_object *first; /* First list element. */
276 struct lto_object *last; /* Last list element. */
279 static struct lto_object_list lto_objects;
281 /* Special kinds of symbols that a name may denote. */
283 typedef enum {
284 SYM_REGULAR = 0, /* nothing special */
286 SYM_CTOR = 1, /* constructor */
287 SYM_DTOR = 2, /* destructor */
288 SYM_INIT = 3, /* shared object routine that calls all the ctors */
289 SYM_FINI = 4, /* shared object routine that calls all the dtors */
290 SYM_DWEH = 5, /* DWARF exception handling table */
291 SYM_AIXI = 6,
292 SYM_AIXD = 7
293 } symkind;
295 static symkind is_ctor_dtor (const char *);
297 static void handler (int);
298 static void do_wait (const char *, struct pex_obj *);
299 static void fork_execute (const char *, char **);
300 static void maybe_unlink (const char *);
301 static void maybe_unlink_list (char **);
302 static void add_to_list (struct head *, const char *);
303 static int extract_init_priority (const char *);
304 static void sort_ids (struct head *);
305 static void write_list (FILE *, const char *, struct id *);
306 #ifdef COLLECT_EXPORT_LIST
307 static void dump_list (FILE *, const char *, struct id *);
308 #endif
309 #if 0
310 static void dump_prefix_list (FILE *, const char *, struct prefix_list *);
311 #endif
312 static void write_list_with_asm (FILE *, const char *, struct id *);
313 static void write_c_file (FILE *, const char *);
314 static void write_c_file_stat (FILE *, const char *);
315 #ifndef LD_INIT_SWITCH
316 static void write_c_file_glob (FILE *, const char *);
317 #endif
318 #ifdef SCAN_LIBRARIES
319 static void scan_libraries (const char *);
320 #endif
321 #ifdef COLLECT_EXPORT_LIST
322 #if 0
323 static int is_in_list (const char *, struct id *);
324 #endif
325 static void write_aix_file (FILE *, struct id *);
326 static char *resolve_lib_name (const char *);
327 #endif
328 static char *extract_string (const char **);
329 static void post_ld_pass (bool);
330 static void process_args (int *argcp, char **argv);
332 /* Enumerations describing which pass this is for scanning the
333 program file ... */
335 typedef enum {
336 PASS_FIRST, /* without constructors */
337 PASS_OBJ, /* individual objects */
338 PASS_LIB, /* looking for shared libraries */
339 PASS_SECOND, /* with constructors linked in */
340 PASS_LTOINFO /* looking for objects with LTO info */
341 } scanpass;
343 /* ... and which kinds of symbols are to be considered. */
345 enum scanfilter_masks {
346 SCAN_NOTHING = 0,
348 SCAN_CTOR = 1 << SYM_CTOR,
349 SCAN_DTOR = 1 << SYM_DTOR,
350 SCAN_INIT = 1 << SYM_INIT,
351 SCAN_FINI = 1 << SYM_FINI,
352 SCAN_DWEH = 1 << SYM_DWEH,
353 SCAN_AIXI = 1 << SYM_AIXI,
354 SCAN_AIXD = 1 << SYM_AIXD,
355 SCAN_ALL = ~0
358 /* This type is used for parameters and variables which hold
359 combinations of the flags in enum scanfilter_masks. */
360 typedef int scanfilter;
362 /* Scan the name list of the loaded program for the symbols g++ uses for
363 static constructors and destructors.
365 The SCANPASS argument tells which collect processing pass this is for and
366 the SCANFILTER argument tells which kinds of symbols to consider in this
367 pass. Symbols of a special kind not in the filter mask are considered as
368 regular ones.
370 The constructor table begins at __CTOR_LIST__ and contains a count of the
371 number of pointers (or -1 if the constructors are built in a separate
372 section by the linker), followed by the pointers to the constructor
373 functions, terminated with a null pointer. The destructor table has the
374 same format, and begins at __DTOR_LIST__. */
376 static void scan_prog_file (const char *, scanpass, scanfilter);
379 /* Delete tempfiles and exit function. */
381 static void
382 collect_atexit (void)
384 if (c_file != 0 && c_file[0])
385 maybe_unlink (c_file);
387 if (o_file != 0 && o_file[0])
388 maybe_unlink (o_file);
390 #ifdef COLLECT_EXPORT_LIST
391 if (export_file != 0 && export_file[0])
392 maybe_unlink (export_file);
393 #endif
395 if (lto_o_files)
396 maybe_unlink_list (lto_o_files);
398 if (ldout != 0 && ldout[0])
400 dump_ld_file (ldout, stdout);
401 maybe_unlink (ldout);
404 if (lderrout != 0 && lderrout[0])
406 dump_ld_file (lderrout, stderr);
407 maybe_unlink (lderrout);
410 if (response_file)
411 maybe_unlink (response_file);
415 /* Notify user of a non-error. */
416 void
417 notice (const char *cmsgid, ...)
419 va_list ap;
421 va_start (ap, cmsgid);
422 vfprintf (stderr, _(cmsgid), ap);
423 va_end (ap);
426 /* Notify user of a non-error, without translating the format string. */
427 void
428 notice_translated (const char *cmsgid, ...)
430 va_list ap;
432 va_start (ap, cmsgid);
433 vfprintf (stderr, cmsgid, ap);
434 va_end (ap);
437 static void
438 handler (int signo)
440 if (c_file != 0 && c_file[0])
441 maybe_unlink (c_file);
443 if (o_file != 0 && o_file[0])
444 maybe_unlink (o_file);
446 if (ldout != 0 && ldout[0])
447 maybe_unlink (ldout);
449 if (lderrout != 0 && lderrout[0])
450 maybe_unlink (lderrout);
452 #ifdef COLLECT_EXPORT_LIST
453 if (export_file != 0 && export_file[0])
454 maybe_unlink (export_file);
455 #endif
457 if (lto_o_files)
458 maybe_unlink_list (lto_o_files);
460 if (response_file)
461 maybe_unlink (response_file);
463 signal (signo, SIG_DFL);
464 raise (signo);
469 file_exists (const char *name)
471 return access (name, R_OK) == 0;
474 /* Parse a reasonable subset of shell quoting syntax. */
476 static char *
477 extract_string (const char **pp)
479 const char *p = *pp;
480 int backquote = 0;
481 int inside = 0;
483 for (;;)
485 char c = *p;
486 if (c == '\0')
487 break;
488 ++p;
489 if (backquote)
490 obstack_1grow (&temporary_obstack, c);
491 else if (! inside && c == ' ')
492 break;
493 else if (! inside && c == '\\')
494 backquote = 1;
495 else if (c == '\'')
496 inside = !inside;
497 else
498 obstack_1grow (&temporary_obstack, c);
501 obstack_1grow (&temporary_obstack, '\0');
502 *pp = p;
503 return XOBFINISH (&temporary_obstack, char *);
506 void
507 dump_ld_file (const char *name, FILE *to)
509 FILE *stream = fopen (name, "r");
511 if (stream == 0)
512 return;
513 while (1)
515 int c;
516 while (c = getc (stream),
517 c != EOF && (ISIDNUM (c) || c == '$' || c == '.'))
518 obstack_1grow (&temporary_obstack, c);
519 if (obstack_object_size (&temporary_obstack) > 0)
521 const char *word, *p;
522 char *result;
523 obstack_1grow (&temporary_obstack, '\0');
524 word = XOBFINISH (&temporary_obstack, const char *);
526 if (*word == '.')
527 ++word, putc ('.', to);
528 p = word;
529 if (!strncmp (p, USER_LABEL_PREFIX, strlen (USER_LABEL_PREFIX)))
530 p += strlen (USER_LABEL_PREFIX);
532 #ifdef HAVE_LD_DEMANGLE
533 result = 0;
534 #else
535 if (no_demangle)
536 result = 0;
537 else
538 result = cplus_demangle (p, DMGL_PARAMS | DMGL_ANSI | DMGL_VERBOSE);
539 #endif
541 if (result)
543 int diff;
544 fputs (result, to);
546 diff = strlen (word) - strlen (result);
547 while (diff > 0 && c == ' ')
548 --diff, putc (' ', to);
549 if (diff < 0 && c == ' ')
551 while (diff < 0 && c == ' ')
552 ++diff, c = getc (stream);
553 if (!ISSPACE (c))
555 /* Make sure we output at least one space, or
556 the demangled symbol name will run into
557 whatever text follows. */
558 putc (' ', to);
562 free (result);
564 else
565 fputs (word, to);
567 fflush (to);
568 obstack_free (&temporary_obstack, temporary_firstobj);
570 if (c == EOF)
571 break;
572 putc (c, to);
574 fclose (stream);
577 /* Return the kind of symbol denoted by name S. */
579 static symkind
580 is_ctor_dtor (const char *s)
582 struct names { const char *const name; const int len; symkind ret;
583 const int two_underscores; };
585 const struct names *p;
586 int ch;
587 const char *orig_s = s;
589 static const struct names special[] = {
590 #ifndef NO_DOLLAR_IN_LABEL
591 { "GLOBAL__I$", sizeof ("GLOBAL__I$")-1, SYM_CTOR, 0 },
592 { "GLOBAL__D$", sizeof ("GLOBAL__D$")-1, SYM_DTOR, 0 },
593 #else
594 #ifndef NO_DOT_IN_LABEL
595 { "GLOBAL__I.", sizeof ("GLOBAL__I.")-1, SYM_CTOR, 0 },
596 { "GLOBAL__D.", sizeof ("GLOBAL__D.")-1, SYM_DTOR, 0 },
597 #endif /* NO_DOT_IN_LABEL */
598 #endif /* NO_DOLLAR_IN_LABEL */
599 { "GLOBAL__I_", sizeof ("GLOBAL__I_")-1, SYM_CTOR, 0 },
600 { "GLOBAL__D_", sizeof ("GLOBAL__D_")-1, SYM_DTOR, 0 },
601 { "GLOBAL__F_", sizeof ("GLOBAL__F_")-1, SYM_DWEH, 0 },
602 { "GLOBAL__FI_", sizeof ("GLOBAL__FI_")-1, SYM_INIT, 0 },
603 { "GLOBAL__FD_", sizeof ("GLOBAL__FD_")-1, SYM_FINI, 0 },
604 #ifdef TARGET_AIX_VERSION
605 { "GLOBAL__AIXI_", sizeof ("GLOBAL__AIXI_")-1, SYM_AIXI, 0 },
606 { "GLOBAL__AIXD_", sizeof ("GLOBAL__AIXD_")-1, SYM_AIXD, 0 },
607 #endif
608 { NULL, 0, SYM_REGULAR, 0 }
611 while ((ch = *s) == '_')
612 ++s;
614 if (s == orig_s)
615 return SYM_REGULAR;
617 for (p = &special[0]; p->len > 0; p++)
619 if (ch == p->name[0]
620 && (!p->two_underscores || ((s - orig_s) >= 2))
621 && strncmp (s, p->name, p->len) == 0)
623 return p->ret;
626 return SYM_REGULAR;
629 /* We maintain two prefix lists: one from COMPILER_PATH environment variable
630 and one from the PATH variable. */
632 static struct path_prefix cpath, path;
634 #ifdef CROSS_DIRECTORY_STRUCTURE
635 /* This is the name of the target machine. We use it to form the name
636 of the files to execute. */
638 static const char *const target_machine = TARGET_MACHINE;
639 #endif
641 /* Search for NAME using prefix list PPREFIX. We only look for executable
642 files.
644 Return 0 if not found, otherwise return its name, allocated with malloc. */
646 #ifdef OBJECT_FORMAT_NONE
648 /* Add an entry for the object file NAME to object file list LIST.
649 New entries are added at the end of the list. The original pointer
650 value of NAME is preserved, i.e., no string copy is performed. */
652 static void
653 add_lto_object (struct lto_object_list *list, const char *name)
655 struct lto_object *n = XNEW (struct lto_object);
656 n->name = name;
657 n->next = NULL;
659 if (list->last)
660 list->last->next = n;
661 else
662 list->first = n;
664 list->last = n;
666 #endif /* OBJECT_FORMAT_NONE */
669 /* Perform a link-time recompilation and relink if any of the object
670 files contain LTO info. The linker command line LTO_LD_ARGV
671 represents the linker command that would produce a final executable
672 without the use of LTO. OBJECT_LST is a vector of object file names
673 appearing in LTO_LD_ARGV that are to be considered for link-time
674 recompilation, where OBJECT is a pointer to the last valid element.
675 (This awkward convention avoids an impedance mismatch with the
676 usage of similarly-named variables in main().) The elements of
677 OBJECT_LST must be identical, i.e., pointer equal, to the
678 corresponding arguments in LTO_LD_ARGV.
680 Upon entry, at least one linker run has been performed without the
681 use of any LTO info that might be present. Any recompilations
682 necessary for template instantiations have been performed, and
683 initializer/finalizer tables have been created if needed and
684 included in the linker command line LTO_LD_ARGV. If any of the
685 object files contain LTO info, we run the LTO back end on all such
686 files, and perform the final link with the LTO back end output
687 substituted for the LTO-optimized files. In some cases, a final
688 link with all link-time generated code has already been performed,
689 so there is no need to relink if no LTO info is found. In other
690 cases, our caller has not produced the final executable, and is
691 relying on us to perform the required link whether LTO info is
692 present or not. In that case, the FORCE argument should be true.
693 Note that the linker command line argument LTO_LD_ARGV passed into
694 this function may be modified in place. */
696 static void
697 maybe_run_lto_and_relink (char **lto_ld_argv, char **object_lst,
698 const char **object, bool force)
700 const char **object_file = CONST_CAST2 (const char **, char **, object_lst);
702 int num_lto_c_args = 1; /* Allow space for the terminating NULL. */
704 while (object_file < object)
706 /* If file contains LTO info, add it to the list of LTO objects. */
707 scan_prog_file (*object_file++, PASS_LTOINFO, SCAN_ALL);
709 /* Increment the argument count by the number of object file arguments
710 we will add. An upper bound suffices, so just count all of the
711 object files regardless of whether they contain LTO info. */
712 num_lto_c_args++;
715 if (lto_objects.first)
717 char **lto_c_argv;
718 const char **lto_c_ptr;
719 char **p;
720 char **lto_o_ptr;
721 struct lto_object *list;
722 char *lto_wrapper = getenv ("COLLECT_LTO_WRAPPER");
723 struct pex_obj *pex;
724 const char *prog = "lto-wrapper";
725 int lto_ld_argv_size = 0;
726 char **out_lto_ld_argv;
727 int out_lto_ld_argv_size;
728 size_t num_files;
730 if (!lto_wrapper)
731 fatal_error ("COLLECT_LTO_WRAPPER must be set");
733 num_lto_c_args++;
735 /* There is at least one object file containing LTO info,
736 so we need to run the LTO back end and relink.
738 To do so we build updated ld arguments with first
739 LTO object replaced by all partitions and other LTO
740 objects removed. */
742 lto_c_argv = (char **) xcalloc (sizeof (char *), num_lto_c_args);
743 lto_c_ptr = CONST_CAST2 (const char **, char **, lto_c_argv);
745 *lto_c_ptr++ = lto_wrapper;
747 /* Add LTO objects to the wrapper command line. */
748 for (list = lto_objects.first; list; list = list->next)
749 *lto_c_ptr++ = list->name;
751 *lto_c_ptr = NULL;
753 /* Run the LTO back end. */
754 pex = collect_execute (prog, lto_c_argv, NULL, NULL, PEX_SEARCH);
756 int c;
757 FILE *stream;
758 size_t i;
759 char *start, *end;
761 stream = pex_read_output (pex, 0);
762 gcc_assert (stream);
764 num_files = 0;
765 while ((c = getc (stream)) != EOF)
767 obstack_1grow (&temporary_obstack, c);
768 if (c == '\n')
769 ++num_files;
772 lto_o_files = XNEWVEC (char *, num_files + 1);
773 lto_o_files[num_files] = NULL;
774 start = XOBFINISH (&temporary_obstack, char *);
775 for (i = 0; i < num_files; ++i)
777 end = start;
778 while (*end != '\n')
779 ++end;
780 *end = '\0';
782 lto_o_files[i] = xstrdup (start);
784 start = end + 1;
787 obstack_free (&temporary_obstack, temporary_firstobj);
789 do_wait (prog, pex);
790 pex = NULL;
792 /* Compute memory needed for new LD arguments. At most number of original arguemtns
793 plus number of partitions. */
794 for (lto_ld_argv_size = 0; lto_ld_argv[lto_ld_argv_size]; lto_ld_argv_size++)
796 out_lto_ld_argv = XCNEWVEC (char *, num_files + lto_ld_argv_size + 1);
797 out_lto_ld_argv_size = 0;
799 /* After running the LTO back end, we will relink, substituting
800 the LTO output for the object files that we submitted to the
801 LTO. Here, we modify the linker command line for the relink. */
803 /* Copy all arguments until we find first LTO file. */
804 p = lto_ld_argv;
805 while (*p != NULL)
807 for (list = lto_objects.first; list; list = list->next)
808 if (*p == list->name) /* Note test for pointer equality! */
809 break;
810 if (list)
811 break;
812 out_lto_ld_argv[out_lto_ld_argv_size++] = *p++;
815 /* Now insert all LTO partitions. */
816 lto_o_ptr = lto_o_files;
817 while (*lto_o_ptr)
818 out_lto_ld_argv[out_lto_ld_argv_size++] = *lto_o_ptr++;
820 /* ... and copy the rest. */
821 while (*p != NULL)
823 for (list = lto_objects.first; list; list = list->next)
824 if (*p == list->name) /* Note test for pointer equality! */
825 break;
826 if (!list)
827 out_lto_ld_argv[out_lto_ld_argv_size++] = *p;
828 p++;
830 out_lto_ld_argv[out_lto_ld_argv_size++] = 0;
832 /* Run the linker again, this time replacing the object files
833 optimized by the LTO with the temporary file generated by the LTO. */
834 fork_execute ("ld", out_lto_ld_argv);
835 post_ld_pass (true);
836 free (lto_ld_argv);
838 maybe_unlink_list (lto_o_files);
840 else if (force)
842 /* Our caller is relying on us to do the link
843 even though there is no LTO back end work to be done. */
844 fork_execute ("ld", lto_ld_argv);
845 post_ld_pass (false);
849 /* Main program. */
852 main (int argc, char **argv)
854 enum linker_select
856 USE_DEFAULT_LD,
857 USE_PLUGIN_LD,
858 USE_GOLD_LD,
859 USE_BFD_LD,
860 USE_LD_MAX
861 } selected_linker = USE_DEFAULT_LD;
862 static const char *const ld_suffixes[USE_LD_MAX] =
864 "ld",
865 PLUGIN_LD_SUFFIX,
866 "ld.gold",
867 "ld.bfd"
869 static const char *const real_ld_suffix = "real-ld";
870 static const char *const collect_ld_suffix = "collect-ld";
871 static const char *const nm_suffix = "nm";
872 static const char *const gnm_suffix = "gnm";
873 #ifdef LDD_SUFFIX
874 static const char *const ldd_suffix = LDD_SUFFIX;
875 #endif
876 static const char *const strip_suffix = "strip";
877 static const char *const gstrip_suffix = "gstrip";
879 const char *full_ld_suffixes[USE_LD_MAX];
880 #ifdef CROSS_DIRECTORY_STRUCTURE
881 /* If we look for a program in the compiler directories, we just use
882 the short name, since these directories are already system-specific.
883 But it we look for a program in the system directories, we need to
884 qualify the program name with the target machine. */
886 const char *const full_nm_suffix =
887 concat (target_machine, "-", nm_suffix, NULL);
888 const char *const full_gnm_suffix =
889 concat (target_machine, "-", gnm_suffix, NULL);
890 #ifdef LDD_SUFFIX
891 const char *const full_ldd_suffix =
892 concat (target_machine, "-", ldd_suffix, NULL);
893 #endif
894 const char *const full_strip_suffix =
895 concat (target_machine, "-", strip_suffix, NULL);
896 const char *const full_gstrip_suffix =
897 concat (target_machine, "-", gstrip_suffix, NULL);
898 #else
899 #ifdef LDD_SUFFIX
900 const char *const full_ldd_suffix = ldd_suffix;
901 #endif
902 const char *const full_nm_suffix = nm_suffix;
903 const char *const full_gnm_suffix = gnm_suffix;
904 const char *const full_strip_suffix = strip_suffix;
905 const char *const full_gstrip_suffix = gstrip_suffix;
906 #endif /* CROSS_DIRECTORY_STRUCTURE */
908 const char *arg;
909 FILE *outf;
910 #ifdef COLLECT_EXPORT_LIST
911 FILE *exportf;
912 #endif
913 const char *ld_file_name;
914 const char *p;
915 char **c_argv;
916 const char **c_ptr;
917 char **ld1_argv;
918 const char **ld1;
919 bool use_plugin = false;
920 bool use_collect_ld = false;
922 /* The kinds of symbols we will have to consider when scanning the
923 outcome of a first pass link. This is ALL to start with, then might
924 be adjusted before getting to the first pass link per se, typically on
925 AIX where we perform an early scan of objects and libraries to fetch
926 the list of global ctors/dtors and make sure they are not garbage
927 collected. */
928 scanfilter ld1_filter = SCAN_ALL;
930 char **ld2_argv;
931 const char **ld2;
932 char **object_lst;
933 const char **object;
934 #ifdef TARGET_AIX_VERSION
935 int object_nbr = argc;
936 #endif
937 int first_file;
938 int num_c_args;
939 char **old_argv;
940 int i;
942 for (i = 0; i < USE_LD_MAX; i++)
943 full_ld_suffixes[i]
944 #ifdef CROSS_DIRECTORY_STRUCTURE
945 = concat (target_machine, "-", ld_suffixes[i], NULL);
946 #else
947 = ld_suffixes[i];
948 #endif
950 p = argv[0] + strlen (argv[0]);
951 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
952 --p;
953 progname = p;
955 xmalloc_set_program_name (progname);
957 old_argv = argv;
958 expandargv (&argc, &argv);
959 if (argv != old_argv)
960 at_file_supplied = 1;
962 process_args (&argc, argv);
964 num_c_args = argc + 9;
966 #ifndef HAVE_LD_DEMANGLE
967 no_demangle = !! getenv ("COLLECT_NO_DEMANGLE");
969 /* Suppress demangling by the real linker, which may be broken. */
970 putenv (xstrdup ("COLLECT_NO_DEMANGLE=1"));
971 #endif
973 #if defined (COLLECT2_HOST_INITIALIZATION)
974 /* Perform system dependent initialization, if necessary. */
975 COLLECT2_HOST_INITIALIZATION;
976 #endif
978 #ifdef SIGCHLD
979 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
980 receive the signal. A different setting is inheritable */
981 signal (SIGCHLD, SIG_DFL);
982 #endif
984 if (atexit (collect_atexit) != 0)
985 fatal_error ("atexit failed");
987 /* Unlock the stdio streams. */
988 unlock_std_streams ();
990 gcc_init_libintl ();
992 diagnostic_initialize (global_dc, 0);
994 /* Do not invoke xcalloc before this point, since locale needs to be
995 set first, in case a diagnostic is issued. */
997 ld1_argv = XCNEWVEC (char *, argc + 4);
998 ld1 = CONST_CAST2 (const char **, char **, ld1_argv);
999 ld2_argv = XCNEWVEC (char *, argc + 11);
1000 ld2 = CONST_CAST2 (const char **, char **, ld2_argv);
1001 object_lst = XCNEWVEC (char *, argc);
1002 object = CONST_CAST2 (const char **, char **, object_lst);
1004 #ifdef DEBUG
1005 debug = 1;
1006 #endif
1008 /* Parse command line early for instances of -debug. This allows
1009 the debug flag to be set before functions like find_a_file()
1010 are called. We also look for the -flto or -flto-partition=none flag to know
1011 what LTO mode we are in. */
1013 bool no_partition = false;
1015 for (i = 1; argv[i] != NULL; i ++)
1017 if (! strcmp (argv[i], "-debug"))
1018 debug = true;
1019 else if (! strcmp (argv[i], "-flto-partition=none"))
1020 no_partition = true;
1021 else if ((! strncmp (argv[i], "-flto=", 6)
1022 || ! strcmp (argv[i], "-flto")) && ! use_plugin)
1023 lto_mode = LTO_MODE_WHOPR;
1024 else if (!strncmp (argv[i], "-fno-lto", 8))
1025 lto_mode = LTO_MODE_NONE;
1026 else if (! strcmp (argv[i], "-plugin"))
1028 use_plugin = true;
1029 lto_mode = LTO_MODE_NONE;
1030 if (selected_linker == USE_DEFAULT_LD)
1031 selected_linker = USE_PLUGIN_LD;
1033 else if (strcmp (argv[i], "-fuse-ld=bfd") == 0)
1034 selected_linker = USE_BFD_LD;
1035 else if (strcmp (argv[i], "-fuse-ld=gold") == 0)
1036 selected_linker = USE_GOLD_LD;
1038 #ifdef COLLECT_EXPORT_LIST
1039 /* These flags are position independent, although their order
1040 is important - subsequent flags override earlier ones. */
1041 else if (strcmp (argv[i], "-b64") == 0)
1042 aix64_flag = 1;
1043 /* -bexport:filename always needs the :filename */
1044 else if (strncmp (argv[i], "-bE:", 4) == 0
1045 || strncmp (argv[i], "-bexport:", 9) == 0)
1046 export_flag = 1;
1047 else if (strcmp (argv[i], "-brtl") == 0
1048 || strcmp (argv[i], "-bsvr4") == 0
1049 || strcmp (argv[i], "-G") == 0)
1050 aixrtl_flag = 1;
1051 else if (strcmp (argv[i], "-bnortl") == 0)
1052 aixrtl_flag = 0;
1053 else if (strcmp (argv[i], "-blazy") == 0)
1054 aixlazy_flag = 1;
1055 #endif
1057 vflag = debug;
1058 find_file_set_debug (debug);
1059 if (no_partition && lto_mode == LTO_MODE_WHOPR)
1060 lto_mode = LTO_MODE_LTO;
1063 #ifndef DEFAULT_A_OUT_NAME
1064 output_file = "a.out";
1065 #else
1066 output_file = DEFAULT_A_OUT_NAME;
1067 #endif
1069 obstack_begin (&temporary_obstack, 0);
1070 temporary_firstobj = (char *) obstack_alloc (&temporary_obstack, 0);
1072 #ifndef HAVE_LD_DEMANGLE
1073 current_demangling_style = auto_demangling;
1074 #endif
1075 p = getenv ("COLLECT_GCC_OPTIONS");
1076 while (p && *p)
1078 const char *q = extract_string (&p);
1079 if (*q == '-' && (q[1] == 'm' || q[1] == 'f'))
1080 num_c_args++;
1082 obstack_free (&temporary_obstack, temporary_firstobj);
1084 /* -fno-profile-arcs -fno-test-coverage -fno-branch-probabilities
1085 -fno-exceptions -w -fno-whole-program */
1086 num_c_args += 6;
1088 c_argv = XCNEWVEC (char *, num_c_args);
1089 c_ptr = CONST_CAST2 (const char **, char **, c_argv);
1091 if (argc < 2)
1092 fatal_error ("no arguments");
1094 #ifdef SIGQUIT
1095 if (signal (SIGQUIT, SIG_IGN) != SIG_IGN)
1096 signal (SIGQUIT, handler);
1097 #endif
1098 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
1099 signal (SIGINT, handler);
1100 #ifdef SIGALRM
1101 if (signal (SIGALRM, SIG_IGN) != SIG_IGN)
1102 signal (SIGALRM, handler);
1103 #endif
1104 #ifdef SIGHUP
1105 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
1106 signal (SIGHUP, handler);
1107 #endif
1108 if (signal (SIGSEGV, SIG_IGN) != SIG_IGN)
1109 signal (SIGSEGV, handler);
1110 #ifdef SIGBUS
1111 if (signal (SIGBUS, SIG_IGN) != SIG_IGN)
1112 signal (SIGBUS, handler);
1113 #endif
1115 /* Extract COMPILER_PATH and PATH into our prefix list. */
1116 prefix_from_env ("COMPILER_PATH", &cpath);
1117 prefix_from_env ("PATH", &path);
1119 /* Try to discover a valid linker/nm/strip to use. */
1121 /* Maybe we know the right file to use (if not cross). */
1122 ld_file_name = 0;
1123 #ifdef DEFAULT_LINKER
1124 if (access (DEFAULT_LINKER, X_OK) == 0)
1125 ld_file_name = DEFAULT_LINKER;
1126 if (ld_file_name == 0)
1127 #endif
1128 #ifdef REAL_LD_FILE_NAME
1129 ld_file_name = find_a_file (&path, REAL_LD_FILE_NAME, X_OK);
1130 if (ld_file_name == 0)
1131 #endif
1132 /* Search the (target-specific) compiler dirs for ld'. */
1133 ld_file_name = find_a_file (&cpath, real_ld_suffix, X_OK);
1134 /* Likewise for `collect-ld'. */
1135 if (ld_file_name == 0)
1137 ld_file_name = find_a_file (&cpath, collect_ld_suffix, X_OK);
1138 use_collect_ld = ld_file_name != 0;
1140 /* Search the compiler directories for `ld'. We have protection against
1141 recursive calls in find_a_file. */
1142 if (ld_file_name == 0)
1143 ld_file_name = find_a_file (&cpath, ld_suffixes[selected_linker], X_OK);
1144 /* Search the ordinary system bin directories
1145 for `ld' (if native linking) or `TARGET-ld' (if cross). */
1146 if (ld_file_name == 0)
1147 ld_file_name = find_a_file (&path, full_ld_suffixes[selected_linker], X_OK);
1149 #ifdef REAL_NM_FILE_NAME
1150 nm_file_name = find_a_file (&path, REAL_NM_FILE_NAME, X_OK);
1151 if (nm_file_name == 0)
1152 #endif
1153 nm_file_name = find_a_file (&cpath, gnm_suffix, X_OK);
1154 if (nm_file_name == 0)
1155 nm_file_name = find_a_file (&path, full_gnm_suffix, X_OK);
1156 if (nm_file_name == 0)
1157 nm_file_name = find_a_file (&cpath, nm_suffix, X_OK);
1158 if (nm_file_name == 0)
1159 nm_file_name = find_a_file (&path, full_nm_suffix, X_OK);
1161 #ifdef LDD_SUFFIX
1162 ldd_file_name = find_a_file (&cpath, ldd_suffix, X_OK);
1163 if (ldd_file_name == 0)
1164 ldd_file_name = find_a_file (&path, full_ldd_suffix, X_OK);
1165 #endif
1167 #ifdef REAL_STRIP_FILE_NAME
1168 strip_file_name = find_a_file (&path, REAL_STRIP_FILE_NAME, X_OK);
1169 if (strip_file_name == 0)
1170 #endif
1171 strip_file_name = find_a_file (&cpath, gstrip_suffix, X_OK);
1172 if (strip_file_name == 0)
1173 strip_file_name = find_a_file (&path, full_gstrip_suffix, X_OK);
1174 if (strip_file_name == 0)
1175 strip_file_name = find_a_file (&cpath, strip_suffix, X_OK);
1176 if (strip_file_name == 0)
1177 strip_file_name = find_a_file (&path, full_strip_suffix, X_OK);
1179 /* Determine the full path name of the C compiler to use. */
1180 c_file_name = getenv ("COLLECT_GCC");
1181 if (c_file_name == 0)
1183 #ifdef CROSS_DIRECTORY_STRUCTURE
1184 c_file_name = concat (target_machine, "-gcc", NULL);
1185 #else
1186 c_file_name = "gcc";
1187 #endif
1190 p = find_a_file (&cpath, c_file_name, X_OK);
1192 /* Here it should be safe to use the system search path since we should have
1193 already qualified the name of the compiler when it is needed. */
1194 if (p == 0)
1195 p = find_a_file (&path, c_file_name, X_OK);
1197 if (p)
1198 c_file_name = p;
1200 *ld1++ = *ld2++ = ld_file_name;
1202 /* Make temp file names. */
1203 c_file = make_temp_file (".c");
1204 o_file = make_temp_file (".o");
1205 #ifdef COLLECT_EXPORT_LIST
1206 export_file = make_temp_file (".x");
1207 #endif
1208 if (!debug)
1210 ldout = make_temp_file (".ld");
1211 lderrout = make_temp_file (".le");
1213 *c_ptr++ = c_file_name;
1214 *c_ptr++ = "-x";
1215 *c_ptr++ = "c";
1216 *c_ptr++ = "-c";
1217 *c_ptr++ = "-o";
1218 *c_ptr++ = o_file;
1220 #ifdef COLLECT_EXPORT_LIST
1221 /* Generate a list of directories from LIBPATH. */
1222 prefix_from_env ("LIBPATH", &libpath_lib_dirs);
1223 /* Add to this list also two standard directories where
1224 AIX loader always searches for libraries. */
1225 add_prefix (&libpath_lib_dirs, "/lib");
1226 add_prefix (&libpath_lib_dirs, "/usr/lib");
1227 #endif
1229 /* Get any options that the upper GCC wants to pass to the sub-GCC.
1231 AIX support needs to know if -shared has been specified before
1232 parsing commandline arguments. */
1234 p = getenv ("COLLECT_GCC_OPTIONS");
1235 while (p && *p)
1237 const char *q = extract_string (&p);
1238 if (*q == '-' && (q[1] == 'm' || q[1] == 'f'))
1239 *c_ptr++ = xstrdup (q);
1240 if (strcmp (q, "-EL") == 0 || strcmp (q, "-EB") == 0)
1241 *c_ptr++ = xstrdup (q);
1242 if (strcmp (q, "-shared") == 0)
1243 shared_obj = 1;
1244 if (*q == '-' && q[1] == 'B')
1246 *c_ptr++ = xstrdup (q);
1247 if (q[2] == 0)
1249 q = extract_string (&p);
1250 *c_ptr++ = xstrdup (q);
1254 obstack_free (&temporary_obstack, temporary_firstobj);
1255 *c_ptr++ = "-fno-profile-arcs";
1256 *c_ptr++ = "-fno-test-coverage";
1257 *c_ptr++ = "-fno-branch-probabilities";
1258 *c_ptr++ = "-fno-exceptions";
1259 *c_ptr++ = "-w";
1260 *c_ptr++ = "-fno-whole-program";
1262 /* !!! When GCC calls collect2,
1263 it does not know whether it is calling collect2 or ld.
1264 So collect2 cannot meaningfully understand any options
1265 except those ld understands.
1266 If you propose to make GCC pass some other option,
1267 just imagine what will happen if ld is really ld!!! */
1269 /* Parse arguments. Remember output file spec, pass the rest to ld. */
1270 /* After the first file, put in the c++ rt0. */
1272 first_file = 1;
1273 while ((arg = *++argv) != (char *) 0)
1275 *ld1++ = *ld2++ = arg;
1277 if (arg[0] == '-')
1279 switch (arg[1])
1281 case 'd':
1282 if (!strcmp (arg, "-debug"))
1284 /* Already parsed. */
1285 ld1--;
1286 ld2--;
1288 if (!strcmp (arg, "-dynamic-linker") && argv[1])
1290 ++argv;
1291 *ld1++ = *ld2++ = *argv;
1293 break;
1295 case 'f':
1296 if (strncmp (arg, "-flto", 5) == 0)
1298 #ifdef ENABLE_LTO
1299 /* Do not pass LTO flag to the linker. */
1300 ld1--;
1301 ld2--;
1302 #else
1303 error ("LTO support has not been enabled in this "
1304 "configuration");
1305 #endif
1307 else if (!use_collect_ld
1308 && strncmp (arg, "-fuse-ld=", 9) == 0)
1310 /* Do not pass -fuse-ld={bfd|gold} to the linker. */
1311 ld1--;
1312 ld2--;
1314 #ifdef TARGET_AIX_VERSION
1315 else
1317 /* File containing a list of input files to process. */
1319 FILE *stream;
1320 char buf[MAXPATHLEN + 2];
1321 /* Number of additionnal object files. */
1322 int add_nbr = 0;
1323 /* Maximum of additionnal object files before vector
1324 expansion. */
1325 int add_max = 0;
1326 const char *list_filename = arg + 2;
1328 /* Accept -fFILENAME and -f FILENAME. */
1329 if (*list_filename == '\0' && argv[1])
1331 ++argv;
1332 list_filename = *argv;
1333 *ld1++ = *ld2++ = *argv;
1336 stream = fopen (list_filename, "r");
1337 if (stream == NULL)
1338 fatal_error ("can't open %s: %m", list_filename);
1340 while (fgets (buf, sizeof buf, stream) != NULL)
1342 /* Remove end of line. */
1343 int len = strlen (buf);
1344 if (len >= 1 && buf[len - 1] =='\n')
1345 buf[len - 1] = '\0';
1347 /* Put on object vector.
1348 Note: we only expanse vector here, so we must keep
1349 extra space for remaining arguments. */
1350 if (add_nbr >= add_max)
1352 int pos =
1353 object - CONST_CAST2 (const char **, char **,
1354 object_lst);
1355 add_max = (add_max == 0) ? 16 : add_max * 2;
1356 object_lst = XRESIZEVEC (char *, object_lst,
1357 object_nbr + add_max);
1358 object = CONST_CAST2 (const char **, char **,
1359 object_lst) + pos;
1360 object_nbr += add_max;
1362 *object++ = xstrdup (buf);
1363 add_nbr++;
1365 fclose (stream);
1367 #endif
1368 break;
1370 case 'l':
1371 if (first_file)
1373 /* place o_file BEFORE this argument! */
1374 first_file = 0;
1375 ld2--;
1376 *ld2++ = o_file;
1377 *ld2++ = arg;
1379 #ifdef COLLECT_EXPORT_LIST
1381 /* Resolving full library name. */
1382 const char *s = resolve_lib_name (arg+2);
1384 /* Saving a full library name. */
1385 add_to_list (&libs, s);
1387 #endif
1388 break;
1390 #ifdef COLLECT_EXPORT_LIST
1391 /* Saving directories where to search for libraries. */
1392 case 'L':
1393 add_prefix (&cmdline_lib_dirs, arg+2);
1394 break;
1395 #endif
1397 case 'o':
1398 if (arg[2] == '\0')
1399 output_file = *ld1++ = *ld2++ = *++argv;
1400 else
1401 output_file = &arg[2];
1402 break;
1404 case 'r':
1405 if (arg[2] == '\0')
1406 rflag = 1;
1407 break;
1409 case 's':
1410 if (arg[2] == '\0' && do_collecting)
1412 /* We must strip after the nm run, otherwise C++ linking
1413 will not work. Thus we strip in the second ld run, or
1414 else with strip if there is no second ld run. */
1415 strip_flag = 1;
1416 ld1--;
1418 break;
1420 case 'v':
1421 if (arg[2] == '\0')
1422 vflag = true;
1423 break;
1425 case '-':
1426 if (strcmp (arg, "--no-demangle") == 0)
1428 #ifndef HAVE_LD_DEMANGLE
1429 no_demangle = 1;
1430 ld1--;
1431 ld2--;
1432 #endif
1434 else if (strncmp (arg, "--demangle", 10) == 0)
1436 #ifndef HAVE_LD_DEMANGLE
1437 no_demangle = 0;
1438 if (arg[10] == '=')
1440 enum demangling_styles style
1441 = cplus_demangle_name_to_style (arg+11);
1442 if (style == unknown_demangling)
1443 error ("unknown demangling style '%s'", arg+11);
1444 else
1445 current_demangling_style = style;
1447 ld1--;
1448 ld2--;
1449 #endif
1451 else if (strncmp (arg, "--sysroot=", 10) == 0)
1452 target_system_root = arg + 10;
1453 else if (strcmp (arg, "--version") == 0)
1454 vflag = true;
1455 else if (strcmp (arg, "--help") == 0)
1456 helpflag = true;
1457 break;
1460 else if ((p = strrchr (arg, '.')) != (char *) 0
1461 && (strcmp (p, ".o") == 0 || strcmp (p, ".a") == 0
1462 || strcmp (p, ".so") == 0 || strcmp (p, ".lo") == 0
1463 || strcmp (p, ".obj") == 0))
1465 if (first_file)
1467 first_file = 0;
1468 if (p[1] == 'o')
1469 *ld2++ = o_file;
1470 else
1472 /* place o_file BEFORE this argument! */
1473 ld2--;
1474 *ld2++ = o_file;
1475 *ld2++ = arg;
1478 if (p[1] == 'o' || p[1] == 'l')
1479 *object++ = arg;
1480 #ifdef COLLECT_EXPORT_LIST
1481 /* libraries can be specified directly, i.e. without -l flag. */
1482 else
1484 /* Saving a full library name. */
1485 add_to_list (&libs, arg);
1487 #endif
1491 #ifdef COLLECT_EXPORT_LIST
1492 /* This is added only for debugging purposes. */
1493 if (debug)
1495 fprintf (stderr, "List of libraries:\n");
1496 dump_list (stderr, "\t", libs.first);
1499 /* The AIX linker will discard static constructors in object files if
1500 nothing else in the file is referenced, so look at them first. Unless
1501 we are building a shared object, ignore the eh frame tables, as we
1502 would otherwise reference them all, hence drag all the corresponding
1503 objects even if nothing else is referenced. */
1505 const char **export_object_lst
1506 = CONST_CAST2 (const char **, char **, object_lst);
1508 struct id *list = libs.first;
1510 /* Compute the filter to use from the current one, do scan, then adjust
1511 the "current" filter to remove what we just included here. This will
1512 control whether we need a first pass link later on or not, and what
1513 will remain to be scanned there. */
1515 scanfilter this_filter = ld1_filter;
1516 #if HAVE_AS_REF
1517 if (!shared_obj)
1518 this_filter &= ~SCAN_DWEH;
1519 #endif
1521 while (export_object_lst < object)
1522 scan_prog_file (*export_object_lst++, PASS_OBJ, this_filter);
1524 for (; list; list = list->next)
1525 scan_prog_file (list->name, PASS_FIRST, this_filter);
1527 ld1_filter = ld1_filter & ~this_filter;
1530 if (exports.first)
1532 char *buf = concat ("-bE:", export_file, NULL);
1534 *ld1++ = buf;
1535 *ld2++ = buf;
1537 exportf = fopen (export_file, "w");
1538 if (exportf == (FILE *) 0)
1539 fatal_error ("fopen %s: %m", export_file);
1540 write_aix_file (exportf, exports.first);
1541 if (fclose (exportf))
1542 fatal_error ("fclose %s: %m", export_file);
1544 #endif
1546 *c_ptr++ = c_file;
1547 *c_ptr = *ld1 = *object = (char *) 0;
1549 if (vflag)
1550 notice ("collect2 version %s\n", version_string);
1552 if (helpflag)
1554 printf ("Usage: collect2 [options]\n");
1555 printf (" Wrap linker and generate constructor code if needed.\n");
1556 printf (" Options:\n");
1557 printf (" -debug Enable debug output\n");
1558 printf (" --help Display this information\n");
1559 printf (" -v, --version Display this program's version number\n");
1560 printf ("\n");
1561 printf ("Overview: http://gcc.gnu.org/onlinedocs/gccint/Collect2.html\n");
1562 printf ("Report bugs: %s\n", bug_report_url);
1563 printf ("\n");
1566 if (debug)
1568 const char *ptr;
1569 fprintf (stderr, "ld_file_name = %s\n",
1570 (ld_file_name ? ld_file_name : "not found"));
1571 fprintf (stderr, "c_file_name = %s\n",
1572 (c_file_name ? c_file_name : "not found"));
1573 fprintf (stderr, "nm_file_name = %s\n",
1574 (nm_file_name ? nm_file_name : "not found"));
1575 #ifdef LDD_SUFFIX
1576 fprintf (stderr, "ldd_file_name = %s\n",
1577 (ldd_file_name ? ldd_file_name : "not found"));
1578 #endif
1579 fprintf (stderr, "strip_file_name = %s\n",
1580 (strip_file_name ? strip_file_name : "not found"));
1581 fprintf (stderr, "c_file = %s\n",
1582 (c_file ? c_file : "not found"));
1583 fprintf (stderr, "o_file = %s\n",
1584 (o_file ? o_file : "not found"));
1586 ptr = getenv ("COLLECT_GCC_OPTIONS");
1587 if (ptr)
1588 fprintf (stderr, "COLLECT_GCC_OPTIONS = %s\n", ptr);
1590 ptr = getenv ("COLLECT_GCC");
1591 if (ptr)
1592 fprintf (stderr, "COLLECT_GCC = %s\n", ptr);
1594 ptr = getenv ("COMPILER_PATH");
1595 if (ptr)
1596 fprintf (stderr, "COMPILER_PATH = %s\n", ptr);
1598 ptr = getenv (LIBRARY_PATH_ENV);
1599 if (ptr)
1600 fprintf (stderr, "%-20s= %s\n", LIBRARY_PATH_ENV, ptr);
1602 fprintf (stderr, "\n");
1605 /* Load the program, searching all libraries and attempting to provide
1606 undefined symbols from repository information.
1608 If -r or they will be run via some other method, do not build the
1609 constructor or destructor list, just return now. */
1611 bool early_exit
1612 = rflag || (! DO_COLLECT_EXPORT_LIST && ! do_collecting);
1614 /* Perform the first pass link now, if we're about to exit or if we need
1615 to scan for things we haven't collected yet before pursuing further.
1617 On AIX, the latter typically includes nothing for shared objects or
1618 frame tables for an executable, out of what the required early scan on
1619 objects and libraries has performed above. In the !shared_obj case, we
1620 expect the relevant tables to be dragged together with their associated
1621 functions from precise cross reference insertions by the compiler. */
1623 if (early_exit || ld1_filter != SCAN_NOTHING)
1624 do_tlink (ld1_argv, object_lst);
1626 if (early_exit)
1628 #ifdef COLLECT_EXPORT_LIST
1629 /* Make sure we delete the export file we may have created. */
1630 if (export_file != 0 && export_file[0])
1631 maybe_unlink (export_file);
1632 #endif
1633 if (lto_mode != LTO_MODE_NONE)
1634 maybe_run_lto_and_relink (ld1_argv, object_lst, object, false);
1635 else
1636 post_ld_pass (false);
1638 maybe_unlink (c_file);
1639 maybe_unlink (o_file);
1640 return 0;
1644 /* Unless we have done it all already, examine the namelist and search for
1645 static constructors and destructors to call. Write the constructor and
1646 destructor tables to a .s file and reload. */
1648 if (ld1_filter != SCAN_NOTHING)
1649 scan_prog_file (output_file, PASS_FIRST, ld1_filter);
1651 #ifdef SCAN_LIBRARIES
1652 scan_libraries (output_file);
1653 #endif
1655 if (debug)
1657 notice_translated (ngettext ("%d constructor found\n",
1658 "%d constructors found\n",
1659 constructors.number),
1660 constructors.number);
1661 notice_translated (ngettext ("%d destructor found\n",
1662 "%d destructors found\n",
1663 destructors.number),
1664 destructors.number);
1665 notice_translated (ngettext ("%d frame table found\n",
1666 "%d frame tables found\n",
1667 frame_tables.number),
1668 frame_tables.number);
1671 /* If the scan exposed nothing of special interest, there's no need to
1672 generate the glue code and relink so return now. */
1674 if (constructors.number == 0 && destructors.number == 0
1675 && frame_tables.number == 0
1676 #if defined (SCAN_LIBRARIES) || defined (COLLECT_EXPORT_LIST)
1677 /* If we will be running these functions ourselves, we want to emit
1678 stubs into the shared library so that we do not have to relink
1679 dependent programs when we add static objects. */
1680 && ! shared_obj
1681 #endif
1684 /* Do tlink without additional code generation now if we didn't
1685 do it earlier for scanning purposes. */
1686 if (ld1_filter == SCAN_NOTHING)
1687 do_tlink (ld1_argv, object_lst);
1689 if (lto_mode)
1690 maybe_run_lto_and_relink (ld1_argv, object_lst, object, false);
1692 /* Strip now if it was requested on the command line. */
1693 if (strip_flag)
1695 char **real_strip_argv = XCNEWVEC (char *, 3);
1696 const char ** strip_argv = CONST_CAST2 (const char **, char **,
1697 real_strip_argv);
1699 strip_argv[0] = strip_file_name;
1700 strip_argv[1] = output_file;
1701 strip_argv[2] = (char *) 0;
1702 fork_execute ("strip", real_strip_argv);
1705 #ifdef COLLECT_EXPORT_LIST
1706 maybe_unlink (export_file);
1707 #endif
1708 post_ld_pass (false);
1710 maybe_unlink (c_file);
1711 maybe_unlink (o_file);
1712 return 0;
1715 /* Sort ctor and dtor lists by priority. */
1716 sort_ids (&constructors);
1717 sort_ids (&destructors);
1719 maybe_unlink (output_file);
1720 outf = fopen (c_file, "w");
1721 if (outf == (FILE *) 0)
1722 fatal_error ("fopen %s: %m", c_file);
1724 write_c_file (outf, c_file);
1726 if (fclose (outf))
1727 fatal_error ("fclose %s: %m", c_file);
1729 /* Tell the linker that we have initializer and finalizer functions. */
1730 #ifdef LD_INIT_SWITCH
1731 #ifdef COLLECT_EXPORT_LIST
1732 *ld2++ = concat (LD_INIT_SWITCH, ":", initname, ":", fininame, NULL);
1733 #else
1734 *ld2++ = LD_INIT_SWITCH;
1735 *ld2++ = initname;
1736 *ld2++ = LD_FINI_SWITCH;
1737 *ld2++ = fininame;
1738 #endif
1739 #endif
1741 #ifdef COLLECT_EXPORT_LIST
1742 if (shared_obj)
1744 /* If we did not add export flag to link arguments before, add it to
1745 second link phase now. No new exports should have been added. */
1746 if (! exports.first)
1747 *ld2++ = concat ("-bE:", export_file, NULL);
1749 #ifdef TARGET_AIX_VERSION
1750 add_to_list (&exports, aix_shared_initname);
1751 add_to_list (&exports, aix_shared_fininame);
1752 #endif
1754 #ifndef LD_INIT_SWITCH
1755 add_to_list (&exports, initname);
1756 add_to_list (&exports, fininame);
1757 add_to_list (&exports, "_GLOBAL__DI");
1758 add_to_list (&exports, "_GLOBAL__DD");
1759 #endif
1760 exportf = fopen (export_file, "w");
1761 if (exportf == (FILE *) 0)
1762 fatal_error ("fopen %s: %m", export_file);
1763 write_aix_file (exportf, exports.first);
1764 if (fclose (exportf))
1765 fatal_error ("fclose %s: %m", export_file);
1767 #endif
1769 /* End of arguments to second link phase. */
1770 *ld2 = (char*) 0;
1772 if (debug)
1774 fprintf (stderr, "\n========== output_file = %s, c_file = %s\n",
1775 output_file, c_file);
1776 write_c_file (stderr, "stderr");
1777 fprintf (stderr, "========== end of c_file\n\n");
1778 #ifdef COLLECT_EXPORT_LIST
1779 fprintf (stderr, "\n========== export_file = %s\n", export_file);
1780 write_aix_file (stderr, exports.first);
1781 fprintf (stderr, "========== end of export_file\n\n");
1782 #endif
1785 /* Assemble the constructor and destructor tables.
1786 Link the tables in with the rest of the program. */
1788 fork_execute ("gcc", c_argv);
1789 #ifdef COLLECT_EXPORT_LIST
1790 /* On AIX we must call tlink because of possible templates resolution. */
1791 do_tlink (ld2_argv, object_lst);
1793 if (lto_mode)
1794 maybe_run_lto_and_relink (ld2_argv, object_lst, object, false);
1795 #else
1796 /* Otherwise, simply call ld because tlink is already done. */
1797 if (lto_mode)
1798 maybe_run_lto_and_relink (ld2_argv, object_lst, object, true);
1799 else
1801 fork_execute ("ld", ld2_argv);
1802 post_ld_pass (false);
1805 /* Let scan_prog_file do any final mods (OSF/rose needs this for
1806 constructors/destructors in shared libraries. */
1807 scan_prog_file (output_file, PASS_SECOND, SCAN_ALL);
1808 #endif
1810 maybe_unlink (c_file);
1811 maybe_unlink (o_file);
1813 #ifdef COLLECT_EXPORT_LIST
1814 maybe_unlink (export_file);
1815 #endif
1817 return 0;
1821 /* Wait for a process to finish, and exit if a nonzero status is found. */
1824 collect_wait (const char *prog, struct pex_obj *pex)
1826 int status;
1828 if (!pex_get_status (pex, 1, &status))
1829 fatal_error ("can't get program status: %m");
1830 pex_free (pex);
1832 if (status)
1834 if (WIFSIGNALED (status))
1836 int sig = WTERMSIG (status);
1837 error ("%s terminated with signal %d [%s]%s",
1838 prog, sig, strsignal (sig),
1839 WCOREDUMP (status) ? ", core dumped" : "");
1840 exit (FATAL_EXIT_CODE);
1843 if (WIFEXITED (status))
1844 return WEXITSTATUS (status);
1846 return 0;
1849 static void
1850 do_wait (const char *prog, struct pex_obj *pex)
1852 int ret = collect_wait (prog, pex);
1853 if (ret != 0)
1855 error ("%s returned %d exit status", prog, ret);
1856 exit (ret);
1859 if (response_file)
1861 unlink (response_file);
1862 response_file = NULL;
1867 /* Execute a program, and wait for the reply. */
1869 struct pex_obj *
1870 collect_execute (const char *prog, char **argv, const char *outname,
1871 const char *errname, int flags)
1873 struct pex_obj *pex;
1874 const char *errmsg;
1875 int err;
1876 char *response_arg = NULL;
1877 char *response_argv[3] ATTRIBUTE_UNUSED;
1879 if (HAVE_GNU_LD && at_file_supplied && argv[0] != NULL)
1881 /* If using @file arguments, create a temporary file and put the
1882 contents of argv into it. Then change argv to an array corresponding
1883 to a single argument @FILE, where FILE is the temporary filename. */
1885 char **current_argv = argv + 1;
1886 char *argv0 = argv[0];
1887 int status;
1888 FILE *f;
1890 /* Note: we assume argv contains at least one element; this is
1891 checked above. */
1893 response_file = make_temp_file ("");
1895 f = fopen (response_file, "w");
1897 if (f == NULL)
1898 fatal_error ("could not open response file %s", response_file);
1900 status = writeargv (current_argv, f);
1902 if (status)
1903 fatal_error ("could not write to response file %s", response_file);
1905 status = fclose (f);
1907 if (EOF == status)
1908 fatal_error ("could not close response file %s", response_file);
1910 response_arg = concat ("@", response_file, NULL);
1911 response_argv[0] = argv0;
1912 response_argv[1] = response_arg;
1913 response_argv[2] = NULL;
1915 argv = response_argv;
1918 if (vflag || debug)
1920 char **p_argv;
1921 const char *str;
1923 if (argv[0])
1924 fprintf (stderr, "%s", argv[0]);
1925 else
1926 notice ("[cannot find %s]", prog);
1928 for (p_argv = &argv[1]; (str = *p_argv) != (char *) 0; p_argv++)
1929 fprintf (stderr, " %s", str);
1931 fprintf (stderr, "\n");
1934 fflush (stdout);
1935 fflush (stderr);
1937 /* If we cannot find a program we need, complain error. Do this here
1938 since we might not end up needing something that we could not find. */
1940 if (argv[0] == 0)
1941 fatal_error ("cannot find '%s'", prog);
1943 pex = pex_init (0, "collect2", NULL);
1944 if (pex == NULL)
1945 fatal_error ("pex_init failed: %m");
1947 errmsg = pex_run (pex, flags, argv[0], argv, outname,
1948 errname, &err);
1949 if (errmsg != NULL)
1951 if (err != 0)
1953 errno = err;
1954 fatal_error ("%s: %m", _(errmsg));
1956 else
1957 fatal_error (errmsg);
1960 free (response_arg);
1962 return pex;
1965 static void
1966 fork_execute (const char *prog, char **argv)
1968 struct pex_obj *pex;
1970 pex = collect_execute (prog, argv, NULL, NULL, PEX_LAST | PEX_SEARCH);
1971 do_wait (prog, pex);
1974 /* Unlink FILE unless we are debugging or this is the output_file
1975 and we may not unlink it. */
1977 static void
1978 maybe_unlink (const char *file)
1980 if (debug)
1982 notice ("[Leaving %s]\n", file);
1983 return;
1986 if (file == output_file && !may_unlink_output_file)
1987 return;
1989 unlink_if_ordinary (file);
1992 /* Call maybe_unlink on the NULL-terminated list, FILE_LIST. */
1994 static void
1995 maybe_unlink_list (char **file_list)
1997 char **tmp = file_list;
1999 while (*tmp)
2000 maybe_unlink (*(tmp++));
2004 static long sequence_number = 0;
2006 /* Add a name to a linked list. */
2008 static void
2009 add_to_list (struct head *head_ptr, const char *name)
2011 struct id *newid
2012 = (struct id *) xcalloc (sizeof (struct id) + strlen (name), 1);
2013 struct id *p;
2014 strcpy (newid->name, name);
2016 if (head_ptr->first)
2017 head_ptr->last->next = newid;
2018 else
2019 head_ptr->first = newid;
2021 /* Check for duplicate symbols. */
2022 for (p = head_ptr->first;
2023 strcmp (name, p->name) != 0;
2024 p = p->next)
2026 if (p != newid)
2028 head_ptr->last->next = 0;
2029 free (newid);
2030 return;
2033 newid->sequence = ++sequence_number;
2034 head_ptr->last = newid;
2035 head_ptr->number++;
2038 /* Grab the init priority number from an init function name that
2039 looks like "_GLOBAL_.I.12345.foo". */
2041 static int
2042 extract_init_priority (const char *name)
2044 int pos = 0, pri;
2046 #ifdef TARGET_AIX_VERSION
2047 /* Run dependent module initializers before any constructors in this
2048 module. */
2049 switch (is_ctor_dtor (name))
2051 case SYM_AIXI:
2052 case SYM_AIXD:
2053 return INT_MIN;
2054 default:
2055 break;
2057 #endif
2059 while (name[pos] == '_')
2060 ++pos;
2061 pos += 10; /* strlen ("GLOBAL__X_") */
2063 /* Extract init_p number from ctor/dtor name. */
2064 pri = atoi (name + pos);
2065 return pri ? pri : DEFAULT_INIT_PRIORITY;
2068 /* Insertion sort the ids from ctor/dtor list HEAD_PTR in descending order.
2069 ctors will be run from right to left, dtors from left to right. */
2071 static void
2072 sort_ids (struct head *head_ptr)
2074 /* id holds the current element to insert. id_next holds the next
2075 element to insert. id_ptr iterates through the already sorted elements
2076 looking for the place to insert id. */
2077 struct id *id, *id_next, **id_ptr;
2079 id = head_ptr->first;
2081 /* We don't have any sorted elements yet. */
2082 head_ptr->first = NULL;
2084 for (; id; id = id_next)
2086 id_next = id->next;
2087 id->sequence = extract_init_priority (id->name);
2089 for (id_ptr = &(head_ptr->first); ; id_ptr = &((*id_ptr)->next))
2090 if (*id_ptr == NULL
2091 /* If the sequence numbers are the same, we put the id from the
2092 file later on the command line later in the list. */
2093 || id->sequence > (*id_ptr)->sequence
2094 /* Hack: do lexical compare, too.
2095 || (id->sequence == (*id_ptr)->sequence
2096 && strcmp (id->name, (*id_ptr)->name) > 0) */
2099 id->next = *id_ptr;
2100 *id_ptr = id;
2101 break;
2105 /* Now set the sequence numbers properly so write_c_file works. */
2106 for (id = head_ptr->first; id; id = id->next)
2107 id->sequence = ++sequence_number;
2110 /* Write: `prefix', the names on list LIST, `suffix'. */
2112 static void
2113 write_list (FILE *stream, const char *prefix, struct id *list)
2115 while (list)
2117 fprintf (stream, "%sx%d,\n", prefix, list->sequence);
2118 list = list->next;
2122 #ifdef COLLECT_EXPORT_LIST
2123 /* This function is really used only on AIX, but may be useful. */
2124 #if 0
2125 static int
2126 is_in_list (const char *prefix, struct id *list)
2128 while (list)
2130 if (!strcmp (prefix, list->name)) return 1;
2131 list = list->next;
2133 return 0;
2135 #endif
2136 #endif /* COLLECT_EXPORT_LIST */
2138 /* Added for debugging purpose. */
2139 #ifdef COLLECT_EXPORT_LIST
2140 static void
2141 dump_list (FILE *stream, const char *prefix, struct id *list)
2143 while (list)
2145 fprintf (stream, "%s%s,\n", prefix, list->name);
2146 list = list->next;
2149 #endif
2151 #if 0
2152 static void
2153 dump_prefix_list (FILE *stream, const char *prefix, struct prefix_list *list)
2155 while (list)
2157 fprintf (stream, "%s%s,\n", prefix, list->prefix);
2158 list = list->next;
2161 #endif
2163 static void
2164 write_list_with_asm (FILE *stream, const char *prefix, struct id *list)
2166 while (list)
2168 fprintf (stream, "%sx%d __asm__ (\"%s\");\n",
2169 prefix, list->sequence, list->name);
2170 list = list->next;
2174 /* Write out the constructor and destructor tables statically (for a shared
2175 object), along with the functions to execute them. */
2177 static void
2178 write_c_file_stat (FILE *stream, const char *name ATTRIBUTE_UNUSED)
2180 const char *p, *q;
2181 char *prefix, *r;
2182 int frames = (frame_tables.number > 0);
2184 /* Figure out name of output_file, stripping off .so version. */
2185 q = p = lbasename (output_file);
2187 while (q)
2189 q = strchr (q,'.');
2190 if (q == 0)
2192 q = p + strlen (p);
2193 break;
2195 else
2197 if (filename_ncmp (q, SHLIB_SUFFIX, strlen (SHLIB_SUFFIX)) == 0)
2199 q += strlen (SHLIB_SUFFIX);
2200 break;
2202 else
2203 q++;
2206 /* q points to null at end of the string (or . of the .so version) */
2207 prefix = XNEWVEC (char, q - p + 1);
2208 strncpy (prefix, p, q - p);
2209 prefix[q - p] = 0;
2210 for (r = prefix; *r; r++)
2211 if (!ISALNUM ((unsigned char)*r))
2212 *r = '_';
2213 if (debug)
2214 notice ("\nwrite_c_file - output name is %s, prefix is %s\n",
2215 output_file, prefix);
2217 initname = concat ("_GLOBAL__FI_", prefix, NULL);
2218 fininame = concat ("_GLOBAL__FD_", prefix, NULL);
2219 #ifdef TARGET_AIX_VERSION
2220 aix_shared_initname = concat ("_GLOBAL__AIXI_", prefix, NULL);
2221 aix_shared_fininame = concat ("_GLOBAL__AIXD_", prefix, NULL);
2222 #endif
2224 free (prefix);
2226 /* Write the tables as C code. */
2228 /* This count variable is used to prevent multiple calls to the
2229 constructors/destructors.
2230 This guard against multiple calls is important on AIX as the initfini
2231 functions are deliberately invoked multiple times as part of the
2232 mechanisms GCC uses to order constructors across different dependent
2233 shared libraries (see config/rs6000/aix.h).
2235 fprintf (stream, "static int count;\n");
2236 fprintf (stream, "typedef void entry_pt();\n");
2237 write_list_with_asm (stream, "extern entry_pt ", constructors.first);
2239 if (frames)
2241 write_list_with_asm (stream, "extern void *", frame_tables.first);
2243 fprintf (stream, "\tstatic void *frame_table[] = {\n");
2244 write_list (stream, "\t\t&", frame_tables.first);
2245 fprintf (stream, "\t0\n};\n");
2247 /* This must match what's in frame.h. */
2248 fprintf (stream, "struct object {\n");
2249 fprintf (stream, " void *pc_begin;\n");
2250 fprintf (stream, " void *pc_end;\n");
2251 fprintf (stream, " void *fde_begin;\n");
2252 fprintf (stream, " void *fde_array;\n");
2253 fprintf (stream, " __SIZE_TYPE__ count;\n");
2254 fprintf (stream, " struct object *next;\n");
2255 fprintf (stream, "};\n");
2257 fprintf (stream, "extern void __register_frame_info_table (void *, struct object *);\n");
2258 fprintf (stream, "extern void *__deregister_frame_info (void *);\n");
2260 fprintf (stream, "static void reg_frame () {\n");
2261 fprintf (stream, "\tstatic struct object ob;\n");
2262 fprintf (stream, "\t__register_frame_info_table (frame_table, &ob);\n");
2263 fprintf (stream, "\t}\n");
2265 fprintf (stream, "static void dereg_frame () {\n");
2266 fprintf (stream, "\t__deregister_frame_info (frame_table);\n");
2267 fprintf (stream, "\t}\n");
2270 fprintf (stream, "void %s() {\n", initname);
2271 if (constructors.number > 0 || frames)
2273 fprintf (stream, "\tstatic entry_pt *ctors[] = {\n");
2274 write_list (stream, "\t\t", constructors.first);
2275 if (frames)
2276 fprintf (stream, "\treg_frame,\n");
2277 fprintf (stream, "\t};\n");
2278 fprintf (stream, "\tentry_pt **p;\n");
2279 fprintf (stream, "\tif (count++ != 0) return;\n");
2280 fprintf (stream, "\tp = ctors + %d;\n", constructors.number + frames);
2281 fprintf (stream, "\twhile (p > ctors) (*--p)();\n");
2283 else
2284 fprintf (stream, "\t++count;\n");
2285 fprintf (stream, "}\n");
2286 write_list_with_asm (stream, "extern entry_pt ", destructors.first);
2287 fprintf (stream, "void %s() {\n", fininame);
2288 if (destructors.number > 0 || frames)
2290 fprintf (stream, "\tstatic entry_pt *dtors[] = {\n");
2291 write_list (stream, "\t\t", destructors.first);
2292 if (frames)
2293 fprintf (stream, "\tdereg_frame,\n");
2294 fprintf (stream, "\t};\n");
2295 fprintf (stream, "\tentry_pt **p;\n");
2296 fprintf (stream, "\tif (--count != 0) return;\n");
2297 fprintf (stream, "\tp = dtors;\n");
2298 fprintf (stream, "\twhile (p < dtors + %d) (*p++)();\n",
2299 destructors.number + frames);
2301 fprintf (stream, "}\n");
2303 if (shared_obj)
2305 COLLECT_SHARED_INIT_FUNC (stream, initname);
2306 COLLECT_SHARED_FINI_FUNC (stream, fininame);
2310 /* Write the constructor/destructor tables. */
2312 #ifndef LD_INIT_SWITCH
2313 static void
2314 write_c_file_glob (FILE *stream, const char *name ATTRIBUTE_UNUSED)
2316 /* Write the tables as C code. */
2318 int frames = (frame_tables.number > 0);
2320 fprintf (stream, "typedef void entry_pt();\n\n");
2322 write_list_with_asm (stream, "extern entry_pt ", constructors.first);
2324 if (frames)
2326 write_list_with_asm (stream, "extern void *", frame_tables.first);
2328 fprintf (stream, "\tstatic void *frame_table[] = {\n");
2329 write_list (stream, "\t\t&", frame_tables.first);
2330 fprintf (stream, "\t0\n};\n");
2332 /* This must match what's in frame.h. */
2333 fprintf (stream, "struct object {\n");
2334 fprintf (stream, " void *pc_begin;\n");
2335 fprintf (stream, " void *pc_end;\n");
2336 fprintf (stream, " void *fde_begin;\n");
2337 fprintf (stream, " void *fde_array;\n");
2338 fprintf (stream, " __SIZE_TYPE__ count;\n");
2339 fprintf (stream, " struct object *next;\n");
2340 fprintf (stream, "};\n");
2342 fprintf (stream, "extern void __register_frame_info_table (void *, struct object *);\n");
2343 fprintf (stream, "extern void *__deregister_frame_info (void *);\n");
2345 fprintf (stream, "static void reg_frame () {\n");
2346 fprintf (stream, "\tstatic struct object ob;\n");
2347 fprintf (stream, "\t__register_frame_info_table (frame_table, &ob);\n");
2348 fprintf (stream, "\t}\n");
2350 fprintf (stream, "static void dereg_frame () {\n");
2351 fprintf (stream, "\t__deregister_frame_info (frame_table);\n");
2352 fprintf (stream, "\t}\n");
2355 fprintf (stream, "\nentry_pt * __CTOR_LIST__[] = {\n");
2356 fprintf (stream, "\t(entry_pt *) %d,\n", constructors.number + frames);
2357 write_list (stream, "\t", constructors.first);
2358 if (frames)
2359 fprintf (stream, "\treg_frame,\n");
2360 fprintf (stream, "\t0\n};\n\n");
2362 write_list_with_asm (stream, "extern entry_pt ", destructors.first);
2364 fprintf (stream, "\nentry_pt * __DTOR_LIST__[] = {\n");
2365 fprintf (stream, "\t(entry_pt *) %d,\n", destructors.number + frames);
2366 write_list (stream, "\t", destructors.first);
2367 if (frames)
2368 fprintf (stream, "\tdereg_frame,\n");
2369 fprintf (stream, "\t0\n};\n\n");
2371 fprintf (stream, "extern entry_pt %s;\n", NAME__MAIN);
2372 fprintf (stream, "entry_pt *__main_reference = %s;\n\n", NAME__MAIN);
2374 #endif /* ! LD_INIT_SWITCH */
2376 static void
2377 write_c_file (FILE *stream, const char *name)
2379 #ifndef LD_INIT_SWITCH
2380 if (! shared_obj)
2381 write_c_file_glob (stream, name);
2382 else
2383 #endif
2384 write_c_file_stat (stream, name);
2387 #ifdef COLLECT_EXPORT_LIST
2388 static void
2389 write_aix_file (FILE *stream, struct id *list)
2391 for (; list; list = list->next)
2393 fputs (list->name, stream);
2394 putc ('\n', stream);
2397 #endif
2399 #ifdef OBJECT_FORMAT_NONE
2401 /* Check to make sure the file is an LTO object file. */
2403 static bool
2404 maybe_lto_object_file (const char *prog_name)
2406 FILE *f;
2407 unsigned char buf[4];
2408 int i;
2410 static unsigned char elfmagic[4] = { 0x7f, 'E', 'L', 'F' };
2411 static unsigned char coffmagic[2] = { 0x4c, 0x01 };
2412 static unsigned char coffmagic_x64[2] = { 0x64, 0x86 };
2413 static unsigned char machomagic[4][4] = {
2414 { 0xcf, 0xfa, 0xed, 0xfe },
2415 { 0xce, 0xfa, 0xed, 0xfe },
2416 { 0xfe, 0xed, 0xfa, 0xcf },
2417 { 0xfe, 0xed, 0xfa, 0xce }
2420 f = fopen (prog_name, "rb");
2421 if (f == NULL)
2422 return false;
2423 if (fread (buf, sizeof (buf), 1, f) != 1)
2424 buf[0] = 0;
2425 fclose (f);
2427 if (memcmp (buf, elfmagic, sizeof (elfmagic)) == 0
2428 || memcmp (buf, coffmagic, sizeof (coffmagic)) == 0
2429 || memcmp (buf, coffmagic_x64, sizeof (coffmagic_x64)) == 0)
2430 return true;
2431 for (i = 0; i < 4; i++)
2432 if (memcmp (buf, machomagic[i], sizeof (machomagic[i])) == 0)
2433 return true;
2435 return false;
2438 /* Generic version to scan the name list of the loaded program for
2439 the symbols g++ uses for static constructors and destructors. */
2441 static void
2442 scan_prog_file (const char *prog_name, scanpass which_pass,
2443 scanfilter filter)
2445 void (*int_handler) (int);
2446 #ifdef SIGQUIT
2447 void (*quit_handler) (int);
2448 #endif
2449 char *real_nm_argv[4];
2450 const char **nm_argv = CONST_CAST2 (const char **, char**, real_nm_argv);
2451 int argc = 0;
2452 struct pex_obj *pex;
2453 const char *errmsg;
2454 int err;
2455 char *p, buf[1024];
2456 FILE *inf;
2457 int found_lto = 0;
2459 if (which_pass == PASS_SECOND)
2460 return;
2462 /* LTO objects must be in a known format. This check prevents
2463 us from accepting an archive containing LTO objects, which
2464 gcc cannot currently handle. */
2465 if (which_pass == PASS_LTOINFO && !maybe_lto_object_file (prog_name))
2466 return;
2468 /* If we do not have an `nm', complain. */
2469 if (nm_file_name == 0)
2470 fatal_error ("cannot find 'nm'");
2472 nm_argv[argc++] = nm_file_name;
2473 if (NM_FLAGS[0] != '\0')
2474 nm_argv[argc++] = NM_FLAGS;
2476 nm_argv[argc++] = prog_name;
2477 nm_argv[argc++] = (char *) 0;
2479 /* Trace if needed. */
2480 if (vflag)
2482 const char **p_argv;
2483 const char *str;
2485 for (p_argv = &nm_argv[0]; (str = *p_argv) != (char *) 0; p_argv++)
2486 fprintf (stderr, " %s", str);
2488 fprintf (stderr, "\n");
2491 fflush (stdout);
2492 fflush (stderr);
2494 pex = pex_init (PEX_USE_PIPES, "collect2", NULL);
2495 if (pex == NULL)
2496 fatal_error ("pex_init failed: %m");
2498 errmsg = pex_run (pex, 0, nm_file_name, real_nm_argv, NULL, HOST_BIT_BUCKET,
2499 &err);
2500 if (errmsg != NULL)
2502 if (err != 0)
2504 errno = err;
2505 fatal_error ("%s: %m", _(errmsg));
2507 else
2508 fatal_error (errmsg);
2511 int_handler = (void (*) (int)) signal (SIGINT, SIG_IGN);
2512 #ifdef SIGQUIT
2513 quit_handler = (void (*) (int)) signal (SIGQUIT, SIG_IGN);
2514 #endif
2516 inf = pex_read_output (pex, 0);
2517 if (inf == NULL)
2518 fatal_error ("can't open nm output: %m");
2520 if (debug)
2522 if (which_pass == PASS_LTOINFO)
2523 fprintf (stderr, "\nnm output with LTO info marker symbol.\n");
2524 else
2525 fprintf (stderr, "\nnm output with constructors/destructors.\n");
2528 /* Read each line of nm output. */
2529 while (fgets (buf, sizeof buf, inf) != (char *) 0)
2531 int ch, ch2;
2532 char *name, *end;
2534 if (debug)
2535 fprintf (stderr, "\t%s\n", buf);
2537 if (which_pass == PASS_LTOINFO)
2539 if (found_lto)
2540 continue;
2542 /* Look for the LTO info marker symbol, and add filename to
2543 the LTO objects list if found. */
2544 for (p = buf; (ch = *p) != '\0' && ch != '\n'; p++)
2545 if (ch == ' ' && p[1] == '_' && p[2] == '_'
2546 && (strncmp (p + (p[3] == '_' ? 2 : 1), "__gnu_lto_v1", 12) == 0)
2547 && ISSPACE (p[p[3] == '_' ? 14 : 13]))
2549 add_lto_object (&lto_objects, prog_name);
2551 /* We need to read all the input, so we can't just
2552 return here. But we can avoid useless work. */
2553 found_lto = 1;
2555 break;
2558 continue;
2561 /* If it contains a constructor or destructor name, add the name
2562 to the appropriate list unless this is a kind of symbol we're
2563 not supposed to even consider. */
2565 for (p = buf; (ch = *p) != '\0' && ch != '\n' && ch != '_'; p++)
2566 if (ch == ' ' && p[1] == 'U' && p[2] == ' ')
2567 break;
2569 if (ch != '_')
2570 continue;
2572 name = p;
2573 /* Find the end of the symbol name.
2574 Do not include `|', because Encore nm can tack that on the end. */
2575 for (end = p; (ch2 = *end) != '\0' && !ISSPACE (ch2) && ch2 != '|';
2576 end++)
2577 continue;
2580 *end = '\0';
2582 switch (is_ctor_dtor (name))
2584 case SYM_CTOR:
2585 if (! (filter & SCAN_CTOR))
2586 break;
2587 if (which_pass != PASS_LIB)
2588 add_to_list (&constructors, name);
2589 break;
2591 case SYM_DTOR:
2592 if (! (filter & SCAN_DTOR))
2593 break;
2594 if (which_pass != PASS_LIB)
2595 add_to_list (&destructors, name);
2596 break;
2598 case SYM_INIT:
2599 if (! (filter & SCAN_INIT))
2600 break;
2601 if (which_pass != PASS_LIB)
2602 fatal_error ("init function found in object %s", prog_name);
2603 #ifndef LD_INIT_SWITCH
2604 add_to_list (&constructors, name);
2605 #endif
2606 break;
2608 case SYM_FINI:
2609 if (! (filter & SCAN_FINI))
2610 break;
2611 if (which_pass != PASS_LIB)
2612 fatal_error ("fini function found in object %s", prog_name);
2613 #ifndef LD_FINI_SWITCH
2614 add_to_list (&destructors, name);
2615 #endif
2616 break;
2618 case SYM_DWEH:
2619 if (! (filter & SCAN_DWEH))
2620 break;
2621 if (which_pass != PASS_LIB)
2622 add_to_list (&frame_tables, name);
2623 break;
2625 default: /* not a constructor or destructor */
2626 continue;
2630 if (debug)
2631 fprintf (stderr, "\n");
2633 do_wait (nm_file_name, pex);
2635 signal (SIGINT, int_handler);
2636 #ifdef SIGQUIT
2637 signal (SIGQUIT, quit_handler);
2638 #endif
2641 #ifdef LDD_SUFFIX
2643 /* Use the List Dynamic Dependencies program to find shared libraries that
2644 the output file depends upon and their initialization/finalization
2645 routines, if any. */
2647 static void
2648 scan_libraries (const char *prog_name)
2650 static struct head libraries; /* list of shared libraries found */
2651 struct id *list;
2652 void (*int_handler) (int);
2653 #ifdef SIGQUIT
2654 void (*quit_handler) (int);
2655 #endif
2656 char *real_ldd_argv[4];
2657 const char **ldd_argv = CONST_CAST2 (const char **, char **, real_ldd_argv);
2658 int argc = 0;
2659 struct pex_obj *pex;
2660 const char *errmsg;
2661 int err;
2662 char buf[1024];
2663 FILE *inf;
2665 /* If we do not have an `ldd', complain. */
2666 if (ldd_file_name == 0)
2668 error ("cannot find 'ldd'");
2669 return;
2672 ldd_argv[argc++] = ldd_file_name;
2673 ldd_argv[argc++] = prog_name;
2674 ldd_argv[argc++] = (char *) 0;
2676 /* Trace if needed. */
2677 if (vflag)
2679 const char **p_argv;
2680 const char *str;
2682 for (p_argv = &ldd_argv[0]; (str = *p_argv) != (char *) 0; p_argv++)
2683 fprintf (stderr, " %s", str);
2685 fprintf (stderr, "\n");
2688 fflush (stdout);
2689 fflush (stderr);
2691 pex = pex_init (PEX_USE_PIPES, "collect2", NULL);
2692 if (pex == NULL)
2693 fatal_error ("pex_init failed: %m");
2695 errmsg = pex_run (pex, 0, ldd_file_name, real_ldd_argv, NULL, NULL, &err);
2696 if (errmsg != NULL)
2698 if (err != 0)
2700 errno = err;
2701 fatal_error ("%s: %m", _(errmsg));
2703 else
2704 fatal_error (errmsg);
2707 int_handler = (void (*) (int)) signal (SIGINT, SIG_IGN);
2708 #ifdef SIGQUIT
2709 quit_handler = (void (*) (int)) signal (SIGQUIT, SIG_IGN);
2710 #endif
2712 inf = pex_read_output (pex, 0);
2713 if (inf == NULL)
2714 fatal_error ("can't open ldd output: %m");
2716 if (debug)
2717 notice ("\nldd output with constructors/destructors.\n");
2719 /* Read each line of ldd output. */
2720 while (fgets (buf, sizeof buf, inf) != (char *) 0)
2722 int ch2;
2723 char *name, *end, *p = buf;
2725 /* Extract names of libraries and add to list. */
2726 PARSE_LDD_OUTPUT (p);
2727 if (p == 0)
2728 continue;
2730 name = p;
2731 if (strncmp (name, "not found", sizeof ("not found") - 1) == 0)
2732 fatal_error ("dynamic dependency %s not found", buf);
2734 /* Find the end of the symbol name. */
2735 for (end = p;
2736 (ch2 = *end) != '\0' && ch2 != '\n' && !ISSPACE (ch2) && ch2 != '|';
2737 end++)
2738 continue;
2739 *end = '\0';
2741 if (access (name, R_OK) == 0)
2742 add_to_list (&libraries, name);
2743 else
2744 fatal_error ("unable to open dynamic dependency '%s'", buf);
2746 if (debug)
2747 fprintf (stderr, "\t%s\n", buf);
2749 if (debug)
2750 fprintf (stderr, "\n");
2752 do_wait (ldd_file_name, pex);
2754 signal (SIGINT, int_handler);
2755 #ifdef SIGQUIT
2756 signal (SIGQUIT, quit_handler);
2757 #endif
2759 /* Now iterate through the library list adding their symbols to
2760 the list. */
2761 for (list = libraries.first; list; list = list->next)
2762 scan_prog_file (list->name, PASS_LIB, SCAN_ALL);
2765 #endif /* LDD_SUFFIX */
2767 #endif /* OBJECT_FORMAT_NONE */
2771 * COFF specific stuff.
2774 #ifdef OBJECT_FORMAT_COFF
2776 #if defined (EXTENDED_COFF)
2778 # define GCC_SYMBOLS(X) (SYMHEADER (X).isymMax + SYMHEADER (X).iextMax)
2779 # define GCC_SYMENT SYMR
2780 # define GCC_OK_SYMBOL(X) ((X).st == stProc || (X).st == stGlobal)
2781 # define GCC_SYMINC(X) (1)
2782 # define GCC_SYMZERO(X) (SYMHEADER (X).isymMax)
2783 # define GCC_CHECK_HDR(X) (PSYMTAB (X) != 0)
2785 #else
2787 # define GCC_SYMBOLS(X) (HEADER (ldptr).f_nsyms)
2788 # define GCC_SYMENT SYMENT
2789 # if defined (C_WEAKEXT)
2790 # define GCC_OK_SYMBOL(X) \
2791 (((X).n_sclass == C_EXT || (X).n_sclass == C_WEAKEXT) && \
2792 ((X).n_scnum > N_UNDEF) && \
2793 (aix64_flag \
2794 || (((X).n_type & N_TMASK) == (DT_NON << N_BTSHFT) \
2795 || ((X).n_type & N_TMASK) == (DT_FCN << N_BTSHFT))))
2796 # define GCC_UNDEF_SYMBOL(X) \
2797 (((X).n_sclass == C_EXT || (X).n_sclass == C_WEAKEXT) && \
2798 ((X).n_scnum == N_UNDEF))
2799 # else
2800 # define GCC_OK_SYMBOL(X) \
2801 (((X).n_sclass == C_EXT) && \
2802 ((X).n_scnum > N_UNDEF) && \
2803 (aix64_flag \
2804 || (((X).n_type & N_TMASK) == (DT_NON << N_BTSHFT) \
2805 || ((X).n_type & N_TMASK) == (DT_FCN << N_BTSHFT))))
2806 # define GCC_UNDEF_SYMBOL(X) \
2807 (((X).n_sclass == C_EXT) && ((X).n_scnum == N_UNDEF))
2808 # endif
2809 # define GCC_SYMINC(X) ((X).n_numaux+1)
2810 # define GCC_SYMZERO(X) 0
2812 /* 0757 = U803XTOCMAGIC (AIX 4.3) and 0767 = U64_TOCMAGIC (AIX V5) */
2813 #if TARGET_AIX_VERSION >= 51
2814 # define GCC_CHECK_HDR(X) \
2815 (((HEADER (X).f_magic == U802TOCMAGIC && ! aix64_flag) \
2816 || (HEADER (X).f_magic == 0767 && aix64_flag)) \
2817 && !(HEADER (X).f_flags & F_LOADONLY))
2818 #else
2819 # define GCC_CHECK_HDR(X) \
2820 (((HEADER (X).f_magic == U802TOCMAGIC && ! aix64_flag) \
2821 || (HEADER (X).f_magic == 0757 && aix64_flag)) \
2822 && !(HEADER (X).f_flags & F_LOADONLY))
2823 #endif
2825 #endif
2827 #ifdef COLLECT_EXPORT_LIST
2828 /* Array of standard AIX libraries which should not
2829 be scanned for ctors/dtors. */
2830 static const char *const aix_std_libs[] = {
2831 "/unix",
2832 "/lib/libc.a",
2833 "/lib/libm.a",
2834 "/lib/libc_r.a",
2835 "/lib/libm_r.a",
2836 "/usr/lib/libc.a",
2837 "/usr/lib/libm.a",
2838 "/usr/lib/libc_r.a",
2839 "/usr/lib/libm_r.a",
2840 "/usr/lib/threads/libc.a",
2841 "/usr/ccs/lib/libc.a",
2842 "/usr/ccs/lib/libm.a",
2843 "/usr/ccs/lib/libc_r.a",
2844 "/usr/ccs/lib/libm_r.a",
2845 NULL
2848 /* This function checks the filename and returns 1
2849 if this name matches the location of a standard AIX library. */
2850 static int ignore_library (const char *);
2851 static int
2852 ignore_library (const char *name)
2854 const char *const *p;
2855 size_t length;
2857 if (target_system_root[0] != '\0')
2859 length = strlen (target_system_root);
2860 if (strncmp (name, target_system_root, length) != 0)
2861 return 0;
2862 name += length;
2864 for (p = &aix_std_libs[0]; *p != NULL; ++p)
2865 if (strcmp (name, *p) == 0)
2866 return 1;
2867 return 0;
2869 #endif /* COLLECT_EXPORT_LIST */
2871 #if defined (HAVE_DECL_LDGETNAME) && !HAVE_DECL_LDGETNAME
2872 extern char *ldgetname (LDFILE *, GCC_SYMENT *);
2873 #endif
2875 /* COFF version to scan the name list of the loaded program for
2876 the symbols g++ uses for static constructors and destructors. */
2878 static void
2879 scan_prog_file (const char *prog_name, scanpass which_pass,
2880 scanfilter filter)
2882 LDFILE *ldptr = NULL;
2883 int sym_index, sym_count;
2884 int is_shared = 0;
2886 if (which_pass != PASS_FIRST && which_pass != PASS_OBJ)
2887 return;
2889 #ifdef COLLECT_EXPORT_LIST
2890 /* We do not need scanning for some standard C libraries. */
2891 if (which_pass == PASS_FIRST && ignore_library (prog_name))
2892 return;
2894 /* On AIX we have a loop, because there is not much difference
2895 between an object and an archive. This trick allows us to
2896 eliminate scan_libraries() function. */
2899 #endif
2900 /* Some platforms (e.g. OSF4) declare ldopen as taking a
2901 non-const char * filename parameter, even though it will not
2902 modify that string. So we must cast away const-ness here,
2903 using CONST_CAST to prevent complaints from -Wcast-qual. */
2904 if ((ldptr = ldopen (CONST_CAST (char *, prog_name), ldptr)) != NULL)
2906 if (! MY_ISCOFF (HEADER (ldptr).f_magic))
2907 fatal_error ("%s: not a COFF file", prog_name);
2909 if (GCC_CHECK_HDR (ldptr))
2911 sym_count = GCC_SYMBOLS (ldptr);
2912 sym_index = GCC_SYMZERO (ldptr);
2914 #ifdef COLLECT_EXPORT_LIST
2915 /* Is current archive member a shared object? */
2916 is_shared = HEADER (ldptr).f_flags & F_SHROBJ;
2917 #endif
2919 while (sym_index < sym_count)
2921 GCC_SYMENT symbol;
2923 if (ldtbread (ldptr, sym_index, &symbol) <= 0)
2924 break;
2925 sym_index += GCC_SYMINC (symbol);
2927 if (GCC_OK_SYMBOL (symbol))
2929 char *name;
2931 if ((name = ldgetname (ldptr, &symbol)) == NULL)
2932 continue; /* Should never happen. */
2934 #ifdef XCOFF_DEBUGGING_INFO
2935 /* All AIX function names have a duplicate entry
2936 beginning with a dot. */
2937 if (*name == '.')
2938 ++name;
2939 #endif
2941 switch (is_ctor_dtor (name))
2943 #if TARGET_AIX_VERSION
2944 /* Add AIX shared library initalisers/finalisers
2945 to the constructors/destructors list of the
2946 current module. */
2947 case SYM_AIXI:
2948 if (! (filter & SCAN_CTOR))
2949 break;
2950 if (is_shared && !aixlazy_flag)
2951 add_to_list (&constructors, name);
2952 break;
2954 case SYM_AIXD:
2955 if (! (filter & SCAN_DTOR))
2956 break;
2957 if (is_shared && !aixlazy_flag)
2958 add_to_list (&destructors, name);
2959 break;
2960 #endif
2962 case SYM_CTOR:
2963 if (! (filter & SCAN_CTOR))
2964 break;
2965 if (! is_shared)
2966 add_to_list (&constructors, name);
2967 #if defined (COLLECT_EXPORT_LIST) && !defined (LD_INIT_SWITCH)
2968 if (which_pass == PASS_OBJ)
2969 add_to_list (&exports, name);
2970 #endif
2971 break;
2973 case SYM_DTOR:
2974 if (! (filter & SCAN_DTOR))
2975 break;
2976 if (! is_shared)
2977 add_to_list (&destructors, name);
2978 #if defined (COLLECT_EXPORT_LIST) && !defined (LD_INIT_SWITCH)
2979 if (which_pass == PASS_OBJ)
2980 add_to_list (&exports, name);
2981 #endif
2982 break;
2984 #ifdef COLLECT_EXPORT_LIST
2985 case SYM_INIT:
2986 if (! (filter & SCAN_INIT))
2987 break;
2988 #ifndef LD_INIT_SWITCH
2989 if (is_shared)
2990 add_to_list (&constructors, name);
2991 #endif
2992 break;
2994 case SYM_FINI:
2995 if (! (filter & SCAN_FINI))
2996 break;
2997 #ifndef LD_INIT_SWITCH
2998 if (is_shared)
2999 add_to_list (&destructors, name);
3000 #endif
3001 break;
3002 #endif
3004 case SYM_DWEH:
3005 if (! (filter & SCAN_DWEH))
3006 break;
3007 if (! is_shared)
3008 add_to_list (&frame_tables, 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;
3015 default: /* not a constructor or destructor */
3016 #ifdef COLLECT_EXPORT_LIST
3017 /* Explicitly export all global symbols when
3018 building a shared object on AIX, but do not
3019 re-export symbols from another shared object
3020 and do not export symbols if the user
3021 provides an explicit export list. */
3022 if (shared_obj && !is_shared
3023 && which_pass == PASS_OBJ && !export_flag)
3024 add_to_list (&exports, name);
3025 #endif
3026 continue;
3029 if (debug)
3030 #if !defined(EXTENDED_COFF)
3031 fprintf (stderr, "\tsec=%d class=%d type=%s%o %s\n",
3032 symbol.n_scnum, symbol.n_sclass,
3033 (symbol.n_type ? "0" : ""), symbol.n_type,
3034 name);
3035 #else
3036 fprintf (stderr,
3037 "\tiss = %5d, value = %5ld, index = %5d, name = %s\n",
3038 symbol.iss, (long) symbol.value, symbol.index, name);
3039 #endif
3043 #ifdef COLLECT_EXPORT_LIST
3044 else
3046 /* If archive contains both 32-bit and 64-bit objects,
3047 we want to skip objects in other mode so mismatch normal. */
3048 if (debug)
3049 fprintf (stderr, "%s : magic=%o aix64=%d mismatch\n",
3050 prog_name, HEADER (ldptr).f_magic, aix64_flag);
3052 #endif
3054 else
3056 fatal_error ("%s: cannot open as COFF file", prog_name);
3058 #ifdef COLLECT_EXPORT_LIST
3059 /* On AIX loop continues while there are more members in archive. */
3061 while (ldclose (ldptr) == FAILURE);
3062 #else
3063 /* Otherwise we simply close ldptr. */
3064 (void) ldclose (ldptr);
3065 #endif
3067 #endif /* OBJECT_FORMAT_COFF */
3069 #ifdef COLLECT_EXPORT_LIST
3070 /* Given a library name without "lib" prefix, this function
3071 returns a full library name including a path. */
3072 static char *
3073 resolve_lib_name (const char *name)
3075 char *lib_buf;
3076 int i, j, l = 0;
3077 /* Library extensions for AIX dynamic linking. */
3078 const char * const libexts[2] = {"a", "so"};
3080 for (i = 0; libpaths[i]; i++)
3081 if (libpaths[i]->max_len > l)
3082 l = libpaths[i]->max_len;
3084 lib_buf = XNEWVEC (char, l + strlen (name) + 10);
3086 for (i = 0; libpaths[i]; i++)
3088 struct prefix_list *list = libpaths[i]->plist;
3089 for (; list; list = list->next)
3091 /* The following lines are needed because path_prefix list
3092 may contain directories both with trailing DIR_SEPARATOR and
3093 without it. */
3094 const char *p = "";
3095 if (!IS_DIR_SEPARATOR (list->prefix[strlen (list->prefix)-1]))
3096 p = "/";
3097 for (j = 0; j < 2; j++)
3099 sprintf (lib_buf, "%s%slib%s.%s",
3100 list->prefix, p, name,
3101 libexts[(j + aixrtl_flag) % 2]);
3102 if (debug) fprintf (stderr, "searching for: %s\n", lib_buf);
3103 if (file_exists (lib_buf))
3105 if (debug) fprintf (stderr, "found: %s\n", lib_buf);
3106 return (lib_buf);
3111 if (debug)
3112 fprintf (stderr, "not found\n");
3113 else
3114 fatal_error ("library lib%s not found", name);
3115 return (NULL);
3117 #endif /* COLLECT_EXPORT_LIST */
3119 #ifdef COLLECT_RUN_DSYMUTIL
3120 static int flag_dsym = false;
3121 static int flag_idsym = false;
3123 static void
3124 process_args (int *argcp, char **argv) {
3125 int i, j;
3126 int argc = *argcp;
3127 for (i=0; i<argc; ++i)
3129 if (strcmp (argv[i], "-dsym") == 0)
3131 flag_dsym = true;
3132 /* Remove the flag, as we handle all processing for it. */
3133 j = i;
3135 argv[j] = argv[j+1];
3136 while (++j < argc);
3137 --i;
3138 argc = --(*argcp);
3140 else if (strcmp (argv[i], "-idsym") == 0)
3142 flag_idsym = true;
3143 /* Remove the flag, as we handle all processing for it. */
3144 j = i;
3146 argv[j] = argv[j+1];
3147 while (++j < argc);
3148 --i;
3149 argc = --(*argcp);
3154 static void
3155 do_dsymutil (const char *output_file) {
3156 const char *dsymutil = DSYMUTIL + 1;
3157 struct pex_obj *pex;
3158 char **real_argv = XCNEWVEC (char *, 3);
3159 const char ** argv = CONST_CAST2 (const char **, char **,
3160 real_argv);
3162 argv[0] = dsymutil;
3163 argv[1] = output_file;
3164 argv[2] = (char *) 0;
3166 pex = collect_execute (dsymutil, real_argv, NULL, NULL, PEX_LAST | PEX_SEARCH);
3167 do_wait (dsymutil, pex);
3170 static void
3171 post_ld_pass (bool temp_file) {
3172 if (!(temp_file && flag_idsym) && !flag_dsym)
3173 return;
3175 do_dsymutil (output_file);
3177 #else
3178 static void
3179 process_args (int *argcp ATTRIBUTE_UNUSED, char **argv ATTRIBUTE_UNUSED) { }
3180 static void post_ld_pass (bool temp_file ATTRIBUTE_UNUSED) { }
3181 #endif