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