gcc-dg.exp (dg-build-dso): Reset dg-do-what-default to compile.
[official-gcc.git] / gcc / collect2.c
blobf0ab6b8c8f108e18f0c4a7c5474e99948b778fc0
1 /* Collect static initialization info into data structures that can be
2 traversed by C++ initialization and finalization routines.
3 Copyright (C) 1992-2014 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 #ifdef ENABLE_LTO
196 static enum lto_mode_d lto_mode = LTO_MODE_WHOPR;
197 #else
198 static enum lto_mode_d lto_mode = LTO_MODE_NONE;
199 #endif
201 bool debug; /* true if -debug */
202 bool helpflag; /* true if --help */
204 static int shared_obj; /* true if -shared */
206 static const char *c_file; /* <xxx>.c for constructor/destructor list. */
207 static const char *o_file; /* <xxx>.o for constructor/destructor list. */
208 #ifdef COLLECT_EXPORT_LIST
209 static const char *export_file; /* <xxx>.x for AIX export list. */
210 #endif
211 static char **lto_o_files; /* Output files for LTO. */
212 const char *ldout; /* File for ld stdout. */
213 const char *lderrout; /* File for ld stderr. */
214 static const char *output_file; /* Output file for ld. */
215 static const char *nm_file_name; /* pathname of nm */
216 #ifdef LDD_SUFFIX
217 static const char *ldd_file_name; /* pathname of ldd (or equivalent) */
218 #endif
219 static const char *strip_file_name; /* pathname of strip */
220 const char *c_file_name; /* pathname of gcc */
221 static char *initname, *fininame; /* names of init and fini funcs */
224 #ifdef TARGET_AIX_VERSION
225 static char *aix_shared_initname;
226 static char *aix_shared_fininame; /* init/fini names as per the scheme
227 described in config/rs6000/aix.h */
228 #endif
230 static struct head constructors; /* list of constructors found */
231 static struct head destructors; /* list of destructors found */
232 #ifdef COLLECT_EXPORT_LIST
233 static struct head exports; /* list of exported symbols */
234 #endif
235 static struct head frame_tables; /* list of frame unwind info tables */
237 static bool at_file_supplied; /* Whether to use @file arguments */
238 static char *response_file; /* Name of any current response file */
240 struct obstack temporary_obstack;
241 char * temporary_firstobj;
243 /* A string that must be prepended to a target OS path in order to find
244 it on the host system. */
245 #ifdef TARGET_SYSTEM_ROOT
246 static const char *target_system_root = TARGET_SYSTEM_ROOT;
247 #else
248 static const char *target_system_root = "";
249 #endif
251 /* Whether we may unlink the output file, which should be set as soon as we
252 know we have successfully produced it. This is typically useful to prevent
253 blindly attempting to unlink a read-only output that the target linker
254 would leave untouched. */
255 bool may_unlink_output_file = false;
257 #ifdef COLLECT_EXPORT_LIST
258 /* Lists to keep libraries to be scanned for global constructors/destructors. */
259 static struct head libs; /* list of libraries */
260 static struct path_prefix cmdline_lib_dirs; /* directories specified with -L */
261 static struct path_prefix libpath_lib_dirs; /* directories in LIBPATH */
262 static struct path_prefix *libpaths[3] = {&cmdline_lib_dirs,
263 &libpath_lib_dirs, NULL};
264 #endif
266 /* List of names of object files containing LTO information.
267 These are a subset of the object file names appearing on the
268 command line, and must be identical, in the sense of pointer
269 equality, with the names passed to maybe_run_lto_and_relink(). */
271 struct lto_object
273 const char *name; /* Name of object file. */
274 struct lto_object *next; /* Next in linked list. */
277 struct lto_object_list
279 struct lto_object *first; /* First list element. */
280 struct lto_object *last; /* Last list element. */
283 static struct lto_object_list lto_objects;
285 /* Special kinds of symbols that a name may denote. */
287 typedef enum {
288 SYM_REGULAR = 0, /* nothing special */
290 SYM_CTOR = 1, /* constructor */
291 SYM_DTOR = 2, /* destructor */
292 SYM_INIT = 3, /* shared object routine that calls all the ctors */
293 SYM_FINI = 4, /* shared object routine that calls all the dtors */
294 SYM_DWEH = 5, /* DWARF exception handling table */
295 SYM_AIXI = 6,
296 SYM_AIXD = 7
297 } symkind;
299 static symkind is_ctor_dtor (const char *);
301 static void handler (int);
302 static void do_wait (const char *, struct pex_obj *);
303 static void fork_execute (const char *, char **);
304 static void maybe_unlink (const char *);
305 static void maybe_unlink_list (char **);
306 static void add_to_list (struct head *, const char *);
307 static int extract_init_priority (const char *);
308 static void sort_ids (struct head *);
309 static void write_list (FILE *, const char *, struct id *);
310 #ifdef COLLECT_EXPORT_LIST
311 static void dump_list (FILE *, const char *, struct id *);
312 #endif
313 #if 0
314 static void dump_prefix_list (FILE *, const char *, struct prefix_list *);
315 #endif
316 static void write_list_with_asm (FILE *, const char *, struct id *);
317 static void write_c_file (FILE *, const char *);
318 static void write_c_file_stat (FILE *, const char *);
319 #ifndef LD_INIT_SWITCH
320 static void write_c_file_glob (FILE *, const char *);
321 #endif
322 #ifdef SCAN_LIBRARIES
323 static void scan_libraries (const char *);
324 #endif
325 #ifdef COLLECT_EXPORT_LIST
326 #if 0
327 static int is_in_list (const char *, struct id *);
328 #endif
329 static void write_aix_file (FILE *, struct id *);
330 static char *resolve_lib_name (const char *);
331 #endif
332 static char *extract_string (const char **);
333 static void post_ld_pass (bool);
334 static void process_args (int *argcp, char **argv);
336 /* Enumerations describing which pass this is for scanning the
337 program file ... */
339 typedef enum {
340 PASS_FIRST, /* without constructors */
341 PASS_OBJ, /* individual objects */
342 PASS_LIB, /* looking for shared libraries */
343 PASS_SECOND, /* with constructors linked in */
344 PASS_LTOINFO /* looking for objects with LTO info */
345 } scanpass;
347 /* ... and which kinds of symbols are to be considered. */
349 enum scanfilter_masks {
350 SCAN_NOTHING = 0,
352 SCAN_CTOR = 1 << SYM_CTOR,
353 SCAN_DTOR = 1 << SYM_DTOR,
354 SCAN_INIT = 1 << SYM_INIT,
355 SCAN_FINI = 1 << SYM_FINI,
356 SCAN_DWEH = 1 << SYM_DWEH,
357 SCAN_AIXI = 1 << SYM_AIXI,
358 SCAN_AIXD = 1 << SYM_AIXD,
359 SCAN_ALL = ~0
362 /* This type is used for parameters and variables which hold
363 combinations of the flags in enum scanfilter_masks. */
364 typedef int scanfilter;
366 /* Scan the name list of the loaded program for the symbols g++ uses for
367 static constructors and destructors.
369 The SCANPASS argument tells which collect processing pass this is for and
370 the SCANFILTER argument tells which kinds of symbols to consider in this
371 pass. Symbols of a special kind not in the filter mask are considered as
372 regular ones.
374 The constructor table begins at __CTOR_LIST__ and contains a count of the
375 number of pointers (or -1 if the constructors are built in a separate
376 section by the linker), followed by the pointers to the constructor
377 functions, terminated with a null pointer. The destructor table has the
378 same format, and begins at __DTOR_LIST__. */
380 static void scan_prog_file (const char *, scanpass, scanfilter);
383 /* Delete tempfiles and exit function. */
385 static void
386 collect_atexit (void)
388 if (c_file != 0 && c_file[0])
389 maybe_unlink (c_file);
391 if (o_file != 0 && o_file[0])
392 maybe_unlink (o_file);
394 #ifdef COLLECT_EXPORT_LIST
395 if (export_file != 0 && export_file[0])
396 maybe_unlink (export_file);
397 #endif
399 if (lto_o_files)
400 maybe_unlink_list (lto_o_files);
402 if (ldout != 0 && ldout[0])
404 dump_ld_file (ldout, stdout);
405 maybe_unlink (ldout);
408 if (lderrout != 0 && lderrout[0])
410 dump_ld_file (lderrout, stderr);
411 maybe_unlink (lderrout);
414 if (response_file)
415 maybe_unlink (response_file);
419 /* Notify user of a non-error. */
420 void
421 notice (const char *cmsgid, ...)
423 va_list ap;
425 va_start (ap, cmsgid);
426 vfprintf (stderr, _(cmsgid), ap);
427 va_end (ap);
430 /* Notify user of a non-error, without translating the format string. */
431 void
432 notice_translated (const char *cmsgid, ...)
434 va_list ap;
436 va_start (ap, cmsgid);
437 vfprintf (stderr, cmsgid, ap);
438 va_end (ap);
441 static void
442 handler (int signo)
444 if (c_file != 0 && c_file[0])
445 maybe_unlink (c_file);
447 if (o_file != 0 && o_file[0])
448 maybe_unlink (o_file);
450 if (ldout != 0 && ldout[0])
451 maybe_unlink (ldout);
453 if (lderrout != 0 && lderrout[0])
454 maybe_unlink (lderrout);
456 #ifdef COLLECT_EXPORT_LIST
457 if (export_file != 0 && export_file[0])
458 maybe_unlink (export_file);
459 #endif
461 if (lto_o_files)
462 maybe_unlink_list (lto_o_files);
464 if (response_file)
465 maybe_unlink (response_file);
467 signal (signo, SIG_DFL);
468 raise (signo);
473 file_exists (const char *name)
475 return access (name, R_OK) == 0;
478 /* Parse a reasonable subset of shell quoting syntax. */
480 static char *
481 extract_string (const char **pp)
483 const char *p = *pp;
484 int backquote = 0;
485 int inside = 0;
487 for (;;)
489 char c = *p;
490 if (c == '\0')
491 break;
492 ++p;
493 if (backquote)
494 obstack_1grow (&temporary_obstack, c);
495 else if (! inside && c == ' ')
496 break;
497 else if (! inside && c == '\\')
498 backquote = 1;
499 else if (c == '\'')
500 inside = !inside;
501 else
502 obstack_1grow (&temporary_obstack, c);
505 obstack_1grow (&temporary_obstack, '\0');
506 *pp = p;
507 return XOBFINISH (&temporary_obstack, char *);
510 void
511 dump_ld_file (const char *name, FILE *to)
513 FILE *stream = fopen (name, "r");
515 if (stream == 0)
516 return;
517 while (1)
519 int c;
520 while (c = getc (stream),
521 c != EOF && (ISIDNUM (c) || c == '$' || c == '.'))
522 obstack_1grow (&temporary_obstack, c);
523 if (obstack_object_size (&temporary_obstack) > 0)
525 const char *word, *p;
526 char *result;
527 obstack_1grow (&temporary_obstack, '\0');
528 word = XOBFINISH (&temporary_obstack, const char *);
530 if (*word == '.')
531 ++word, putc ('.', to);
532 p = word;
533 if (!strncmp (p, USER_LABEL_PREFIX, strlen (USER_LABEL_PREFIX)))
534 p += strlen (USER_LABEL_PREFIX);
536 #ifdef HAVE_LD_DEMANGLE
537 result = 0;
538 #else
539 if (no_demangle)
540 result = 0;
541 else
542 result = cplus_demangle (p, DMGL_PARAMS | DMGL_ANSI | DMGL_VERBOSE);
543 #endif
545 if (result)
547 int diff;
548 fputs (result, to);
550 diff = strlen (word) - strlen (result);
551 while (diff > 0 && c == ' ')
552 --diff, putc (' ', to);
553 if (diff < 0 && c == ' ')
555 while (diff < 0 && c == ' ')
556 ++diff, c = getc (stream);
557 if (!ISSPACE (c))
559 /* Make sure we output at least one space, or
560 the demangled symbol name will run into
561 whatever text follows. */
562 putc (' ', to);
566 free (result);
568 else
569 fputs (word, to);
571 fflush (to);
572 obstack_free (&temporary_obstack, temporary_firstobj);
574 if (c == EOF)
575 break;
576 putc (c, to);
578 fclose (stream);
581 /* Return the kind of symbol denoted by name S. */
583 static symkind
584 is_ctor_dtor (const char *s)
586 struct names { const char *const name; const int len; symkind ret;
587 const int two_underscores; };
589 const struct names *p;
590 int ch;
591 const char *orig_s = s;
593 static const struct names special[] = {
594 #ifndef NO_DOLLAR_IN_LABEL
595 { "GLOBAL__I$", sizeof ("GLOBAL__I$")-1, SYM_CTOR, 0 },
596 { "GLOBAL__D$", sizeof ("GLOBAL__D$")-1, SYM_DTOR, 0 },
597 #else
598 #ifndef NO_DOT_IN_LABEL
599 { "GLOBAL__I.", sizeof ("GLOBAL__I.")-1, SYM_CTOR, 0 },
600 { "GLOBAL__D.", sizeof ("GLOBAL__D.")-1, SYM_DTOR, 0 },
601 #endif /* NO_DOT_IN_LABEL */
602 #endif /* NO_DOLLAR_IN_LABEL */
603 { "GLOBAL__I_", sizeof ("GLOBAL__I_")-1, SYM_CTOR, 0 },
604 { "GLOBAL__D_", sizeof ("GLOBAL__D_")-1, SYM_DTOR, 0 },
605 { "GLOBAL__F_", sizeof ("GLOBAL__F_")-1, SYM_DWEH, 0 },
606 { "GLOBAL__FI_", sizeof ("GLOBAL__FI_")-1, SYM_INIT, 0 },
607 { "GLOBAL__FD_", sizeof ("GLOBAL__FD_")-1, SYM_FINI, 0 },
608 #ifdef TARGET_AIX_VERSION
609 { "GLOBAL__AIXI_", sizeof ("GLOBAL__AIXI_")-1, SYM_AIXI, 0 },
610 { "GLOBAL__AIXD_", sizeof ("GLOBAL__AIXD_")-1, SYM_AIXD, 0 },
611 #endif
612 { NULL, 0, SYM_REGULAR, 0 }
615 while ((ch = *s) == '_')
616 ++s;
618 if (s == orig_s)
619 return SYM_REGULAR;
621 for (p = &special[0]; p->len > 0; p++)
623 if (ch == p->name[0]
624 && (!p->two_underscores || ((s - orig_s) >= 2))
625 && strncmp (s, p->name, p->len) == 0)
627 return p->ret;
630 return SYM_REGULAR;
633 /* We maintain two prefix lists: one from COMPILER_PATH environment variable
634 and one from the PATH variable. */
636 static struct path_prefix cpath, path;
638 #ifdef CROSS_DIRECTORY_STRUCTURE
639 /* This is the name of the target machine. We use it to form the name
640 of the files to execute. */
642 static const char *const target_machine = TARGET_MACHINE;
643 #endif
645 /* Search for NAME using prefix list PPREFIX. We only look for executable
646 files.
648 Return 0 if not found, otherwise return its name, allocated with malloc. */
650 #ifdef OBJECT_FORMAT_NONE
652 /* Add an entry for the object file NAME to object file list LIST.
653 New entries are added at the end of the list. The original pointer
654 value of NAME is preserved, i.e., no string copy is performed. */
656 static void
657 add_lto_object (struct lto_object_list *list, const char *name)
659 struct lto_object *n = XNEW (struct lto_object);
660 n->name = name;
661 n->next = NULL;
663 if (list->last)
664 list->last->next = n;
665 else
666 list->first = n;
668 list->last = n;
670 #endif /* OBJECT_FORMAT_NONE */
673 /* Perform a link-time recompilation and relink if any of the object
674 files contain LTO info. The linker command line LTO_LD_ARGV
675 represents the linker command that would produce a final executable
676 without the use of LTO. OBJECT_LST is a vector of object file names
677 appearing in LTO_LD_ARGV that are to be considered for link-time
678 recompilation, where OBJECT is a pointer to the last valid element.
679 (This awkward convention avoids an impedance mismatch with the
680 usage of similarly-named variables in main().) The elements of
681 OBJECT_LST must be identical, i.e., pointer equal, to the
682 corresponding arguments in LTO_LD_ARGV.
684 Upon entry, at least one linker run has been performed without the
685 use of any LTO info that might be present. Any recompilations
686 necessary for template instantiations have been performed, and
687 initializer/finalizer tables have been created if needed and
688 included in the linker command line LTO_LD_ARGV. If any of the
689 object files contain LTO info, we run the LTO back end on all such
690 files, and perform the final link with the LTO back end output
691 substituted for the LTO-optimized files. In some cases, a final
692 link with all link-time generated code has already been performed,
693 so there is no need to relink if no LTO info is found. In other
694 cases, our caller has not produced the final executable, and is
695 relying on us to perform the required link whether LTO info is
696 present or not. In that case, the FORCE argument should be true.
697 Note that the linker command line argument LTO_LD_ARGV passed into
698 this function may be modified in place. */
700 static void
701 maybe_run_lto_and_relink (char **lto_ld_argv, char **object_lst,
702 const char **object, bool force)
704 const char **object_file = CONST_CAST2 (const char **, char **, object_lst);
706 int num_lto_c_args = 1; /* Allow space for the terminating NULL. */
708 while (object_file < object)
710 /* If file contains LTO info, add it to the list of LTO objects. */
711 scan_prog_file (*object_file++, PASS_LTOINFO, SCAN_ALL);
713 /* Increment the argument count by the number of object file arguments
714 we will add. An upper bound suffices, so just count all of the
715 object files regardless of whether they contain LTO info. */
716 num_lto_c_args++;
719 if (lto_objects.first)
721 char **lto_c_argv;
722 const char **lto_c_ptr;
723 char **p;
724 char **lto_o_ptr;
725 struct lto_object *list;
726 char *lto_wrapper = getenv ("COLLECT_LTO_WRAPPER");
727 struct pex_obj *pex;
728 const char *prog = "lto-wrapper";
729 int lto_ld_argv_size = 0;
730 char **out_lto_ld_argv;
731 int out_lto_ld_argv_size;
732 size_t num_files;
734 if (!lto_wrapper)
735 fatal_error ("COLLECT_LTO_WRAPPER must be set");
737 num_lto_c_args++;
739 /* There is at least one object file containing LTO info,
740 so we need to run the LTO back end and relink.
742 To do so we build updated ld arguments with first
743 LTO object replaced by all partitions and other LTO
744 objects removed. */
746 lto_c_argv = (char **) xcalloc (sizeof (char *), num_lto_c_args);
747 lto_c_ptr = CONST_CAST2 (const char **, char **, lto_c_argv);
749 *lto_c_ptr++ = lto_wrapper;
751 /* Add LTO objects to the wrapper command line. */
752 for (list = lto_objects.first; list; list = list->next)
753 *lto_c_ptr++ = list->name;
755 *lto_c_ptr = NULL;
757 /* Run the LTO back end. */
758 pex = collect_execute (prog, lto_c_argv, NULL, NULL, PEX_SEARCH);
760 int c;
761 FILE *stream;
762 size_t i;
763 char *start, *end;
765 stream = pex_read_output (pex, 0);
766 gcc_assert (stream);
768 num_files = 0;
769 while ((c = getc (stream)) != EOF)
771 obstack_1grow (&temporary_obstack, c);
772 if (c == '\n')
773 ++num_files;
776 lto_o_files = XNEWVEC (char *, num_files + 1);
777 lto_o_files[num_files] = NULL;
778 start = XOBFINISH (&temporary_obstack, char *);
779 for (i = 0; i < num_files; ++i)
781 end = start;
782 while (*end != '\n')
783 ++end;
784 *end = '\0';
786 lto_o_files[i] = xstrdup (start);
788 start = end + 1;
791 obstack_free (&temporary_obstack, temporary_firstobj);
793 do_wait (prog, pex);
794 pex = NULL;
796 /* Compute memory needed for new LD arguments. At most number of original arguemtns
797 plus number of partitions. */
798 for (lto_ld_argv_size = 0; lto_ld_argv[lto_ld_argv_size]; lto_ld_argv_size++)
800 out_lto_ld_argv = XCNEWVEC (char *, num_files + lto_ld_argv_size + 1);
801 out_lto_ld_argv_size = 0;
803 /* After running the LTO back end, we will relink, substituting
804 the LTO output for the object files that we submitted to the
805 LTO. Here, we modify the linker command line for the relink. */
807 /* Copy all arguments until we find first LTO file. */
808 p = lto_ld_argv;
809 while (*p != NULL)
811 for (list = lto_objects.first; list; list = list->next)
812 if (*p == list->name) /* Note test for pointer equality! */
813 break;
814 if (list)
815 break;
816 out_lto_ld_argv[out_lto_ld_argv_size++] = *p++;
819 /* Now insert all LTO partitions. */
820 lto_o_ptr = lto_o_files;
821 while (*lto_o_ptr)
822 out_lto_ld_argv[out_lto_ld_argv_size++] = *lto_o_ptr++;
824 /* ... and copy the rest. */
825 while (*p != NULL)
827 for (list = lto_objects.first; list; list = list->next)
828 if (*p == list->name) /* Note test for pointer equality! */
829 break;
830 if (!list)
831 out_lto_ld_argv[out_lto_ld_argv_size++] = *p;
832 p++;
834 out_lto_ld_argv[out_lto_ld_argv_size++] = 0;
836 /* Run the linker again, this time replacing the object files
837 optimized by the LTO with the temporary file generated by the LTO. */
838 fork_execute ("ld", out_lto_ld_argv);
839 post_ld_pass (true);
840 free (lto_ld_argv);
842 maybe_unlink_list (lto_o_files);
844 else if (force)
846 /* Our caller is relying on us to do the link
847 even though there is no LTO back end work to be done. */
848 fork_execute ("ld", lto_ld_argv);
849 post_ld_pass (false);
853 /* Main program. */
856 main (int argc, char **argv)
858 enum linker_select
860 USE_DEFAULT_LD,
861 USE_PLUGIN_LD,
862 USE_GOLD_LD,
863 USE_BFD_LD,
864 USE_LD_MAX
865 } selected_linker = USE_DEFAULT_LD;
866 static const char *const ld_suffixes[USE_LD_MAX] =
868 "ld",
869 PLUGIN_LD_SUFFIX,
870 "ld.gold",
871 "ld.bfd"
873 static const char *const real_ld_suffix = "real-ld";
874 static const char *const collect_ld_suffix = "collect-ld";
875 static const char *const nm_suffix = "nm";
876 static const char *const gnm_suffix = "gnm";
877 #ifdef LDD_SUFFIX
878 static const char *const ldd_suffix = LDD_SUFFIX;
879 #endif
880 static const char *const strip_suffix = "strip";
881 static const char *const gstrip_suffix = "gstrip";
883 const char *full_ld_suffixes[USE_LD_MAX];
884 #ifdef CROSS_DIRECTORY_STRUCTURE
885 /* If we look for a program in the compiler directories, we just use
886 the short name, since these directories are already system-specific.
887 But it we look for a program in the system directories, we need to
888 qualify the program name with the target machine. */
890 const char *const full_nm_suffix =
891 concat (target_machine, "-", nm_suffix, NULL);
892 const char *const full_gnm_suffix =
893 concat (target_machine, "-", gnm_suffix, NULL);
894 #ifdef LDD_SUFFIX
895 const char *const full_ldd_suffix =
896 concat (target_machine, "-", ldd_suffix, NULL);
897 #endif
898 const char *const full_strip_suffix =
899 concat (target_machine, "-", strip_suffix, NULL);
900 const char *const full_gstrip_suffix =
901 concat (target_machine, "-", gstrip_suffix, NULL);
902 #else
903 #ifdef LDD_SUFFIX
904 const char *const full_ldd_suffix = ldd_suffix;
905 #endif
906 const char *const full_nm_suffix = nm_suffix;
907 const char *const full_gnm_suffix = gnm_suffix;
908 const char *const full_strip_suffix = strip_suffix;
909 const char *const full_gstrip_suffix = gstrip_suffix;
910 #endif /* CROSS_DIRECTORY_STRUCTURE */
912 const char *arg;
913 FILE *outf;
914 #ifdef COLLECT_EXPORT_LIST
915 FILE *exportf;
916 #endif
917 const char *ld_file_name;
918 const char *p;
919 char **c_argv;
920 const char **c_ptr;
921 char **ld1_argv;
922 const char **ld1;
923 bool use_plugin = false;
924 bool use_collect_ld = false;
926 /* The kinds of symbols we will have to consider when scanning the
927 outcome of a first pass link. This is ALL to start with, then might
928 be adjusted before getting to the first pass link per se, typically on
929 AIX where we perform an early scan of objects and libraries to fetch
930 the list of global ctors/dtors and make sure they are not garbage
931 collected. */
932 scanfilter ld1_filter = SCAN_ALL;
934 char **ld2_argv;
935 const char **ld2;
936 char **object_lst;
937 const char **object;
938 #ifdef TARGET_AIX_VERSION
939 int object_nbr = argc;
940 #endif
941 int first_file;
942 int num_c_args;
943 char **old_argv;
944 int i;
946 for (i = 0; i < USE_LD_MAX; i++)
947 full_ld_suffixes[i]
948 #ifdef CROSS_DIRECTORY_STRUCTURE
949 = concat (target_machine, "-", ld_suffixes[i], NULL);
950 #else
951 = ld_suffixes[i];
952 #endif
954 p = argv[0] + strlen (argv[0]);
955 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
956 --p;
957 progname = p;
959 xmalloc_set_program_name (progname);
961 old_argv = argv;
962 expandargv (&argc, &argv);
963 if (argv != old_argv)
964 at_file_supplied = 1;
966 process_args (&argc, argv);
968 num_c_args = argc + 9;
970 #ifndef HAVE_LD_DEMANGLE
971 no_demangle = !! getenv ("COLLECT_NO_DEMANGLE");
973 /* Suppress demangling by the real linker, which may be broken. */
974 putenv (xstrdup ("COLLECT_NO_DEMANGLE=1"));
975 #endif
977 #if defined (COLLECT2_HOST_INITIALIZATION)
978 /* Perform system dependent initialization, if necessary. */
979 COLLECT2_HOST_INITIALIZATION;
980 #endif
982 #ifdef SIGCHLD
983 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
984 receive the signal. A different setting is inheritable */
985 signal (SIGCHLD, SIG_DFL);
986 #endif
988 if (atexit (collect_atexit) != 0)
989 fatal_error ("atexit failed");
991 /* Unlock the stdio streams. */
992 unlock_std_streams ();
994 gcc_init_libintl ();
996 diagnostic_initialize (global_dc, 0);
998 /* Do not invoke xcalloc before this point, since locale needs to be
999 set first, in case a diagnostic is issued. */
1001 ld1_argv = XCNEWVEC (char *, argc + 4);
1002 ld1 = CONST_CAST2 (const char **, char **, ld1_argv);
1003 ld2_argv = XCNEWVEC (char *, argc + 11);
1004 ld2 = CONST_CAST2 (const char **, char **, ld2_argv);
1005 object_lst = XCNEWVEC (char *, argc);
1006 object = CONST_CAST2 (const char **, char **, object_lst);
1008 #ifdef DEBUG
1009 debug = 1;
1010 #endif
1012 /* Parse command line early for instances of -debug. This allows
1013 the debug flag to be set before functions like find_a_file()
1014 are called. We also look for the -flto or -flto-partition=none flag to know
1015 what LTO mode we are in. */
1017 bool no_partition = false;
1019 for (i = 1; argv[i] != NULL; i ++)
1021 if (! strcmp (argv[i], "-debug"))
1022 debug = true;
1023 else if (! strcmp (argv[i], "-flto-partition=none"))
1024 no_partition = true;
1025 else if (!strncmp (argv[i], "-fno-lto", 8))
1026 lto_mode = LTO_MODE_NONE;
1027 else if (! strcmp (argv[i], "-plugin"))
1029 use_plugin = true;
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 (use_plugin)
1060 lto_mode = LTO_MODE_NONE;
1061 if (no_partition && lto_mode == LTO_MODE_WHOPR)
1062 lto_mode = LTO_MODE_LTO;
1065 #ifndef DEFAULT_A_OUT_NAME
1066 output_file = "a.out";
1067 #else
1068 output_file = DEFAULT_A_OUT_NAME;
1069 #endif
1071 obstack_begin (&temporary_obstack, 0);
1072 temporary_firstobj = (char *) obstack_alloc (&temporary_obstack, 0);
1074 #ifndef HAVE_LD_DEMANGLE
1075 current_demangling_style = auto_demangling;
1076 #endif
1077 p = getenv ("COLLECT_GCC_OPTIONS");
1078 while (p && *p)
1080 const char *q = extract_string (&p);
1081 if (*q == '-' && (q[1] == 'm' || q[1] == 'f'))
1082 num_c_args++;
1084 obstack_free (&temporary_obstack, temporary_firstobj);
1086 /* -fno-profile-arcs -fno-test-coverage -fno-branch-probabilities
1087 -fno-exceptions -w -fno-whole-program */
1088 num_c_args += 6;
1090 c_argv = XCNEWVEC (char *, num_c_args);
1091 c_ptr = CONST_CAST2 (const char **, char **, c_argv);
1093 if (argc < 2)
1094 fatal_error ("no arguments");
1096 #ifdef SIGQUIT
1097 if (signal (SIGQUIT, SIG_IGN) != SIG_IGN)
1098 signal (SIGQUIT, handler);
1099 #endif
1100 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
1101 signal (SIGINT, handler);
1102 #ifdef SIGALRM
1103 if (signal (SIGALRM, SIG_IGN) != SIG_IGN)
1104 signal (SIGALRM, handler);
1105 #endif
1106 #ifdef SIGHUP
1107 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
1108 signal (SIGHUP, handler);
1109 #endif
1110 if (signal (SIGSEGV, SIG_IGN) != SIG_IGN)
1111 signal (SIGSEGV, handler);
1112 #ifdef SIGBUS
1113 if (signal (SIGBUS, SIG_IGN) != SIG_IGN)
1114 signal (SIGBUS, handler);
1115 #endif
1117 /* Extract COMPILER_PATH and PATH into our prefix list. */
1118 prefix_from_env ("COMPILER_PATH", &cpath);
1119 prefix_from_env ("PATH", &path);
1121 /* Try to discover a valid linker/nm/strip to use. */
1123 /* Maybe we know the right file to use (if not cross). */
1124 ld_file_name = 0;
1125 #ifdef DEFAULT_LINKER
1126 if (selected_linker == USE_BFD_LD || selected_linker == USE_GOLD_LD)
1128 char *linker_name;
1129 # ifdef HOST_EXECUTABLE_SUFFIX
1130 int len = (sizeof (DEFAULT_LINKER)
1131 - sizeof (HOST_EXECUTABLE_SUFFIX));
1132 linker_name = NULL;
1133 if (len > 0)
1135 char *default_linker = xstrdup (DEFAULT_LINKER);
1136 /* Strip HOST_EXECUTABLE_SUFFIX if DEFAULT_LINKER contains
1137 HOST_EXECUTABLE_SUFFIX. */
1138 if (! strcmp (&default_linker[len], HOST_EXECUTABLE_SUFFIX))
1140 default_linker[len] = '\0';
1141 linker_name = concat (default_linker,
1142 &ld_suffixes[selected_linker][2],
1143 HOST_EXECUTABLE_SUFFIX, NULL);
1146 if (linker_name == NULL)
1147 # endif
1148 linker_name = concat (DEFAULT_LINKER,
1149 &ld_suffixes[selected_linker][2],
1150 NULL);
1151 if (access (linker_name, X_OK) == 0)
1152 ld_file_name = linker_name;
1154 if (ld_file_name == 0 && access (DEFAULT_LINKER, X_OK) == 0)
1155 ld_file_name = DEFAULT_LINKER;
1156 if (ld_file_name == 0)
1157 #endif
1158 #ifdef REAL_LD_FILE_NAME
1159 ld_file_name = find_a_file (&path, REAL_LD_FILE_NAME, X_OK);
1160 if (ld_file_name == 0)
1161 #endif
1162 /* Search the (target-specific) compiler dirs for ld'. */
1163 ld_file_name = find_a_file (&cpath, real_ld_suffix, X_OK);
1164 /* Likewise for `collect-ld'. */
1165 if (ld_file_name == 0)
1167 ld_file_name = find_a_file (&cpath, collect_ld_suffix, X_OK);
1168 use_collect_ld = ld_file_name != 0;
1170 /* Search the compiler directories for `ld'. We have protection against
1171 recursive calls in find_a_file. */
1172 if (ld_file_name == 0)
1173 ld_file_name = find_a_file (&cpath, ld_suffixes[selected_linker], X_OK);
1174 /* Search the ordinary system bin directories
1175 for `ld' (if native linking) or `TARGET-ld' (if cross). */
1176 if (ld_file_name == 0)
1177 ld_file_name = find_a_file (&path, full_ld_suffixes[selected_linker], X_OK);
1179 #ifdef REAL_NM_FILE_NAME
1180 nm_file_name = find_a_file (&path, REAL_NM_FILE_NAME, X_OK);
1181 if (nm_file_name == 0)
1182 #endif
1183 nm_file_name = find_a_file (&cpath, gnm_suffix, X_OK);
1184 if (nm_file_name == 0)
1185 nm_file_name = find_a_file (&path, full_gnm_suffix, X_OK);
1186 if (nm_file_name == 0)
1187 nm_file_name = find_a_file (&cpath, nm_suffix, X_OK);
1188 if (nm_file_name == 0)
1189 nm_file_name = find_a_file (&path, full_nm_suffix, X_OK);
1191 #ifdef LDD_SUFFIX
1192 ldd_file_name = find_a_file (&cpath, ldd_suffix, X_OK);
1193 if (ldd_file_name == 0)
1194 ldd_file_name = find_a_file (&path, full_ldd_suffix, X_OK);
1195 #endif
1197 #ifdef REAL_STRIP_FILE_NAME
1198 strip_file_name = find_a_file (&path, REAL_STRIP_FILE_NAME, X_OK);
1199 if (strip_file_name == 0)
1200 #endif
1201 strip_file_name = find_a_file (&cpath, gstrip_suffix, X_OK);
1202 if (strip_file_name == 0)
1203 strip_file_name = find_a_file (&path, full_gstrip_suffix, X_OK);
1204 if (strip_file_name == 0)
1205 strip_file_name = find_a_file (&cpath, strip_suffix, X_OK);
1206 if (strip_file_name == 0)
1207 strip_file_name = find_a_file (&path, full_strip_suffix, X_OK);
1209 /* Determine the full path name of the C compiler to use. */
1210 c_file_name = getenv ("COLLECT_GCC");
1211 if (c_file_name == 0)
1213 #ifdef CROSS_DIRECTORY_STRUCTURE
1214 c_file_name = concat (target_machine, "-gcc", NULL);
1215 #else
1216 c_file_name = "gcc";
1217 #endif
1220 p = find_a_file (&cpath, c_file_name, X_OK);
1222 /* Here it should be safe to use the system search path since we should have
1223 already qualified the name of the compiler when it is needed. */
1224 if (p == 0)
1225 p = find_a_file (&path, c_file_name, X_OK);
1227 if (p)
1228 c_file_name = p;
1230 *ld1++ = *ld2++ = ld_file_name;
1232 /* Make temp file names. */
1233 c_file = make_temp_file (".c");
1234 o_file = make_temp_file (".o");
1235 #ifdef COLLECT_EXPORT_LIST
1236 export_file = make_temp_file (".x");
1237 #endif
1238 if (!debug)
1240 ldout = make_temp_file (".ld");
1241 lderrout = make_temp_file (".le");
1243 *c_ptr++ = c_file_name;
1244 *c_ptr++ = "-x";
1245 *c_ptr++ = "c";
1246 *c_ptr++ = "-c";
1247 *c_ptr++ = "-o";
1248 *c_ptr++ = o_file;
1250 #ifdef COLLECT_EXPORT_LIST
1251 /* Generate a list of directories from LIBPATH. */
1252 prefix_from_env ("LIBPATH", &libpath_lib_dirs);
1253 /* Add to this list also two standard directories where
1254 AIX loader always searches for libraries. */
1255 add_prefix (&libpath_lib_dirs, "/lib");
1256 add_prefix (&libpath_lib_dirs, "/usr/lib");
1257 #endif
1259 /* Get any options that the upper GCC wants to pass to the sub-GCC.
1261 AIX support needs to know if -shared has been specified before
1262 parsing commandline arguments. */
1264 p = getenv ("COLLECT_GCC_OPTIONS");
1265 while (p && *p)
1267 const char *q = extract_string (&p);
1268 if (*q == '-' && (q[1] == 'm' || q[1] == 'f'))
1269 *c_ptr++ = xstrdup (q);
1270 if (strcmp (q, "-EL") == 0 || strcmp (q, "-EB") == 0)
1271 *c_ptr++ = xstrdup (q);
1272 if (strcmp (q, "-shared") == 0)
1273 shared_obj = 1;
1274 if (*q == '-' && q[1] == 'B')
1276 *c_ptr++ = xstrdup (q);
1277 if (q[2] == 0)
1279 q = extract_string (&p);
1280 *c_ptr++ = xstrdup (q);
1284 obstack_free (&temporary_obstack, temporary_firstobj);
1285 *c_ptr++ = "-fno-profile-arcs";
1286 *c_ptr++ = "-fno-test-coverage";
1287 *c_ptr++ = "-fno-branch-probabilities";
1288 *c_ptr++ = "-fno-exceptions";
1289 *c_ptr++ = "-w";
1290 *c_ptr++ = "-fno-whole-program";
1292 /* !!! When GCC calls collect2,
1293 it does not know whether it is calling collect2 or ld.
1294 So collect2 cannot meaningfully understand any options
1295 except those ld understands.
1296 If you propose to make GCC pass some other option,
1297 just imagine what will happen if ld is really ld!!! */
1299 /* Parse arguments. Remember output file spec, pass the rest to ld. */
1300 /* After the first file, put in the c++ rt0. */
1302 first_file = 1;
1303 while ((arg = *++argv) != (char *) 0)
1305 *ld1++ = *ld2++ = arg;
1307 if (arg[0] == '-')
1309 switch (arg[1])
1311 case 'd':
1312 if (!strcmp (arg, "-debug"))
1314 /* Already parsed. */
1315 ld1--;
1316 ld2--;
1318 if (!strcmp (arg, "-dynamic-linker") && argv[1])
1320 ++argv;
1321 *ld1++ = *ld2++ = *argv;
1323 break;
1325 case 'f':
1326 if (strncmp (arg, "-flto", 5) == 0)
1328 #ifdef ENABLE_LTO
1329 /* Do not pass LTO flag to the linker. */
1330 ld1--;
1331 ld2--;
1332 #else
1333 error ("LTO support has not been enabled in this "
1334 "configuration");
1335 #endif
1337 else if (!use_collect_ld
1338 && strncmp (arg, "-fuse-ld=", 9) == 0)
1340 /* Do not pass -fuse-ld={bfd|gold} to the linker. */
1341 ld1--;
1342 ld2--;
1344 #ifdef TARGET_AIX_VERSION
1345 else
1347 /* File containing a list of input files to process. */
1349 FILE *stream;
1350 char buf[MAXPATHLEN + 2];
1351 /* Number of additionnal object files. */
1352 int add_nbr = 0;
1353 /* Maximum of additionnal object files before vector
1354 expansion. */
1355 int add_max = 0;
1356 const char *list_filename = arg + 2;
1358 /* Accept -fFILENAME and -f FILENAME. */
1359 if (*list_filename == '\0' && argv[1])
1361 ++argv;
1362 list_filename = *argv;
1363 *ld1++ = *ld2++ = *argv;
1366 stream = fopen (list_filename, "r");
1367 if (stream == NULL)
1368 fatal_error ("can't open %s: %m", list_filename);
1370 while (fgets (buf, sizeof buf, stream) != NULL)
1372 /* Remove end of line. */
1373 int len = strlen (buf);
1374 if (len >= 1 && buf[len - 1] =='\n')
1375 buf[len - 1] = '\0';
1377 /* Put on object vector.
1378 Note: we only expanse vector here, so we must keep
1379 extra space for remaining arguments. */
1380 if (add_nbr >= add_max)
1382 int pos =
1383 object - CONST_CAST2 (const char **, char **,
1384 object_lst);
1385 add_max = (add_max == 0) ? 16 : add_max * 2;
1386 object_lst = XRESIZEVEC (char *, object_lst,
1387 object_nbr + add_max);
1388 object = CONST_CAST2 (const char **, char **,
1389 object_lst) + pos;
1390 object_nbr += add_max;
1392 *object++ = xstrdup (buf);
1393 add_nbr++;
1395 fclose (stream);
1397 #endif
1398 break;
1400 case 'l':
1401 if (first_file)
1403 /* place o_file BEFORE this argument! */
1404 first_file = 0;
1405 ld2--;
1406 *ld2++ = o_file;
1407 *ld2++ = arg;
1409 #ifdef COLLECT_EXPORT_LIST
1411 /* Resolving full library name. */
1412 const char *s = resolve_lib_name (arg+2);
1414 /* Saving a full library name. */
1415 add_to_list (&libs, s);
1417 #endif
1418 break;
1420 #ifdef COLLECT_EXPORT_LIST
1421 /* Saving directories where to search for libraries. */
1422 case 'L':
1423 add_prefix (&cmdline_lib_dirs, arg+2);
1424 break;
1425 #endif
1427 case 'o':
1428 if (arg[2] == '\0')
1429 output_file = *ld1++ = *ld2++ = *++argv;
1430 else
1431 output_file = &arg[2];
1432 break;
1434 case 'r':
1435 if (arg[2] == '\0')
1436 rflag = 1;
1437 break;
1439 case 's':
1440 if (arg[2] == '\0' && do_collecting)
1442 /* We must strip after the nm run, otherwise C++ linking
1443 will not work. Thus we strip in the second ld run, or
1444 else with strip if there is no second ld run. */
1445 strip_flag = 1;
1446 ld1--;
1448 break;
1450 case 'v':
1451 if (arg[2] == '\0')
1452 vflag = true;
1453 break;
1455 case '-':
1456 if (strcmp (arg, "--no-demangle") == 0)
1458 #ifndef HAVE_LD_DEMANGLE
1459 no_demangle = 1;
1460 ld1--;
1461 ld2--;
1462 #endif
1464 else if (strncmp (arg, "--demangle", 10) == 0)
1466 #ifndef HAVE_LD_DEMANGLE
1467 no_demangle = 0;
1468 if (arg[10] == '=')
1470 enum demangling_styles style
1471 = cplus_demangle_name_to_style (arg+11);
1472 if (style == unknown_demangling)
1473 error ("unknown demangling style '%s'", arg+11);
1474 else
1475 current_demangling_style = style;
1477 ld1--;
1478 ld2--;
1479 #endif
1481 else if (strncmp (arg, "--sysroot=", 10) == 0)
1482 target_system_root = arg + 10;
1483 else if (strcmp (arg, "--version") == 0)
1484 vflag = true;
1485 else if (strcmp (arg, "--help") == 0)
1486 helpflag = true;
1487 break;
1490 else if ((p = strrchr (arg, '.')) != (char *) 0
1491 && (strcmp (p, ".o") == 0 || strcmp (p, ".a") == 0
1492 || strcmp (p, ".so") == 0 || strcmp (p, ".lo") == 0
1493 || strcmp (p, ".obj") == 0))
1495 if (first_file)
1497 first_file = 0;
1498 if (p[1] == 'o')
1499 *ld2++ = o_file;
1500 else
1502 /* place o_file BEFORE this argument! */
1503 ld2--;
1504 *ld2++ = o_file;
1505 *ld2++ = arg;
1508 if (p[1] == 'o' || p[1] == 'l')
1509 *object++ = arg;
1510 #ifdef COLLECT_EXPORT_LIST
1511 /* libraries can be specified directly, i.e. without -l flag. */
1512 else
1514 /* Saving a full library name. */
1515 add_to_list (&libs, arg);
1517 #endif
1521 #ifdef COLLECT_EXPORT_LIST
1522 /* This is added only for debugging purposes. */
1523 if (debug)
1525 fprintf (stderr, "List of libraries:\n");
1526 dump_list (stderr, "\t", libs.first);
1529 /* The AIX linker will discard static constructors in object files if
1530 nothing else in the file is referenced, so look at them first. Unless
1531 we are building a shared object, ignore the eh frame tables, as we
1532 would otherwise reference them all, hence drag all the corresponding
1533 objects even if nothing else is referenced. */
1535 const char **export_object_lst
1536 = CONST_CAST2 (const char **, char **, object_lst);
1538 struct id *list = libs.first;
1540 /* Compute the filter to use from the current one, do scan, then adjust
1541 the "current" filter to remove what we just included here. This will
1542 control whether we need a first pass link later on or not, and what
1543 will remain to be scanned there. */
1545 scanfilter this_filter = ld1_filter;
1546 #if HAVE_AS_REF
1547 if (!shared_obj)
1548 this_filter &= ~SCAN_DWEH;
1549 #endif
1551 while (export_object_lst < object)
1552 scan_prog_file (*export_object_lst++, PASS_OBJ, this_filter);
1554 for (; list; list = list->next)
1555 scan_prog_file (list->name, PASS_FIRST, this_filter);
1557 ld1_filter = ld1_filter & ~this_filter;
1560 if (exports.first)
1562 char *buf = concat ("-bE:", export_file, NULL);
1564 *ld1++ = buf;
1565 *ld2++ = buf;
1567 exportf = fopen (export_file, "w");
1568 if (exportf == (FILE *) 0)
1569 fatal_error ("fopen %s: %m", export_file);
1570 write_aix_file (exportf, exports.first);
1571 if (fclose (exportf))
1572 fatal_error ("fclose %s: %m", export_file);
1574 #endif
1576 *c_ptr++ = c_file;
1577 *c_ptr = *ld1 = *object = (char *) 0;
1579 if (vflag)
1580 notice ("collect2 version %s\n", version_string);
1582 if (helpflag)
1584 printf ("Usage: collect2 [options]\n");
1585 printf (" Wrap linker and generate constructor code if needed.\n");
1586 printf (" Options:\n");
1587 printf (" -debug Enable debug output\n");
1588 printf (" --help Display this information\n");
1589 printf (" -v, --version Display this program's version number\n");
1590 printf ("\n");
1591 printf ("Overview: http://gcc.gnu.org/onlinedocs/gccint/Collect2.html\n");
1592 printf ("Report bugs: %s\n", bug_report_url);
1593 printf ("\n");
1596 if (debug)
1598 const char *ptr;
1599 fprintf (stderr, "ld_file_name = %s\n",
1600 (ld_file_name ? ld_file_name : "not found"));
1601 fprintf (stderr, "c_file_name = %s\n",
1602 (c_file_name ? c_file_name : "not found"));
1603 fprintf (stderr, "nm_file_name = %s\n",
1604 (nm_file_name ? nm_file_name : "not found"));
1605 #ifdef LDD_SUFFIX
1606 fprintf (stderr, "ldd_file_name = %s\n",
1607 (ldd_file_name ? ldd_file_name : "not found"));
1608 #endif
1609 fprintf (stderr, "strip_file_name = %s\n",
1610 (strip_file_name ? strip_file_name : "not found"));
1611 fprintf (stderr, "c_file = %s\n",
1612 (c_file ? c_file : "not found"));
1613 fprintf (stderr, "o_file = %s\n",
1614 (o_file ? o_file : "not found"));
1616 ptr = getenv ("COLLECT_GCC_OPTIONS");
1617 if (ptr)
1618 fprintf (stderr, "COLLECT_GCC_OPTIONS = %s\n", ptr);
1620 ptr = getenv ("COLLECT_GCC");
1621 if (ptr)
1622 fprintf (stderr, "COLLECT_GCC = %s\n", ptr);
1624 ptr = getenv ("COMPILER_PATH");
1625 if (ptr)
1626 fprintf (stderr, "COMPILER_PATH = %s\n", ptr);
1628 ptr = getenv (LIBRARY_PATH_ENV);
1629 if (ptr)
1630 fprintf (stderr, "%-20s= %s\n", LIBRARY_PATH_ENV, ptr);
1632 fprintf (stderr, "\n");
1635 /* Load the program, searching all libraries and attempting to provide
1636 undefined symbols from repository information.
1638 If -r or they will be run via some other method, do not build the
1639 constructor or destructor list, just return now. */
1641 bool early_exit
1642 = rflag || (! DO_COLLECT_EXPORT_LIST && ! do_collecting);
1644 /* Perform the first pass link now, if we're about to exit or if we need
1645 to scan for things we haven't collected yet before pursuing further.
1647 On AIX, the latter typically includes nothing for shared objects or
1648 frame tables for an executable, out of what the required early scan on
1649 objects and libraries has performed above. In the !shared_obj case, we
1650 expect the relevant tables to be dragged together with their associated
1651 functions from precise cross reference insertions by the compiler. */
1653 if (early_exit || ld1_filter != SCAN_NOTHING)
1654 do_tlink (ld1_argv, object_lst);
1656 if (early_exit)
1658 #ifdef COLLECT_EXPORT_LIST
1659 /* Make sure we delete the export file we may have created. */
1660 if (export_file != 0 && export_file[0])
1661 maybe_unlink (export_file);
1662 #endif
1663 if (lto_mode != LTO_MODE_NONE)
1664 maybe_run_lto_and_relink (ld1_argv, object_lst, object, false);
1665 else
1666 post_ld_pass (false);
1668 maybe_unlink (c_file);
1669 maybe_unlink (o_file);
1670 return 0;
1674 /* Unless we have done it all already, examine the namelist and search for
1675 static constructors and destructors to call. Write the constructor and
1676 destructor tables to a .s file and reload. */
1678 if (ld1_filter != SCAN_NOTHING)
1679 scan_prog_file (output_file, PASS_FIRST, ld1_filter);
1681 #ifdef SCAN_LIBRARIES
1682 scan_libraries (output_file);
1683 #endif
1685 if (debug)
1687 notice_translated (ngettext ("%d constructor found\n",
1688 "%d constructors found\n",
1689 constructors.number),
1690 constructors.number);
1691 notice_translated (ngettext ("%d destructor found\n",
1692 "%d destructors found\n",
1693 destructors.number),
1694 destructors.number);
1695 notice_translated (ngettext ("%d frame table found\n",
1696 "%d frame tables found\n",
1697 frame_tables.number),
1698 frame_tables.number);
1701 /* If the scan exposed nothing of special interest, there's no need to
1702 generate the glue code and relink so return now. */
1704 if (constructors.number == 0 && destructors.number == 0
1705 && frame_tables.number == 0
1706 #if defined (SCAN_LIBRARIES) || defined (COLLECT_EXPORT_LIST)
1707 /* If we will be running these functions ourselves, we want to emit
1708 stubs into the shared library so that we do not have to relink
1709 dependent programs when we add static objects. */
1710 && ! shared_obj
1711 #endif
1714 /* Do tlink without additional code generation now if we didn't
1715 do it earlier for scanning purposes. */
1716 if (ld1_filter == SCAN_NOTHING)
1717 do_tlink (ld1_argv, object_lst);
1719 if (lto_mode)
1720 maybe_run_lto_and_relink (ld1_argv, object_lst, object, false);
1722 /* Strip now if it was requested on the command line. */
1723 if (strip_flag)
1725 char **real_strip_argv = XCNEWVEC (char *, 3);
1726 const char ** strip_argv = CONST_CAST2 (const char **, char **,
1727 real_strip_argv);
1729 strip_argv[0] = strip_file_name;
1730 strip_argv[1] = output_file;
1731 strip_argv[2] = (char *) 0;
1732 fork_execute ("strip", real_strip_argv);
1735 #ifdef COLLECT_EXPORT_LIST
1736 maybe_unlink (export_file);
1737 #endif
1738 post_ld_pass (false);
1740 maybe_unlink (c_file);
1741 maybe_unlink (o_file);
1742 return 0;
1745 /* Sort ctor and dtor lists by priority. */
1746 sort_ids (&constructors);
1747 sort_ids (&destructors);
1749 maybe_unlink (output_file);
1750 outf = fopen (c_file, "w");
1751 if (outf == (FILE *) 0)
1752 fatal_error ("fopen %s: %m", c_file);
1754 write_c_file (outf, c_file);
1756 if (fclose (outf))
1757 fatal_error ("fclose %s: %m", c_file);
1759 /* Tell the linker that we have initializer and finalizer functions. */
1760 #ifdef LD_INIT_SWITCH
1761 #ifdef COLLECT_EXPORT_LIST
1762 *ld2++ = concat (LD_INIT_SWITCH, ":", initname, ":", fininame, NULL);
1763 #else
1764 *ld2++ = LD_INIT_SWITCH;
1765 *ld2++ = initname;
1766 *ld2++ = LD_FINI_SWITCH;
1767 *ld2++ = fininame;
1768 #endif
1769 #endif
1771 #ifdef COLLECT_EXPORT_LIST
1772 if (shared_obj)
1774 /* If we did not add export flag to link arguments before, add it to
1775 second link phase now. No new exports should have been added. */
1776 if (! exports.first)
1777 *ld2++ = concat ("-bE:", export_file, NULL);
1779 #ifdef TARGET_AIX_VERSION
1780 add_to_list (&exports, aix_shared_initname);
1781 add_to_list (&exports, aix_shared_fininame);
1782 #endif
1784 #ifndef LD_INIT_SWITCH
1785 add_to_list (&exports, initname);
1786 add_to_list (&exports, fininame);
1787 add_to_list (&exports, "_GLOBAL__DI");
1788 add_to_list (&exports, "_GLOBAL__DD");
1789 #endif
1790 exportf = fopen (export_file, "w");
1791 if (exportf == (FILE *) 0)
1792 fatal_error ("fopen %s: %m", export_file);
1793 write_aix_file (exportf, exports.first);
1794 if (fclose (exportf))
1795 fatal_error ("fclose %s: %m", export_file);
1797 #endif
1799 /* End of arguments to second link phase. */
1800 *ld2 = (char*) 0;
1802 if (debug)
1804 fprintf (stderr, "\n========== output_file = %s, c_file = %s\n",
1805 output_file, c_file);
1806 write_c_file (stderr, "stderr");
1807 fprintf (stderr, "========== end of c_file\n\n");
1808 #ifdef COLLECT_EXPORT_LIST
1809 fprintf (stderr, "\n========== export_file = %s\n", export_file);
1810 write_aix_file (stderr, exports.first);
1811 fprintf (stderr, "========== end of export_file\n\n");
1812 #endif
1815 /* Assemble the constructor and destructor tables.
1816 Link the tables in with the rest of the program. */
1818 fork_execute ("gcc", c_argv);
1819 #ifdef COLLECT_EXPORT_LIST
1820 /* On AIX we must call tlink because of possible templates resolution. */
1821 do_tlink (ld2_argv, object_lst);
1823 if (lto_mode)
1824 maybe_run_lto_and_relink (ld2_argv, object_lst, object, false);
1825 #else
1826 /* Otherwise, simply call ld because tlink is already done. */
1827 if (lto_mode)
1828 maybe_run_lto_and_relink (ld2_argv, object_lst, object, true);
1829 else
1831 fork_execute ("ld", ld2_argv);
1832 post_ld_pass (false);
1835 /* Let scan_prog_file do any final mods (OSF/rose needs this for
1836 constructors/destructors in shared libraries. */
1837 scan_prog_file (output_file, PASS_SECOND, SCAN_ALL);
1838 #endif
1840 maybe_unlink (c_file);
1841 maybe_unlink (o_file);
1843 #ifdef COLLECT_EXPORT_LIST
1844 maybe_unlink (export_file);
1845 #endif
1847 return 0;
1851 /* Wait for a process to finish, and exit if a nonzero status is found. */
1854 collect_wait (const char *prog, struct pex_obj *pex)
1856 int status;
1858 if (!pex_get_status (pex, 1, &status))
1859 fatal_error ("can't get program status: %m");
1860 pex_free (pex);
1862 if (status)
1864 if (WIFSIGNALED (status))
1866 int sig = WTERMSIG (status);
1867 error ("%s terminated with signal %d [%s]%s",
1868 prog, sig, strsignal (sig),
1869 WCOREDUMP (status) ? ", core dumped" : "");
1870 exit (FATAL_EXIT_CODE);
1873 if (WIFEXITED (status))
1874 return WEXITSTATUS (status);
1876 return 0;
1879 static void
1880 do_wait (const char *prog, struct pex_obj *pex)
1882 int ret = collect_wait (prog, pex);
1883 if (ret != 0)
1885 error ("%s returned %d exit status", prog, ret);
1886 exit (ret);
1889 if (response_file)
1891 unlink (response_file);
1892 response_file = NULL;
1897 /* Execute a program, and wait for the reply. */
1899 struct pex_obj *
1900 collect_execute (const char *prog, char **argv, const char *outname,
1901 const char *errname, int flags)
1903 struct pex_obj *pex;
1904 const char *errmsg;
1905 int err;
1906 char *response_arg = NULL;
1907 char *response_argv[3] ATTRIBUTE_UNUSED;
1909 if (HAVE_GNU_LD && at_file_supplied && argv[0] != NULL)
1911 /* If using @file arguments, create a temporary file and put the
1912 contents of argv into it. Then change argv to an array corresponding
1913 to a single argument @FILE, where FILE is the temporary filename. */
1915 char **current_argv = argv + 1;
1916 char *argv0 = argv[0];
1917 int status;
1918 FILE *f;
1920 /* Note: we assume argv contains at least one element; this is
1921 checked above. */
1923 response_file = make_temp_file ("");
1925 f = fopen (response_file, "w");
1927 if (f == NULL)
1928 fatal_error ("could not open response file %s", response_file);
1930 status = writeargv (current_argv, f);
1932 if (status)
1933 fatal_error ("could not write to response file %s", response_file);
1935 status = fclose (f);
1937 if (EOF == status)
1938 fatal_error ("could not close response file %s", response_file);
1940 response_arg = concat ("@", response_file, NULL);
1941 response_argv[0] = argv0;
1942 response_argv[1] = response_arg;
1943 response_argv[2] = NULL;
1945 argv = response_argv;
1948 if (vflag || debug)
1950 char **p_argv;
1951 const char *str;
1953 if (argv[0])
1954 fprintf (stderr, "%s", argv[0]);
1955 else
1956 notice ("[cannot find %s]", prog);
1958 for (p_argv = &argv[1]; (str = *p_argv) != (char *) 0; p_argv++)
1959 fprintf (stderr, " %s", str);
1961 fprintf (stderr, "\n");
1964 fflush (stdout);
1965 fflush (stderr);
1967 /* If we cannot find a program we need, complain error. Do this here
1968 since we might not end up needing something that we could not find. */
1970 if (argv[0] == 0)
1971 fatal_error ("cannot find '%s'", prog);
1973 pex = pex_init (0, "collect2", NULL);
1974 if (pex == NULL)
1975 fatal_error ("pex_init failed: %m");
1977 errmsg = pex_run (pex, flags, argv[0], argv, outname,
1978 errname, &err);
1979 if (errmsg != NULL)
1981 if (err != 0)
1983 errno = err;
1984 fatal_error ("%s: %m", _(errmsg));
1986 else
1987 fatal_error (errmsg);
1990 free (response_arg);
1992 return pex;
1995 static void
1996 fork_execute (const char *prog, char **argv)
1998 struct pex_obj *pex;
2000 pex = collect_execute (prog, argv, NULL, NULL, PEX_LAST | PEX_SEARCH);
2001 do_wait (prog, pex);
2004 /* Unlink FILE unless we are debugging or this is the output_file
2005 and we may not unlink it. */
2007 static void
2008 maybe_unlink (const char *file)
2010 if (debug)
2012 notice ("[Leaving %s]\n", file);
2013 return;
2016 if (file == output_file && !may_unlink_output_file)
2017 return;
2019 unlink_if_ordinary (file);
2022 /* Call maybe_unlink on the NULL-terminated list, FILE_LIST. */
2024 static void
2025 maybe_unlink_list (char **file_list)
2027 char **tmp = file_list;
2029 while (*tmp)
2030 maybe_unlink (*(tmp++));
2034 static long sequence_number = 0;
2036 /* Add a name to a linked list. */
2038 static void
2039 add_to_list (struct head *head_ptr, const char *name)
2041 struct id *newid
2042 = (struct id *) xcalloc (sizeof (struct id) + strlen (name), 1);
2043 struct id *p;
2044 strcpy (newid->name, name);
2046 if (head_ptr->first)
2047 head_ptr->last->next = newid;
2048 else
2049 head_ptr->first = newid;
2051 /* Check for duplicate symbols. */
2052 for (p = head_ptr->first;
2053 strcmp (name, p->name) != 0;
2054 p = p->next)
2056 if (p != newid)
2058 head_ptr->last->next = 0;
2059 free (newid);
2060 return;
2063 newid->sequence = ++sequence_number;
2064 head_ptr->last = newid;
2065 head_ptr->number++;
2068 /* Grab the init priority number from an init function name that
2069 looks like "_GLOBAL_.I.12345.foo". */
2071 static int
2072 extract_init_priority (const char *name)
2074 int pos = 0, pri;
2076 #ifdef TARGET_AIX_VERSION
2077 /* Run dependent module initializers before any constructors in this
2078 module. */
2079 switch (is_ctor_dtor (name))
2081 case SYM_AIXI:
2082 case SYM_AIXD:
2083 return INT_MIN;
2084 default:
2085 break;
2087 #endif
2089 while (name[pos] == '_')
2090 ++pos;
2091 pos += 10; /* strlen ("GLOBAL__X_") */
2093 /* Extract init_p number from ctor/dtor name. */
2094 pri = atoi (name + pos);
2095 return pri ? pri : DEFAULT_INIT_PRIORITY;
2098 /* Insertion sort the ids from ctor/dtor list HEAD_PTR in descending order.
2099 ctors will be run from right to left, dtors from left to right. */
2101 static void
2102 sort_ids (struct head *head_ptr)
2104 /* id holds the current element to insert. id_next holds the next
2105 element to insert. id_ptr iterates through the already sorted elements
2106 looking for the place to insert id. */
2107 struct id *id, *id_next, **id_ptr;
2109 id = head_ptr->first;
2111 /* We don't have any sorted elements yet. */
2112 head_ptr->first = NULL;
2114 for (; id; id = id_next)
2116 id_next = id->next;
2117 id->sequence = extract_init_priority (id->name);
2119 for (id_ptr = &(head_ptr->first); ; id_ptr = &((*id_ptr)->next))
2120 if (*id_ptr == NULL
2121 /* If the sequence numbers are the same, we put the id from the
2122 file later on the command line later in the list. */
2123 || id->sequence > (*id_ptr)->sequence
2124 /* Hack: do lexical compare, too.
2125 || (id->sequence == (*id_ptr)->sequence
2126 && strcmp (id->name, (*id_ptr)->name) > 0) */
2129 id->next = *id_ptr;
2130 *id_ptr = id;
2131 break;
2135 /* Now set the sequence numbers properly so write_c_file works. */
2136 for (id = head_ptr->first; id; id = id->next)
2137 id->sequence = ++sequence_number;
2140 /* Write: `prefix', the names on list LIST, `suffix'. */
2142 static void
2143 write_list (FILE *stream, const char *prefix, struct id *list)
2145 while (list)
2147 fprintf (stream, "%sx%d,\n", prefix, list->sequence);
2148 list = list->next;
2152 #ifdef COLLECT_EXPORT_LIST
2153 /* This function is really used only on AIX, but may be useful. */
2154 #if 0
2155 static int
2156 is_in_list (const char *prefix, struct id *list)
2158 while (list)
2160 if (!strcmp (prefix, list->name)) return 1;
2161 list = list->next;
2163 return 0;
2165 #endif
2166 #endif /* COLLECT_EXPORT_LIST */
2168 /* Added for debugging purpose. */
2169 #ifdef COLLECT_EXPORT_LIST
2170 static void
2171 dump_list (FILE *stream, const char *prefix, struct id *list)
2173 while (list)
2175 fprintf (stream, "%s%s,\n", prefix, list->name);
2176 list = list->next;
2179 #endif
2181 #if 0
2182 static void
2183 dump_prefix_list (FILE *stream, const char *prefix, struct prefix_list *list)
2185 while (list)
2187 fprintf (stream, "%s%s,\n", prefix, list->prefix);
2188 list = list->next;
2191 #endif
2193 static void
2194 write_list_with_asm (FILE *stream, const char *prefix, struct id *list)
2196 while (list)
2198 fprintf (stream, "%sx%d __asm__ (\"%s\");\n",
2199 prefix, list->sequence, list->name);
2200 list = list->next;
2204 /* Write out the constructor and destructor tables statically (for a shared
2205 object), along with the functions to execute them. */
2207 static void
2208 write_c_file_stat (FILE *stream, const char *name ATTRIBUTE_UNUSED)
2210 const char *p, *q;
2211 char *prefix, *r;
2212 int frames = (frame_tables.number > 0);
2214 /* Figure out name of output_file, stripping off .so version. */
2215 q = p = lbasename (output_file);
2217 while (q)
2219 q = strchr (q,'.');
2220 if (q == 0)
2222 q = p + strlen (p);
2223 break;
2225 else
2227 if (filename_ncmp (q, SHLIB_SUFFIX, strlen (SHLIB_SUFFIX)) == 0)
2229 q += strlen (SHLIB_SUFFIX);
2230 break;
2232 else
2233 q++;
2236 /* q points to null at end of the string (or . of the .so version) */
2237 prefix = XNEWVEC (char, q - p + 1);
2238 strncpy (prefix, p, q - p);
2239 prefix[q - p] = 0;
2240 for (r = prefix; *r; r++)
2241 if (!ISALNUM ((unsigned char)*r))
2242 *r = '_';
2243 if (debug)
2244 notice ("\nwrite_c_file - output name is %s, prefix is %s\n",
2245 output_file, prefix);
2247 initname = concat ("_GLOBAL__FI_", prefix, NULL);
2248 fininame = concat ("_GLOBAL__FD_", prefix, NULL);
2249 #ifdef TARGET_AIX_VERSION
2250 aix_shared_initname = concat ("_GLOBAL__AIXI_", prefix, NULL);
2251 aix_shared_fininame = concat ("_GLOBAL__AIXD_", prefix, NULL);
2252 #endif
2254 free (prefix);
2256 /* Write the tables as C code. */
2258 /* This count variable is used to prevent multiple calls to the
2259 constructors/destructors.
2260 This guard against multiple calls is important on AIX as the initfini
2261 functions are deliberately invoked multiple times as part of the
2262 mechanisms GCC uses to order constructors across different dependent
2263 shared libraries (see config/rs6000/aix.h).
2265 fprintf (stream, "static int count;\n");
2266 fprintf (stream, "typedef void entry_pt();\n");
2267 write_list_with_asm (stream, "extern entry_pt ", constructors.first);
2269 if (frames)
2271 write_list_with_asm (stream, "extern void *", frame_tables.first);
2273 fprintf (stream, "\tstatic void *frame_table[] = {\n");
2274 write_list (stream, "\t\t&", frame_tables.first);
2275 fprintf (stream, "\t0\n};\n");
2277 /* This must match what's in frame.h. */
2278 fprintf (stream, "struct object {\n");
2279 fprintf (stream, " void *pc_begin;\n");
2280 fprintf (stream, " void *pc_end;\n");
2281 fprintf (stream, " void *fde_begin;\n");
2282 fprintf (stream, " void *fde_array;\n");
2283 fprintf (stream, " __SIZE_TYPE__ count;\n");
2284 fprintf (stream, " struct object *next;\n");
2285 fprintf (stream, "};\n");
2287 fprintf (stream, "extern void __register_frame_info_table (void *, struct object *);\n");
2288 fprintf (stream, "extern void *__deregister_frame_info (void *);\n");
2290 fprintf (stream, "static void reg_frame () {\n");
2291 fprintf (stream, "\tstatic struct object ob;\n");
2292 fprintf (stream, "\t__register_frame_info_table (frame_table, &ob);\n");
2293 fprintf (stream, "\t}\n");
2295 fprintf (stream, "static void dereg_frame () {\n");
2296 fprintf (stream, "\t__deregister_frame_info (frame_table);\n");
2297 fprintf (stream, "\t}\n");
2300 fprintf (stream, "void %s() {\n", initname);
2301 if (constructors.number > 0 || frames)
2303 fprintf (stream, "\tstatic entry_pt *ctors[] = {\n");
2304 write_list (stream, "\t\t", constructors.first);
2305 if (frames)
2306 fprintf (stream, "\treg_frame,\n");
2307 fprintf (stream, "\t};\n");
2308 fprintf (stream, "\tentry_pt **p;\n");
2309 fprintf (stream, "\tif (count++ != 0) return;\n");
2310 fprintf (stream, "\tp = ctors + %d;\n", constructors.number + frames);
2311 fprintf (stream, "\twhile (p > ctors) (*--p)();\n");
2313 else
2314 fprintf (stream, "\t++count;\n");
2315 fprintf (stream, "}\n");
2316 write_list_with_asm (stream, "extern entry_pt ", destructors.first);
2317 fprintf (stream, "void %s() {\n", fininame);
2318 if (destructors.number > 0 || frames)
2320 fprintf (stream, "\tstatic entry_pt *dtors[] = {\n");
2321 write_list (stream, "\t\t", destructors.first);
2322 if (frames)
2323 fprintf (stream, "\tdereg_frame,\n");
2324 fprintf (stream, "\t};\n");
2325 fprintf (stream, "\tentry_pt **p;\n");
2326 fprintf (stream, "\tif (--count != 0) return;\n");
2327 fprintf (stream, "\tp = dtors;\n");
2328 fprintf (stream, "\twhile (p < dtors + %d) (*p++)();\n",
2329 destructors.number + frames);
2331 fprintf (stream, "}\n");
2333 if (shared_obj)
2335 COLLECT_SHARED_INIT_FUNC (stream, initname);
2336 COLLECT_SHARED_FINI_FUNC (stream, fininame);
2340 /* Write the constructor/destructor tables. */
2342 #ifndef LD_INIT_SWITCH
2343 static void
2344 write_c_file_glob (FILE *stream, const char *name ATTRIBUTE_UNUSED)
2346 /* Write the tables as C code. */
2348 int frames = (frame_tables.number > 0);
2350 fprintf (stream, "typedef void entry_pt();\n\n");
2352 write_list_with_asm (stream, "extern entry_pt ", constructors.first);
2354 if (frames)
2356 write_list_with_asm (stream, "extern void *", frame_tables.first);
2358 fprintf (stream, "\tstatic void *frame_table[] = {\n");
2359 write_list (stream, "\t\t&", frame_tables.first);
2360 fprintf (stream, "\t0\n};\n");
2362 /* This must match what's in frame.h. */
2363 fprintf (stream, "struct object {\n");
2364 fprintf (stream, " void *pc_begin;\n");
2365 fprintf (stream, " void *pc_end;\n");
2366 fprintf (stream, " void *fde_begin;\n");
2367 fprintf (stream, " void *fde_array;\n");
2368 fprintf (stream, " __SIZE_TYPE__ count;\n");
2369 fprintf (stream, " struct object *next;\n");
2370 fprintf (stream, "};\n");
2372 fprintf (stream, "extern void __register_frame_info_table (void *, struct object *);\n");
2373 fprintf (stream, "extern void *__deregister_frame_info (void *);\n");
2375 fprintf (stream, "static void reg_frame () {\n");
2376 fprintf (stream, "\tstatic struct object ob;\n");
2377 fprintf (stream, "\t__register_frame_info_table (frame_table, &ob);\n");
2378 fprintf (stream, "\t}\n");
2380 fprintf (stream, "static void dereg_frame () {\n");
2381 fprintf (stream, "\t__deregister_frame_info (frame_table);\n");
2382 fprintf (stream, "\t}\n");
2385 fprintf (stream, "\nentry_pt * __CTOR_LIST__[] = {\n");
2386 fprintf (stream, "\t(entry_pt *) %d,\n", constructors.number + frames);
2387 write_list (stream, "\t", constructors.first);
2388 if (frames)
2389 fprintf (stream, "\treg_frame,\n");
2390 fprintf (stream, "\t0\n};\n\n");
2392 write_list_with_asm (stream, "extern entry_pt ", destructors.first);
2394 fprintf (stream, "\nentry_pt * __DTOR_LIST__[] = {\n");
2395 fprintf (stream, "\t(entry_pt *) %d,\n", destructors.number + frames);
2396 write_list (stream, "\t", destructors.first);
2397 if (frames)
2398 fprintf (stream, "\tdereg_frame,\n");
2399 fprintf (stream, "\t0\n};\n\n");
2401 fprintf (stream, "extern entry_pt %s;\n", NAME__MAIN);
2402 fprintf (stream, "entry_pt *__main_reference = %s;\n\n", NAME__MAIN);
2404 #endif /* ! LD_INIT_SWITCH */
2406 static void
2407 write_c_file (FILE *stream, const char *name)
2409 #ifndef LD_INIT_SWITCH
2410 if (! shared_obj)
2411 write_c_file_glob (stream, name);
2412 else
2413 #endif
2414 write_c_file_stat (stream, name);
2417 #ifdef COLLECT_EXPORT_LIST
2418 static void
2419 write_aix_file (FILE *stream, struct id *list)
2421 for (; list; list = list->next)
2423 fputs (list->name, stream);
2424 putc ('\n', stream);
2427 #endif
2429 #ifdef OBJECT_FORMAT_NONE
2431 /* Check to make sure the file is an LTO object file. */
2433 static bool
2434 maybe_lto_object_file (const char *prog_name)
2436 FILE *f;
2437 unsigned char buf[4];
2438 int i;
2440 static unsigned char elfmagic[4] = { 0x7f, 'E', 'L', 'F' };
2441 static unsigned char coffmagic[2] = { 0x4c, 0x01 };
2442 static unsigned char coffmagic_x64[2] = { 0x64, 0x86 };
2443 static unsigned char machomagic[4][4] = {
2444 { 0xcf, 0xfa, 0xed, 0xfe },
2445 { 0xce, 0xfa, 0xed, 0xfe },
2446 { 0xfe, 0xed, 0xfa, 0xcf },
2447 { 0xfe, 0xed, 0xfa, 0xce }
2450 f = fopen (prog_name, "rb");
2451 if (f == NULL)
2452 return false;
2453 if (fread (buf, sizeof (buf), 1, f) != 1)
2454 buf[0] = 0;
2455 fclose (f);
2457 if (memcmp (buf, elfmagic, sizeof (elfmagic)) == 0
2458 || memcmp (buf, coffmagic, sizeof (coffmagic)) == 0
2459 || memcmp (buf, coffmagic_x64, sizeof (coffmagic_x64)) == 0)
2460 return true;
2461 for (i = 0; i < 4; i++)
2462 if (memcmp (buf, machomagic[i], sizeof (machomagic[i])) == 0)
2463 return true;
2465 return false;
2468 /* Generic version to scan the name list of the loaded program for
2469 the symbols g++ uses for static constructors and destructors. */
2471 static void
2472 scan_prog_file (const char *prog_name, scanpass which_pass,
2473 scanfilter filter)
2475 void (*int_handler) (int);
2476 #ifdef SIGQUIT
2477 void (*quit_handler) (int);
2478 #endif
2479 char *real_nm_argv[4];
2480 const char **nm_argv = CONST_CAST2 (const char **, char**, real_nm_argv);
2481 int argc = 0;
2482 struct pex_obj *pex;
2483 const char *errmsg;
2484 int err;
2485 char *p, buf[1024];
2486 FILE *inf;
2487 int found_lto = 0;
2489 if (which_pass == PASS_SECOND)
2490 return;
2492 /* LTO objects must be in a known format. This check prevents
2493 us from accepting an archive containing LTO objects, which
2494 gcc cannot currently handle. */
2495 if (which_pass == PASS_LTOINFO && !maybe_lto_object_file (prog_name))
2496 return;
2498 /* If we do not have an `nm', complain. */
2499 if (nm_file_name == 0)
2500 fatal_error ("cannot find 'nm'");
2502 nm_argv[argc++] = nm_file_name;
2503 if (NM_FLAGS[0] != '\0')
2504 nm_argv[argc++] = NM_FLAGS;
2506 nm_argv[argc++] = prog_name;
2507 nm_argv[argc++] = (char *) 0;
2509 /* Trace if needed. */
2510 if (vflag)
2512 const char **p_argv;
2513 const char *str;
2515 for (p_argv = &nm_argv[0]; (str = *p_argv) != (char *) 0; p_argv++)
2516 fprintf (stderr, " %s", str);
2518 fprintf (stderr, "\n");
2521 fflush (stdout);
2522 fflush (stderr);
2524 pex = pex_init (PEX_USE_PIPES, "collect2", NULL);
2525 if (pex == NULL)
2526 fatal_error ("pex_init failed: %m");
2528 errmsg = pex_run (pex, 0, nm_file_name, real_nm_argv, NULL, HOST_BIT_BUCKET,
2529 &err);
2530 if (errmsg != NULL)
2532 if (err != 0)
2534 errno = err;
2535 fatal_error ("%s: %m", _(errmsg));
2537 else
2538 fatal_error (errmsg);
2541 int_handler = (void (*) (int)) signal (SIGINT, SIG_IGN);
2542 #ifdef SIGQUIT
2543 quit_handler = (void (*) (int)) signal (SIGQUIT, SIG_IGN);
2544 #endif
2546 inf = pex_read_output (pex, 0);
2547 if (inf == NULL)
2548 fatal_error ("can't open nm output: %m");
2550 if (debug)
2552 if (which_pass == PASS_LTOINFO)
2553 fprintf (stderr, "\nnm output with LTO info marker symbol.\n");
2554 else
2555 fprintf (stderr, "\nnm output with constructors/destructors.\n");
2558 /* Read each line of nm output. */
2559 while (fgets (buf, sizeof buf, inf) != (char *) 0)
2561 int ch, ch2;
2562 char *name, *end;
2564 if (debug)
2565 fprintf (stderr, "\t%s\n", buf);
2567 if (which_pass == PASS_LTOINFO)
2569 if (found_lto)
2570 continue;
2572 /* Look for the LTO info marker symbol, and add filename to
2573 the LTO objects list if found. */
2574 for (p = buf; (ch = *p) != '\0' && ch != '\n'; p++)
2575 if (ch == ' ' && p[1] == '_' && p[2] == '_'
2576 && (strncmp (p + (p[3] == '_' ? 2 : 1), "__gnu_lto_v1", 12) == 0)
2577 && ISSPACE (p[p[3] == '_' ? 14 : 13]))
2579 add_lto_object (&lto_objects, prog_name);
2581 /* We need to read all the input, so we can't just
2582 return here. But we can avoid useless work. */
2583 found_lto = 1;
2585 break;
2588 continue;
2591 /* If it contains a constructor or destructor name, add the name
2592 to the appropriate list unless this is a kind of symbol we're
2593 not supposed to even consider. */
2595 for (p = buf; (ch = *p) != '\0' && ch != '\n' && ch != '_'; p++)
2596 if (ch == ' ' && p[1] == 'U' && p[2] == ' ')
2597 break;
2599 if (ch != '_')
2600 continue;
2602 name = p;
2603 /* Find the end of the symbol name.
2604 Do not include `|', because Encore nm can tack that on the end. */
2605 for (end = p; (ch2 = *end) != '\0' && !ISSPACE (ch2) && ch2 != '|';
2606 end++)
2607 continue;
2610 *end = '\0';
2612 switch (is_ctor_dtor (name))
2614 case SYM_CTOR:
2615 if (! (filter & SCAN_CTOR))
2616 break;
2617 if (which_pass != PASS_LIB)
2618 add_to_list (&constructors, name);
2619 break;
2621 case SYM_DTOR:
2622 if (! (filter & SCAN_DTOR))
2623 break;
2624 if (which_pass != PASS_LIB)
2625 add_to_list (&destructors, name);
2626 break;
2628 case SYM_INIT:
2629 if (! (filter & SCAN_INIT))
2630 break;
2631 if (which_pass != PASS_LIB)
2632 fatal_error ("init function found in object %s", prog_name);
2633 #ifndef LD_INIT_SWITCH
2634 add_to_list (&constructors, name);
2635 #endif
2636 break;
2638 case SYM_FINI:
2639 if (! (filter & SCAN_FINI))
2640 break;
2641 if (which_pass != PASS_LIB)
2642 fatal_error ("fini function found in object %s", prog_name);
2643 #ifndef LD_FINI_SWITCH
2644 add_to_list (&destructors, name);
2645 #endif
2646 break;
2648 case SYM_DWEH:
2649 if (! (filter & SCAN_DWEH))
2650 break;
2651 if (which_pass != PASS_LIB)
2652 add_to_list (&frame_tables, name);
2653 break;
2655 default: /* not a constructor or destructor */
2656 continue;
2660 if (debug)
2661 fprintf (stderr, "\n");
2663 do_wait (nm_file_name, pex);
2665 signal (SIGINT, int_handler);
2666 #ifdef SIGQUIT
2667 signal (SIGQUIT, quit_handler);
2668 #endif
2671 #ifdef LDD_SUFFIX
2673 /* Use the List Dynamic Dependencies program to find shared libraries that
2674 the output file depends upon and their initialization/finalization
2675 routines, if any. */
2677 static void
2678 scan_libraries (const char *prog_name)
2680 static struct head libraries; /* list of shared libraries found */
2681 struct id *list;
2682 void (*int_handler) (int);
2683 #ifdef SIGQUIT
2684 void (*quit_handler) (int);
2685 #endif
2686 char *real_ldd_argv[4];
2687 const char **ldd_argv = CONST_CAST2 (const char **, char **, real_ldd_argv);
2688 int argc = 0;
2689 struct pex_obj *pex;
2690 const char *errmsg;
2691 int err;
2692 char buf[1024];
2693 FILE *inf;
2695 /* If we do not have an `ldd', complain. */
2696 if (ldd_file_name == 0)
2698 error ("cannot find 'ldd'");
2699 return;
2702 ldd_argv[argc++] = ldd_file_name;
2703 ldd_argv[argc++] = prog_name;
2704 ldd_argv[argc++] = (char *) 0;
2706 /* Trace if needed. */
2707 if (vflag)
2709 const char **p_argv;
2710 const char *str;
2712 for (p_argv = &ldd_argv[0]; (str = *p_argv) != (char *) 0; p_argv++)
2713 fprintf (stderr, " %s", str);
2715 fprintf (stderr, "\n");
2718 fflush (stdout);
2719 fflush (stderr);
2721 pex = pex_init (PEX_USE_PIPES, "collect2", NULL);
2722 if (pex == NULL)
2723 fatal_error ("pex_init failed: %m");
2725 errmsg = pex_run (pex, 0, ldd_file_name, real_ldd_argv, NULL, NULL, &err);
2726 if (errmsg != NULL)
2728 if (err != 0)
2730 errno = err;
2731 fatal_error ("%s: %m", _(errmsg));
2733 else
2734 fatal_error (errmsg);
2737 int_handler = (void (*) (int)) signal (SIGINT, SIG_IGN);
2738 #ifdef SIGQUIT
2739 quit_handler = (void (*) (int)) signal (SIGQUIT, SIG_IGN);
2740 #endif
2742 inf = pex_read_output (pex, 0);
2743 if (inf == NULL)
2744 fatal_error ("can't open ldd output: %m");
2746 if (debug)
2747 notice ("\nldd output with constructors/destructors.\n");
2749 /* Read each line of ldd output. */
2750 while (fgets (buf, sizeof buf, inf) != (char *) 0)
2752 int ch2;
2753 char *name, *end, *p = buf;
2755 /* Extract names of libraries and add to list. */
2756 PARSE_LDD_OUTPUT (p);
2757 if (p == 0)
2758 continue;
2760 name = p;
2761 if (strncmp (name, "not found", sizeof ("not found") - 1) == 0)
2762 fatal_error ("dynamic dependency %s not found", buf);
2764 /* Find the end of the symbol name. */
2765 for (end = p;
2766 (ch2 = *end) != '\0' && ch2 != '\n' && !ISSPACE (ch2) && ch2 != '|';
2767 end++)
2768 continue;
2769 *end = '\0';
2771 if (access (name, R_OK) == 0)
2772 add_to_list (&libraries, name);
2773 else
2774 fatal_error ("unable to open dynamic dependency '%s'", buf);
2776 if (debug)
2777 fprintf (stderr, "\t%s\n", buf);
2779 if (debug)
2780 fprintf (stderr, "\n");
2782 do_wait (ldd_file_name, pex);
2784 signal (SIGINT, int_handler);
2785 #ifdef SIGQUIT
2786 signal (SIGQUIT, quit_handler);
2787 #endif
2789 /* Now iterate through the library list adding their symbols to
2790 the list. */
2791 for (list = libraries.first; list; list = list->next)
2792 scan_prog_file (list->name, PASS_LIB, SCAN_ALL);
2795 #endif /* LDD_SUFFIX */
2797 #endif /* OBJECT_FORMAT_NONE */
2801 * COFF specific stuff.
2804 #ifdef OBJECT_FORMAT_COFF
2806 #if defined (EXTENDED_COFF)
2808 # define GCC_SYMBOLS(X) (SYMHEADER (X).isymMax + SYMHEADER (X).iextMax)
2809 # define GCC_SYMENT SYMR
2810 # define GCC_OK_SYMBOL(X) ((X).st == stProc || (X).st == stGlobal)
2811 # define GCC_SYMINC(X) (1)
2812 # define GCC_SYMZERO(X) (SYMHEADER (X).isymMax)
2813 # define GCC_CHECK_HDR(X) (PSYMTAB (X) != 0)
2815 #else
2817 # define GCC_SYMBOLS(X) (HEADER (ldptr).f_nsyms)
2818 # define GCC_SYMENT SYMENT
2819 # if defined (C_WEAKEXT)
2820 # define GCC_OK_SYMBOL(X) \
2821 (((X).n_sclass == C_EXT || (X).n_sclass == C_WEAKEXT) && \
2822 ((X).n_scnum > N_UNDEF) && \
2823 (aix64_flag \
2824 || (((X).n_type & N_TMASK) == (DT_NON << N_BTSHFT) \
2825 || ((X).n_type & N_TMASK) == (DT_FCN << N_BTSHFT))))
2826 # define GCC_UNDEF_SYMBOL(X) \
2827 (((X).n_sclass == C_EXT || (X).n_sclass == C_WEAKEXT) && \
2828 ((X).n_scnum == N_UNDEF))
2829 # else
2830 # define GCC_OK_SYMBOL(X) \
2831 (((X).n_sclass == C_EXT) && \
2832 ((X).n_scnum > N_UNDEF) && \
2833 (aix64_flag \
2834 || (((X).n_type & N_TMASK) == (DT_NON << N_BTSHFT) \
2835 || ((X).n_type & N_TMASK) == (DT_FCN << N_BTSHFT))))
2836 # define GCC_UNDEF_SYMBOL(X) \
2837 (((X).n_sclass == C_EXT) && ((X).n_scnum == N_UNDEF))
2838 # endif
2839 # define GCC_SYMINC(X) ((X).n_numaux+1)
2840 # define GCC_SYMZERO(X) 0
2842 /* 0757 = U803XTOCMAGIC (AIX 4.3) and 0767 = U64_TOCMAGIC (AIX V5) */
2843 #if TARGET_AIX_VERSION >= 51
2844 # define GCC_CHECK_HDR(X) \
2845 (((HEADER (X).f_magic == U802TOCMAGIC && ! aix64_flag) \
2846 || (HEADER (X).f_magic == 0767 && aix64_flag)) \
2847 && !(HEADER (X).f_flags & F_LOADONLY))
2848 #else
2849 # define GCC_CHECK_HDR(X) \
2850 (((HEADER (X).f_magic == U802TOCMAGIC && ! aix64_flag) \
2851 || (HEADER (X).f_magic == 0757 && aix64_flag)) \
2852 && !(HEADER (X).f_flags & F_LOADONLY))
2853 #endif
2855 #endif
2857 #ifdef COLLECT_EXPORT_LIST
2858 /* Array of standard AIX libraries which should not
2859 be scanned for ctors/dtors. */
2860 static const char *const aix_std_libs[] = {
2861 "/unix",
2862 "/lib/libc.a",
2863 "/lib/libm.a",
2864 "/lib/libc_r.a",
2865 "/lib/libm_r.a",
2866 "/usr/lib/libc.a",
2867 "/usr/lib/libm.a",
2868 "/usr/lib/libc_r.a",
2869 "/usr/lib/libm_r.a",
2870 "/usr/lib/threads/libc.a",
2871 "/usr/ccs/lib/libc.a",
2872 "/usr/ccs/lib/libm.a",
2873 "/usr/ccs/lib/libc_r.a",
2874 "/usr/ccs/lib/libm_r.a",
2875 NULL
2878 /* This function checks the filename and returns 1
2879 if this name matches the location of a standard AIX library. */
2880 static int ignore_library (const char *);
2881 static int
2882 ignore_library (const char *name)
2884 const char *const *p;
2885 size_t length;
2887 if (target_system_root[0] != '\0')
2889 length = strlen (target_system_root);
2890 if (strncmp (name, target_system_root, length) != 0)
2891 return 0;
2892 name += length;
2894 for (p = &aix_std_libs[0]; *p != NULL; ++p)
2895 if (strcmp (name, *p) == 0)
2896 return 1;
2897 return 0;
2899 #endif /* COLLECT_EXPORT_LIST */
2901 #if defined (HAVE_DECL_LDGETNAME) && !HAVE_DECL_LDGETNAME
2902 extern char *ldgetname (LDFILE *, GCC_SYMENT *);
2903 #endif
2905 /* COFF version to scan the name list of the loaded program for
2906 the symbols g++ uses for static constructors and destructors. */
2908 static void
2909 scan_prog_file (const char *prog_name, scanpass which_pass,
2910 scanfilter filter)
2912 LDFILE *ldptr = NULL;
2913 int sym_index, sym_count;
2914 int is_shared = 0;
2916 if (which_pass != PASS_FIRST && which_pass != PASS_OBJ)
2917 return;
2919 #ifdef COLLECT_EXPORT_LIST
2920 /* We do not need scanning for some standard C libraries. */
2921 if (which_pass == PASS_FIRST && ignore_library (prog_name))
2922 return;
2924 /* On AIX we have a loop, because there is not much difference
2925 between an object and an archive. This trick allows us to
2926 eliminate scan_libraries() function. */
2929 #endif
2930 /* Some platforms (e.g. OSF4) declare ldopen as taking a
2931 non-const char * filename parameter, even though it will not
2932 modify that string. So we must cast away const-ness here,
2933 using CONST_CAST to prevent complaints from -Wcast-qual. */
2934 if ((ldptr = ldopen (CONST_CAST (char *, prog_name), ldptr)) != NULL)
2936 if (! MY_ISCOFF (HEADER (ldptr).f_magic))
2937 fatal_error ("%s: not a COFF file", prog_name);
2939 if (GCC_CHECK_HDR (ldptr))
2941 sym_count = GCC_SYMBOLS (ldptr);
2942 sym_index = GCC_SYMZERO (ldptr);
2944 #ifdef COLLECT_EXPORT_LIST
2945 /* Is current archive member a shared object? */
2946 is_shared = HEADER (ldptr).f_flags & F_SHROBJ;
2947 #endif
2949 while (sym_index < sym_count)
2951 GCC_SYMENT symbol;
2953 if (ldtbread (ldptr, sym_index, &symbol) <= 0)
2954 break;
2955 sym_index += GCC_SYMINC (symbol);
2957 if (GCC_OK_SYMBOL (symbol))
2959 char *name;
2961 if ((name = ldgetname (ldptr, &symbol)) == NULL)
2962 continue; /* Should never happen. */
2964 #ifdef XCOFF_DEBUGGING_INFO
2965 /* All AIX function names have a duplicate entry
2966 beginning with a dot. */
2967 if (*name == '.')
2968 ++name;
2969 #endif
2971 switch (is_ctor_dtor (name))
2973 #if TARGET_AIX_VERSION
2974 /* Add AIX shared library initalisers/finalisers
2975 to the constructors/destructors list of the
2976 current module. */
2977 case SYM_AIXI:
2978 if (! (filter & SCAN_CTOR))
2979 break;
2980 if (is_shared && !aixlazy_flag)
2981 add_to_list (&constructors, name);
2982 break;
2984 case SYM_AIXD:
2985 if (! (filter & SCAN_DTOR))
2986 break;
2987 if (is_shared && !aixlazy_flag)
2988 add_to_list (&destructors, name);
2989 break;
2990 #endif
2992 case SYM_CTOR:
2993 if (! (filter & SCAN_CTOR))
2994 break;
2995 if (! is_shared)
2996 add_to_list (&constructors, name);
2997 #if defined (COLLECT_EXPORT_LIST) && !defined (LD_INIT_SWITCH)
2998 if (which_pass == PASS_OBJ)
2999 add_to_list (&exports, name);
3000 #endif
3001 break;
3003 case SYM_DTOR:
3004 if (! (filter & SCAN_DTOR))
3005 break;
3006 if (! is_shared)
3007 add_to_list (&destructors, name);
3008 #if defined (COLLECT_EXPORT_LIST) && !defined (LD_INIT_SWITCH)
3009 if (which_pass == PASS_OBJ)
3010 add_to_list (&exports, name);
3011 #endif
3012 break;
3014 #ifdef COLLECT_EXPORT_LIST
3015 case SYM_INIT:
3016 if (! (filter & SCAN_INIT))
3017 break;
3018 #ifndef LD_INIT_SWITCH
3019 if (is_shared)
3020 add_to_list (&constructors, name);
3021 #endif
3022 break;
3024 case SYM_FINI:
3025 if (! (filter & SCAN_FINI))
3026 break;
3027 #ifndef LD_INIT_SWITCH
3028 if (is_shared)
3029 add_to_list (&destructors, name);
3030 #endif
3031 break;
3032 #endif
3034 case SYM_DWEH:
3035 if (! (filter & SCAN_DWEH))
3036 break;
3037 if (! is_shared)
3038 add_to_list (&frame_tables, name);
3039 #if defined (COLLECT_EXPORT_LIST) && !defined (LD_INIT_SWITCH)
3040 if (which_pass == PASS_OBJ)
3041 add_to_list (&exports, name);
3042 #endif
3043 break;
3045 default: /* not a constructor or destructor */
3046 #ifdef COLLECT_EXPORT_LIST
3047 /* Explicitly export all global symbols when
3048 building a shared object on AIX, but do not
3049 re-export symbols from another shared object
3050 and do not export symbols if the user
3051 provides an explicit export list. */
3052 if (shared_obj && !is_shared
3053 && which_pass == PASS_OBJ && !export_flag)
3054 add_to_list (&exports, name);
3055 #endif
3056 continue;
3059 if (debug)
3060 #if !defined(EXTENDED_COFF)
3061 fprintf (stderr, "\tsec=%d class=%d type=%s%o %s\n",
3062 symbol.n_scnum, symbol.n_sclass,
3063 (symbol.n_type ? "0" : ""), symbol.n_type,
3064 name);
3065 #else
3066 fprintf (stderr,
3067 "\tiss = %5d, value = %5ld, index = %5d, name = %s\n",
3068 symbol.iss, (long) symbol.value, symbol.index, name);
3069 #endif
3073 #ifdef COLLECT_EXPORT_LIST
3074 else
3076 /* If archive contains both 32-bit and 64-bit objects,
3077 we want to skip objects in other mode so mismatch normal. */
3078 if (debug)
3079 fprintf (stderr, "%s : magic=%o aix64=%d mismatch\n",
3080 prog_name, HEADER (ldptr).f_magic, aix64_flag);
3082 #endif
3084 else
3086 fatal_error ("%s: cannot open as COFF file", prog_name);
3088 #ifdef COLLECT_EXPORT_LIST
3089 /* On AIX loop continues while there are more members in archive. */
3091 while (ldclose (ldptr) == FAILURE);
3092 #else
3093 /* Otherwise we simply close ldptr. */
3094 (void) ldclose (ldptr);
3095 #endif
3097 #endif /* OBJECT_FORMAT_COFF */
3099 #ifdef COLLECT_EXPORT_LIST
3100 /* Given a library name without "lib" prefix, this function
3101 returns a full library name including a path. */
3102 static char *
3103 resolve_lib_name (const char *name)
3105 char *lib_buf;
3106 int i, j, l = 0;
3107 /* Library extensions for AIX dynamic linking. */
3108 const char * const libexts[2] = {"a", "so"};
3110 for (i = 0; libpaths[i]; i++)
3111 if (libpaths[i]->max_len > l)
3112 l = libpaths[i]->max_len;
3114 lib_buf = XNEWVEC (char, l + strlen (name) + 10);
3116 for (i = 0; libpaths[i]; i++)
3118 struct prefix_list *list = libpaths[i]->plist;
3119 for (; list; list = list->next)
3121 /* The following lines are needed because path_prefix list
3122 may contain directories both with trailing DIR_SEPARATOR and
3123 without it. */
3124 const char *p = "";
3125 if (!IS_DIR_SEPARATOR (list->prefix[strlen (list->prefix)-1]))
3126 p = "/";
3127 for (j = 0; j < 2; j++)
3129 sprintf (lib_buf, "%s%slib%s.%s",
3130 list->prefix, p, name,
3131 libexts[(j + aixrtl_flag) % 2]);
3132 if (debug) fprintf (stderr, "searching for: %s\n", lib_buf);
3133 if (file_exists (lib_buf))
3135 if (debug) fprintf (stderr, "found: %s\n", lib_buf);
3136 return (lib_buf);
3141 if (debug)
3142 fprintf (stderr, "not found\n");
3143 else
3144 fatal_error ("library lib%s not found", name);
3145 return (NULL);
3147 #endif /* COLLECT_EXPORT_LIST */
3149 #ifdef COLLECT_RUN_DSYMUTIL
3150 static int flag_dsym = false;
3151 static int flag_idsym = false;
3153 static void
3154 process_args (int *argcp, char **argv) {
3155 int i, j;
3156 int argc = *argcp;
3157 for (i=0; i<argc; ++i)
3159 if (strcmp (argv[i], "-dsym") == 0)
3161 flag_dsym = true;
3162 /* Remove the flag, as we handle all processing for it. */
3163 j = i;
3165 argv[j] = argv[j+1];
3166 while (++j < argc);
3167 --i;
3168 argc = --(*argcp);
3170 else if (strcmp (argv[i], "-idsym") == 0)
3172 flag_idsym = true;
3173 /* Remove the flag, as we handle all processing for it. */
3174 j = i;
3176 argv[j] = argv[j+1];
3177 while (++j < argc);
3178 --i;
3179 argc = --(*argcp);
3184 static void
3185 do_dsymutil (const char *output_file) {
3186 const char *dsymutil = DSYMUTIL + 1;
3187 struct pex_obj *pex;
3188 char **real_argv = XCNEWVEC (char *, 3);
3189 const char ** argv = CONST_CAST2 (const char **, char **,
3190 real_argv);
3192 argv[0] = dsymutil;
3193 argv[1] = output_file;
3194 argv[2] = (char *) 0;
3196 pex = collect_execute (dsymutil, real_argv, NULL, NULL, PEX_LAST | PEX_SEARCH);
3197 do_wait (dsymutil, pex);
3200 static void
3201 post_ld_pass (bool temp_file) {
3202 if (!(temp_file && flag_idsym) && !flag_dsym)
3203 return;
3205 do_dsymutil (output_file);
3207 #else
3208 static void
3209 process_args (int *argcp ATTRIBUTE_UNUSED, char **argv ATTRIBUTE_UNUSED) { }
3210 static void post_ld_pass (bool temp_file ATTRIBUTE_UNUSED) { }
3211 #endif