Support ELF SHF_GNU_MBIND and PT_GNU_MBIND_XXX
[deliverable/binutils-gdb.git] / ld / emultempl / elf32.em
CommitLineData
252b5132
RH
1# This shell script emits a C file. -*- C -*-
2# It does some substitutions.
3# This file is now misnamed, because it supports both 32 bit and 64 bit
4# ELF emulations.
5test -z "${ELFSIZE}" && ELFSIZE=32
86af25fe
L
6if [ -z "$MACHINE" ]; then
7 OUTPUT_ARCH=${ARCH}
8else
9 OUTPUT_ARCH=${ARCH}:${MACHINE}
10fi
92b93329 11fragment <<EOF
252b5132
RH
12/* This file is is generated by a shell script. DO NOT EDIT! */
13
14/* ${ELFSIZE} bit ELF emulation code for ${EMULATION_NAME}
2571583a 15 Copyright (C) 1991-2017 Free Software Foundation, Inc.
252b5132
RH
16 Written by Steve Chamberlain <sac@cygnus.com>
17 ELF support by Ian Lance Taylor <ian@cygnus.com>
18
f96b4a7b
NC
19 This file is part of the GNU Binutils.
20
21 This program is free software; you can redistribute it and/or modify
22 it under the terms of the GNU General Public License as published by
23 the Free Software Foundation; either version 3 of the License, or
24 (at your option) any later version.
25
26 This program is distributed in the hope that it will be useful,
27 but WITHOUT ANY WARRANTY; without even the implied warranty of
28 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
29 GNU General Public License for more details.
30
31 You should have received a copy of the GNU General Public License
32 along with this program; if not, write to the Free Software
33 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
34 MA 02110-1301, USA. */
252b5132
RH
35
36#define TARGET_IS_${EMULATION_NAME}
37
252b5132 38#include "sysdep.h"
3db64b00 39#include "bfd.h"
1c9acd94 40#include "libiberty.h"
8056826a 41#include "safe-ctype.h"
42627821 42#include "filenames.h"
fcf65871 43#include "getopt.h"
24382dca 44#include <fcntl.h>
252b5132
RH
45
46#include "bfdlink.h"
47
48#include "ld.h"
49#include "ldmain.h"
252b5132
RH
50#include "ldmisc.h"
51#include "ldexp.h"
52#include "ldlang.h"
b71e2778
AM
53#include "ldfile.h"
54#include "ldemul.h"
61e2488c 55#include "ldbuildid.h"
df2a7313 56#include <ldgram.h>
e0ee487b 57#include "elf/common.h"
ecca9871 58#include "elf-bfd.h"
07f1e47a 59#include "filenames.h"
252b5132 60
0c7a8e5a
AM
61/* Declare functions used by various EXTRA_EM_FILEs. */
62static void gld${EMULATION_NAME}_before_parse (void);
5fe2850d 63static void gld${EMULATION_NAME}_after_parse (void);
0c7a8e5a
AM
64static void gld${EMULATION_NAME}_after_open (void);
65static void gld${EMULATION_NAME}_before_allocation (void);
eaeb0a9d 66static void gld${EMULATION_NAME}_after_allocation (void);
c2edb4b8 67static lang_output_section_statement_type *gld${EMULATION_NAME}_place_orphan
8a99a385 68 (asection *, const char *, int);
41392f03
AM
69EOF
70
d3989512
JJ
71if [ "x${USE_LIBPATH}" = xyes ] ; then
72 case ${target} in
a5244b7e 73 *-*-linux-* | *-*-k*bsd*-* | *-*-gnu*)
92b93329 74 fragment <<EOF
0b48acfe 75#ifdef HAVE_GLOB
d3989512 76#include <glob.h>
0b48acfe 77#endif
d3989512
JJ
78EOF
79 ;;
80 esac
81fi
82
41392f03
AM
83# Import any needed special functions and/or overrides.
84#
92b93329 85source_em ${srcdir}/emultempl/elf-generic.em
41392f03 86if test -n "$EXTRA_EM_FILE" ; then
92b93329 87 source_em ${srcdir}/emultempl/${EXTRA_EM_FILE}.em
41392f03
AM
88fi
89
f813923c 90# Functions in this file can be overridden by setting the LDEMUL_* shell
41392f03
AM
91# variables. If the name of the overriding function is the same as is
92# defined in this file, then don't output this file's version.
93# If a different overriding name is given then output the standard function
94# as presumably it is called from the overriding function.
95#
96if test x"$LDEMUL_BEFORE_PARSE" != xgld"$EMULATION_NAME"_before_parse; then
92b93329 97fragment <<EOF
41392f03 98
252b5132 99static void
0c7a8e5a 100gld${EMULATION_NAME}_before_parse (void)
252b5132 101{
5e2f1575 102 ldfile_set_output_arch ("${OUTPUT_ARCH}", bfd_arch_`echo ${ARCH} | sed -e 's/:.*//'`);
66be1055 103 input_flags.dynamic = ${DYNAMIC_LINK-TRUE};
b34976b6 104 config.has_shared = `if test -n "$GENERATE_SHLIB_SCRIPT" ; then echo TRUE ; else echo FALSE ; fi`;
4724d37e 105 config.separate_code = `if test "x${SEPARATE_CODE}" = xyes ; then echo TRUE ; else echo FALSE ; fi`;
caa65211 106 `if test -n "$CALL_NOP_BYTE" ; then echo link_info.call_nop_byte = $CALL_NOP_BYTE; fi`;
d9689752 107 link_info.check_relocs_after_open_input = `if test "x${CHECK_RELOCS_AFTER_OPEN_INPUT}" = xyes ; then echo TRUE ; else echo FALSE ; fi`;
647e4d46 108 link_info.relro = DEFAULT_LD_Z_RELRO;
663fa543
L
109}
110
822b8bf4 111EOF
663fa543 112fi
822b8bf4 113
5fe2850d
L
114if test x"$LDEMUL_AFTER_PARSE" != xgld"$EMULATION_NAME"_after_parse; then
115fragment <<EOF
116
117static void
118gld${EMULATION_NAME}_after_parse (void)
119{
120 if (bfd_link_pie (&link_info))
121 link_info.flags_1 |= (bfd_vma) DF_1_PIE;
122
123 after_parse_default ();
124}
125
126EOF
127fi
128
4a43e768 129if test x"$LDEMUL_RECOGNIZED_FILE" != xgld"${EMULATION_NAME}"_load_symbols; then
92b93329 130fragment <<EOF
ddbb8a31 131/* Handle the generation of DT_NEEDED tags. */
4a43e768
AM
132
133static bfd_boolean
134gld${EMULATION_NAME}_load_symbols (lang_input_statement_type *entry)
135{
96d56e9f 136 int link_class = 0;
4a43e768
AM
137
138 /* Tell the ELF linker that we don't want the output file to have a
139 DT_NEEDED entry for this file, unless it is used to resolve
140 references in a regular object. */
66be1055 141 if (entry->flags.add_DT_NEEDED_for_regular)
96d56e9f 142 link_class = DYN_AS_NEEDED;
e56f61be
L
143
144 /* Tell the ELF linker that we don't want the output file to have a
145 DT_NEEDED entry for any dynamic library in DT_NEEDED tags from
146 this file at all. */
66be1055 147 if (!entry->flags.add_DT_NEEDED_for_dynamic)
96d56e9f 148 link_class |= DYN_NO_ADD_NEEDED;
e56f61be 149
66be1055 150 if (entry->flags.just_syms
12b9ff6c
L
151 && (bfd_get_file_flags (entry->the_bfd) & DYNAMIC) != 0)
152 einfo (_("%P%F: --just-symbols may not be used on DSO: %B\n"),
153 entry->the_bfd);
154
ddbb8a31 155 if (link_class == 0
e56f61be
L
156 || (bfd_get_file_flags (entry->the_bfd) & DYNAMIC) == 0)
157 return FALSE;
158
1e9cc1c2 159 bfd_elf_set_dyn_lib_class (entry->the_bfd,
4724d37e 160 (enum dynamic_lib_link_class) link_class);
4a43e768
AM
161
162 /* Continue on with normal load_symbols processing. */
163 return FALSE;
164}
165EOF
166fi
167
92b93329 168fragment <<EOF
252b5132
RH
169
170/* These variables are required to pass information back and forth
171 between after_open and check_needed and stat_needed and vercheck. */
172
173static struct bfd_link_needed_list *global_needed;
174static struct stat global_stat;
e13629bc 175static lang_input_statement_type *global_found;
252b5132 176static struct bfd_link_needed_list *global_vercheck_needed;
b34976b6 177static bfd_boolean global_vercheck_failed;
252b5132 178
7ee314fa
AM
179/* These variables are used to implement target options */
180
181static char *audit; /* colon (typically) separated list of libs */
182static char *depaudit; /* colon (typically) separated list of libs */
252b5132 183
30e8ee25
AM
184/* Style of .note.gnu.build-id section. */
185static const char *emit_note_gnu_build_id;
186
04925e1e
AM
187/* On Linux, it's possible to have different versions of the same
188 shared library linked against different versions of libc. The
189 dynamic linker somehow tags which libc version to use in
190 /etc/ld.so.cache, and, based on the libc that it sees in the
191 executable, chooses which version of the shared library to use.
252b5132 192
04925e1e
AM
193 We try to do a similar check here by checking whether this shared
194 library needs any other shared libraries which may conflict with
195 libraries we have already included in the link. If it does, we
196 skip it, and try to find another shared library farther on down the
197 link path.
252b5132 198
04925e1e
AM
199 This is called via lang_for_each_input_file.
200 GLOBAL_VERCHECK_NEEDED is the list of objects needed by the object
f813923c 201 which we are checking. This sets GLOBAL_VERCHECK_FAILED if we find
04925e1e 202 a conflicting version. */
252b5132 203
04925e1e 204static void
0c7a8e5a 205gld${EMULATION_NAME}_vercheck (lang_input_statement_type *s)
04925e1e 206{
1c9acd94 207 const char *soname;
04925e1e 208 struct bfd_link_needed_list *l;
252b5132 209
04925e1e
AM
210 if (global_vercheck_failed)
211 return;
212 if (s->the_bfd == NULL
213 || (bfd_get_file_flags (s->the_bfd) & DYNAMIC) == 0)
214 return;
252b5132 215
04925e1e
AM
216 soname = bfd_elf_get_dt_soname (s->the_bfd);
217 if (soname == NULL)
fed2999d 218 soname = lbasename (bfd_get_filename (s->the_bfd));
04925e1e
AM
219
220 for (l = global_vercheck_needed; l != NULL; l = l->next)
221 {
222 const char *suffix;
223
42627821 224 if (filename_cmp (soname, l->name) == 0)
04925e1e
AM
225 {
226 /* Probably can't happen, but it's an easy check. */
227 continue;
252b5132
RH
228 }
229
04925e1e 230 if (strchr (l->name, '/') != NULL)
252b5132
RH
231 continue;
232
04925e1e
AM
233 suffix = strstr (l->name, ".so.");
234 if (suffix == NULL)
235 continue;
236
237 suffix += sizeof ".so." - 1;
238
42627821 239 if (filename_ncmp (soname, l->name, suffix - l->name) == 0)
04925e1e
AM
240 {
241 /* Here we know that S is a dynamic object FOO.SO.VER1, and
0c7a8e5a
AM
242 the object we are considering needs a dynamic object
243 FOO.SO.VER2, and VER1 and VER2 are different. This
244 appears to be a version mismatch, so we tell the caller
245 to try a different version of this library. */
b34976b6 246 global_vercheck_failed = TRUE;
04925e1e
AM
247 return;
248 }
252b5132
RH
249 }
250}
251
252b5132 252
04925e1e
AM
253/* See if an input file matches a DT_NEEDED entry by running stat on
254 the file. */
255
256static void
0c7a8e5a 257gld${EMULATION_NAME}_stat_needed (lang_input_statement_type *s)
252b5132 258{
04925e1e
AM
259 struct stat st;
260 const char *suffix;
261 const char *soname;
252b5132 262
e13629bc 263 if (global_found != NULL)
04925e1e
AM
264 return;
265 if (s->the_bfd == NULL)
266 return;
e13629bc
AM
267
268 /* If this input file was an as-needed entry, and wasn't found to be
269 needed at the stage it was linked, then don't say we have loaded it. */
270 if ((bfd_elf_get_dyn_lib_class (s->the_bfd) & DYN_AS_NEEDED) != 0)
7cedef86 271 return;
04925e1e
AM
272
273 if (bfd_stat (s->the_bfd, &st) != 0)
252b5132 274 {
04925e1e
AM
275 einfo ("%P:%B: bfd_stat failed: %E\n", s->the_bfd);
276 return;
277 }
252b5132 278
9eabd475
ZW
279 /* Some operating systems, e.g. Windows, do not provide a meaningful
280 st_ino; they always set it to zero. (Windows does provide a
281 meaningful st_dev.) Do not indicate a duplicate library in that
282 case. While there is no guarantee that a system that provides
283 meaningful inode numbers will never set st_ino to zero, this is
284 merely an optimization, so we do not need to worry about false
285 negatives. */
04925e1e 286 if (st.st_dev == global_stat.st_dev
9eabd475
ZW
287 && st.st_ino == global_stat.st_ino
288 && st.st_ino != 0)
04925e1e 289 {
e13629bc 290 global_found = s;
04925e1e
AM
291 return;
292 }
252b5132 293
04925e1e
AM
294 /* We issue a warning if it looks like we are including two
295 different versions of the same shared library. For example,
296 there may be a problem if -lc picks up libc.so.6 but some other
297 shared library has a DT_NEEDED entry of libc.so.5. This is a
f813923c 298 heuristic test, and it will only work if the name looks like
04925e1e
AM
299 NAME.so.VERSION. FIXME: Depending on file names is error-prone.
300 If we really want to issue warnings about mixing version numbers
301 of shared libraries, we need to find a better way. */
252b5132 302
04925e1e
AM
303 if (strchr (global_needed->name, '/') != NULL)
304 return;
305 suffix = strstr (global_needed->name, ".so.");
306 if (suffix == NULL)
307 return;
308 suffix += sizeof ".so." - 1;
252b5132 309
04925e1e
AM
310 soname = bfd_elf_get_dt_soname (s->the_bfd);
311 if (soname == NULL)
fed2999d 312 soname = lbasename (s->filename);
252b5132 313
42627821 314 if (filename_ncmp (soname, global_needed->name, suffix - global_needed->name) == 0)
04925e1e 315 einfo ("%P: warning: %s, needed by %B, may conflict with %s\n",
1c9acd94 316 global_needed->name, global_needed->by, soname);
252b5132
RH
317}
318
e56f61be
L
319struct dt_needed
320{
321 bfd *by;
322 const char *name;
323};
04925e1e 324
252b5132
RH
325/* This function is called for each possible name for a dynamic object
326 named by a DT_NEEDED entry. The FORCE parameter indicates whether
327 to skip the check for a conflicting version. */
328
b34976b6 329static bfd_boolean
e56f61be
L
330gld${EMULATION_NAME}_try_needed (struct dt_needed *needed,
331 int force)
252b5132
RH
332{
333 bfd *abfd;
e56f61be 334 const char *name = needed->name;
ec4eb78a 335 const char *soname;
96d56e9f 336 int link_class;
252b5132 337
f13a99db 338 abfd = bfd_openr (name, bfd_get_target (link_info.output_bfd));
252b5132 339 if (abfd == NULL)
0ec22c2c
NC
340 {
341 if (verbose)
342 info_msg (_("attempt to open %s failed\n"), name);
343 return FALSE;
344 }
4a114e3e
L
345
346 /* Linker needs to decompress sections. */
347 abfd->flags |= BFD_DECOMPRESS;
348
252b5132
RH
349 if (! bfd_check_format (abfd, bfd_object))
350 {
cde43e70 351 bfd_close (abfd);
b34976b6 352 return FALSE;
252b5132
RH
353 }
354 if ((bfd_get_file_flags (abfd) & DYNAMIC) == 0)
355 {
cde43e70 356 bfd_close (abfd);
b34976b6 357 return FALSE;
252b5132
RH
358 }
359
c4bb8067 360 /* For DT_NEEDED, they have to match. */
f13a99db 361 if (abfd->xvec != link_info.output_bfd->xvec)
c4bb8067
L
362 {
363 bfd_close (abfd);
b34976b6 364 return FALSE;
c4bb8067
L
365 }
366
252b5132
RH
367 /* Check whether this object would include any conflicting library
368 versions. If FORCE is set, then we skip this check; we use this
369 the second time around, if we couldn't find any compatible
370 instance of the shared library. */
371
372 if (! force)
373 {
91d6fa6a 374 struct bfd_link_needed_list *needs;
252b5132 375
91d6fa6a 376 if (! bfd_elf_get_bfd_needed_list (abfd, &needs))
252b5132
RH
377 einfo ("%F%P:%B: bfd_elf_get_bfd_needed_list failed: %E\n", abfd);
378
91d6fa6a 379 if (needs != NULL)
252b5132 380 {
91d6fa6a 381 global_vercheck_needed = needs;
b34976b6 382 global_vercheck_failed = FALSE;
252b5132
RH
383 lang_for_each_input_file (gld${EMULATION_NAME}_vercheck);
384 if (global_vercheck_failed)
385 {
cde43e70 386 bfd_close (abfd);
b34976b6 387 /* Return FALSE to force the caller to move on to try
0c7a8e5a 388 another file on the search path. */
b34976b6 389 return FALSE;
252b5132
RH
390 }
391
392 /* But wait! It gets much worse. On Linux, if a shared
0c7a8e5a
AM
393 library does not use libc at all, we are supposed to skip
394 it the first time around in case we encounter a shared
395 library later on with the same name which does use the
396 version of libc that we want. This is much too horrible
397 to use on any system other than Linux. */
252b5132
RH
398
399EOF
400case ${target} in
a5244b7e 401 *-*-linux-* | *-*-k*bsd*-* | *-*-gnu*)
92b93329 402 fragment <<EOF
252b5132
RH
403 {
404 struct bfd_link_needed_list *l;
405
91d6fa6a 406 for (l = needs; l != NULL; l = l->next)
0112cd26 407 if (CONST_STRNEQ (l->name, "libc.so"))
252b5132
RH
408 break;
409 if (l == NULL)
410 {
cde43e70 411 bfd_close (abfd);
b34976b6 412 return FALSE;
252b5132
RH
413 }
414 }
415
416EOF
417 ;;
418esac
92b93329 419fragment <<EOF
252b5132
RH
420 }
421 }
422
423 /* We've found a dynamic object matching the DT_NEEDED entry. */
424
04925e1e
AM
425 /* We have already checked that there is no other input file of the
426 same name. We must now check again that we are not including the
427 same file twice. We need to do this because on many systems
428 libc.so is a symlink to, e.g., libc.so.1. The SONAME entry will
429 reference libc.so.1. If we have already included libc.so, we
430 don't want to include libc.so.1 if they are the same file, and we
431 can only check that using stat. */
432
433 if (bfd_stat (abfd, &global_stat) != 0)
434 einfo ("%F%P:%B: bfd_stat failed: %E\n", abfd);
ec4eb78a
L
435
436 /* First strip off everything before the last '/'. */
fed2999d 437 soname = lbasename (abfd->filename);
ec4eb78a 438
cd6f1cf3 439 if (verbose)
ec4eb78a
L
440 info_msg (_("found %s at %s\n"), soname, name);
441
e13629bc 442 global_found = NULL;
04925e1e 443 lang_for_each_input_file (gld${EMULATION_NAME}_stat_needed);
e13629bc 444 if (global_found != NULL)
04925e1e 445 {
b34976b6 446 /* Return TRUE to indicate that we found the file, even though
0c7a8e5a 447 we aren't going to do anything with it. */
b34976b6 448 return TRUE;
04925e1e
AM
449 }
450
4a43e768
AM
451 /* Specify the soname to use. */
452 bfd_elf_set_dt_needed_name (abfd, soname);
04925e1e 453
4a43e768
AM
454 /* Tell the ELF linker that we don't want the output file to have a
455 DT_NEEDED entry for this file, unless it is used to resolve
456 references in a regular object. */
96d56e9f 457 link_class = DYN_DT_NEEDED;
e56f61be
L
458
459 /* Tell the ELF linker that we don't want the output file to have a
460 DT_NEEDED entry for this file at all if the entry is from a file
461 with DYN_NO_ADD_NEEDED. */
7e9f0867
AM
462 if (needed->by != NULL
463 && (bfd_elf_get_dyn_lib_class (needed->by) & DYN_NO_ADD_NEEDED) != 0)
96d56e9f 464 link_class |= DYN_NO_NEEDED | DYN_NO_ADD_NEEDED;
e56f61be 465
1e9cc1c2 466 bfd_elf_set_dyn_lib_class (abfd, (enum dynamic_lib_link_class) link_class);
04925e1e
AM
467
468 /* Add this file into the symbol table. */
469 if (! bfd_link_add_symbols (abfd, &link_info))
8ff4c1f3 470 einfo ("%F%B: error adding symbols: %E\n", abfd);
04925e1e 471
b34976b6 472 return TRUE;
04925e1e
AM
473}
474
04925e1e
AM
475/* Search for a needed file in a path. */
476
b34976b6 477static bfd_boolean
e56f61be
L
478gld${EMULATION_NAME}_search_needed (const char *path,
479 struct dt_needed *n, int force)
04925e1e
AM
480{
481 const char *s;
e56f61be 482 const char *name = n->name;
04925e1e 483 size_t len;
e56f61be 484 struct dt_needed needed;
04925e1e 485
cc5ce052 486 if (name[0] == '/')
e56f61be 487 return gld${EMULATION_NAME}_try_needed (n, force);
cc5ce052 488
04925e1e 489 if (path == NULL || *path == '\0')
b34976b6 490 return FALSE;
e56f61be
L
491
492 needed.by = n->by;
493 needed.name = n->name;
494
04925e1e
AM
495 len = strlen (name);
496 while (1)
497 {
e680a6b6 498 unsigned offset = 0;
199fa1b7 499 char * var;
04925e1e
AM
500 char *filename, *sset;
501
c76308d2 502 s = strchr (path, config.rpath_separator);
04925e1e
AM
503 if (s == NULL)
504 s = path + strlen (path);
505
07f1e47a
AM
506#if HAVE_DOS_BASED_FILE_SYSTEM
507 /* Assume a match on the second char is part of drive specifier. */
508 else if (config.rpath_separator == ':'
509 && s == path + 1
510 && ISALPHA (*path))
511 {
512 s = strchr (s + 1, config.rpath_separator);
513 if (s == NULL)
514 s = path + strlen (path);
515 }
516#endif
04925e1e
AM
517 filename = (char *) xmalloc (s - path + len + 2);
518 if (s == path)
519 sset = filename;
520 else
521 {
522 memcpy (filename, path, s - path);
523 filename[s - path] = '/';
524 sset = filename + (s - path) + 1;
525 }
526 strcpy (sset, name);
527
199fa1b7
NC
528 /* PR 20535: Support the same pseudo-environment variables that
529 are supported by ld.so. Namely, $ORIGIN, $LIB and $PLATFORM.
530 Since there can be more than one occurrence of these tokens in
e680a6b6
NC
531 the path we loop until no more are found. Since we might not
532 be able to substitute some of the tokens we maintain an offset
533 into the filename for where we should begin our scan. */
534 while ((var = strchr (filename + offset, '$')) != NULL)
199fa1b7
NC
535 {
536 /* The ld.so manual page does not say, but I am going to assume that
839b0b3f 537 these tokens are terminated by a directory separator character
199fa1b7
NC
538 (/) or the end of the string. There is also an implication that
539 $ORIGIN should only be used at the start of a path, but that is
540 not enforced here.
541
e680a6b6
NC
542 The ld.so manual page also states that it allows ${ORIGIN},
543 ${LIB} and ${PLATFORM}, so these are supported as well.
199fa1b7
NC
544
545 FIXME: The code could be a lot cleverer about allocating space
546 for the processed string. */
547 char * end = strchr (var, '/');
548 char * replacement = NULL;
e680a6b6 549 char * v = var + 1;
199fa1b7
NC
550 char * freeme = NULL;
551 unsigned flen = strlen (filename);
552
553 if (end != NULL)
554 /* Temporarily terminate the filename at the end of the token. */
555 * end = 0;
556
e680a6b6
NC
557 if (*v == '{')
558 ++ v;
559 switch (*v++)
199fa1b7
NC
560 {
561 case 'O':
e680a6b6 562 if (strcmp (v, "RIGIN") == 0 || strcmp (v, "RIGIN}") == 0)
199fa1b7
NC
563 {
564 /* ORIGIN - replace with the full path to the directory
565 containing the program or shared object. */
566 if (needed.by == NULL)
e680a6b6
NC
567 {
568 if (link_info.output_bfd == NULL)
569 {
570 break;
571 }
572 else
573 replacement = bfd_get_filename (link_info.output_bfd);
574 }
575 else
576 replacement = bfd_get_filename (needed.by);
577
199fa1b7
NC
578 if (replacement)
579 {
580 char * slash;
581
582 if (replacement[0] == '/')
583 freeme = xstrdup (replacement);
584 else
585 {
586 char * current_dir = getpwd ();
587
51750acd 588 freeme = xmalloc (strlen (replacement) + strlen (current_dir) + 2);
199fa1b7
NC
589 sprintf (freeme, "%s/%s", current_dir, replacement);
590 }
591
592 replacement = freeme;
593 if ((slash = strrchr (replacement, '/')) != NULL)
594 * slash = 0;
595 }
596 }
597 break;
598
599 case 'L':
e680a6b6 600 if (strcmp (v, "IB") == 0 || strcmp (v, "IB}") == 0)
199fa1b7
NC
601 {
602 /* LIB - replace with "lib" in 32-bit environments
603 and "lib64" in 64-bit environments. */
604
605 /* Note - we could replace this switch statement by
606 conditional fragments of shell script, but that is messy.
607 Any compiler worth its salt is going to optimize away
608 all but one of these case statements anyway. */
609 switch ($ELFSIZE)
610 {
611 case 32: replacement = "lib"; break;
612 case 64: replacement = "lib64"; break;
613 default:
614 /* $ELFSIZE is not 32 or 64 ... */
615 abort ();
616 }
617 }
618 break;
619
620 case 'P':
e680a6b6
NC
621 /* Supporting $PLATFORM in a cross-hosted environment is not
622 possible. Supporting it in a native environment involves
623 loading the <sys/auxv.h> header file which loads the
624 system <elf.h> header file, which conflicts with the
625 "include/elf/mips.h" header file. */
626 /* Fall through. */
199fa1b7
NC
627 default:
628 break;
629 }
630
631 if (replacement)
632 {
633 char * filename2 = xmalloc (flen + strlen (replacement));
634
635 if (end)
e680a6b6
NC
636 {
637 sprintf (filename2, "%.*s%s/%s",
638 (int)(var - filename), filename,
639 replacement, end + 1);
640 offset = (var - filename) + 1 + strlen (replacement);
641 }
199fa1b7 642 else
e680a6b6
NC
643 {
644 sprintf (filename2, "%.*s%s",
645 (int)(var - filename), filename,
646 replacement);
647 offset = var - filename + strlen (replacement);
648 }
649
199fa1b7
NC
650 free (filename);
651 filename = filename2;
652 /* There is no need to restore the path separator (when
653 end != NULL) as we have replaced the entire string. */
654 }
655 else
656 {
657 if (verbose)
658 /* We only issue an "unrecognised" message in verbose mode
659 as the $<foo> token might be a legitimate component of
660 a path name in the target's file system. */
88ba72a2 661 info_msg (_("unrecognised or unsupported token '%s' in search path\n"), var);
199fa1b7
NC
662
663 if (end)
664 /* Restore the path separator. */
665 * end = '/';
e680a6b6
NC
666
667 /* PR 20784: Make sure that we resume the scan
668 *after* the token that we could not replace. */
669 offset = (var + 1) - filename;
199fa1b7
NC
670 }
671
672 free (freeme);
673 }
674
e56f61be 675 needed.name = filename;
e680a6b6 676
e56f61be 677 if (gld${EMULATION_NAME}_try_needed (&needed, force))
b34976b6 678 return TRUE;
04925e1e
AM
679
680 free (filename);
681
682 if (*s == '\0')
683 break;
684 path = s + 1;
685 }
686
b34976b6 687 return FALSE;
04925e1e
AM
688}
689
690EOF
9c8ebd6a 691if [ "x${USE_LIBPATH}" = xyes ] ; then
92b93329 692 fragment <<EOF
9c8ebd6a 693
316a1245
AM
694/* Prefix the sysroot to absolute paths in PATH, a string containing
695 paths separated by config.rpath_separator. If running on a DOS
696 file system, paths containing a drive spec won't have the sysroot
697 prefix added, unless the sysroot also specifies the same drive. */
9c8ebd6a 698
316a1245 699static const char *
0c7a8e5a 700gld${EMULATION_NAME}_add_sysroot (const char *path)
9c8ebd6a 701{
316a1245
AM
702 size_t len, extra;
703 const char *p;
704 char *ret, *q;
705 int dos_drive_sysroot = HAS_DRIVE_SPEC (ld_sysroot);
706
707 len = strlen (ld_sysroot);
708 for (extra = 0, p = path; ; )
709 {
710 int dos_drive = HAS_DRIVE_SPEC (p);
711
712 if (dos_drive)
713 p += 2;
714 if (IS_DIR_SEPARATOR (*p)
715 && (!dos_drive
716 || (dos_drive_sysroot
717 && ld_sysroot[0] == p[-2])))
718 {
719 if (dos_drive && dos_drive_sysroot)
720 extra += len - 2;
721 else
722 extra += len;
723 }
724 p = strchr (p, config.rpath_separator);
725 if (!p)
726 break;
727 ++p;
728 }
729
730 ret = xmalloc (strlen (path) + extra + 1);
731
732 for (q = ret, p = path; ; )
733 {
734 const char *end;
735 int dos_drive = HAS_DRIVE_SPEC (p);
736
737 if (dos_drive)
738 {
739 *q++ = *p++;
740 *q++ = *p++;
741 }
742 if (IS_DIR_SEPARATOR (*p)
743 && (!dos_drive
744 || (dos_drive_sysroot
745 && ld_sysroot[0] == p[-2])))
746 {
747 if (dos_drive && dos_drive_sysroot)
748 {
749 strcpy (q, ld_sysroot + 2);
750 q += len - 2;
751 }
752 else
753 {
754 strcpy (q, ld_sysroot);
755 q += len;
756 }
757 }
758 end = strchr (p, config.rpath_separator);
759 if (end)
760 {
761 size_t n = end - p + 1;
762 strncpy (q, p, n);
763 q += n;
764 p += n;
765 }
766 else
767 {
768 strcpy (q, p);
769 break;
770 }
771 }
772
9c8ebd6a
DJ
773 return ret;
774}
04925e1e 775
3dc16cab
DJ
776EOF
777 case ${target} in
ebe1fac1 778 *-*-freebsd* | *-*-dragonfly*)
92b93329 779 fragment <<EOF
ebe1fac1
NC
780/* Read the system search path the FreeBSD way rather than the Linux way. */
781#ifdef HAVE_ELF_HINTS_H
782#include <elf-hints.h>
783#else
784#include "elf-hints-local.h"
785#endif
786
787static bfd_boolean
d5c8b1f8
AM
788gld${EMULATION_NAME}_check_ld_elf_hints (const struct bfd_link_needed_list *l,
789 int force)
ebe1fac1
NC
790{
791 static bfd_boolean initialized;
316a1245 792 static const char *ld_elf_hints;
ebe1fac1
NC
793 struct dt_needed needed;
794
795 if (!initialized)
796 {
797 FILE *f;
798 char *tmppath;
799
ff7a0acf 800 tmppath = concat (ld_sysroot, _PATH_ELF_HINTS, (const char *) NULL);
ebe1fac1
NC
801 f = fopen (tmppath, FOPEN_RB);
802 free (tmppath);
803 if (f != NULL)
804 {
805 struct elfhints_hdr hdr;
806
807 if (fread (&hdr, 1, sizeof (hdr), f) == sizeof (hdr)
808 && hdr.magic == ELFHINTS_MAGIC
809 && hdr.version == 1)
810 {
811 if (fseek (f, hdr.strtab + hdr.dirlist, SEEK_SET) != -1)
812 {
813 char *b;
814
815 b = xmalloc (hdr.dirlistlen + 1);
816 if (fread (b, 1, hdr.dirlistlen + 1, f) ==
817 hdr.dirlistlen + 1)
818 ld_elf_hints = gld${EMULATION_NAME}_add_sysroot (b);
e13629bc 819
ebe1fac1
NC
820 free (b);
821 }
822 }
823 fclose (f);
824 }
825
826 initialized = TRUE;
827 }
828
829 if (ld_elf_hints == NULL)
830 return FALSE;
831
d5c8b1f8
AM
832 needed.by = l->by;
833 needed.name = l->name;
834 return gld${EMULATION_NAME}_search_needed (ld_elf_hints, &needed, force);
ebe1fac1
NC
835}
836EOF
837 # FreeBSD
838 ;;
839
a5244b7e 840 *-*-linux-* | *-*-k*bsd*-* | *-*-gnu*)
92b93329 841 fragment <<EOF
04925e1e
AM
842/* For a native linker, check the file /etc/ld.so.conf for directories
843 in which we may find shared libraries. /etc/ld.so.conf is really
482e8b32 844 only meaningful on Linux. */
04925e1e 845
d3989512 846struct gld${EMULATION_NAME}_ld_so_conf
04925e1e 847{
d3989512
JJ
848 char *path;
849 size_t len, alloc;
850};
04925e1e 851
dfcffada 852static bfd_boolean
d3989512
JJ
853gld${EMULATION_NAME}_parse_ld_so_conf
854 (struct gld${EMULATION_NAME}_ld_so_conf *info, const char *filename);
855
856static void
857gld${EMULATION_NAME}_parse_ld_so_conf_include
858 (struct gld${EMULATION_NAME}_ld_so_conf *info, const char *filename,
859 const char *pattern)
860{
861 char *newp = NULL;
0b48acfe 862#ifdef HAVE_GLOB
d3989512 863 glob_t gl;
0b48acfe 864#endif
d3989512
JJ
865
866 if (pattern[0] != '/')
04925e1e 867 {
d3989512
JJ
868 char *p = strrchr (filename, '/');
869 size_t patlen = strlen (pattern) + 1;
04925e1e 870
d3989512
JJ
871 newp = xmalloc (p - filename + 1 + patlen);
872 memcpy (newp, filename, p - filename + 1);
873 memcpy (newp + (p - filename + 1), pattern, patlen);
874 pattern = newp;
875 }
04925e1e 876
0b48acfe 877#ifdef HAVE_GLOB
d3989512
JJ
878 if (glob (pattern, 0, NULL, &gl) == 0)
879 {
880 size_t i;
881
882 for (i = 0; i < gl.gl_pathc; ++i)
883 gld${EMULATION_NAME}_parse_ld_so_conf (info, gl.gl_pathv[i]);
884 globfree (&gl);
885 }
0b48acfe
MM
886#else
887 /* If we do not have glob, treat the pattern as a literal filename. */
888 gld${EMULATION_NAME}_parse_ld_so_conf (info, pattern);
889#endif
d3989512
JJ
890
891 if (newp)
892 free (newp);
893}
894
dfcffada 895static bfd_boolean
d3989512
JJ
896gld${EMULATION_NAME}_parse_ld_so_conf
897 (struct gld${EMULATION_NAME}_ld_so_conf *info, const char *filename)
898{
899 FILE *f = fopen (filename, FOPEN_RT);
563f4125
JJ
900 char *line;
901 size_t linelen;
d3989512
JJ
902
903 if (f == NULL)
dfcffada 904 return FALSE;
d3989512 905
563f4125
JJ
906 linelen = 256;
907 line = xmalloc (linelen);
908 do
d3989512 909 {
563f4125
JJ
910 char *p = line, *q;
911
912 /* Normally this would use getline(3), but we need to be portable. */
913 while ((q = fgets (p, linelen - (p - line), f)) != NULL
914 && strlen (q) == linelen - (p - line) - 1
915 && line[linelen - 2] != '\n')
916 {
917 line = xrealloc (line, 2 * linelen);
918 p = line + linelen - 1;
919 linelen += linelen;
920 }
921
922 if (q == NULL && p == line)
923 break;
d3989512
JJ
924
925 p = strchr (line, '\n');
926 if (p)
927 *p = '\0';
928
929 /* Because the file format does not know any form of quoting we
930 can search forward for the next '#' character and if found
931 make it terminating the line. */
932 p = strchr (line, '#');
933 if (p)
934 *p = '\0';
935
936 /* Remove leading whitespace. NUL is no whitespace character. */
937 p = line;
938 while (*p == ' ' || *p == '\f' || *p == '\r' || *p == '\t' || *p == '\v')
939 ++p;
940
941 /* If the line is blank it is ignored. */
942 if (p[0] == '\0')
943 continue;
04925e1e 944
0112cd26 945 if (CONST_STRNEQ (p, "include") && (p[7] == ' ' || p[7] == '\t'))
d3989512
JJ
946 {
947 char *dir, c;
948 p += 8;
949 do
04925e1e 950 {
d3989512
JJ
951 while (*p == ' ' || *p == '\t')
952 ++p;
04925e1e 953
d3989512
JJ
954 if (*p == '\0')
955 break;
252b5132 956
d3989512
JJ
957 dir = p;
958
959 while (*p != ' ' && *p != '\t' && *p)
960 ++p;
961
962 c = *p;
963 *p++ = '\0';
964 if (dir[0] != '\0')
965 gld${EMULATION_NAME}_parse_ld_so_conf_include (info, filename,
966 dir);
967 }
968 while (c != '\0');
969 }
970 else
971 {
972 char *dir = p;
973 while (*p && *p != '=' && *p != ' ' && *p != '\t' && *p != '\f'
974 && *p != '\r' && *p != '\v')
975 ++p;
976
977 while (p != dir && p[-1] == '/')
978 --p;
979 if (info->path == NULL)
980 {
981 info->alloc = p - dir + 1 + 256;
982 info->path = xmalloc (info->alloc);
983 info->len = 0;
984 }
04925e1e
AM
985 else
986 {
d3989512
JJ
987 if (info->len + 1 + (p - dir) >= info->alloc)
988 {
989 info->alloc += p - dir + 256;
990 info->path = xrealloc (info->path, info->alloc);
991 }
c76308d2 992 info->path[info->len++] = config.rpath_separator;
04925e1e 993 }
d3989512
JJ
994 memcpy (info->path + info->len, dir, p - dir);
995 info->len += p - dir;
996 info->path[info->len] = '\0';
997 }
998 }
563f4125 999 while (! feof (f));
d3989512
JJ
1000 free (line);
1001 fclose (f);
dfcffada 1002 return TRUE;
d3989512 1003}
252b5132 1004
d3989512 1005static bfd_boolean
d5c8b1f8
AM
1006gld${EMULATION_NAME}_check_ld_so_conf (const struct bfd_link_needed_list *l,
1007 int force)
d3989512
JJ
1008{
1009 static bfd_boolean initialized;
316a1245 1010 static const char *ld_so_conf;
d3989512 1011 struct dt_needed needed;
252b5132 1012
d3989512
JJ
1013 if (! initialized)
1014 {
1015 char *tmppath;
1016 struct gld${EMULATION_NAME}_ld_so_conf info;
9c8ebd6a 1017
d3989512
JJ
1018 info.path = NULL;
1019 info.len = info.alloc = 0;
ff7a0acf
AM
1020 tmppath = concat (ld_sysroot, "${prefix}/etc/ld.so.conf",
1021 (const char *) NULL);
dfcffada
AM
1022 if (!gld${EMULATION_NAME}_parse_ld_so_conf (&info, tmppath))
1023 {
1024 free (tmppath);
ff7a0acf
AM
1025 tmppath = concat (ld_sysroot, "/etc/ld.so.conf",
1026 (const char *) NULL);
dfcffada
AM
1027 gld${EMULATION_NAME}_parse_ld_so_conf (&info, tmppath);
1028 }
d3989512 1029 free (tmppath);
dfcffada 1030
d3989512
JJ
1031 if (info.path)
1032 {
316a1245 1033 ld_so_conf = gld${EMULATION_NAME}_add_sysroot (info.path);
d3989512 1034 free (info.path);
04925e1e 1035 }
b34976b6 1036 initialized = TRUE;
04925e1e 1037 }
49e56c49 1038
04925e1e 1039 if (ld_so_conf == NULL)
b34976b6 1040 return FALSE;
252b5132 1041
e56f61be 1042
d5c8b1f8
AM
1043 needed.by = l->by;
1044 needed.name = l->name;
e56f61be 1045 return gld${EMULATION_NAME}_search_needed (ld_so_conf, &needed, force);
252b5132
RH
1046}
1047
04925e1e 1048EOF
9c8ebd6a
DJ
1049 # Linux
1050 ;;
04925e1e
AM
1051 esac
1052fi
92b93329 1053fragment <<EOF
04925e1e 1054
252b5132
RH
1055/* See if an input file matches a DT_NEEDED entry by name. */
1056
1057static void
0c7a8e5a 1058gld${EMULATION_NAME}_check_needed (lang_input_statement_type *s)
252b5132 1059{
e13629bc
AM
1060 const char *soname;
1061
1062 /* Stop looking if we've found a loaded lib. */
1063 if (global_found != NULL
1064 && (bfd_elf_get_dyn_lib_class (global_found->the_bfd)
1065 & DYN_AS_NEEDED) == 0)
252b5132
RH
1066 return;
1067
e13629bc
AM
1068 if (s->filename == NULL || s->the_bfd == NULL)
1069 return;
1070
1071 /* Don't look for a second non-loaded as-needed lib. */
1072 if (global_found != NULL
1073 && (bfd_elf_get_dyn_lib_class (s->the_bfd) & DYN_AS_NEEDED) != 0)
7cedef86
AM
1074 return;
1075
42627821 1076 if (filename_cmp (s->filename, global_needed->name) == 0)
252b5132 1077 {
e13629bc
AM
1078 global_found = s;
1079 return;
1080 }
577a0623 1081
66be1055 1082 if (s->flags.search_dirs)
e13629bc
AM
1083 {
1084 const char *f = strrchr (s->filename, '/');
1085 if (f != NULL
42627821 1086 && filename_cmp (f + 1, global_needed->name) == 0)
577a0623 1087 {
e13629bc 1088 global_found = s;
577a0623
AM
1089 return;
1090 }
252b5132
RH
1091 }
1092
e13629bc
AM
1093 soname = bfd_elf_get_dt_soname (s->the_bfd);
1094 if (soname != NULL
42627821 1095 && filename_cmp (soname, global_needed->name) == 0)
252b5132 1096 {
e13629bc
AM
1097 global_found = s;
1098 return;
252b5132 1099 }
252b5132
RH
1100}
1101
41392f03
AM
1102EOF
1103
1104if test x"$LDEMUL_AFTER_OPEN" != xgld"$EMULATION_NAME"_after_open; then
92b93329 1105fragment <<EOF
04925e1e 1106
24382dca 1107static bfd_size_type
677e5a92 1108id_note_section_size (bfd *abfd ATTRIBUTE_UNUSED)
24382dca 1109{
30e8ee25 1110 const char *style = emit_note_gnu_build_id;
24382dca 1111 bfd_size_type size;
61e2488c 1112 bfd_size_type build_id_size;
24382dca 1113
24382dca
RM
1114 size = offsetof (Elf_External_Note, name[sizeof "GNU"]);
1115 size = (size + 3) & -(bfd_size_type) 4;
1116
61e2488c
JT
1117 build_id_size = compute_build_id_size (style);
1118 if (build_id_size)
1119 size += build_id_size;
24382dca
RM
1120 else
1121 size = 0;
1122
1123 return size;
1124}
1125
24382dca 1126static bfd_boolean
30e8ee25 1127write_build_id (bfd *abfd)
24382dca
RM
1128{
1129 const struct elf_backend_data *bed = get_elf_backend_data (abfd);
30e8ee25
AM
1130 struct elf_obj_tdata *t = elf_tdata (abfd);
1131 const char *style;
24382dca
RM
1132 asection *asec;
1133 Elf_Internal_Shdr *i_shdr;
1134 unsigned char *contents, *id_bits;
1135 bfd_size_type size;
30e8ee25 1136 file_ptr position;
24382dca
RM
1137 Elf_External_Note *e_note;
1138
c0355132
AM
1139 style = t->o->build_id.style;
1140 asec = t->o->build_id.sec;
83e4970b 1141 if (bfd_is_abs_section (asec->output_section))
24382dca 1142 {
83e4970b
AM
1143 einfo (_("%P: warning: .note.gnu.build-id section discarded,"
1144 " --build-id ignored.\n"));
1145 return TRUE;
24382dca
RM
1146 }
1147 i_shdr = &elf_section_data (asec->output_section)->this_hdr;
1148
1149 if (i_shdr->contents == NULL)
1150 {
b2ff8454 1151 if (asec->contents == NULL)
1e9cc1c2 1152 asec->contents = (unsigned char *) xmalloc (asec->size);
b2ff8454 1153 contents = asec->contents;
24382dca 1154 }
b2ff8454
RM
1155 else
1156 contents = i_shdr->contents + asec->output_offset;
24382dca 1157
1e9cc1c2 1158 e_note = (Elf_External_Note *) contents;
24382dca
RM
1159 size = offsetof (Elf_External_Note, name[sizeof "GNU"]);
1160 size = (size + 3) & -(bfd_size_type) 4;
1161 id_bits = contents + size;
1162 size = asec->size - size;
1163
1164 bfd_h_put_32 (abfd, sizeof "GNU", &e_note->namesz);
1165 bfd_h_put_32 (abfd, size, &e_note->descsz);
1166 bfd_h_put_32 (abfd, NT_GNU_BUILD_ID, &e_note->type);
1167 memcpy (e_note->name, "GNU", sizeof "GNU");
1168
61e2488c 1169 generate_build_id (abfd, style, bed->s->checksum_contents, id_bits, size);
24382dca 1170
30e8ee25 1171 position = i_shdr->sh_offset + asec->output_offset;
b2ff8454 1172 size = asec->size;
30e8ee25 1173 return (bfd_seek (abfd, position, SEEK_SET) == 0
b2ff8454 1174 && bfd_bwrite (contents, size, abfd) == size);
24382dca
RM
1175}
1176
30e8ee25
AM
1177/* Make .note.gnu.build-id section, and set up elf_tdata->build_id. */
1178
1179static bfd_boolean
1180setup_build_id (bfd *ibfd)
1181{
1182 asection *s;
1183 bfd_size_type size;
1184 flagword flags;
1185
1186 size = id_note_section_size (ibfd);
1187 if (size == 0)
1188 {
1189 einfo ("%P: warning: unrecognized --build-id style ignored.\n");
1190 return FALSE;
1191 }
1192
1193 flags = (SEC_ALLOC | SEC_LOAD | SEC_IN_MEMORY
1194 | SEC_LINKER_CREATED | SEC_READONLY | SEC_DATA);
1195 s = bfd_make_section_with_flags (ibfd, ".note.gnu.build-id", flags);
1196 if (s != NULL && bfd_set_section_alignment (ibfd, s, 2))
1197 {
1198 struct elf_obj_tdata *t = elf_tdata (link_info.output_bfd);
c0355132
AM
1199 t->o->build_id.after_write_object_contents = &write_build_id;
1200 t->o->build_id.style = emit_note_gnu_build_id;
1201 t->o->build_id.sec = s;
1202 elf_section_type (s) = SHT_NOTE;
1203 s->size = size;
1204 return TRUE;
30e8ee25
AM
1205 }
1206
1207 einfo ("%P: warning: Cannot create .note.gnu.build-id section,"
1208 " --build-id ignored.\n");
1209 return FALSE;
1210}
24382dca 1211
04925e1e 1212/* This is called after all the input files have been opened. */
252b5132
RH
1213
1214static void
0c7a8e5a 1215gld${EMULATION_NAME}_after_open (void)
252b5132 1216{
04925e1e 1217 struct bfd_link_needed_list *needed, *l;
d10e7fcc
AM
1218 struct elf_link_hash_table *htab;
1219
5c3049d2
AM
1220 after_open_default ();
1221
d10e7fcc
AM
1222 htab = elf_hash_table (&link_info);
1223 if (!is_elf_hash_table (htab))
1224 return;
252b5132 1225
76359541
TP
1226 if (command_line.out_implib_filename)
1227 {
1228 unlink_if_ordinary (command_line.out_implib_filename);
1229 link_info.out_implib_bfd
1230 = bfd_openw (command_line.out_implib_filename,
1231 bfd_get_target (link_info.output_bfd));
1232
1233 if (link_info.out_implib_bfd == NULL)
1234 {
1235 einfo ("%F%s: Can't open for writing: %E\n",
1236 command_line.out_implib_filename);
1237 }
1238 }
1239
30e8ee25 1240 if (emit_note_gnu_build_id != NULL)
c0065db7
RM
1241 {
1242 bfd *abfd;
c0065db7 1243
a654efd6
L
1244 /* Find an ELF input. */
1245 for (abfd = link_info.input_bfds;
c72f2fb2 1246 abfd != (bfd *) NULL; abfd = abfd->link.next)
ca0694ad
AM
1247 if (bfd_get_flavour (abfd) == bfd_target_elf_flavour
1248 && bfd_count_sections (abfd) != 0)
a654efd6 1249 break;
c0065db7 1250
30e8ee25
AM
1251 /* PR 10555: If there are no ELF input files do not try to
1252 create a .note.gnu-build-id section. */
1253 if (abfd == NULL
1254 || !setup_build_id (abfd))
c0065db7 1255 {
30e8ee25
AM
1256 free ((char *) emit_note_gnu_build_id);
1257 emit_note_gnu_build_id = NULL;
c0065db7
RM
1258 }
1259 }
1260
46bed679
L
1261 get_elf_backend_data (link_info.output_bfd)->setup_gnu_properties (&link_info);
1262
0e1862bb 1263 if (bfd_link_relocatable (&link_info))
76f0cad6
NC
1264 {
1265 if (link_info.execstack == ! link_info.noexecstack)
1266 /* PR ld/16744: If "-z [no]execstack" has been specified on the
1267 command line and we are perfoming a relocatable link then no
1268 PT_GNU_STACK segment will be created and so the
1269 linkinfo.[no]execstack values set in _handle_option() will have no
1270 effect. Instead we create a .note.GNU-stack section in much the
1271 same way as the assembler does with its --[no]execstack option. */
1272 (void) bfd_make_section_with_flags (link_info.input_bfds,
1273 ".note.GNU-stack",
1274 SEC_READONLY | (link_info.execstack ? SEC_CODE : 0));
1275
1276 return;
1277 }
d10e7fcc 1278
2f0c68f2 1279 if (!link_info.traditional_format)
eb3d5f3b 1280 {
a654efd6
L
1281 bfd *abfd, *elfbfd = NULL;
1282 bfd_boolean warn_eh_frame = FALSE;
d10e7fcc 1283 asection *s;
2f0c68f2 1284 int seen_type = 0;
eb3d5f3b 1285
c72f2fb2 1286 for (abfd = link_info.input_bfds; abfd; abfd = abfd->link.next)
eb3d5f3b 1287 {
2f0c68f2
CM
1288 int type = 0;
1289 for (s = abfd->sections; s && type < COMPACT_EH_HDR; s = s->next)
4440bb77 1290 {
2f0c68f2
CM
1291 const char *name = bfd_get_section_name (abfd, s);
1292
1293 if (bfd_is_abs_section (s->output_section))
1294 continue;
1295 if (CONST_STRNEQ (name, ".eh_frame_entry"))
1296 type = COMPACT_EH_HDR;
1297 else if (strcmp (name, ".eh_frame") == 0 && s->size > 8)
1298 type = DWARF2_EH_HDR;
4440bb77 1299 }
2f0c68f2
CM
1300
1301 if (type != 0)
1302 {
1303 if (seen_type == 0)
1304 {
1305 seen_type = type;
1306 }
1307 else if (seen_type != type)
1308 {
1309 einfo (_("%P%F: compact frame descriptions incompatible with"
1310 " DWARF2 .eh_frame from %B\n"),
1311 type == DWARF2_EH_HDR ? abfd : elfbfd);
1312 break;
1313 }
1314
1315 if (!elfbfd
1316 && (type == COMPACT_EH_HDR || link_info.eh_frame_hdr_type != 0))
1317 {
1318 if (bfd_get_flavour (abfd) == bfd_target_elf_flavour)
1319 elfbfd = abfd;
1320
1321 warn_eh_frame = TRUE;
1322 }
1323 }
1324
1325 if (seen_type == COMPACT_EH_HDR)
1326 link_info.eh_frame_hdr_type = COMPACT_EH_HDR;
1327
1328 if (bfd_count_sections (abfd) == 0)
1329 continue;
d10e7fcc 1330 }
a654efd6 1331 if (elfbfd)
d10e7fcc
AM
1332 {
1333 const struct elf_backend_data *bed;
1334
a654efd6
L
1335 bed = get_elf_backend_data (elfbfd);
1336 s = bfd_make_section_with_flags (elfbfd, ".eh_frame_hdr",
1337 bed->dynamic_sec_flags
1338 | SEC_READONLY);
d10e7fcc 1339 if (s != NULL
a654efd6
L
1340 && bfd_set_section_alignment (elfbfd, s, 2))
1341 {
1342 htab->eh_info.hdr_sec = s;
1343 warn_eh_frame = FALSE;
1344 }
eb3d5f3b 1345 }
a654efd6
L
1346 if (warn_eh_frame)
1347 einfo ("%P: warning: Cannot create .eh_frame_hdr section,"
1348 " --eh-frame-hdr ignored.\n");
eb3d5f3b
JB
1349 }
1350
04925e1e
AM
1351 /* Get the list of files which appear in DT_NEEDED entries in
1352 dynamic objects included in the link (often there will be none).
1353 For each such file, we want to track down the corresponding
1354 library, and include the symbol table in the link. This is what
1355 the runtime dynamic linker will do. Tracking the files down here
1356 permits one dynamic object to include another without requiring
1357 special action by the person doing the link. Note that the
1358 needed list can actually grow while we are stepping through this
1359 loop. */
f13a99db 1360 needed = bfd_elf_get_needed_list (link_info.output_bfd, &link_info);
04925e1e 1361 for (l = needed; l != NULL; l = l->next)
252b5132 1362 {
04925e1e 1363 struct bfd_link_needed_list *ll;
e56f61be 1364 struct dt_needed n, nn;
04925e1e 1365 int force;
252b5132 1366
7e9f0867 1367 /* If the lib that needs this one was --as-needed and wasn't
4706eab9 1368 found to be needed, then this lib isn't needed either. */
7e9f0867 1369 if (l->by != NULL
4706eab9
AM
1370 && (bfd_elf_get_dyn_lib_class (l->by) & DYN_AS_NEEDED) != 0)
1371 continue;
1372
1373 /* Skip the lib if --no-copy-dt-needed-entries and
1374 --allow-shlib-undefined is in effect. */
1375 if (l->by != NULL
1376 && link_info.unresolved_syms_in_shared_libs == RM_IGNORE
1377 && (bfd_elf_get_dyn_lib_class (l->by) & DYN_NO_ADD_NEEDED) != 0)
7e9f0867
AM
1378 continue;
1379
04925e1e
AM
1380 /* If we've already seen this file, skip it. */
1381 for (ll = needed; ll != l; ll = ll->next)
7e9f0867
AM
1382 if ((ll->by == NULL
1383 || (bfd_elf_get_dyn_lib_class (ll->by) & DYN_AS_NEEDED) == 0)
1384 && strcmp (ll->name, l->name) == 0)
04925e1e
AM
1385 break;
1386 if (ll != l)
1387 continue;
252b5132 1388
04925e1e
AM
1389 /* See if this file was included in the link explicitly. */
1390 global_needed = l;
e13629bc 1391 global_found = NULL;
04925e1e 1392 lang_for_each_input_file (gld${EMULATION_NAME}_check_needed);
e13629bc
AM
1393 if (global_found != NULL
1394 && (bfd_elf_get_dyn_lib_class (global_found->the_bfd)
1395 & DYN_AS_NEEDED) == 0)
04925e1e 1396 continue;
252b5132 1397
e56f61be
L
1398 n.by = l->by;
1399 n.name = l->name;
1400 nn.by = l->by;
cd6f1cf3 1401 if (verbose)
ec4eb78a
L
1402 info_msg (_("%s needed by %B\n"), l->name, l->by);
1403
e13629bc
AM
1404 /* As-needed libs specified on the command line (or linker script)
1405 take priority over libs found in search dirs. */
1406 if (global_found != NULL)
1407 {
1408 nn.name = global_found->filename;
1409 if (gld${EMULATION_NAME}_try_needed (&nn, TRUE))
1410 continue;
1411 }
1412
04925e1e
AM
1413 /* We need to find this file and include the symbol table. We
1414 want to search for the file in the same way that the dynamic
1415 linker will search. That means that we want to use
1416 rpath_link, rpath, then the environment variable
ec4eb78a
L
1417 LD_LIBRARY_PATH (native only), then the DT_RPATH/DT_RUNPATH
1418 entries (native only), then the linker script LIB_SEARCH_DIRS.
1419 We do not search using the -L arguments.
252b5132 1420
04925e1e
AM
1421 We search twice. The first time, we skip objects which may
1422 introduce version mismatches. The second time, we force
1423 their use. See gld${EMULATION_NAME}_vercheck comment. */
1424 for (force = 0; force < 2; force++)
1425 {
04925e1e
AM
1426 size_t len;
1427 search_dirs_type *search;
6dd8c765 1428EOF
316a1245 1429if [ "x${NATIVE}" = xyes ] || [ "x${USE_LIBPATH}" = xyes ] ; then
92b93329 1430fragment <<EOF
316a1245 1431 const char *path;
ff925e69
KK
1432EOF
1433fi
1434if [ "x${USE_LIBPATH}" = xyes ] ; then
92b93329 1435fragment <<EOF
6dd8c765
L
1436 struct bfd_link_needed_list *rp;
1437 int found;
1438EOF
6dd8c765 1439fi
92b93329 1440fragment <<EOF
252b5132 1441
04925e1e 1442 if (gld${EMULATION_NAME}_search_needed (command_line.rpath_link,
e56f61be 1443 &n, force))
04925e1e 1444 break;
dcb0bd0e 1445EOF
9c8ebd6a 1446if [ "x${USE_LIBPATH}" = xyes ] ; then
92b93329 1447fragment <<EOF
316a1245
AM
1448 path = command_line.rpath;
1449 if (path)
1450 {
118aa6cf 1451 path = gld${EMULATION_NAME}_add_sysroot (path);
316a1245 1452 found = gld${EMULATION_NAME}_search_needed (path, &n, force);
118aa6cf 1453 free ((char *) path);
316a1245
AM
1454 if (found)
1455 break;
1456 }
9c8ebd6a
DJ
1457EOF
1458fi
1459if [ "x${NATIVE}" = xyes ] ; then
92b93329 1460fragment <<EOF
04925e1e
AM
1461 if (command_line.rpath_link == NULL
1462 && command_line.rpath == NULL)
1463 {
316a1245
AM
1464 path = (const char *) getenv ("LD_RUN_PATH");
1465 if (path
1466 && gld${EMULATION_NAME}_search_needed (path, &n, force))
04925e1e
AM
1467 break;
1468 }
316a1245
AM
1469 path = (const char *) getenv ("LD_LIBRARY_PATH");
1470 if (path
1471 && gld${EMULATION_NAME}_search_needed (path, &n, force))
04925e1e 1472 break;
9c8ebd6a
DJ
1473EOF
1474fi
1475if [ "x${USE_LIBPATH}" = xyes ] ; then
92b93329 1476fragment <<EOF
ec4eb78a 1477 found = 0;
f13a99db 1478 rp = bfd_elf_get_runpath_list (link_info.output_bfd, &link_info);
6dd8c765 1479 for (; !found && rp != NULL; rp = rp->next)
ec4eb78a 1480 {
316a1245 1481 path = gld${EMULATION_NAME}_add_sysroot (rp->name);
ec4eb78a 1482 found = (rp->by == l->by
316a1245 1483 && gld${EMULATION_NAME}_search_needed (path, &n,
ec4eb78a 1484 force));
316a1245 1485 free ((char *) path);
ec4eb78a
L
1486 }
1487 if (found)
1488 break;
1489
04925e1e 1490EOF
04925e1e 1491fi
c1446dba
L
1492if [ "x${USE_LIBPATH}" = xyes ] ; then
1493 case ${target} in
ebe1fac1 1494 *-*-freebsd* | *-*-dragonfly*)
92b93329 1495 fragment <<EOF
d5c8b1f8 1496 if (gld${EMULATION_NAME}_check_ld_elf_hints (l, force))
ebe1fac1
NC
1497 break;
1498EOF
1499 # FreeBSD
1500 ;;
1501
a5244b7e 1502 *-*-linux-* | *-*-k*bsd*-* | *-*-gnu*)
92b93329 1503 fragment <<EOF
d5c8b1f8 1504 if (gld${EMULATION_NAME}_check_ld_so_conf (l, force))
c1446dba
L
1505 break;
1506
1507EOF
eeaa4577 1508 # Linux
c1446dba
L
1509 ;;
1510 esac
1511fi
92b93329 1512fragment <<EOF
04925e1e
AM
1513 len = strlen (l->name);
1514 for (search = search_head; search != NULL; search = search->next)
1515 {
1516 char *filename;
252b5132 1517
04925e1e
AM
1518 if (search->cmdline)
1519 continue;
1520 filename = (char *) xmalloc (strlen (search->name) + len + 2);
1521 sprintf (filename, "%s/%s", search->name, l->name);
e56f61be
L
1522 nn.name = filename;
1523 if (gld${EMULATION_NAME}_try_needed (&nn, force))
04925e1e
AM
1524 break;
1525 free (filename);
1526 }
1527 if (search != NULL)
1528 break;
1529EOF
92b93329 1530fragment <<EOF
04925e1e 1531 }
252b5132 1532
04925e1e
AM
1533 if (force < 2)
1534 continue;
252b5132 1535
e374f1d9 1536 einfo ("%P: warning: %s, needed by %B, not found (try using -rpath or -rpath-link)\n",
04925e1e
AM
1537 l->name, l->by);
1538 }
2f0c68f2
CM
1539
1540 if (link_info.eh_frame_hdr_type == COMPACT_EH_HDR)
1541 if (bfd_elf_parse_eh_frame_entries (NULL, &link_info) == FALSE)
1542 einfo (_("%P%F: Failed to parse EH frame entries.\n"));
04925e1e 1543}
252b5132 1544
41392f03
AM
1545EOF
1546fi
1547
92b93329 1548fragment <<EOF
252b5132 1549
04925e1e 1550/* Look through an expression for an assignment statement. */
252b5132 1551
04925e1e 1552static void
0c7a8e5a 1553gld${EMULATION_NAME}_find_exp_assignment (etree_type *exp)
04925e1e 1554{
4ea42fb7 1555 bfd_boolean provide = FALSE;
04925e1e
AM
1556
1557 switch (exp->type.node_class)
252b5132 1558 {
04925e1e 1559 case etree_provide:
bded3693 1560 case etree_provided:
4ea42fb7 1561 provide = TRUE;
839b0b3f 1562 /* Fallthru */
4ea42fb7 1563 case etree_assign:
04925e1e
AM
1564 /* We call record_link_assignment even if the symbol is defined.
1565 This is because if it is defined by a dynamic object, we
1566 actually want to use the value defined by the linker script,
1567 not the value from the dynamic object (because we are setting
1568 symbols like etext). If the symbol is defined by a regular
1569 object, then, as it happens, calling record_link_assignment
1570 will do no harm. */
04925e1e 1571 if (strcmp (exp->assign.dst, ".") != 0)
252b5132 1572 {
f13a99db
AM
1573 if (!bfd_elf_record_link_assignment (link_info.output_bfd,
1574 &link_info,
fe21a8fc
L
1575 exp->assign.dst, provide,
1576 exp->assign.hidden))
04925e1e
AM
1577 einfo ("%P%F: failed to record assignment to %s: %E\n",
1578 exp->assign.dst);
252b5132 1579 }
04925e1e
AM
1580 gld${EMULATION_NAME}_find_exp_assignment (exp->assign.src);
1581 break;
252b5132 1582
04925e1e
AM
1583 case etree_binary:
1584 gld${EMULATION_NAME}_find_exp_assignment (exp->binary.lhs);
1585 gld${EMULATION_NAME}_find_exp_assignment (exp->binary.rhs);
1586 break;
252b5132 1587
04925e1e
AM
1588 case etree_trinary:
1589 gld${EMULATION_NAME}_find_exp_assignment (exp->trinary.cond);
1590 gld${EMULATION_NAME}_find_exp_assignment (exp->trinary.lhs);
1591 gld${EMULATION_NAME}_find_exp_assignment (exp->trinary.rhs);
1592 break;
252b5132 1593
04925e1e
AM
1594 case etree_unary:
1595 gld${EMULATION_NAME}_find_exp_assignment (exp->unary.child);
1596 break;
252b5132 1597
04925e1e
AM
1598 default:
1599 break;
252b5132
RH
1600 }
1601}
1602
04925e1e
AM
1603
1604/* This is called by the before_allocation routine via
1605 lang_for_each_statement. It locates any assignment statements, and
1606 tells the ELF backend about them, in case they are assignments to
1607 symbols which are referred to by dynamic objects. */
1608
1609static void
0c7a8e5a 1610gld${EMULATION_NAME}_find_statement_assignment (lang_statement_union_type *s)
04925e1e
AM
1611{
1612 if (s->header.type == lang_assignment_statement_enum)
1613 gld${EMULATION_NAME}_find_exp_assignment (s->assignment_statement.exp);
1614}
1615
41392f03
AM
1616EOF
1617
1618if test x"$LDEMUL_BEFORE_ALLOCATION" != xgld"$EMULATION_NAME"_before_allocation; then
57e6abd2
AO
1619 if test x"${ELF_INTERPRETER_NAME+set}" = xset; then
1620 ELF_INTERPRETER_SET_DEFAULT="
1621 if (sinterp != NULL)
1622 {
5718918d
AM
1623 sinterp->contents = (unsigned char *) ${ELF_INTERPRETER_NAME};
1624 sinterp->size = strlen ((char *) sinterp->contents) + 1;
57e6abd2
AO
1625 }
1626
1627"
1628 else
1629 ELF_INTERPRETER_SET_DEFAULT=
1630 fi
92b93329 1631fragment <<EOF
04925e1e 1632
7ee314fa 1633/* used by before_allocation and handle_option. */
4724d37e 1634static void
91d6fa6a 1635gld${EMULATION_NAME}_append_to_separated_string (char **to, char *op_arg)
7ee314fa
AM
1636{
1637 if (*to == NULL)
91d6fa6a 1638 *to = xstrdup (op_arg);
7ee314fa
AM
1639 else
1640 {
1641 size_t to_len = strlen (*to);
91d6fa6a 1642 size_t op_arg_len = strlen (op_arg);
7ee314fa
AM
1643 char *buf;
1644 char *cp = *to;
1645
1646 /* First see whether OPTARG is already in the path. */
1647 do
1648 {
91d6fa6a
NC
1649 if (strncmp (op_arg, cp, op_arg_len) == 0
1650 && (cp[op_arg_len] == 0
1651 || cp[op_arg_len] == config.rpath_separator))
7ee314fa
AM
1652 /* We found it. */
1653 break;
1654
1655 /* Not yet found. */
1656 cp = strchr (cp, config.rpath_separator);
1657 if (cp != NULL)
1658 ++cp;
1659 }
1660 while (cp != NULL);
1661
1662 if (cp == NULL)
1663 {
91d6fa6a 1664 buf = xmalloc (to_len + op_arg_len + 2);
7ee314fa 1665 sprintf (buf, "%s%c%s", *to,
91d6fa6a 1666 config.rpath_separator, op_arg);
7ee314fa
AM
1667 free (*to);
1668 *to = buf;
1669 }
1670 }
1671}
1672
b6518b38
NC
1673#if defined(__GNUC__) && GCC_VERSION < 4006
1674 /* Work around a GCC uninitialized warning bug fixed in GCC 4.6. */
1675static struct bfd_link_hash_entry ehdr_start_empty;
1676#endif
1677
252b5132
RH
1678/* This is called after the sections have been attached to output
1679 sections, but before any sizes or addresses have been set. */
1680
1681static void
0c7a8e5a 1682gld${EMULATION_NAME}_before_allocation (void)
252b5132
RH
1683{
1684 const char *rpath;
1685 asection *sinterp;
7ee314fa 1686 bfd *abfd;
4199e3b8 1687 struct elf_link_hash_entry *ehdr_start = NULL;
a0bde398
L
1688#if defined(__GNUC__) && GCC_VERSION < 4006
1689 /* Work around a GCC uninitialized warning bug fixed in GCC 4.6. */
b6518b38 1690 struct bfd_link_hash_entry ehdr_start_save = ehdr_start_empty;
a0bde398 1691#else
4a0bc59e 1692 struct bfd_link_hash_entry ehdr_start_save;
a0bde398 1693#endif
252b5132 1694
b4d040b1 1695 if (is_elf_hash_table (link_info.hash))
a5382c42
MR
1696 {
1697 _bfd_elf_tls_setup (link_info.output_bfd, &link_info);
e1918d23 1698
cde7cb01
MR
1699 /* Make __ehdr_start hidden if it has been referenced, to
1700 prevent the symbol from being dynamic. */
0e1862bb 1701 if (!bfd_link_relocatable (&link_info))
c2763e27
RM
1702 {
1703 struct elf_link_hash_entry *h
1704 = elf_link_hash_lookup (elf_hash_table (&link_info), "__ehdr_start",
1705 FALSE, FALSE, TRUE);
1706
1707 /* Only adjust the export class if the symbol was referenced
1708 and not defined, otherwise leave it alone. */
1709 if (h != NULL
1710 && (h->root.type == bfd_link_hash_new
1711 || h->root.type == bfd_link_hash_undefined
1712 || h->root.type == bfd_link_hash_undefweak
1713 || h->root.type == bfd_link_hash_common))
1714 {
1715 _bfd_elf_link_hash_hide_symbol (&link_info, h, TRUE);
1716 if (ELF_ST_VISIBILITY (h->other) != STV_INTERNAL)
1717 h->other = (h->other & ~ELF_ST_VISIBILITY (-1)) | STV_HIDDEN;
4199e3b8
AM
1718 /* Don't leave the symbol undefined. Undefined hidden
1719 symbols typically won't have dynamic relocations, but
1720 we most likely will need dynamic relocations for
1721 __ehdr_start if we are building a PIE or shared
1722 library. */
1723 ehdr_start = h;
1724 ehdr_start_save = h->root;
1725 h->root.type = bfd_link_hash_defined;
1726 h->root.u.def.section = bfd_abs_section_ptr;
1727 h->root.u.def.value = 0;
c2763e27
RM
1728 }
1729 }
cde7cb01 1730
a5382c42
MR
1731 /* If we are going to make any variable assignments, we need to
1732 let the ELF backend know about them in case the variables are
1733 referred to by dynamic objects. */
1734 lang_for_each_statement (gld${EMULATION_NAME}_find_statement_assignment);
1735 }
252b5132
RH
1736
1737 /* Let the ELF backend work out the sizes of any sections required
1738 by dynamic linking. */
1739 rpath = command_line.rpath;
1740 if (rpath == NULL)
1741 rpath = (const char *) getenv ("LD_RUN_PATH");
7ee314fa 1742
c72f2fb2 1743 for (abfd = link_info.input_bfds; abfd; abfd = abfd->link.next)
8dd881b6
L
1744 if (bfd_get_flavour (abfd) == bfd_target_elf_flavour)
1745 {
1746 const char *audit_libs = elf_dt_audit (abfd);
7ee314fa 1747
4724d37e 1748 /* If the input bfd contains an audit entry, we need to add it as
8dd881b6
L
1749 a dep audit entry. */
1750 if (audit_libs && *audit_libs != '\0')
1751 {
1752 char *cp = xstrdup (audit_libs);
1753 do
1754 {
1755 int more = 0;
1756 char *cp2 = strchr (cp, config.rpath_separator);
7ee314fa 1757
8dd881b6
L
1758 if (cp2)
1759 {
1760 *cp2 = '\0';
1761 more = 1;
1762 }
7ee314fa 1763
8dd881b6
L
1764 if (cp != NULL && *cp != '\0')
1765 gld${EMULATION_NAME}_append_to_separated_string (&depaudit, cp);
1766
1767 cp = more ? ++cp2 : NULL;
1768 }
1769 while (cp != NULL);
1770 }
1771 }
7ee314fa 1772
5a580b3a 1773 if (! (bfd_elf_size_dynamic_sections
f13a99db 1774 (link_info.output_bfd, command_line.soname, rpath,
7ee314fa 1775 command_line.filter_shlib, audit, depaudit,
252b5132 1776 (const char * const *) command_line.auxiliary_filters,
fd91d419 1777 &link_info, &sinterp)))
252b5132 1778 einfo ("%P%F: failed to set dynamic section sizes: %E\n");
8423293d 1779
57e6abd2 1780${ELF_INTERPRETER_SET_DEFAULT}
252b5132
RH
1781 /* Let the user override the dynamic linker we are using. */
1782 if (command_line.interpreter != NULL
1783 && sinterp != NULL)
1784 {
1785 sinterp->contents = (bfd_byte *) command_line.interpreter;
eea6121a 1786 sinterp->size = strlen (command_line.interpreter) + 1;
252b5132
RH
1787 }
1788
1789 /* Look for any sections named .gnu.warning. As a GNU extensions,
1790 we treat such sections as containing warning messages. We print
1791 out the warning message, and then zero out the section size so
1792 that it does not get copied into the output file. */
1793
1794 {
1795 LANG_FOR_EACH_INPUT_STATEMENT (is)
1796 {
1797 asection *s;
1798 bfd_size_type sz;
1799 char *msg;
252b5132 1800
66be1055 1801 if (is->flags.just_syms)
252b5132
RH
1802 continue;
1803
1804 s = bfd_get_section_by_name (is->the_bfd, ".gnu.warning");
1805 if (s == NULL)
1806 continue;
1807
eea6121a 1808 sz = s->size;
1e9cc1c2 1809 msg = (char *) xmalloc ((size_t) (sz + 1));
bc251d50 1810 if (! bfd_get_section_contents (is->the_bfd, s, msg,
8c675694 1811 (file_ptr) 0, sz))
252b5132
RH
1812 einfo ("%F%B: Can't read contents of section .gnu.warning: %E\n",
1813 is->the_bfd);
bc251d50 1814 msg[sz] = '\0';
1a72702b
AM
1815 (*link_info.callbacks->warning) (&link_info, msg,
1816 (const char *) NULL, is->the_bfd,
1817 (asection *) NULL, (bfd_vma) 0);
252b5132
RH
1818 free (msg);
1819
9e3be61d
AM
1820 /* Clobber the section size, so that we don't waste space
1821 copying the warning into the output file. If we've already
1822 sized the output section, adjust its size. The adjustment
1823 is on rawsize because targets that size sections early will
1824 have called lang_reset_memory_regions after sizing. */
1825 if (s->output_section != NULL
1826 && s->output_section->rawsize >= s->size)
1827 s->output_section->rawsize -= s->size;
1828
eea6121a 1829 s->size = 0;
11d2f718 1830
9e3be61d
AM
1831 /* Also set SEC_EXCLUDE, so that local symbols defined in the
1832 warning section don't get copied to the output. */
a14a5de3 1833 s->flags |= SEC_EXCLUDE | SEC_KEEP;
252b5132
RH
1834 }
1835 }
8423293d 1836
1e035701 1837 before_allocation_default ();
8423293d 1838
f13a99db 1839 if (!bfd_elf_size_dynsym_hash_dynstr (link_info.output_bfd, &link_info))
8423293d 1840 einfo ("%P%F: failed to set dynamic section sizes: %E\n");
4199e3b8
AM
1841
1842 if (ehdr_start != NULL)
1843 {
1844 /* If we twiddled __ehdr_start to defined earlier, put it back
1845 as it was. */
1846 ehdr_start->root.type = ehdr_start_save.type;
1847 ehdr_start->root.u = ehdr_start_save.u;
1848 }
252b5132
RH
1849}
1850
41392f03
AM
1851EOF
1852fi
1853
1854if test x"$LDEMUL_OPEN_DYNAMIC_ARCHIVE" != xgld"$EMULATION_NAME"_open_dynamic_archive; then
92b93329 1855fragment <<EOF
252b5132 1856
04925e1e
AM
1857/* Try to open a dynamic archive. This is where we know that ELF
1858 dynamic libraries have an extension of .so (or .sl on oddball systems
1859 like hpux). */
1860
b34976b6 1861static bfd_boolean
0c7a8e5a
AM
1862gld${EMULATION_NAME}_open_dynamic_archive
1863 (const char *arch, search_dirs_type *search, lang_input_statement_type *entry)
252b5132 1864{
04925e1e
AM
1865 const char *filename;
1866 char *string;
d4ae5fb0
AM
1867 size_t len;
1868 bfd_boolean opened = FALSE;
252b5132 1869
66be1055 1870 if (! entry->flags.maybe_archive)
b34976b6 1871 return FALSE;
252b5132 1872
04925e1e 1873 filename = entry->filename;
d4ae5fb0
AM
1874 len = strlen (search->name) + strlen (filename);
1875 if (entry->flags.full_name_provided)
1876 {
1877 len += sizeof "/";
1878 string = (char *) xmalloc (len);
1879 sprintf (string, "%s/%s", search->name, filename);
1880 }
1881 else
1882 {
1883 size_t xlen = 0;
252b5132 1884
d4ae5fb0 1885 len += strlen (arch) + sizeof "/lib.so";
04925e1e 1886#ifdef EXTRA_SHLIB_EXTENSION
d4ae5fb0
AM
1887 xlen = (strlen (EXTRA_SHLIB_EXTENSION) > 3
1888 ? strlen (EXTRA_SHLIB_EXTENSION) - 3
1889 : 0);
04925e1e 1890#endif
d4ae5fb0
AM
1891 string = (char *) xmalloc (len + xlen);
1892 sprintf (string, "%s/lib%s%s.so", search->name, filename, arch);
04925e1e 1893#ifdef EXTRA_SHLIB_EXTENSION
d4ae5fb0
AM
1894 /* Try the .so extension first. If that fails build a new filename
1895 using EXTRA_SHLIB_EXTENSION. */
1896 opened = ldfile_try_open_bfd (string, entry);
1897 if (!opened)
1898 strcpy (string + len - 4, EXTRA_SHLIB_EXTENSION);
04925e1e 1899#endif
d4ae5fb0 1900 }
04925e1e 1901
d4ae5fb0 1902 if (!opened && !ldfile_try_open_bfd (string, entry))
252b5132 1903 {
04925e1e 1904 free (string);
b34976b6 1905 return FALSE;
04925e1e 1906 }
252b5132 1907
04925e1e 1908 entry->filename = string;
252b5132 1909
04925e1e
AM
1910 /* We have found a dynamic object to include in the link. The ELF
1911 backend linker will create a DT_NEEDED entry in the .dynamic
1912 section naming this file. If this file includes a DT_SONAME
1913 entry, it will be used. Otherwise, the ELF linker will just use
1914 the name of the file. For an archive found by searching, like
1915 this one, the DT_NEEDED entry should consist of just the name of
1916 the file, without the path information used to find it. Note
1917 that we only need to do this if we have a dynamic object; an
1918 archive will never be referenced by a DT_NEEDED entry.
252b5132 1919
04925e1e
AM
1920 FIXME: This approach--using bfd_elf_set_dt_needed_name--is not
1921 very pretty. I haven't been able to think of anything that is
1922 pretty, though. */
1923 if (bfd_check_format (entry->the_bfd, bfd_object)
1924 && (entry->the_bfd->flags & DYNAMIC) != 0)
1925 {
66be1055 1926 ASSERT (entry->flags.maybe_archive && entry->flags.search_dirs);
252b5132 1927
04925e1e 1928 /* Rather than duplicating the logic above. Just use the
1c9acd94 1929 filename we recorded earlier. */
04925e1e 1930
d4ae5fb0
AM
1931 if (!entry->flags.full_name_provided)
1932 filename = lbasename (entry->filename);
1c9acd94 1933 bfd_elf_set_dt_needed_name (entry->the_bfd, filename);
04925e1e
AM
1934 }
1935
b34976b6 1936 return TRUE;
04925e1e
AM
1937}
1938
41392f03
AM
1939EOF
1940fi
cde43e70
AM
1941
1942if test x"$LDEMUL_PLACE_ORPHAN" != xgld"$EMULATION_NAME"_place_orphan; then
92b93329 1943fragment <<EOF
41392f03 1944
afd7a018 1945/* A variant of lang_output_section_find used by place_orphan. */
04925e1e 1946
04925e1e 1947static lang_output_section_statement_type *
2a36a117 1948output_rel_find (asection *sec, int isdyn)
04925e1e 1949{
04925e1e 1950 lang_output_section_statement_type *lookup;
ba493122 1951 lang_output_section_statement_type *last = NULL;
2a36a117 1952 lang_output_section_statement_type *last_alloc = NULL;
48f2ff54 1953 lang_output_section_statement_type *last_ro_alloc = NULL;
ba493122
AM
1954 lang_output_section_statement_type *last_rel = NULL;
1955 lang_output_section_statement_type *last_rel_alloc = NULL;
24cdb50a 1956 int rela = sec->name[4] == 'a';
04925e1e 1957
afd7a018
AM
1958 for (lookup = &lang_output_section_statement.head->output_section_statement;
1959 lookup != NULL;
1960 lookup = lookup->next)
04925e1e 1961 {
66c103b7 1962 if (lookup->constraint >= 0
0112cd26 1963 && CONST_STRNEQ (lookup->name, ".rel"))
04925e1e 1964 {
24cdb50a 1965 int lookrela = lookup->name[4] == 'a';
ba493122 1966
2a36a117
AM
1967 /* .rel.dyn must come before all other reloc sections, to suit
1968 GNU ld.so. */
1969 if (isdyn)
1970 break;
1971
1972 /* Don't place after .rel.plt as doing so results in wrong
1973 dynamic tags. */
1974 if (strcmp (".plt", lookup->name + 4 + lookrela) == 0)
ba493122 1975 break;
2a36a117
AM
1976
1977 if (rela == lookrela || last_rel == NULL)
24cdb50a 1978 last_rel = lookup;
2a36a117
AM
1979 if ((rela == lookrela || last_rel_alloc == NULL)
1980 && lookup->bfd_section != NULL
ba493122
AM
1981 && (lookup->bfd_section->flags & SEC_ALLOC) != 0)
1982 last_rel_alloc = lookup;
04925e1e 1983 }
2a36a117
AM
1984
1985 last = lookup;
1986 if (lookup->bfd_section != NULL
1987 && (lookup->bfd_section->flags & SEC_ALLOC) != 0)
48f2ff54
AM
1988 {
1989 last_alloc = lookup;
1990 if ((lookup->bfd_section->flags & SEC_READONLY) != 0)
1991 last_ro_alloc = lookup;
1992 }
252b5132 1993 }
ba493122
AM
1994
1995 if (last_rel_alloc)
1996 return last_rel_alloc;
1997
1998 if (last_rel)
1999 return last_rel;
2000
48f2ff54
AM
2001 if (last_ro_alloc)
2002 return last_ro_alloc;
2003
2a36a117
AM
2004 if (last_alloc)
2005 return last_alloc;
2006
ba493122 2007 return last;
252b5132
RH
2008}
2009
2010/* Place an orphan section. We use this to put random SHF_ALLOC
2011 sections in the right segment. */
2012
c2edb4b8 2013static lang_output_section_statement_type *
8a99a385
AM
2014gld${EMULATION_NAME}_place_orphan (asection *s,
2015 const char *secname,
2016 int constraint)
252b5132 2017{
afd7a018
AM
2018 static struct orphan_save hold[] =
2019 {
2020 { ".text",
2021 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_READONLY | SEC_CODE,
2022 0, 0, 0, 0 },
2023 { ".rodata",
2024 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_READONLY | SEC_DATA,
2025 0, 0, 0, 0 },
d85e71fe
L
2026 { ".tdata",
2027 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_DATA | SEC_THREAD_LOCAL,
2028 0, 0, 0, 0 },
afd7a018
AM
2029 { ".data",
2030 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_DATA,
2031 0, 0, 0, 0 },
2032 { ".bss",
2033 SEC_ALLOC,
2034 0, 0, 0, 0 },
2035 { 0,
2036 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_READONLY | SEC_DATA,
2037 0, 0, 0, 0 },
2038 { ".interp",
2039 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_READONLY | SEC_DATA,
2040 0, 0, 0, 0 },
2041 { ".sdata",
2042 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_DATA | SEC_SMALL_DATA,
07890c07 2043 0, 0, 0, 0 },
175b7cd4 2044 { ".comment",
07890c07
AM
2045 SEC_HAS_CONTENTS,
2046 0, 0, 0, 0 },
afd7a018
AM
2047 };
2048 enum orphan_save_index
2049 {
2050 orphan_text = 0,
2051 orphan_rodata,
d85e71fe 2052 orphan_tdata,
afd7a018
AM
2053 orphan_data,
2054 orphan_bss,
2055 orphan_rel,
2056 orphan_interp,
07890c07
AM
2057 orphan_sdata,
2058 orphan_nonalloc
afd7a018
AM
2059 };
2060 static int orphan_init_done = 0;
6a345e87 2061 struct orphan_save *place;
afd7a018 2062 lang_output_section_statement_type *after;
252b5132 2063 lang_output_section_statement_type *os;
b5f14a6d 2064 lang_output_section_statement_type *match_by_name = NULL;
24cdb50a 2065 int isdyn = 0;
ecca9871
L
2066 int iself = s->owner->xvec->flavour == bfd_target_elf_flavour;
2067 unsigned int sh_type = iself ? elf_section_type (s) : SHT_NULL;
199af150
AM
2068 flagword flags;
2069 asection *nexts;
252b5132 2070
0e1862bb 2071 if (!bfd_link_relocatable (&link_info)
24cdb50a 2072 && link_info.combreloc
ecca9871 2073 && (s->flags & SEC_ALLOC))
24cdb50a 2074 {
ecca9871
L
2075 if (iself)
2076 switch (sh_type)
2077 {
2078 case SHT_RELA:
2079 secname = ".rela.dyn";
2080 isdyn = 1;
2081 break;
2082 case SHT_REL:
2083 secname = ".rel.dyn";
2084 isdyn = 1;
2085 break;
2086 default:
2087 break;
2088 }
0112cd26 2089 else if (CONST_STRNEQ (secname, ".rel"))
ecca9871
L
2090 {
2091 secname = secname[4] == 'a' ? ".rela.dyn" : ".rel.dyn";
2092 isdyn = 1;
2093 }
24cdb50a 2094 }
aea4bd9d 2095
a91e1603
L
2096 if (!bfd_link_relocatable (&link_info)
2097 && (s->flags & SEC_ALLOC) != 0
2098 && (elf_section_flags (s) & SHF_GNU_MBIND) != 0)
2099 {
2100 /* Find the output mbind section with the same type, attributes
2101 and sh_info field. */
2102 for (os = &lang_output_section_statement.head->output_section_statement;
2103 os != NULL;
2104 os = os->next)
2105 if (os->bfd_section != NULL
2106 && !bfd_is_abs_section (os->bfd_section)
2107 && (elf_section_flags (os->bfd_section) & SHF_GNU_MBIND) != 0
2108 && ((s->flags & (SEC_ALLOC
2109 | SEC_LOAD
2110 | SEC_HAS_CONTENTS
2111 | SEC_READONLY
2112 | SEC_CODE))
2113 == (os->bfd_section->flags & (SEC_ALLOC
2114 | SEC_LOAD
2115 | SEC_HAS_CONTENTS
2116 | SEC_READONLY
2117 | SEC_CODE)))
2118 && (elf_section_data (os->bfd_section)->this_hdr.sh_info
2119 == elf_section_data (s)->this_hdr.sh_info))
2120 {
2121 lang_add_section (&os->children, s, NULL, os);
2122 return os;
2123 }
2124
2125 /* Create the output mbind section with the ".mbind." prefix
2126 in section name. */
2127 if ((s->flags & (SEC_LOAD | SEC_HAS_CONTENTS)) == 0)
2128 secname = ".mbind.bss";
2129 else if ((s->flags & SEC_READONLY) == 0)
2130 secname = ".mbind.data";
2131 else if ((s->flags & SEC_CODE) == 0)
2132 secname = ".mbind.rodata";
2133 else
2134 secname = ".mbind.text";
2135 }
2136
bcacc0f5 2137 /* Look through the script to see where to place this section. */
d127ecce
AM
2138 if (constraint == 0)
2139 for (os = lang_output_section_find (secname);
2140 os != NULL;
2141 os = next_matching_output_section_statement (os, 0))
2142 {
2143 /* If we don't match an existing output section, tell
2144 lang_insert_orphan to create a new output section. */
2145 constraint = SPECIAL;
2146
93dc595d
L
2147 /* SEC_EXCLUDE is cleared when doing a relocatable link. But
2148 we can't merge 2 input sections with the same name when only
a91e1603
L
2149 one of them has SHF_EXCLUDE. Don't merge 2 sections with
2150 different sh_info. */
d127ecce 2151 if (os->bfd_section != NULL
a91e1603
L
2152 && (elf_section_data (os->bfd_section)->this_hdr.sh_info
2153 == elf_section_data (s)->this_hdr.sh_info)
d127ecce 2154 && (os->bfd_section->flags == 0
93dc595d 2155 || ((!bfd_link_relocatable (&link_info)
68c638d6
NC
2156 || (iself && (((elf_section_flags (s)
2157 ^ elf_section_flags (os->bfd_section))
2158 & SHF_EXCLUDE) == 0)))
93dc595d 2159 && ((s->flags ^ os->bfd_section->flags)
199af150
AM
2160 & (SEC_LOAD | SEC_ALLOC)) == 0
2161 && _bfd_elf_match_sections_by_type (link_info.output_bfd,
2162 os->bfd_section,
2163 s->owner, s))))
d127ecce
AM
2164 {
2165 /* We already have an output section statement with this
2166 name, and its bfd section has compatible flags.
2167 If the section already exists but does not have any flags
2168 set, then it has been created by the linker, probably as a
2169 result of a --section-start command line switch. */
b9c361e0 2170 lang_add_section (&os->children, s, NULL, os);
d127ecce
AM
2171 return os;
2172 }
b5f14a6d
DD
2173
2174 /* Save unused output sections in case we can match them
2175 against orphans later. */
2176 if (os->bfd_section == NULL)
2177 match_by_name = os;
d127ecce 2178 }
252b5132 2179
b5f14a6d
DD
2180 /* If we didn't match an active output section, see if we matched an
2181 unused one and use that. */
2182 if (match_by_name)
2183 {
b9c361e0 2184 lang_add_section (&match_by_name->children, s, NULL, match_by_name);
b5f14a6d
DD
2185 return match_by_name;
2186 }
2187
afd7a018
AM
2188 if (!orphan_init_done)
2189 {
2190 struct orphan_save *ho;
07890c07 2191
afd7a018
AM
2192 for (ho = hold; ho < hold + sizeof (hold) / sizeof (hold[0]); ++ho)
2193 if (ho->name != NULL)
2194 {
2195 ho->os = lang_output_section_find (ho->name);
2196 if (ho->os != NULL && ho->os->flags == 0)
2197 ho->os->flags = ho->flags;
2198 }
2199 orphan_init_done = 1;
2200 }
252b5132
RH
2201
2202 /* If this is a final link, then always put .gnu.warning.SYMBOL
2203 sections into the .text section to get them out of the way. */
0e1862bb 2204 if (bfd_link_executable (&link_info)
bcacc0f5 2205 && CONST_STRNEQ (s->name, ".gnu.warning.")
afd7a018 2206 && hold[orphan_text].os != NULL)
252b5132 2207 {
c2edb4b8 2208 os = hold[orphan_text].os;
b9c361e0 2209 lang_add_section (&os->children, s, NULL, os);
c2edb4b8 2210 return os;
252b5132
RH
2211 }
2212
077fcd6a
L
2213 flags = s->flags;
2214 if (!bfd_link_relocatable (&link_info))
2215 {
2216 nexts = s;
2217 while ((nexts = bfd_get_next_section_by_name (nexts->owner, nexts))
2218 != NULL)
2219 if (nexts->output_section == NULL
2220 && (nexts->flags & SEC_EXCLUDE) == 0
2221 && ((nexts->flags ^ flags) & (SEC_LOAD | SEC_ALLOC)) == 0
2222 && (nexts->owner->flags & DYNAMIC) == 0
2223 && nexts->owner->usrdata != NULL
2224 && !(((lang_input_statement_type *) nexts->owner->usrdata)
2225 ->flags.just_syms)
2226 && _bfd_elf_match_sections_by_type (nexts->owner, nexts,
2227 s->owner, s))
2228 flags = (((flags ^ SEC_READONLY)
2229 | (nexts->flags ^ SEC_READONLY))
2230 ^ SEC_READONLY);
2231 }
2232
252b5132
RH
2233 /* Decide which segment the section should go in based on the
2234 section name and section flags. We put loadable .note sections
2235 right after the .interp section, so that the PT_NOTE segment is
2236 stored right after the program headers where the OS can read it
2237 in the first page. */
aea4bd9d 2238
71bfc0ae 2239 place = NULL;
199af150 2240 if ((flags & (SEC_ALLOC | SEC_DEBUGGING)) == 0)
07890c07 2241 place = &hold[orphan_nonalloc];
199af150 2242 else if ((flags & SEC_ALLOC) == 0)
71bfc0ae 2243 ;
199af150 2244 else if ((flags & SEC_LOAD) != 0
ecca9871 2245 && ((iself && sh_type == SHT_NOTE)
0112cd26 2246 || (!iself && CONST_STRNEQ (secname, ".note"))))
afd7a018 2247 place = &hold[orphan_interp];
199af150 2248 else if ((flags & (SEC_LOAD | SEC_HAS_CONTENTS | SEC_THREAD_LOCAL)) == 0)
afd7a018 2249 place = &hold[orphan_bss];
199af150 2250 else if ((flags & SEC_SMALL_DATA) != 0)
afd7a018 2251 place = &hold[orphan_sdata];
199af150 2252 else if ((flags & SEC_THREAD_LOCAL) != 0)
d85e71fe 2253 place = &hold[orphan_tdata];
199af150 2254 else if ((flags & SEC_READONLY) == 0)
afd7a018 2255 place = &hold[orphan_data];
ecca9871 2256 else if (((iself && (sh_type == SHT_RELA || sh_type == SHT_REL))
0112cd26 2257 || (!iself && CONST_STRNEQ (secname, ".rel")))
199af150 2258 && (flags & SEC_LOAD) != 0)
afd7a018 2259 place = &hold[orphan_rel];
199af150 2260 else if ((flags & SEC_CODE) == 0)
afd7a018
AM
2261 place = &hold[orphan_rodata];
2262 else
2263 place = &hold[orphan_text];
71bfc0ae 2264
afd7a018 2265 after = NULL;
5ba47421 2266 if (place != NULL)
252b5132 2267 {
afd7a018 2268 if (place->os == NULL)
5ba47421 2269 {
afd7a018
AM
2270 if (place->name != NULL)
2271 place->os = lang_output_section_find (place->name);
2272 else
2273 place->os = output_rel_find (s, isdyn);
5ba47421 2274 }
afd7a018
AM
2275 after = place->os;
2276 if (after == NULL)
93638471
AM
2277 after
2278 = lang_output_section_find_by_flags (s, flags, &place->os,
2279 _bfd_elf_match_sections_by_type);
afd7a018
AM
2280 if (after == NULL)
2281 /* *ABS* is always the first output section statement. */
2282 after = &lang_output_section_statement.head->output_section_statement;
252b5132
RH
2283 }
2284
c2edb4b8 2285 return lang_insert_orphan (s, secname, constraint, after, place, NULL, NULL);
252b5132 2286}
c56feb2b
AM
2287EOF
2288fi
2289
eaeb0a9d 2290if test x"$LDEMUL_AFTER_ALLOCATION" != xgld"$EMULATION_NAME"_after_allocation; then
92b93329 2291fragment <<EOF
252b5132 2292
deb04cdb 2293static void
eaeb0a9d 2294gld${EMULATION_NAME}_after_allocation (void)
deb04cdb 2295{
75938853
AM
2296 int need_layout = bfd_elf_discard_info (link_info.output_bfd, &link_info);
2297
2298 if (need_layout < 0)
2299 einfo ("%X%P: .eh_frame/.stab edit: %E\n");
2300 else
2301 gld${EMULATION_NAME}_map_segments (need_layout);
73d074b4 2302}
41392f03
AM
2303EOF
2304fi
2305
2306if test x"$LDEMUL_GET_SCRIPT" != xgld"$EMULATION_NAME"_get_script; then
92b93329 2307fragment <<EOF
252b5132
RH
2308
2309static char *
0c7a8e5a 2310gld${EMULATION_NAME}_get_script (int *isfile)
252b5132
RH
2311EOF
2312
7225345d 2313if test x"$COMPILE_IN" = xyes
252b5132
RH
2314then
2315# Scripts compiled in.
2316
2317# sed commands to quote an ld script as a C string.
597e2591 2318sc="-f stringify.sed"
252b5132 2319
92b93329 2320fragment <<EOF
60bcf0fa 2321{
252b5132
RH
2322 *isfile = 0;
2323
0e1862bb 2324 if (bfd_link_relocatable (&link_info) && config.build_constructors)
597e2591 2325 return
252b5132 2326EOF
afd7a018 2327sed $sc ldscripts/${EMULATION_NAME}.xu >> e${EMULATION_NAME}.c
0e1862bb 2328echo ' ; else if (bfd_link_relocatable (&link_info)) return' >> e${EMULATION_NAME}.c
afd7a018
AM
2329sed $sc ldscripts/${EMULATION_NAME}.xr >> e${EMULATION_NAME}.c
2330echo ' ; else if (!config.text_read_only) return' >> e${EMULATION_NAME}.c
2331sed $sc ldscripts/${EMULATION_NAME}.xbn >> e${EMULATION_NAME}.c
61585df2 2332if cmp -s ldscripts/${EMULATION_NAME}.x ldscripts/${EMULATION_NAME}.xn; then : ; else
afd7a018
AM
2333echo ' ; else if (!config.magic_demand_paged) return' >> e${EMULATION_NAME}.c
2334sed $sc ldscripts/${EMULATION_NAME}.xn >> e${EMULATION_NAME}.c
db6751f2 2335fi
36af4a4e
JJ
2336if test -n "$GENERATE_PIE_SCRIPT" ; then
2337if test -n "$GENERATE_COMBRELOC_SCRIPT" ; then
0e1862bb
L
2338echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
2339echo ' && link_info.combreloc' >> e${EMULATION_NAME}.c
2340echo ' && link_info.relro' >> e${EMULATION_NAME}.c
fbfca19e 2341echo ' && (link_info.flags & DF_BIND_NOW)) return' >> e${EMULATION_NAME}.c
afd7a018 2342sed $sc ldscripts/${EMULATION_NAME}.xdw >> e${EMULATION_NAME}.c
0e1862bb
L
2343echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
2344echo ' && link_info.combreloc) return' >> e${EMULATION_NAME}.c
afd7a018 2345sed $sc ldscripts/${EMULATION_NAME}.xdc >> e${EMULATION_NAME}.c
36af4a4e 2346fi
0e1862bb 2347echo ' ; else if (bfd_link_pie (&link_info)) return' >> e${EMULATION_NAME}.c
afd7a018 2348sed $sc ldscripts/${EMULATION_NAME}.xd >> e${EMULATION_NAME}.c
36af4a4e 2349fi
252b5132 2350if test -n "$GENERATE_SHLIB_SCRIPT" ; then
82434356 2351if test -n "$GENERATE_COMBRELOC_SCRIPT" ; then
0e1862bb 2352echo ' ; else if (bfd_link_dll (&link_info) && link_info.combreloc' >> e${EMULATION_NAME}.c
8c37241b 2353echo ' && link_info.relro' >> e${EMULATION_NAME}.c
fbfca19e 2354echo ' && (link_info.flags & DF_BIND_NOW)) return' >> e${EMULATION_NAME}.c
afd7a018 2355sed $sc ldscripts/${EMULATION_NAME}.xsw >> e${EMULATION_NAME}.c
0e1862bb 2356echo ' ; else if (bfd_link_dll (&link_info) && link_info.combreloc) return' >> e${EMULATION_NAME}.c
afd7a018 2357sed $sc ldscripts/${EMULATION_NAME}.xsc >> e${EMULATION_NAME}.c
82434356 2358fi
0e1862bb 2359echo ' ; else if (bfd_link_dll (&link_info)) return' >> e${EMULATION_NAME}.c
afd7a018 2360sed $sc ldscripts/${EMULATION_NAME}.xs >> e${EMULATION_NAME}.c
252b5132 2361fi
82434356 2362if test -n "$GENERATE_COMBRELOC_SCRIPT" ; then
8c37241b 2363echo ' ; else if (link_info.combreloc && link_info.relro' >> e${EMULATION_NAME}.c
fbfca19e 2364echo ' && (link_info.flags & DF_BIND_NOW)) return' >> e${EMULATION_NAME}.c
afd7a018
AM
2365sed $sc ldscripts/${EMULATION_NAME}.xw >> e${EMULATION_NAME}.c
2366echo ' ; else if (link_info.combreloc) return' >> e${EMULATION_NAME}.c
2367sed $sc ldscripts/${EMULATION_NAME}.xc >> e${EMULATION_NAME}.c
82434356 2368fi
afd7a018
AM
2369echo ' ; else return' >> e${EMULATION_NAME}.c
2370sed $sc ldscripts/${EMULATION_NAME}.x >> e${EMULATION_NAME}.c
2371echo '; }' >> e${EMULATION_NAME}.c
252b5132
RH
2372
2373else
2374# Scripts read from the filesystem.
2375
92b93329 2376fragment <<EOF
60bcf0fa 2377{
252b5132
RH
2378 *isfile = 1;
2379
0e1862bb 2380 if (bfd_link_relocatable (&link_info) && config.build_constructors)
252b5132 2381 return "ldscripts/${EMULATION_NAME}.xu";
0e1862bb 2382 else if (bfd_link_relocatable (&link_info))
252b5132
RH
2383 return "ldscripts/${EMULATION_NAME}.xr";
2384 else if (!config.text_read_only)
2385 return "ldscripts/${EMULATION_NAME}.xbn";
a060b769
AM
2386EOF
2387if cmp -s ldscripts/${EMULATION_NAME}.x ldscripts/${EMULATION_NAME}.xn; then :
2388else
92b93329 2389fragment <<EOF
252b5132
RH
2390 else if (!config.magic_demand_paged)
2391 return "ldscripts/${EMULATION_NAME}.xn";
a060b769
AM
2392EOF
2393fi
36af4a4e
JJ
2394if test -n "$GENERATE_PIE_SCRIPT" ; then
2395if test -n "$GENERATE_COMBRELOC_SCRIPT" ; then
92b93329 2396fragment <<EOF
0e1862bb
L
2397 else if (bfd_link_pie (&link_info)
2398 && link_info.combreloc
2399 && link_info.relro
2400 && (link_info.flags & DF_BIND_NOW))
8c37241b 2401 return "ldscripts/${EMULATION_NAME}.xdw";
0e1862bb
L
2402 else if (bfd_link_pie (&link_info)
2403 && link_info.combreloc)
36af4a4e
JJ
2404 return "ldscripts/${EMULATION_NAME}.xdc";
2405EOF
2406fi
92b93329 2407fragment <<EOF
0e1862bb 2408 else if (bfd_link_pie (&link_info))
36af4a4e
JJ
2409 return "ldscripts/${EMULATION_NAME}.xd";
2410EOF
2411fi
a060b769
AM
2412if test -n "$GENERATE_SHLIB_SCRIPT" ; then
2413if test -n "$GENERATE_COMBRELOC_SCRIPT" ; then
92b93329 2414fragment <<EOF
0e1862bb 2415 else if (bfd_link_dll (&link_info) && link_info.combreloc
fbfca19e 2416 && link_info.relro && (link_info.flags & DF_BIND_NOW))
8c37241b 2417 return "ldscripts/${EMULATION_NAME}.xsw";
0e1862bb 2418 else if (bfd_link_dll (&link_info) && link_info.combreloc)
a060b769
AM
2419 return "ldscripts/${EMULATION_NAME}.xsc";
2420EOF
2421fi
92b93329 2422fragment <<EOF
0e1862bb 2423 else if (bfd_link_dll (&link_info))
252b5132 2424 return "ldscripts/${EMULATION_NAME}.xs";
a060b769
AM
2425EOF
2426fi
2427if test -n "$GENERATE_COMBRELOC_SCRIPT" ; then
92b93329 2428fragment <<EOF
8c37241b 2429 else if (link_info.combreloc && link_info.relro
fbfca19e 2430 && (link_info.flags & DF_BIND_NOW))
8c37241b 2431 return "ldscripts/${EMULATION_NAME}.xw";
a060b769
AM
2432 else if (link_info.combreloc)
2433 return "ldscripts/${EMULATION_NAME}.xc";
2434EOF
2435fi
92b93329 2436fragment <<EOF
252b5132
RH
2437 else
2438 return "ldscripts/${EMULATION_NAME}.x";
2439}
252b5132 2440
3b108066 2441EOF
41392f03
AM
2442fi
2443fi
3b108066 2444
e0ee487b 2445if test -n "$PARSE_AND_LIST_PROLOGUE" ; then
92b93329 2446fragment <<EOF
e0ee487b
L
2447 $PARSE_AND_LIST_PROLOGUE
2448EOF
2449fi
2450
92b93329 2451fragment <<EOF
e0ee487b 2452
29063f8b
NC
2453enum elf_options
2454{
2455 OPTION_DISABLE_NEW_DTAGS = 400,
2456 OPTION_ENABLE_NEW_DTAGS,
2457 OPTION_GROUP,
2458 OPTION_EH_FRAME_HDR,
2459 OPTION_NO_EH_FRAME_HDR,
2460 OPTION_EXCLUDE_LIBS,
2461 OPTION_HASH_STYLE,
2462 OPTION_BUILD_ID,
2463 OPTION_AUDIT,
2464 OPTION_COMPRESS_DEBUG
2465};
e13629bc 2466
3bcf5557 2467static void
0c7a8e5a
AM
2468gld${EMULATION_NAME}_add_options
2469 (int ns, char **shortopts, int nl, struct option **longopts,
2470 int nrl ATTRIBUTE_UNUSED, struct option **really_longopts ATTRIBUTE_UNUSED)
e0ee487b 2471{
fb42df5e
AM
2472EOF
2473if test x"$GENERATE_SHLIB_SCRIPT" = xyes; then
2474fragment <<EOF
7ee314fa 2475 static const char xtra_short[] = "${PARSE_AND_LIST_SHORTOPTS}z:P:";
fb42df5e
AM
2476EOF
2477else
2478fragment <<EOF
2479 static const char xtra_short[] = "${PARSE_AND_LIST_SHORTOPTS}z:";
2480EOF
2481fi
2482fragment <<EOF
3bcf5557 2483 static const struct option xtra_long[] = {
fb42df5e
AM
2484EOF
2485if test x"$GENERATE_SHLIB_SCRIPT" = xyes; then
2486fragment <<EOF
7ee314fa 2487 {"audit", required_argument, NULL, OPTION_AUDIT},
fb42df5e
AM
2488 {"Bgroup", no_argument, NULL, OPTION_GROUP},
2489EOF
2490fi
2491fragment <<EOF
2492 {"build-id", optional_argument, NULL, OPTION_BUILD_ID},
0ce398f1 2493 {"compress-debug-sections", required_argument, NULL, OPTION_COMPRESS_DEBUG},
e0ee487b 2494EOF
e0ee487b 2495if test x"$GENERATE_SHLIB_SCRIPT" = xyes; then
92b93329 2496fragment <<EOF
fb42df5e 2497 {"depaudit", required_argument, NULL, 'P'},
3bcf5557
AM
2498 {"disable-new-dtags", no_argument, NULL, OPTION_DISABLE_NEW_DTAGS},
2499 {"enable-new-dtags", no_argument, NULL, OPTION_ENABLE_NEW_DTAGS},
2500 {"eh-frame-hdr", no_argument, NULL, OPTION_EH_FRAME_HDR},
29063f8b 2501 {"no-eh-frame-hdr", no_argument, NULL, OPTION_NO_EH_FRAME_HDR},
b58f81ae 2502 {"exclude-libs", required_argument, NULL, OPTION_EXCLUDE_LIBS},
fdc90cb4 2503 {"hash-style", required_argument, NULL, OPTION_HASH_STYLE},
e0ee487b
L
2504EOF
2505fi
e0ee487b 2506if test -n "$PARSE_AND_LIST_LONGOPTS" ; then
92b93329 2507fragment <<EOF
3bcf5557 2508 $PARSE_AND_LIST_LONGOPTS
e0ee487b
L
2509EOF
2510fi
92b93329 2511fragment <<EOF
3bcf5557
AM
2512 {NULL, no_argument, NULL, 0}
2513 };
2514
2515 *shortopts = (char *) xrealloc (*shortopts, ns + sizeof (xtra_short));
2516 memcpy (*shortopts + ns, &xtra_short, sizeof (xtra_short));
2517 *longopts = (struct option *)
2518 xrealloc (*longopts, nl * sizeof (struct option) + sizeof (xtra_long));
2519 memcpy (*longopts + nl, &xtra_long, sizeof (xtra_long));
2520}
04925e1e 2521
24382dca 2522#define DEFAULT_BUILD_ID_STYLE "sha1"
c0065db7 2523
3bcf5557 2524static bfd_boolean
0c7a8e5a 2525gld${EMULATION_NAME}_handle_option (int optc)
e0ee487b 2526{
e0ee487b
L
2527 switch (optc)
2528 {
2529 default:
3bcf5557 2530 return FALSE;
6c1439be 2531
c0065db7 2532 case OPTION_BUILD_ID:
30e8ee25 2533 if (emit_note_gnu_build_id != NULL)
c0065db7 2534 {
30e8ee25
AM
2535 free ((char *) emit_note_gnu_build_id);
2536 emit_note_gnu_build_id = NULL;
c0065db7
RM
2537 }
2538 if (optarg == NULL)
2539 optarg = DEFAULT_BUILD_ID_STYLE;
2540 if (strcmp (optarg, "none"))
30e8ee25 2541 emit_note_gnu_build_id = xstrdup (optarg);
c0065db7 2542 break;
fb42df5e 2543
0ce398f1
L
2544 case OPTION_COMPRESS_DEBUG:
2545 if (strcasecmp (optarg, "none") == 0)
2546 link_info.compress_debug = COMPRESS_DEBUG_NONE;
2547 else if (strcasecmp (optarg, "zlib") == 0)
19a7fe52 2548 link_info.compress_debug = COMPRESS_DEBUG_GABI_ZLIB;
0ce398f1
L
2549 else if (strcasecmp (optarg, "zlib-gnu") == 0)
2550 link_info.compress_debug = COMPRESS_DEBUG_GNU_ZLIB;
2551 else if (strcasecmp (optarg, "zlib-gabi") == 0)
2552 link_info.compress_debug = COMPRESS_DEBUG_GABI_ZLIB;
2553 else
2554 einfo (_("%P%F: invalid --compress-debug-sections option: \`%s'\n"),
2555 optarg);
2556 break;
fb42df5e
AM
2557EOF
2558
2559if test x"$GENERATE_SHLIB_SCRIPT" = xyes; then
2560fragment <<EOF
7ee314fa 2561 case OPTION_AUDIT:
4724d37e 2562 gld${EMULATION_NAME}_append_to_separated_string (&audit, optarg);
7ee314fa 2563 break;
fb42df5e 2564
7ee314fa
AM
2565 case 'P':
2566 gld${EMULATION_NAME}_append_to_separated_string (&depaudit, optarg);
2567 break;
c0065db7 2568
6c1439be 2569 case OPTION_DISABLE_NEW_DTAGS:
b34976b6 2570 link_info.new_dtags = FALSE;
6c1439be
L
2571 break;
2572
2573 case OPTION_ENABLE_NEW_DTAGS:
b34976b6 2574 link_info.new_dtags = TRUE;
6c1439be
L
2575 break;
2576
65765700 2577 case OPTION_EH_FRAME_HDR:
2f0c68f2 2578 link_info.eh_frame_hdr_type = DWARF2_EH_HDR;
65765700
JJ
2579 break;
2580
29063f8b
NC
2581 case OPTION_NO_EH_FRAME_HDR:
2582 link_info.eh_frame_hdr_type = 0;
2583 break;
2584
a1ab1d2a
UD
2585 case OPTION_GROUP:
2586 link_info.flags_1 |= (bfd_vma) DF_1_GROUP;
2587 /* Groups must be self-contained. */
560e09e9
NC
2588 link_info.unresolved_syms_in_objects = RM_GENERATE_ERROR;
2589 link_info.unresolved_syms_in_shared_libs = RM_GENERATE_ERROR;
a1ab1d2a
UD
2590 break;
2591
b58f81ae
DJ
2592 case OPTION_EXCLUDE_LIBS:
2593 add_excluded_libs (optarg);
2594 break;
2595
fdc90cb4
JJ
2596 case OPTION_HASH_STYLE:
2597 link_info.emit_hash = FALSE;
2598 link_info.emit_gnu_hash = FALSE;
2599 if (strcmp (optarg, "sysv") == 0)
2600 link_info.emit_hash = TRUE;
2601 else if (strcmp (optarg, "gnu") == 0)
2602 link_info.emit_gnu_hash = TRUE;
2603 else if (strcmp (optarg, "both") == 0)
2604 {
2605 link_info.emit_hash = TRUE;
2606 link_info.emit_gnu_hash = TRUE;
2607 }
2608 else
2609 einfo (_("%P%F: invalid hash style \`%s'\n"), optarg);
2610 break;
2611
fb42df5e
AM
2612EOF
2613fi
2614fragment <<EOF
e0ee487b 2615 case 'z':
fb42df5e
AM
2616 if (strcmp (optarg, "defs") == 0)
2617 link_info.unresolved_syms_in_objects = RM_GENERATE_ERROR;
2618 else if (strcmp (optarg, "muldefs") == 0)
2619 link_info.allow_multiple_definition = TRUE;
2620 else if (CONST_STRNEQ (optarg, "max-page-size="))
2621 {
2622 char *end;
2623
2624 config.maxpagesize = strtoul (optarg + 14, &end, 0);
2625 if (*end || (config.maxpagesize & (config.maxpagesize - 1)) != 0)
2626 einfo (_("%P%F: invalid maxium page size \`%s'\n"),
2627 optarg + 14);
2628 }
2629 else if (CONST_STRNEQ (optarg, "common-page-size="))
2630 {
2631 char *end;
2632 config.commonpagesize = strtoul (optarg + 17, &end, 0);
2633 if (*end
2634 || (config.commonpagesize & (config.commonpagesize - 1)) != 0)
2635 einfo (_("%P%F: invalid common page size \`%s'\n"),
2636 optarg + 17);
2637 }
04c3a755
NS
2638 else if (CONST_STRNEQ (optarg, "stack-size="))
2639 {
2640 char *end;
2641 link_info.stacksize = strtoul (optarg + 11, &end, 0);
2642 if (*end || link_info.stacksize < 0)
2643 einfo (_("%P%F: invalid stack size \`%s'\n"), optarg + 11);
2644 if (!link_info.stacksize)
2645 /* Use -1 for explicit no-stack, because zero means
2646 'default'. */
2647 link_info.stacksize = -1;
2648 }
fb42df5e
AM
2649 else if (strcmp (optarg, "execstack") == 0)
2650 {
2651 link_info.execstack = TRUE;
2652 link_info.noexecstack = FALSE;
2653 }
2654 else if (strcmp (optarg, "noexecstack") == 0)
2655 {
2656 link_info.noexecstack = TRUE;
2657 link_info.execstack = FALSE;
2658 }
2659EOF
d258b828 2660
fb42df5e
AM
2661if test x"$GENERATE_SHLIB_SCRIPT" = xyes; then
2662fragment <<EOF
b039ef04
L
2663 else if (strcmp (optarg, "global") == 0)
2664 link_info.flags_1 |= (bfd_vma) DF_1_GLOBAL;
fb42df5e 2665 else if (strcmp (optarg, "initfirst") == 0)
e0ee487b
L
2666 link_info.flags_1 |= (bfd_vma) DF_1_INITFIRST;
2667 else if (strcmp (optarg, "interpose") == 0)
2668 link_info.flags_1 |= (bfd_vma) DF_1_INTERPOSE;
2669 else if (strcmp (optarg, "loadfltr") == 0)
2670 link_info.flags_1 |= (bfd_vma) DF_1_LOADFLTR;
2671 else if (strcmp (optarg, "nodefaultlib") == 0)
2672 link_info.flags_1 |= (bfd_vma) DF_1_NODEFLIB;
2673 else if (strcmp (optarg, "nodelete") == 0)
2674 link_info.flags_1 |= (bfd_vma) DF_1_NODELETE;
2675 else if (strcmp (optarg, "nodlopen") == 0)
2676 link_info.flags_1 |= (bfd_vma) DF_1_NOOPEN;
2677 else if (strcmp (optarg, "nodump") == 0)
2678 link_info.flags_1 |= (bfd_vma) DF_1_NODUMP;
2679 else if (strcmp (optarg, "now") == 0)
2680 {
2681 link_info.flags |= (bfd_vma) DF_BIND_NOW;
2682 link_info.flags_1 |= (bfd_vma) DF_1_NOW;
2683 }
5fa222e4
AM
2684 else if (strcmp (optarg, "lazy") == 0)
2685 {
2686 link_info.flags &= ~(bfd_vma) DF_BIND_NOW;
2687 link_info.flags_1 &= ~(bfd_vma) DF_1_NOW;
2688 }
e0ee487b
L
2689 else if (strcmp (optarg, "origin") == 0)
2690 {
2691 link_info.flags |= (bfd_vma) DF_ORIGIN;
2692 link_info.flags_1 |= (bfd_vma) DF_1_ORIGIN;
2693 }
db6751f2 2694 else if (strcmp (optarg, "combreloc") == 0)
b34976b6 2695 link_info.combreloc = TRUE;
db6751f2 2696 else if (strcmp (optarg, "nocombreloc") == 0)
b34976b6 2697 link_info.combreloc = FALSE;
8bd621d8 2698 else if (strcmp (optarg, "nocopyreloc") == 0)
0c7a8e5a 2699 link_info.nocopyreloc = TRUE;
8c37241b
JJ
2700 else if (strcmp (optarg, "relro") == 0)
2701 link_info.relro = TRUE;
2702 else if (strcmp (optarg, "norelro") == 0)
2703 link_info.relro = FALSE;
b8871f35
L
2704 else if (strcmp (optarg, "common") == 0)
2705 link_info.elf_stt_common = elf_stt_common;
2706 else if (strcmp (optarg, "nocommon") == 0)
2707 link_info.elf_stt_common = no_elf_stt_common;
c192a133
AM
2708 else if (strcmp (optarg, "text") == 0)
2709 link_info.error_textrel = TRUE;
2710 else if (strcmp (optarg, "notext") == 0)
2711 link_info.error_textrel = FALSE;
2712 else if (strcmp (optarg, "textoff") == 0)
2713 link_info.error_textrel = FALSE;
88b882e9 2714EOF
fb42df5e 2715fi
88b882e9 2716
eba27bd7
L
2717if test -n "$PARSE_AND_LIST_ARGS_CASE_Z" ; then
2718fragment <<EOF
2719 $PARSE_AND_LIST_ARGS_CASE_Z
2720EOF
2721fi
2722
92b93329 2723fragment <<EOF
fb42df5e
AM
2724 else
2725 einfo (_("%P: warning: -z %s ignored.\n"), optarg);
6c1439be 2726 break;
e0ee487b 2727EOF
e0ee487b
L
2728
2729if test -n "$PARSE_AND_LIST_ARGS_CASES" ; then
92b93329 2730fragment <<EOF
e0ee487b
L
2731 $PARSE_AND_LIST_ARGS_CASES
2732EOF
2733fi
2734
92b93329 2735fragment <<EOF
e0ee487b
L
2736 }
2737
3bcf5557 2738 return TRUE;
e0ee487b
L
2739}
2740
41392f03 2741EOF
41392f03 2742
4b209b22 2743if test x"$LDEMUL_LIST_OPTIONS" != xgld"$EMULATION_NAME"_list_options; then
c58212ea 2744gld_list_options="gld${EMULATION_NAME}_list_options"
eba27bd7 2745if test -n "$PARSE_AND_LIST_OPTIONS"; then
92b93329 2746fragment <<EOF
41392f03 2747
e0ee487b 2748static void
0c7a8e5a 2749gld${EMULATION_NAME}_list_options (FILE * file)
e0ee487b 2750{
fb42df5e 2751EOF
e0ee487b
L
2752
2753if test -n "$PARSE_AND_LIST_OPTIONS" ; then
92b93329 2754fragment <<EOF
e0ee487b
L
2755 $PARSE_AND_LIST_OPTIONS
2756EOF
2757fi
2758
92b93329 2759fragment <<EOF
e0ee487b
L
2760}
2761EOF
c58212ea
L
2762else
2763 gld_list_options="NULL"
2764fi
e0ee487b
L
2765
2766if test -n "$PARSE_AND_LIST_EPILOGUE" ; then
92b93329 2767fragment <<EOF
e0ee487b
L
2768 $PARSE_AND_LIST_EPILOGUE
2769EOF
2770fi
41392f03 2771fi
e0ee487b 2772
92b93329 2773fragment <<EOF
252b5132 2774
60bcf0fa 2775struct ld_emulation_xfer_struct ld_${EMULATION_NAME}_emulation =
252b5132 2776{
41392f03
AM
2777 ${LDEMUL_BEFORE_PARSE-gld${EMULATION_NAME}_before_parse},
2778 ${LDEMUL_SYSLIB-syslib_default},
2779 ${LDEMUL_HLL-hll_default},
5fe2850d 2780 ${LDEMUL_AFTER_PARSE-gld${EMULATION_NAME}_after_parse},
41392f03 2781 ${LDEMUL_AFTER_OPEN-gld${EMULATION_NAME}_after_open},
eaeb0a9d 2782 ${LDEMUL_AFTER_ALLOCATION-gld${EMULATION_NAME}_after_allocation},
41392f03
AM
2783 ${LDEMUL_SET_OUTPUT_ARCH-set_output_arch_default},
2784 ${LDEMUL_CHOOSE_TARGET-ldemul_default_target},
2785 ${LDEMUL_BEFORE_ALLOCATION-gld${EMULATION_NAME}_before_allocation},
2786 ${LDEMUL_GET_SCRIPT-gld${EMULATION_NAME}_get_script},
252b5132
RH
2787 "${EMULATION_NAME}",
2788 "${OUTPUT_FORMAT}",
eaeb0a9d 2789 ${LDEMUL_FINISH-finish_default},
41392f03
AM
2790 ${LDEMUL_CREATE_OUTPUT_SECTION_STATEMENTS-NULL},
2791 ${LDEMUL_OPEN_DYNAMIC_ARCHIVE-gld${EMULATION_NAME}_open_dynamic_archive},
2792 ${LDEMUL_PLACE_ORPHAN-gld${EMULATION_NAME}_place_orphan},
2793 ${LDEMUL_SET_SYMBOLS-NULL},
3bcf5557
AM
2794 ${LDEMUL_PARSE_ARGS-NULL},
2795 gld${EMULATION_NAME}_add_options,
2796 gld${EMULATION_NAME}_handle_option,
41392f03 2797 ${LDEMUL_UNRECOGNIZED_FILE-NULL},
c58212ea 2798 ${LDEMUL_LIST_OPTIONS-${gld_list_options}},
4a43e768 2799 ${LDEMUL_RECOGNIZED_FILE-gld${EMULATION_NAME}_load_symbols},
41392f03 2800 ${LDEMUL_FIND_POTENTIAL_LIBRARIES-NULL},
7a2f2d82
DD
2801 ${LDEMUL_NEW_VERS_PATTERN-NULL},
2802 ${LDEMUL_EXTRA_MAP_FILE_TEXT-NULL}
252b5132
RH
2803};
2804EOF
This page took 1.107625 seconds and 4 git commands to generate.