]> git.ipfire.org Git - thirdparty/gcc.git/blob - gcc/collect2.c
Merge with trunk.
[thirdparty/gcc.git] / gcc / collect2.c
1 /* Collect static initialization info into data structures that can be
2 traversed by C++ initialization and finalization routines.
3 Copyright (C) 1992-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).
7
8 This file is part of GCC.
9
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.
14
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.
19
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/>. */
23
24
25 /* Build tables of static constructors and destructors and run ld. */
26
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"
33
34 /* TARGET_64BIT may be defined to use driver specific functionality. */
35 #undef TARGET_64BIT
36 #define TARGET_64BIT TARGET_64BIT_DEFAULT
37
38 #ifndef LIBRARY_PATH_ENV
39 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
40 #endif
41
42 #define COLLECT
43
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"
51 \f
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. */
57
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
67
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. */
72
73 #if !defined (OBJECT_FORMAT_COFF)
74 #define OBJECT_FORMAT_NONE
75 #endif
76
77 #ifdef OBJECT_FORMAT_COFF
78
79 #ifndef CROSS_DIRECTORY_STRUCTURE
80 #include <a.out.h>
81 #include <ar.h>
82
83 #ifdef UMAX
84 #include <sgs.h>
85 #endif
86
87 /* Many versions of ldfcn.h define these. */
88 #ifdef FREAD
89 #undef FREAD
90 #undef FWRITE
91 #endif
92
93 #include <ldfcn.h>
94 #endif
95
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. */
100
101 #ifndef MY_ISCOFF
102 #define MY_ISCOFF(X) ISCOFF (X)
103 #endif
104
105 #endif /* OBJECT_FORMAT_COFF */
106
107 #ifdef OBJECT_FORMAT_NONE
108
109 /* Default flags to pass to nm. */
110 #ifndef NM_FLAGS
111 #define NM_FLAGS "-n"
112 #endif
113
114 #endif /* OBJECT_FORMAT_NONE */
115
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
122
123 /* This must match tree.h. */
124 #define DEFAULT_INIT_PRIORITY 65535
125
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
134
135 #ifdef LDD_SUFFIX
136 #define SCAN_LIBRARIES
137 #endif
138
139 #ifndef SHLIB_SUFFIX
140 #define SHLIB_SUFFIX ".so"
141 #endif
142
143 #ifdef USE_COLLECT2
144 int do_collecting = 1;
145 #else
146 int do_collecting = 0;
147 #endif
148
149 /* Cook up an always defined indication of whether we proceed the
150 "EXPORT_LIST" way. */
151
152 #ifdef COLLECT_EXPORT_LIST
153 #define DO_COLLECT_EXPORT_LIST 1
154 #else
155 #define DO_COLLECT_EXPORT_LIST 0
156 #endif
157
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;
161 \f
162 /* Linked lists of constructor and destructor names. */
163
164 struct id
165 {
166 struct id *next;
167 int sequence;
168 char name[1];
169 };
170
171 struct head
172 {
173 struct id *first;
174 struct id *last;
175 int number;
176 };
177
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
187
188 enum lto_mode_d {
189 LTO_MODE_NONE, /* Not doing LTO. */
190 LTO_MODE_LTO, /* Normal LTO. */
191 LTO_MODE_WHOPR /* WHOPR. */
192 };
193
194 /* Current LTO mode. */
195 static enum lto_mode_d lto_mode = LTO_MODE_NONE;
196
197 bool debug; /* true if -debug */
198 bool helpflag; /* true if --help */
199
200 static int shared_obj; /* true if -shared */
201
202 static const char *c_file; /* <xxx>.c for constructor/destructor list. */
203 static const char *o_file; /* <xxx>.o for constructor/destructor list. */
204 #ifdef COLLECT_EXPORT_LIST
205 static const char *export_file; /* <xxx>.x for AIX export list. */
206 #endif
207 static char **lto_o_files; /* Output files for LTO. */
208 const char *ldout; /* File for ld stdout. */
209 const char *lderrout; /* File for ld stderr. */
210 static const char *output_file; /* Output file for ld. */
211 static const char *nm_file_name; /* pathname of nm */
212 #ifdef LDD_SUFFIX
213 static const char *ldd_file_name; /* pathname of ldd (or equivalent) */
214 #endif
215 static const char *strip_file_name; /* pathname of strip */
216 const char *c_file_name; /* pathname of gcc */
217 static char *initname, *fininame; /* names of init and fini funcs */
218
219
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
225
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 */
232
233 static bool at_file_supplied; /* Whether to use @file arguments */
234 static char *response_file; /* Name of any current response file */
235
236 struct obstack temporary_obstack;
237 char * temporary_firstobj;
238
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
246
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;
252
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
261
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(). */
266
267 struct lto_object
268 {
269 const char *name; /* Name of object file. */
270 struct lto_object *next; /* Next in linked list. */
271 };
272
273 struct lto_object_list
274 {
275 struct lto_object *first; /* First list element. */
276 struct lto_object *last; /* Last list element. */
277 };
278
279 static struct lto_object_list lto_objects;
280
281 /* Special kinds of symbols that a name may denote. */
282
283 typedef enum {
284 SYM_REGULAR = 0, /* nothing special */
285
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;
294
295 static symkind is_ctor_dtor (const char *);
296
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);
331
332 /* Enumerations describing which pass this is for scanning the
333 program file ... */
334
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;
342
343 /* ... and which kinds of symbols are to be considered. */
344
345 enum scanfilter_masks {
346 SCAN_NOTHING = 0,
347
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
356 };
357
358 /* This type is used for parameters and variables which hold
359 combinations of the flags in enum scanfilter_masks. */
360 typedef int scanfilter;
361
362 /* Scan the name list of the loaded program for the symbols g++ uses for
363 static constructors and destructors.
364
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.
369
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__. */
375
376 static void scan_prog_file (const char *, scanpass, scanfilter);
377
378 \f
379 /* Delete tempfiles and exit function. */
380
381 static void
382 collect_atexit (void)
383 {
384 if (c_file != 0 && c_file[0])
385 maybe_unlink (c_file);
386
387 if (o_file != 0 && o_file[0])
388 maybe_unlink (o_file);
389
390 #ifdef COLLECT_EXPORT_LIST
391 if (export_file != 0 && export_file[0])
392 maybe_unlink (export_file);
393 #endif
394
395 if (lto_o_files)
396 maybe_unlink_list (lto_o_files);
397
398 if (ldout != 0 && ldout[0])
399 {
400 dump_ld_file (ldout, stdout);
401 maybe_unlink (ldout);
402 }
403
404 if (lderrout != 0 && lderrout[0])
405 {
406 dump_ld_file (lderrout, stderr);
407 maybe_unlink (lderrout);
408 }
409
410 if (response_file)
411 maybe_unlink (response_file);
412 }
413
414 \f
415 /* Notify user of a non-error. */
416 void
417 notice (const char *cmsgid, ...)
418 {
419 va_list ap;
420
421 va_start (ap, cmsgid);
422 vfprintf (stderr, _(cmsgid), ap);
423 va_end (ap);
424 }
425
426 /* Notify user of a non-error, without translating the format string. */
427 void
428 notice_translated (const char *cmsgid, ...)
429 {
430 va_list ap;
431
432 va_start (ap, cmsgid);
433 vfprintf (stderr, cmsgid, ap);
434 va_end (ap);
435 }
436 \f
437 static void
438 handler (int signo)
439 {
440 if (c_file != 0 && c_file[0])
441 maybe_unlink (c_file);
442
443 if (o_file != 0 && o_file[0])
444 maybe_unlink (o_file);
445
446 if (ldout != 0 && ldout[0])
447 maybe_unlink (ldout);
448
449 if (lderrout != 0 && lderrout[0])
450 maybe_unlink (lderrout);
451
452 #ifdef COLLECT_EXPORT_LIST
453 if (export_file != 0 && export_file[0])
454 maybe_unlink (export_file);
455 #endif
456
457 if (lto_o_files)
458 maybe_unlink_list (lto_o_files);
459
460 if (response_file)
461 maybe_unlink (response_file);
462
463 signal (signo, SIG_DFL);
464 raise (signo);
465 }
466
467 \f
468 int
469 file_exists (const char *name)
470 {
471 return access (name, R_OK) == 0;
472 }
473
474 /* Parse a reasonable subset of shell quoting syntax. */
475
476 static char *
477 extract_string (const char **pp)
478 {
479 const char *p = *pp;
480 int backquote = 0;
481 int inside = 0;
482
483 for (;;)
484 {
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);
499 }
500
501 obstack_1grow (&temporary_obstack, '\0');
502 *pp = p;
503 return XOBFINISH (&temporary_obstack, char *);
504 }
505 \f
506 void
507 dump_ld_file (const char *name, FILE *to)
508 {
509 FILE *stream = fopen (name, "r");
510
511 if (stream == 0)
512 return;
513 while (1)
514 {
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)
520 {
521 const char *word, *p;
522 char *result;
523 obstack_1grow (&temporary_obstack, '\0');
524 word = XOBFINISH (&temporary_obstack, const char *);
525
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);
531
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
540
541 if (result)
542 {
543 int diff;
544 fputs (result, to);
545
546 diff = strlen (word) - strlen (result);
547 while (diff > 0 && c == ' ')
548 --diff, putc (' ', to);
549 if (diff < 0 && c == ' ')
550 {
551 while (diff < 0 && c == ' ')
552 ++diff, c = getc (stream);
553 if (!ISSPACE (c))
554 {
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);
559 }
560 }
561
562 free (result);
563 }
564 else
565 fputs (word, to);
566
567 fflush (to);
568 obstack_free (&temporary_obstack, temporary_firstobj);
569 }
570 if (c == EOF)
571 break;
572 putc (c, to);
573 }
574 fclose (stream);
575 }
576 \f
577 /* Return the kind of symbol denoted by name S. */
578
579 static symkind
580 is_ctor_dtor (const char *s)
581 {
582 struct names { const char *const name; const int len; symkind ret;
583 const int two_underscores; };
584
585 const struct names *p;
586 int ch;
587 const char *orig_s = s;
588
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 }
609 };
610
611 while ((ch = *s) == '_')
612 ++s;
613
614 if (s == orig_s)
615 return SYM_REGULAR;
616
617 for (p = &special[0]; p->len > 0; p++)
618 {
619 if (ch == p->name[0]
620 && (!p->two_underscores || ((s - orig_s) >= 2))
621 && strncmp (s, p->name, p->len) == 0)
622 {
623 return p->ret;
624 }
625 }
626 return SYM_REGULAR;
627 }
628 \f
629 /* We maintain two prefix lists: one from COMPILER_PATH environment variable
630 and one from the PATH variable. */
631
632 static struct path_prefix cpath, path;
633
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. */
637
638 static const char *const target_machine = TARGET_MACHINE;
639 #endif
640
641 /* Search for NAME using prefix list PPREFIX. We only look for executable
642 files.
643
644 Return 0 if not found, otherwise return its name, allocated with malloc. */
645
646 #ifdef OBJECT_FORMAT_NONE
647
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. */
651
652 static void
653 add_lto_object (struct lto_object_list *list, const char *name)
654 {
655 struct lto_object *n = XNEW (struct lto_object);
656 n->name = name;
657 n->next = NULL;
658
659 if (list->last)
660 list->last->next = n;
661 else
662 list->first = n;
663
664 list->last = n;
665 }
666 #endif /* OBJECT_FORMAT_NONE */
667
668
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.
679
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. */
695
696 static void
697 maybe_run_lto_and_relink (char **lto_ld_argv, char **object_lst,
698 const char **object, bool force)
699 {
700 const char **object_file = CONST_CAST2 (const char **, char **, object_lst);
701
702 int num_lto_c_args = 1; /* Allow space for the terminating NULL. */
703
704 while (object_file < object)
705 {
706 /* If file contains LTO info, add it to the list of LTO objects. */
707 scan_prog_file (*object_file++, PASS_LTOINFO, SCAN_ALL);
708
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++;
713 }
714
715 if (lto_objects.first)
716 {
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;
729
730 if (!lto_wrapper)
731 fatal_error ("COLLECT_LTO_WRAPPER must be set");
732
733 num_lto_c_args++;
734
735 /* There is at least one object file containing LTO info,
736 so we need to run the LTO back end and relink.
737
738 To do so we build updated ld arguments with first
739 LTO object replaced by all partitions and other LTO
740 objects removed. */
741
742 lto_c_argv = (char **) xcalloc (sizeof (char *), num_lto_c_args);
743 lto_c_ptr = CONST_CAST2 (const char **, char **, lto_c_argv);
744
745 *lto_c_ptr++ = lto_wrapper;
746
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;
750
751 *lto_c_ptr = NULL;
752
753 /* Run the LTO back end. */
754 pex = collect_execute (prog, lto_c_argv, NULL, NULL, PEX_SEARCH);
755 {
756 int c;
757 FILE *stream;
758 size_t i;
759 char *start, *end;
760
761 stream = pex_read_output (pex, 0);
762 gcc_assert (stream);
763
764 num_files = 0;
765 while ((c = getc (stream)) != EOF)
766 {
767 obstack_1grow (&temporary_obstack, c);
768 if (c == '\n')
769 ++num_files;
770 }
771
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)
776 {
777 end = start;
778 while (*end != '\n')
779 ++end;
780 *end = '\0';
781
782 lto_o_files[i] = xstrdup (start);
783
784 start = end + 1;
785 }
786
787 obstack_free (&temporary_obstack, temporary_firstobj);
788 }
789 do_wait (prog, pex);
790 pex = NULL;
791
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++)
795 ;
796 out_lto_ld_argv = XCNEWVEC (char *, num_files + lto_ld_argv_size + 1);
797 out_lto_ld_argv_size = 0;
798
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. */
802
803 /* Copy all arguments until we find first LTO file. */
804 p = lto_ld_argv;
805 while (*p != NULL)
806 {
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++;
813 }
814
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++;
819
820 /* ... and copy the rest. */
821 while (*p != NULL)
822 {
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++;
829 }
830 out_lto_ld_argv[out_lto_ld_argv_size++] = 0;
831
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);
837
838 maybe_unlink_list (lto_o_files);
839 }
840 else if (force)
841 {
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);
846 }
847 }
848 \f
849 /* Main program. */
850
851 int
852 main (int argc, char **argv)
853 {
854 enum linker_select
855 {
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] =
863 {
864 "ld",
865 PLUGIN_LD_SUFFIX,
866 "ld.gold",
867 "ld.bfd"
868 };
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";
878
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. */
885
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 */
907
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;
921
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;
929
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;
941
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
949
950 p = argv[0] + strlen (argv[0]);
951 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
952 --p;
953 progname = p;
954
955 xmalloc_set_program_name (progname);
956
957 old_argv = argv;
958 expandargv (&argc, &argv);
959 if (argv != old_argv)
960 at_file_supplied = 1;
961
962 process_args (&argc, argv);
963
964 num_c_args = argc + 9;
965
966 #ifndef HAVE_LD_DEMANGLE
967 no_demangle = !! getenv ("COLLECT_NO_DEMANGLE");
968
969 /* Suppress demangling by the real linker, which may be broken. */
970 putenv (xstrdup ("COLLECT_NO_DEMANGLE=1"));
971 #endif
972
973 #if defined (COLLECT2_HOST_INITIALIZATION)
974 /* Perform system dependent initialization, if necessary. */
975 COLLECT2_HOST_INITIALIZATION;
976 #endif
977
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
983
984 if (atexit (collect_atexit) != 0)
985 fatal_error ("atexit failed");
986
987 /* Unlock the stdio streams. */
988 unlock_std_streams ();
989
990 gcc_init_libintl ();
991
992 diagnostic_initialize (global_dc, 0);
993
994 /* Do not invoke xcalloc before this point, since locale needs to be
995 set first, in case a diagnostic is issued. */
996
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);
1003
1004 #ifdef DEBUG
1005 debug = 1;
1006 #endif
1007
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. */
1012 {
1013 bool no_partition = false;
1014
1015 for (i = 1; argv[i] != NULL; i ++)
1016 {
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"))
1027 {
1028 use_plugin = true;
1029 lto_mode = LTO_MODE_NONE;
1030 if (selected_linker == USE_DEFAULT_LD)
1031 selected_linker = USE_PLUGIN_LD;
1032 }
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;
1037
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
1056 }
1057 vflag = debug;
1058 find_file_set_debug (debug);
1059 if (no_partition && lto_mode == LTO_MODE_WHOPR)
1060 lto_mode = LTO_MODE_LTO;
1061 }
1062
1063 #ifndef DEFAULT_A_OUT_NAME
1064 output_file = "a.out";
1065 #else
1066 output_file = DEFAULT_A_OUT_NAME;
1067 #endif
1068
1069 obstack_begin (&temporary_obstack, 0);
1070 temporary_firstobj = (char *) obstack_alloc (&temporary_obstack, 0);
1071
1072 #ifndef HAVE_LD_DEMANGLE
1073 current_demangling_style = auto_demangling;
1074 #endif
1075 p = getenv ("COLLECT_GCC_OPTIONS");
1076 while (p && *p)
1077 {
1078 const char *q = extract_string (&p);
1079 if (*q == '-' && (q[1] == 'm' || q[1] == 'f'))
1080 num_c_args++;
1081 }
1082 obstack_free (&temporary_obstack, temporary_firstobj);
1083
1084 /* -fno-profile-arcs -fno-test-coverage -fno-branch-probabilities
1085 -fno-exceptions -w -fno-whole-program */
1086 num_c_args += 6;
1087
1088 c_argv = XCNEWVEC (char *, num_c_args);
1089 c_ptr = CONST_CAST2 (const char **, char **, c_argv);
1090
1091 if (argc < 2)
1092 fatal_error ("no arguments");
1093
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
1114
1115 /* Extract COMPILER_PATH and PATH into our prefix list. */
1116 prefix_from_env ("COMPILER_PATH", &cpath);
1117 prefix_from_env ("PATH", &path);
1118
1119 /* Try to discover a valid linker/nm/strip to use. */
1120
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)
1136 {
1137 ld_file_name = find_a_file (&cpath, collect_ld_suffix, X_OK);
1138 use_collect_ld = ld_file_name != 0;
1139 }
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);
1148
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);
1160
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
1166
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);
1178
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)
1182 {
1183 #ifdef CROSS_DIRECTORY_STRUCTURE
1184 c_file_name = concat (target_machine, "-gcc", NULL);
1185 #else
1186 c_file_name = "gcc";
1187 #endif
1188 }
1189
1190 p = find_a_file (&cpath, c_file_name, X_OK);
1191
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);
1196
1197 if (p)
1198 c_file_name = p;
1199
1200 *ld1++ = *ld2++ = ld_file_name;
1201
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)
1209 {
1210 ldout = make_temp_file (".ld");
1211 lderrout = make_temp_file (".le");
1212 }
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;
1219
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
1228
1229 /* Get any options that the upper GCC wants to pass to the sub-GCC.
1230
1231 AIX support needs to know if -shared has been specified before
1232 parsing commandline arguments. */
1233
1234 p = getenv ("COLLECT_GCC_OPTIONS");
1235 while (p && *p)
1236 {
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')
1245 {
1246 *c_ptr++ = xstrdup (q);
1247 if (q[2] == 0)
1248 {
1249 q = extract_string (&p);
1250 *c_ptr++ = xstrdup (q);
1251 }
1252 }
1253 }
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";
1261
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!!! */
1268
1269 /* Parse arguments. Remember output file spec, pass the rest to ld. */
1270 /* After the first file, put in the c++ rt0. */
1271
1272 first_file = 1;
1273 while ((arg = *++argv) != (char *) 0)
1274 {
1275 *ld1++ = *ld2++ = arg;
1276
1277 if (arg[0] == '-')
1278 {
1279 switch (arg[1])
1280 {
1281 case 'd':
1282 if (!strcmp (arg, "-debug"))
1283 {
1284 /* Already parsed. */
1285 ld1--;
1286 ld2--;
1287 }
1288 if (!strcmp (arg, "-dynamic-linker") && argv[1])
1289 {
1290 ++argv;
1291 *ld1++ = *ld2++ = *argv;
1292 }
1293 break;
1294
1295 case 'f':
1296 if (strncmp (arg, "-flto", 5) == 0)
1297 {
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
1306 }
1307 else if (!use_collect_ld
1308 && strncmp (arg, "-fuse-ld=", 9) == 0)
1309 {
1310 /* Do not pass -fuse-ld={bfd|gold} to the linker. */
1311 ld1--;
1312 ld2--;
1313 }
1314 #ifdef TARGET_AIX_VERSION
1315 else
1316 {
1317 /* File containing a list of input files to process. */
1318
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;
1327
1328 /* Accept -fFILENAME and -f FILENAME. */
1329 if (*list_filename == '\0' && argv[1])
1330 {
1331 ++argv;
1332 list_filename = *argv;
1333 *ld1++ = *ld2++ = *argv;
1334 }
1335
1336 stream = fopen (list_filename, "r");
1337 if (stream == NULL)
1338 fatal_error ("can't open %s: %m", list_filename);
1339
1340 while (fgets (buf, sizeof buf, stream) != NULL)
1341 {
1342 /* Remove end of line. */
1343 int len = strlen (buf);
1344 if (len >= 1 && buf[len - 1] =='\n')
1345 buf[len - 1] = '\0';
1346
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)
1351 {
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;
1361 }
1362 *object++ = xstrdup (buf);
1363 add_nbr++;
1364 }
1365 fclose (stream);
1366 }
1367 #endif
1368 break;
1369
1370 case 'l':
1371 if (first_file)
1372 {
1373 /* place o_file BEFORE this argument! */
1374 first_file = 0;
1375 ld2--;
1376 *ld2++ = o_file;
1377 *ld2++ = arg;
1378 }
1379 #ifdef COLLECT_EXPORT_LIST
1380 {
1381 /* Resolving full library name. */
1382 const char *s = resolve_lib_name (arg+2);
1383
1384 /* Saving a full library name. */
1385 add_to_list (&libs, s);
1386 }
1387 #endif
1388 break;
1389
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
1396
1397 case 'o':
1398 if (arg[2] == '\0')
1399 output_file = *ld1++ = *ld2++ = *++argv;
1400 else
1401 output_file = &arg[2];
1402 break;
1403
1404 case 'r':
1405 if (arg[2] == '\0')
1406 rflag = 1;
1407 break;
1408
1409 case 's':
1410 if (arg[2] == '\0' && do_collecting)
1411 {
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--;
1417 }
1418 break;
1419
1420 case 'v':
1421 if (arg[2] == '\0')
1422 vflag = true;
1423 break;
1424
1425 case '-':
1426 if (strcmp (arg, "--no-demangle") == 0)
1427 {
1428 #ifndef HAVE_LD_DEMANGLE
1429 no_demangle = 1;
1430 ld1--;
1431 ld2--;
1432 #endif
1433 }
1434 else if (strncmp (arg, "--demangle", 10) == 0)
1435 {
1436 #ifndef HAVE_LD_DEMANGLE
1437 no_demangle = 0;
1438 if (arg[10] == '=')
1439 {
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;
1446 }
1447 ld1--;
1448 ld2--;
1449 #endif
1450 }
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;
1458 }
1459 }
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))
1464 {
1465 if (first_file)
1466 {
1467 first_file = 0;
1468 if (p[1] == 'o')
1469 *ld2++ = o_file;
1470 else
1471 {
1472 /* place o_file BEFORE this argument! */
1473 ld2--;
1474 *ld2++ = o_file;
1475 *ld2++ = arg;
1476 }
1477 }
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
1483 {
1484 /* Saving a full library name. */
1485 add_to_list (&libs, arg);
1486 }
1487 #endif
1488 }
1489 }
1490
1491 #ifdef COLLECT_EXPORT_LIST
1492 /* This is added only for debugging purposes. */
1493 if (debug)
1494 {
1495 fprintf (stderr, "List of libraries:\n");
1496 dump_list (stderr, "\t", libs.first);
1497 }
1498
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. */
1504 {
1505 const char **export_object_lst
1506 = CONST_CAST2 (const char **, char **, object_lst);
1507
1508 struct id *list = libs.first;
1509
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. */
1514
1515 scanfilter this_filter = ld1_filter;
1516 #if HAVE_AS_REF
1517 if (!shared_obj)
1518 this_filter &= ~SCAN_DWEH;
1519 #endif
1520
1521 while (export_object_lst < object)
1522 scan_prog_file (*export_object_lst++, PASS_OBJ, this_filter);
1523
1524 for (; list; list = list->next)
1525 scan_prog_file (list->name, PASS_FIRST, this_filter);
1526
1527 ld1_filter = ld1_filter & ~this_filter;
1528 }
1529
1530 if (exports.first)
1531 {
1532 char *buf = concat ("-bE:", export_file, NULL);
1533
1534 *ld1++ = buf;
1535 *ld2++ = buf;
1536
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);
1543 }
1544 #endif
1545
1546 *c_ptr++ = c_file;
1547 *c_ptr = *ld1 = *object = (char *) 0;
1548
1549 if (vflag)
1550 notice ("collect2 version %s\n", version_string);
1551
1552 if (helpflag)
1553 {
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");
1564 }
1565
1566 if (debug)
1567 {
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"));
1585
1586 ptr = getenv ("COLLECT_GCC_OPTIONS");
1587 if (ptr)
1588 fprintf (stderr, "COLLECT_GCC_OPTIONS = %s\n", ptr);
1589
1590 ptr = getenv ("COLLECT_GCC");
1591 if (ptr)
1592 fprintf (stderr, "COLLECT_GCC = %s\n", ptr);
1593
1594 ptr = getenv ("COMPILER_PATH");
1595 if (ptr)
1596 fprintf (stderr, "COMPILER_PATH = %s\n", ptr);
1597
1598 ptr = getenv (LIBRARY_PATH_ENV);
1599 if (ptr)
1600 fprintf (stderr, "%-20s= %s\n", LIBRARY_PATH_ENV, ptr);
1601
1602 fprintf (stderr, "\n");
1603 }
1604
1605 /* Load the program, searching all libraries and attempting to provide
1606 undefined symbols from repository information.
1607
1608 If -r or they will be run via some other method, do not build the
1609 constructor or destructor list, just return now. */
1610 {
1611 bool early_exit
1612 = rflag || (! DO_COLLECT_EXPORT_LIST && ! do_collecting);
1613
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.
1616
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. */
1622
1623 if (early_exit || ld1_filter != SCAN_NOTHING)
1624 do_tlink (ld1_argv, object_lst);
1625
1626 if (early_exit)
1627 {
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);
1637
1638 maybe_unlink (c_file);
1639 maybe_unlink (o_file);
1640 return 0;
1641 }
1642 }
1643
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. */
1647
1648 if (ld1_filter != SCAN_NOTHING)
1649 scan_prog_file (output_file, PASS_FIRST, ld1_filter);
1650
1651 #ifdef SCAN_LIBRARIES
1652 scan_libraries (output_file);
1653 #endif
1654
1655 if (debug)
1656 {
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);
1669 }
1670
1671 /* If the scan exposed nothing of special interest, there's no need to
1672 generate the glue code and relink so return now. */
1673
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
1682 )
1683 {
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);
1688
1689 if (lto_mode)
1690 maybe_run_lto_and_relink (ld1_argv, object_lst, object, false);
1691
1692 /* Strip now if it was requested on the command line. */
1693 if (strip_flag)
1694 {
1695 char **real_strip_argv = XCNEWVEC (char *, 3);
1696 const char ** strip_argv = CONST_CAST2 (const char **, char **,
1697 real_strip_argv);
1698
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);
1703 }
1704
1705 #ifdef COLLECT_EXPORT_LIST
1706 maybe_unlink (export_file);
1707 #endif
1708 post_ld_pass (false);
1709
1710 maybe_unlink (c_file);
1711 maybe_unlink (o_file);
1712 return 0;
1713 }
1714
1715 /* Sort ctor and dtor lists by priority. */
1716 sort_ids (&constructors);
1717 sort_ids (&destructors);
1718
1719 maybe_unlink (output_file);
1720 outf = fopen (c_file, "w");
1721 if (outf == (FILE *) 0)
1722 fatal_error ("fopen %s: %m", c_file);
1723
1724 write_c_file (outf, c_file);
1725
1726 if (fclose (outf))
1727 fatal_error ("fclose %s: %m", c_file);
1728
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
1740
1741 #ifdef COLLECT_EXPORT_LIST
1742 if (shared_obj)
1743 {
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);
1748
1749 #ifdef TARGET_AIX_VERSION
1750 add_to_list (&exports, aix_shared_initname);
1751 add_to_list (&exports, aix_shared_fininame);
1752 #endif
1753
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);
1766 }
1767 #endif
1768
1769 /* End of arguments to second link phase. */
1770 *ld2 = (char*) 0;
1771
1772 if (debug)
1773 {
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
1783 }
1784
1785 /* Assemble the constructor and destructor tables.
1786 Link the tables in with the rest of the program. */
1787
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);
1792
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
1800 {
1801 fork_execute ("ld", ld2_argv);
1802 post_ld_pass (false);
1803 }
1804
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
1809
1810 maybe_unlink (c_file);
1811 maybe_unlink (o_file);
1812
1813 #ifdef COLLECT_EXPORT_LIST
1814 maybe_unlink (export_file);
1815 #endif
1816
1817 return 0;
1818 }
1819
1820 \f
1821 /* Wait for a process to finish, and exit if a nonzero status is found. */
1822
1823 int
1824 collect_wait (const char *prog, struct pex_obj *pex)
1825 {
1826 int status;
1827
1828 if (!pex_get_status (pex, 1, &status))
1829 fatal_error ("can't get program status: %m");
1830 pex_free (pex);
1831
1832 if (status)
1833 {
1834 if (WIFSIGNALED (status))
1835 {
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);
1841 }
1842
1843 if (WIFEXITED (status))
1844 return WEXITSTATUS (status);
1845 }
1846 return 0;
1847 }
1848
1849 static void
1850 do_wait (const char *prog, struct pex_obj *pex)
1851 {
1852 int ret = collect_wait (prog, pex);
1853 if (ret != 0)
1854 {
1855 error ("%s returned %d exit status", prog, ret);
1856 exit (ret);
1857 }
1858
1859 if (response_file)
1860 {
1861 unlink (response_file);
1862 response_file = NULL;
1863 }
1864 }
1865
1866 \f
1867 /* Execute a program, and wait for the reply. */
1868
1869 struct pex_obj *
1870 collect_execute (const char *prog, char **argv, const char *outname,
1871 const char *errname, int flags)
1872 {
1873 struct pex_obj *pex;
1874 const char *errmsg;
1875 int err;
1876 char *response_arg = NULL;
1877 char *response_argv[3] ATTRIBUTE_UNUSED;
1878
1879 if (HAVE_GNU_LD && at_file_supplied && argv[0] != NULL)
1880 {
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. */
1884
1885 char **current_argv = argv + 1;
1886 char *argv0 = argv[0];
1887 int status;
1888 FILE *f;
1889
1890 /* Note: we assume argv contains at least one element; this is
1891 checked above. */
1892
1893 response_file = make_temp_file ("");
1894
1895 f = fopen (response_file, "w");
1896
1897 if (f == NULL)
1898 fatal_error ("could not open response file %s", response_file);
1899
1900 status = writeargv (current_argv, f);
1901
1902 if (status)
1903 fatal_error ("could not write to response file %s", response_file);
1904
1905 status = fclose (f);
1906
1907 if (EOF == status)
1908 fatal_error ("could not close response file %s", response_file);
1909
1910 response_arg = concat ("@", response_file, NULL);
1911 response_argv[0] = argv0;
1912 response_argv[1] = response_arg;
1913 response_argv[2] = NULL;
1914
1915 argv = response_argv;
1916 }
1917
1918 if (vflag || debug)
1919 {
1920 char **p_argv;
1921 const char *str;
1922
1923 if (argv[0])
1924 fprintf (stderr, "%s", argv[0]);
1925 else
1926 notice ("[cannot find %s]", prog);
1927
1928 for (p_argv = &argv[1]; (str = *p_argv) != (char *) 0; p_argv++)
1929 fprintf (stderr, " %s", str);
1930
1931 fprintf (stderr, "\n");
1932 }
1933
1934 fflush (stdout);
1935 fflush (stderr);
1936
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. */
1939
1940 if (argv[0] == 0)
1941 fatal_error ("cannot find '%s'", prog);
1942
1943 pex = pex_init (0, "collect2", NULL);
1944 if (pex == NULL)
1945 fatal_error ("pex_init failed: %m");
1946
1947 errmsg = pex_run (pex, flags, argv[0], argv, outname,
1948 errname, &err);
1949 if (errmsg != NULL)
1950 {
1951 if (err != 0)
1952 {
1953 errno = err;
1954 fatal_error ("%s: %m", _(errmsg));
1955 }
1956 else
1957 fatal_error (errmsg);
1958 }
1959
1960 free (response_arg);
1961
1962 return pex;
1963 }
1964
1965 static void
1966 fork_execute (const char *prog, char **argv)
1967 {
1968 struct pex_obj *pex;
1969
1970 pex = collect_execute (prog, argv, NULL, NULL, PEX_LAST | PEX_SEARCH);
1971 do_wait (prog, pex);
1972 }
1973 \f
1974 /* Unlink FILE unless we are debugging or this is the output_file
1975 and we may not unlink it. */
1976
1977 static void
1978 maybe_unlink (const char *file)
1979 {
1980 if (debug)
1981 {
1982 notice ("[Leaving %s]\n", file);
1983 return;
1984 }
1985
1986 if (file == output_file && !may_unlink_output_file)
1987 return;
1988
1989 unlink_if_ordinary (file);
1990 }
1991
1992 /* Call maybe_unlink on the NULL-terminated list, FILE_LIST. */
1993
1994 static void
1995 maybe_unlink_list (char **file_list)
1996 {
1997 char **tmp = file_list;
1998
1999 while (*tmp)
2000 maybe_unlink (*(tmp++));
2001 }
2002
2003 \f
2004 static long sequence_number = 0;
2005
2006 /* Add a name to a linked list. */
2007
2008 static void
2009 add_to_list (struct head *head_ptr, const char *name)
2010 {
2011 struct id *newid
2012 = (struct id *) xcalloc (sizeof (struct id) + strlen (name), 1);
2013 struct id *p;
2014 strcpy (newid->name, name);
2015
2016 if (head_ptr->first)
2017 head_ptr->last->next = newid;
2018 else
2019 head_ptr->first = newid;
2020
2021 /* Check for duplicate symbols. */
2022 for (p = head_ptr->first;
2023 strcmp (name, p->name) != 0;
2024 p = p->next)
2025 ;
2026 if (p != newid)
2027 {
2028 head_ptr->last->next = 0;
2029 free (newid);
2030 return;
2031 }
2032
2033 newid->sequence = ++sequence_number;
2034 head_ptr->last = newid;
2035 head_ptr->number++;
2036 }
2037
2038 /* Grab the init priority number from an init function name that
2039 looks like "_GLOBAL_.I.12345.foo". */
2040
2041 static int
2042 extract_init_priority (const char *name)
2043 {
2044 int pos = 0, pri;
2045
2046 #ifdef TARGET_AIX_VERSION
2047 /* Run dependent module initializers before any constructors in this
2048 module. */
2049 switch (is_ctor_dtor (name))
2050 {
2051 case SYM_AIXI:
2052 case SYM_AIXD:
2053 return INT_MIN;
2054 default:
2055 break;
2056 }
2057 #endif
2058
2059 while (name[pos] == '_')
2060 ++pos;
2061 pos += 10; /* strlen ("GLOBAL__X_") */
2062
2063 /* Extract init_p number from ctor/dtor name. */
2064 pri = atoi (name + pos);
2065 return pri ? pri : DEFAULT_INIT_PRIORITY;
2066 }
2067
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. */
2070
2071 static void
2072 sort_ids (struct head *head_ptr)
2073 {
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;
2078
2079 id = head_ptr->first;
2080
2081 /* We don't have any sorted elements yet. */
2082 head_ptr->first = NULL;
2083
2084 for (; id; id = id_next)
2085 {
2086 id_next = id->next;
2087 id->sequence = extract_init_priority (id->name);
2088
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) */
2097 )
2098 {
2099 id->next = *id_ptr;
2100 *id_ptr = id;
2101 break;
2102 }
2103 }
2104
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;
2108 }
2109
2110 /* Write: `prefix', the names on list LIST, `suffix'. */
2111
2112 static void
2113 write_list (FILE *stream, const char *prefix, struct id *list)
2114 {
2115 while (list)
2116 {
2117 fprintf (stream, "%sx%d,\n", prefix, list->sequence);
2118 list = list->next;
2119 }
2120 }
2121
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)
2127 {
2128 while (list)
2129 {
2130 if (!strcmp (prefix, list->name)) return 1;
2131 list = list->next;
2132 }
2133 return 0;
2134 }
2135 #endif
2136 #endif /* COLLECT_EXPORT_LIST */
2137
2138 /* Added for debugging purpose. */
2139 #ifdef COLLECT_EXPORT_LIST
2140 static void
2141 dump_list (FILE *stream, const char *prefix, struct id *list)
2142 {
2143 while (list)
2144 {
2145 fprintf (stream, "%s%s,\n", prefix, list->name);
2146 list = list->next;
2147 }
2148 }
2149 #endif
2150
2151 #if 0
2152 static void
2153 dump_prefix_list (FILE *stream, const char *prefix, struct prefix_list *list)
2154 {
2155 while (list)
2156 {
2157 fprintf (stream, "%s%s,\n", prefix, list->prefix);
2158 list = list->next;
2159 }
2160 }
2161 #endif
2162
2163 static void
2164 write_list_with_asm (FILE *stream, const char *prefix, struct id *list)
2165 {
2166 while (list)
2167 {
2168 fprintf (stream, "%sx%d __asm__ (\"%s\");\n",
2169 prefix, list->sequence, list->name);
2170 list = list->next;
2171 }
2172 }
2173
2174 /* Write out the constructor and destructor tables statically (for a shared
2175 object), along with the functions to execute them. */
2176
2177 static void
2178 write_c_file_stat (FILE *stream, const char *name ATTRIBUTE_UNUSED)
2179 {
2180 const char *p, *q;
2181 char *prefix, *r;
2182 int frames = (frame_tables.number > 0);
2183
2184 /* Figure out name of output_file, stripping off .so version. */
2185 q = p = lbasename (output_file);
2186
2187 while (q)
2188 {
2189 q = strchr (q,'.');
2190 if (q == 0)
2191 {
2192 q = p + strlen (p);
2193 break;
2194 }
2195 else
2196 {
2197 if (filename_ncmp (q, SHLIB_SUFFIX, strlen (SHLIB_SUFFIX)) == 0)
2198 {
2199 q += strlen (SHLIB_SUFFIX);
2200 break;
2201 }
2202 else
2203 q++;
2204 }
2205 }
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);
2216
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
2223
2224 free (prefix);
2225
2226 /* Write the tables as C code. */
2227
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).
2234 */
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);
2238
2239 if (frames)
2240 {
2241 write_list_with_asm (stream, "extern void *", frame_tables.first);
2242
2243 fprintf (stream, "\tstatic void *frame_table[] = {\n");
2244 write_list (stream, "\t\t&", frame_tables.first);
2245 fprintf (stream, "\t0\n};\n");
2246
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");
2256
2257 fprintf (stream, "extern void __register_frame_info_table (void *, struct object *);\n");
2258 fprintf (stream, "extern void *__deregister_frame_info (void *);\n");
2259
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");
2264
2265 fprintf (stream, "static void dereg_frame () {\n");
2266 fprintf (stream, "\t__deregister_frame_info (frame_table);\n");
2267 fprintf (stream, "\t}\n");
2268 }
2269
2270 fprintf (stream, "void %s() {\n", initname);
2271 if (constructors.number > 0 || frames)
2272 {
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");
2282 }
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)
2289 {
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);
2300 }
2301 fprintf (stream, "}\n");
2302
2303 if (shared_obj)
2304 {
2305 COLLECT_SHARED_INIT_FUNC (stream, initname);
2306 COLLECT_SHARED_FINI_FUNC (stream, fininame);
2307 }
2308 }
2309
2310 /* Write the constructor/destructor tables. */
2311
2312 #ifndef LD_INIT_SWITCH
2313 static void
2314 write_c_file_glob (FILE *stream, const char *name ATTRIBUTE_UNUSED)
2315 {
2316 /* Write the tables as C code. */
2317
2318 int frames = (frame_tables.number > 0);
2319
2320 fprintf (stream, "typedef void entry_pt();\n\n");
2321
2322 write_list_with_asm (stream, "extern entry_pt ", constructors.first);
2323
2324 if (frames)
2325 {
2326 write_list_with_asm (stream, "extern void *", frame_tables.first);
2327
2328 fprintf (stream, "\tstatic void *frame_table[] = {\n");
2329 write_list (stream, "\t\t&", frame_tables.first);
2330 fprintf (stream, "\t0\n};\n");
2331
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");
2341
2342 fprintf (stream, "extern void __register_frame_info_table (void *, struct object *);\n");
2343 fprintf (stream, "extern void *__deregister_frame_info (void *);\n");
2344
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");
2349
2350 fprintf (stream, "static void dereg_frame () {\n");
2351 fprintf (stream, "\t__deregister_frame_info (frame_table);\n");
2352 fprintf (stream, "\t}\n");
2353 }
2354
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");
2361
2362 write_list_with_asm (stream, "extern entry_pt ", destructors.first);
2363
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");
2370
2371 fprintf (stream, "extern entry_pt %s;\n", NAME__MAIN);
2372 fprintf (stream, "entry_pt *__main_reference = %s;\n\n", NAME__MAIN);
2373 }
2374 #endif /* ! LD_INIT_SWITCH */
2375
2376 static void
2377 write_c_file (FILE *stream, const char *name)
2378 {
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);
2385 }
2386
2387 #ifdef COLLECT_EXPORT_LIST
2388 static void
2389 write_aix_file (FILE *stream, struct id *list)
2390 {
2391 for (; list; list = list->next)
2392 {
2393 fputs (list->name, stream);
2394 putc ('\n', stream);
2395 }
2396 }
2397 #endif
2398 \f
2399 #ifdef OBJECT_FORMAT_NONE
2400
2401 /* Check to make sure the file is an LTO object file. */
2402
2403 static bool
2404 maybe_lto_object_file (const char *prog_name)
2405 {
2406 FILE *f;
2407 unsigned char buf[4];
2408 int i;
2409
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 }
2418 };
2419
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);
2426
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;
2434
2435 return false;
2436 }
2437
2438 /* Generic version to scan the name list of the loaded program for
2439 the symbols g++ uses for static constructors and destructors. */
2440
2441 static void
2442 scan_prog_file (const char *prog_name, scanpass which_pass,
2443 scanfilter filter)
2444 {
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;
2458
2459 if (which_pass == PASS_SECOND)
2460 return;
2461
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;
2467
2468 /* If we do not have an `nm', complain. */
2469 if (nm_file_name == 0)
2470 fatal_error ("cannot find 'nm'");
2471
2472 nm_argv[argc++] = nm_file_name;
2473 if (NM_FLAGS[0] != '\0')
2474 nm_argv[argc++] = NM_FLAGS;
2475
2476 nm_argv[argc++] = prog_name;
2477 nm_argv[argc++] = (char *) 0;
2478
2479 /* Trace if needed. */
2480 if (vflag)
2481 {
2482 const char **p_argv;
2483 const char *str;
2484
2485 for (p_argv = &nm_argv[0]; (str = *p_argv) != (char *) 0; p_argv++)
2486 fprintf (stderr, " %s", str);
2487
2488 fprintf (stderr, "\n");
2489 }
2490
2491 fflush (stdout);
2492 fflush (stderr);
2493
2494 pex = pex_init (PEX_USE_PIPES, "collect2", NULL);
2495 if (pex == NULL)
2496 fatal_error ("pex_init failed: %m");
2497
2498 errmsg = pex_run (pex, 0, nm_file_name, real_nm_argv, NULL, HOST_BIT_BUCKET,
2499 &err);
2500 if (errmsg != NULL)
2501 {
2502 if (err != 0)
2503 {
2504 errno = err;
2505 fatal_error ("%s: %m", _(errmsg));
2506 }
2507 else
2508 fatal_error (errmsg);
2509 }
2510
2511 int_handler = (void (*) (int)) signal (SIGINT, SIG_IGN);
2512 #ifdef SIGQUIT
2513 quit_handler = (void (*) (int)) signal (SIGQUIT, SIG_IGN);
2514 #endif
2515
2516 inf = pex_read_output (pex, 0);
2517 if (inf == NULL)
2518 fatal_error ("can't open nm output: %m");
2519
2520 if (debug)
2521 {
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");
2526 }
2527
2528 /* Read each line of nm output. */
2529 while (fgets (buf, sizeof buf, inf) != (char *) 0)
2530 {
2531 int ch, ch2;
2532 char *name, *end;
2533
2534 if (debug)
2535 fprintf (stderr, "\t%s\n", buf);
2536
2537 if (which_pass == PASS_LTOINFO)
2538 {
2539 if (found_lto)
2540 continue;
2541
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]))
2548 {
2549 add_lto_object (&lto_objects, prog_name);
2550
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;
2554
2555 break;
2556 }
2557
2558 continue;
2559 }
2560
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. */
2564
2565 for (p = buf; (ch = *p) != '\0' && ch != '\n' && ch != '_'; p++)
2566 if (ch == ' ' && p[1] == 'U' && p[2] == ' ')
2567 break;
2568
2569 if (ch != '_')
2570 continue;
2571
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;
2578
2579
2580 *end = '\0';
2581
2582 switch (is_ctor_dtor (name))
2583 {
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;
2590
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;
2597
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;
2607
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;
2617
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;
2624
2625 default: /* not a constructor or destructor */
2626 continue;
2627 }
2628 }
2629
2630 if (debug)
2631 fprintf (stderr, "\n");
2632
2633 do_wait (nm_file_name, pex);
2634
2635 signal (SIGINT, int_handler);
2636 #ifdef SIGQUIT
2637 signal (SIGQUIT, quit_handler);
2638 #endif
2639 }
2640
2641 #ifdef LDD_SUFFIX
2642
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. */
2646
2647 static void
2648 scan_libraries (const char *prog_name)
2649 {
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;
2664
2665 /* If we do not have an `ldd', complain. */
2666 if (ldd_file_name == 0)
2667 {
2668 error ("cannot find 'ldd'");
2669 return;
2670 }
2671
2672 ldd_argv[argc++] = ldd_file_name;
2673 ldd_argv[argc++] = prog_name;
2674 ldd_argv[argc++] = (char *) 0;
2675
2676 /* Trace if needed. */
2677 if (vflag)
2678 {
2679 const char **p_argv;
2680 const char *str;
2681
2682 for (p_argv = &ldd_argv[0]; (str = *p_argv) != (char *) 0; p_argv++)
2683 fprintf (stderr, " %s", str);
2684
2685 fprintf (stderr, "\n");
2686 }
2687
2688 fflush (stdout);
2689 fflush (stderr);
2690
2691 pex = pex_init (PEX_USE_PIPES, "collect2", NULL);
2692 if (pex == NULL)
2693 fatal_error ("pex_init failed: %m");
2694
2695 errmsg = pex_run (pex, 0, ldd_file_name, real_ldd_argv, NULL, NULL, &err);
2696 if (errmsg != NULL)
2697 {
2698 if (err != 0)
2699 {
2700 errno = err;
2701 fatal_error ("%s: %m", _(errmsg));
2702 }
2703 else
2704 fatal_error (errmsg);
2705 }
2706
2707 int_handler = (void (*) (int)) signal (SIGINT, SIG_IGN);
2708 #ifdef SIGQUIT
2709 quit_handler = (void (*) (int)) signal (SIGQUIT, SIG_IGN);
2710 #endif
2711
2712 inf = pex_read_output (pex, 0);
2713 if (inf == NULL)
2714 fatal_error ("can't open ldd output: %m");
2715
2716 if (debug)
2717 notice ("\nldd output with constructors/destructors.\n");
2718
2719 /* Read each line of ldd output. */
2720 while (fgets (buf, sizeof buf, inf) != (char *) 0)
2721 {
2722 int ch2;
2723 char *name, *end, *p = buf;
2724
2725 /* Extract names of libraries and add to list. */
2726 PARSE_LDD_OUTPUT (p);
2727 if (p == 0)
2728 continue;
2729
2730 name = p;
2731 if (strncmp (name, "not found", sizeof ("not found") - 1) == 0)
2732 fatal_error ("dynamic dependency %s not found", buf);
2733
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';
2740
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);
2745
2746 if (debug)
2747 fprintf (stderr, "\t%s\n", buf);
2748 }
2749 if (debug)
2750 fprintf (stderr, "\n");
2751
2752 do_wait (ldd_file_name, pex);
2753
2754 signal (SIGINT, int_handler);
2755 #ifdef SIGQUIT
2756 signal (SIGQUIT, quit_handler);
2757 #endif
2758
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);
2763 }
2764
2765 #endif /* LDD_SUFFIX */
2766
2767 #endif /* OBJECT_FORMAT_NONE */
2768
2769 \f
2770 /*
2771 * COFF specific stuff.
2772 */
2773
2774 #ifdef OBJECT_FORMAT_COFF
2775
2776 #if defined (EXTENDED_COFF)
2777
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)
2784
2785 #else
2786
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
2811
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
2824
2825 #endif
2826
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
2846 };
2847
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)
2853 {
2854 const char *const *p;
2855 size_t length;
2856
2857 if (target_system_root[0] != '\0')
2858 {
2859 length = strlen (target_system_root);
2860 if (strncmp (name, target_system_root, length) != 0)
2861 return 0;
2862 name += length;
2863 }
2864 for (p = &aix_std_libs[0]; *p != NULL; ++p)
2865 if (strcmp (name, *p) == 0)
2866 return 1;
2867 return 0;
2868 }
2869 #endif /* COLLECT_EXPORT_LIST */
2870
2871 #if defined (HAVE_DECL_LDGETNAME) && !HAVE_DECL_LDGETNAME
2872 extern char *ldgetname (LDFILE *, GCC_SYMENT *);
2873 #endif
2874
2875 /* COFF version to scan the name list of the loaded program for
2876 the symbols g++ uses for static constructors and destructors. */
2877
2878 static void
2879 scan_prog_file (const char *prog_name, scanpass which_pass,
2880 scanfilter filter)
2881 {
2882 LDFILE *ldptr = NULL;
2883 int sym_index, sym_count;
2884 int is_shared = 0;
2885
2886 if (which_pass != PASS_FIRST && which_pass != PASS_OBJ)
2887 return;
2888
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;
2893
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. */
2897 do
2898 {
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)
2905 {
2906 if (! MY_ISCOFF (HEADER (ldptr).f_magic))
2907 fatal_error ("%s: not a COFF file", prog_name);
2908
2909 if (GCC_CHECK_HDR (ldptr))
2910 {
2911 sym_count = GCC_SYMBOLS (ldptr);
2912 sym_index = GCC_SYMZERO (ldptr);
2913
2914 #ifdef COLLECT_EXPORT_LIST
2915 /* Is current archive member a shared object? */
2916 is_shared = HEADER (ldptr).f_flags & F_SHROBJ;
2917 #endif
2918
2919 while (sym_index < sym_count)
2920 {
2921 GCC_SYMENT symbol;
2922
2923 if (ldtbread (ldptr, sym_index, &symbol) <= 0)
2924 break;
2925 sym_index += GCC_SYMINC (symbol);
2926
2927 if (GCC_OK_SYMBOL (symbol))
2928 {
2929 char *name;
2930
2931 if ((name = ldgetname (ldptr, &symbol)) == NULL)
2932 continue; /* Should never happen. */
2933
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
2940
2941 switch (is_ctor_dtor (name))
2942 {
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;
2953
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
2961
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;
2972
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;
2983
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;
2993
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
3003
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;
3014
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;
3027 }
3028
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
3040 }
3041 }
3042 }
3043 #ifdef COLLECT_EXPORT_LIST
3044 else
3045 {
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);
3051 }
3052 #endif
3053 }
3054 else
3055 {
3056 fatal_error ("%s: cannot open as COFF file", prog_name);
3057 }
3058 #ifdef COLLECT_EXPORT_LIST
3059 /* On AIX loop continues while there are more members in archive. */
3060 }
3061 while (ldclose (ldptr) == FAILURE);
3062 #else
3063 /* Otherwise we simply close ldptr. */
3064 (void) ldclose (ldptr);
3065 #endif
3066 }
3067 #endif /* OBJECT_FORMAT_COFF */
3068
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)
3074 {
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"};
3079
3080 for (i = 0; libpaths[i]; i++)
3081 if (libpaths[i]->max_len > l)
3082 l = libpaths[i]->max_len;
3083
3084 lib_buf = XNEWVEC (char, l + strlen (name) + 10);
3085
3086 for (i = 0; libpaths[i]; i++)
3087 {
3088 struct prefix_list *list = libpaths[i]->plist;
3089 for (; list; list = list->next)
3090 {
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++)
3098 {
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))
3104 {
3105 if (debug) fprintf (stderr, "found: %s\n", lib_buf);
3106 return (lib_buf);
3107 }
3108 }
3109 }
3110 }
3111 if (debug)
3112 fprintf (stderr, "not found\n");
3113 else
3114 fatal_error ("library lib%s not found", name);
3115 return (NULL);
3116 }
3117 #endif /* COLLECT_EXPORT_LIST */
3118
3119 #ifdef COLLECT_RUN_DSYMUTIL
3120 static int flag_dsym = false;
3121 static int flag_idsym = false;
3122
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)
3128 {
3129 if (strcmp (argv[i], "-dsym") == 0)
3130 {
3131 flag_dsym = true;
3132 /* Remove the flag, as we handle all processing for it. */
3133 j = i;
3134 do
3135 argv[j] = argv[j+1];
3136 while (++j < argc);
3137 --i;
3138 argc = --(*argcp);
3139 }
3140 else if (strcmp (argv[i], "-idsym") == 0)
3141 {
3142 flag_idsym = true;
3143 /* Remove the flag, as we handle all processing for it. */
3144 j = i;
3145 do
3146 argv[j] = argv[j+1];
3147 while (++j < argc);
3148 --i;
3149 argc = --(*argcp);
3150 }
3151 }
3152 }
3153
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);
3161
3162 argv[0] = dsymutil;
3163 argv[1] = output_file;
3164 argv[2] = (char *) 0;
3165
3166 pex = collect_execute (dsymutil, real_argv, NULL, NULL, PEX_LAST | PEX_SEARCH);
3167 do_wait (dsymutil, pex);
3168 }
3169
3170 static void
3171 post_ld_pass (bool temp_file) {
3172 if (!(temp_file && flag_idsym) && !flag_dsym)
3173 return;
3174
3175 do_dsymutil (output_file);
3176 }
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