Rewrite add_sysroot
[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
0e1862bb 1261 if (bfd_link_relocatable (&link_info))
76f0cad6
NC
1262 {
1263 if (link_info.execstack == ! link_info.noexecstack)
1264 /* PR ld/16744: If "-z [no]execstack" has been specified on the
1265 command line and we are perfoming a relocatable link then no
1266 PT_GNU_STACK segment will be created and so the
1267 linkinfo.[no]execstack values set in _handle_option() will have no
1268 effect. Instead we create a .note.GNU-stack section in much the
1269 same way as the assembler does with its --[no]execstack option. */
1270 (void) bfd_make_section_with_flags (link_info.input_bfds,
1271 ".note.GNU-stack",
1272 SEC_READONLY | (link_info.execstack ? SEC_CODE : 0));
1273
1274 return;
1275 }
d10e7fcc 1276
2f0c68f2 1277 if (!link_info.traditional_format)
eb3d5f3b 1278 {
a654efd6
L
1279 bfd *abfd, *elfbfd = NULL;
1280 bfd_boolean warn_eh_frame = FALSE;
d10e7fcc 1281 asection *s;
2f0c68f2 1282 int seen_type = 0;
eb3d5f3b 1283
c72f2fb2 1284 for (abfd = link_info.input_bfds; abfd; abfd = abfd->link.next)
eb3d5f3b 1285 {
2f0c68f2
CM
1286 int type = 0;
1287 for (s = abfd->sections; s && type < COMPACT_EH_HDR; s = s->next)
4440bb77 1288 {
2f0c68f2
CM
1289 const char *name = bfd_get_section_name (abfd, s);
1290
1291 if (bfd_is_abs_section (s->output_section))
1292 continue;
1293 if (CONST_STRNEQ (name, ".eh_frame_entry"))
1294 type = COMPACT_EH_HDR;
1295 else if (strcmp (name, ".eh_frame") == 0 && s->size > 8)
1296 type = DWARF2_EH_HDR;
4440bb77 1297 }
2f0c68f2
CM
1298
1299 if (type != 0)
1300 {
1301 if (seen_type == 0)
1302 {
1303 seen_type = type;
1304 }
1305 else if (seen_type != type)
1306 {
1307 einfo (_("%P%F: compact frame descriptions incompatible with"
1308 " DWARF2 .eh_frame from %B\n"),
1309 type == DWARF2_EH_HDR ? abfd : elfbfd);
1310 break;
1311 }
1312
1313 if (!elfbfd
1314 && (type == COMPACT_EH_HDR || link_info.eh_frame_hdr_type != 0))
1315 {
1316 if (bfd_get_flavour (abfd) == bfd_target_elf_flavour)
1317 elfbfd = abfd;
1318
1319 warn_eh_frame = TRUE;
1320 }
1321 }
1322
1323 if (seen_type == COMPACT_EH_HDR)
1324 link_info.eh_frame_hdr_type = COMPACT_EH_HDR;
1325
1326 if (bfd_count_sections (abfd) == 0)
1327 continue;
d10e7fcc 1328 }
a654efd6 1329 if (elfbfd)
d10e7fcc
AM
1330 {
1331 const struct elf_backend_data *bed;
1332
a654efd6
L
1333 bed = get_elf_backend_data (elfbfd);
1334 s = bfd_make_section_with_flags (elfbfd, ".eh_frame_hdr",
1335 bed->dynamic_sec_flags
1336 | SEC_READONLY);
d10e7fcc 1337 if (s != NULL
a654efd6
L
1338 && bfd_set_section_alignment (elfbfd, s, 2))
1339 {
1340 htab->eh_info.hdr_sec = s;
1341 warn_eh_frame = FALSE;
1342 }
eb3d5f3b 1343 }
a654efd6
L
1344 if (warn_eh_frame)
1345 einfo ("%P: warning: Cannot create .eh_frame_hdr section,"
1346 " --eh-frame-hdr ignored.\n");
eb3d5f3b
JB
1347 }
1348
04925e1e
AM
1349 /* Get the list of files which appear in DT_NEEDED entries in
1350 dynamic objects included in the link (often there will be none).
1351 For each such file, we want to track down the corresponding
1352 library, and include the symbol table in the link. This is what
1353 the runtime dynamic linker will do. Tracking the files down here
1354 permits one dynamic object to include another without requiring
1355 special action by the person doing the link. Note that the
1356 needed list can actually grow while we are stepping through this
1357 loop. */
f13a99db 1358 needed = bfd_elf_get_needed_list (link_info.output_bfd, &link_info);
04925e1e 1359 for (l = needed; l != NULL; l = l->next)
252b5132 1360 {
04925e1e 1361 struct bfd_link_needed_list *ll;
e56f61be 1362 struct dt_needed n, nn;
04925e1e 1363 int force;
252b5132 1364
7e9f0867 1365 /* If the lib that needs this one was --as-needed and wasn't
4706eab9 1366 found to be needed, then this lib isn't needed either. */
7e9f0867 1367 if (l->by != NULL
4706eab9
AM
1368 && (bfd_elf_get_dyn_lib_class (l->by) & DYN_AS_NEEDED) != 0)
1369 continue;
1370
1371 /* Skip the lib if --no-copy-dt-needed-entries and
1372 --allow-shlib-undefined is in effect. */
1373 if (l->by != NULL
1374 && link_info.unresolved_syms_in_shared_libs == RM_IGNORE
1375 && (bfd_elf_get_dyn_lib_class (l->by) & DYN_NO_ADD_NEEDED) != 0)
7e9f0867
AM
1376 continue;
1377
04925e1e
AM
1378 /* If we've already seen this file, skip it. */
1379 for (ll = needed; ll != l; ll = ll->next)
7e9f0867
AM
1380 if ((ll->by == NULL
1381 || (bfd_elf_get_dyn_lib_class (ll->by) & DYN_AS_NEEDED) == 0)
1382 && strcmp (ll->name, l->name) == 0)
04925e1e
AM
1383 break;
1384 if (ll != l)
1385 continue;
252b5132 1386
04925e1e
AM
1387 /* See if this file was included in the link explicitly. */
1388 global_needed = l;
e13629bc 1389 global_found = NULL;
04925e1e 1390 lang_for_each_input_file (gld${EMULATION_NAME}_check_needed);
e13629bc
AM
1391 if (global_found != NULL
1392 && (bfd_elf_get_dyn_lib_class (global_found->the_bfd)
1393 & DYN_AS_NEEDED) == 0)
04925e1e 1394 continue;
252b5132 1395
e56f61be
L
1396 n.by = l->by;
1397 n.name = l->name;
1398 nn.by = l->by;
cd6f1cf3 1399 if (verbose)
ec4eb78a
L
1400 info_msg (_("%s needed by %B\n"), l->name, l->by);
1401
e13629bc
AM
1402 /* As-needed libs specified on the command line (or linker script)
1403 take priority over libs found in search dirs. */
1404 if (global_found != NULL)
1405 {
1406 nn.name = global_found->filename;
1407 if (gld${EMULATION_NAME}_try_needed (&nn, TRUE))
1408 continue;
1409 }
1410
04925e1e
AM
1411 /* We need to find this file and include the symbol table. We
1412 want to search for the file in the same way that the dynamic
1413 linker will search. That means that we want to use
1414 rpath_link, rpath, then the environment variable
ec4eb78a
L
1415 LD_LIBRARY_PATH (native only), then the DT_RPATH/DT_RUNPATH
1416 entries (native only), then the linker script LIB_SEARCH_DIRS.
1417 We do not search using the -L arguments.
252b5132 1418
04925e1e
AM
1419 We search twice. The first time, we skip objects which may
1420 introduce version mismatches. The second time, we force
1421 their use. See gld${EMULATION_NAME}_vercheck comment. */
1422 for (force = 0; force < 2; force++)
1423 {
04925e1e
AM
1424 size_t len;
1425 search_dirs_type *search;
6dd8c765 1426EOF
316a1245 1427if [ "x${NATIVE}" = xyes ] || [ "x${USE_LIBPATH}" = xyes ] ; then
92b93329 1428fragment <<EOF
316a1245 1429 const char *path;
ff925e69
KK
1430EOF
1431fi
1432if [ "x${USE_LIBPATH}" = xyes ] ; then
92b93329 1433fragment <<EOF
6dd8c765
L
1434 struct bfd_link_needed_list *rp;
1435 int found;
1436EOF
6dd8c765 1437fi
92b93329 1438fragment <<EOF
252b5132 1439
04925e1e 1440 if (gld${EMULATION_NAME}_search_needed (command_line.rpath_link,
e56f61be 1441 &n, force))
04925e1e 1442 break;
dcb0bd0e 1443EOF
9c8ebd6a 1444if [ "x${USE_LIBPATH}" = xyes ] ; then
92b93329 1445fragment <<EOF
316a1245
AM
1446 path = command_line.rpath;
1447 if (path)
1448 {
1449 found = gld${EMULATION_NAME}_search_needed (path, &n, force);
1450 if (found)
1451 break;
1452 }
9c8ebd6a
DJ
1453EOF
1454fi
1455if [ "x${NATIVE}" = xyes ] ; then
92b93329 1456fragment <<EOF
04925e1e
AM
1457 if (command_line.rpath_link == NULL
1458 && command_line.rpath == NULL)
1459 {
316a1245
AM
1460 path = (const char *) getenv ("LD_RUN_PATH");
1461 if (path
1462 && gld${EMULATION_NAME}_search_needed (path, &n, force))
04925e1e
AM
1463 break;
1464 }
316a1245
AM
1465 path = (const char *) getenv ("LD_LIBRARY_PATH");
1466 if (path
1467 && gld${EMULATION_NAME}_search_needed (path, &n, force))
04925e1e 1468 break;
9c8ebd6a
DJ
1469EOF
1470fi
1471if [ "x${USE_LIBPATH}" = xyes ] ; then
92b93329 1472fragment <<EOF
ec4eb78a 1473 found = 0;
f13a99db 1474 rp = bfd_elf_get_runpath_list (link_info.output_bfd, &link_info);
6dd8c765 1475 for (; !found && rp != NULL; rp = rp->next)
ec4eb78a 1476 {
316a1245 1477 path = gld${EMULATION_NAME}_add_sysroot (rp->name);
ec4eb78a 1478 found = (rp->by == l->by
316a1245 1479 && gld${EMULATION_NAME}_search_needed (path, &n,
ec4eb78a 1480 force));
316a1245 1481 free ((char *) path);
ec4eb78a
L
1482 }
1483 if (found)
1484 break;
1485
04925e1e 1486EOF
04925e1e 1487fi
c1446dba
L
1488if [ "x${USE_LIBPATH}" = xyes ] ; then
1489 case ${target} in
ebe1fac1 1490 *-*-freebsd* | *-*-dragonfly*)
92b93329 1491 fragment <<EOF
d5c8b1f8 1492 if (gld${EMULATION_NAME}_check_ld_elf_hints (l, force))
ebe1fac1
NC
1493 break;
1494EOF
1495 # FreeBSD
1496 ;;
1497
a5244b7e 1498 *-*-linux-* | *-*-k*bsd*-* | *-*-gnu*)
92b93329 1499 fragment <<EOF
d5c8b1f8 1500 if (gld${EMULATION_NAME}_check_ld_so_conf (l, force))
c1446dba
L
1501 break;
1502
1503EOF
eeaa4577 1504 # Linux
c1446dba
L
1505 ;;
1506 esac
1507fi
92b93329 1508fragment <<EOF
04925e1e
AM
1509 len = strlen (l->name);
1510 for (search = search_head; search != NULL; search = search->next)
1511 {
1512 char *filename;
252b5132 1513
04925e1e
AM
1514 if (search->cmdline)
1515 continue;
1516 filename = (char *) xmalloc (strlen (search->name) + len + 2);
1517 sprintf (filename, "%s/%s", search->name, l->name);
e56f61be
L
1518 nn.name = filename;
1519 if (gld${EMULATION_NAME}_try_needed (&nn, force))
04925e1e
AM
1520 break;
1521 free (filename);
1522 }
1523 if (search != NULL)
1524 break;
1525EOF
92b93329 1526fragment <<EOF
04925e1e 1527 }
252b5132 1528
04925e1e
AM
1529 if (force < 2)
1530 continue;
252b5132 1531
e374f1d9 1532 einfo ("%P: warning: %s, needed by %B, not found (try using -rpath or -rpath-link)\n",
04925e1e
AM
1533 l->name, l->by);
1534 }
2f0c68f2
CM
1535
1536 if (link_info.eh_frame_hdr_type == COMPACT_EH_HDR)
1537 if (bfd_elf_parse_eh_frame_entries (NULL, &link_info) == FALSE)
1538 einfo (_("%P%F: Failed to parse EH frame entries.\n"));
04925e1e 1539}
252b5132 1540
41392f03
AM
1541EOF
1542fi
1543
92b93329 1544fragment <<EOF
252b5132 1545
04925e1e 1546/* Look through an expression for an assignment statement. */
252b5132 1547
04925e1e 1548static void
0c7a8e5a 1549gld${EMULATION_NAME}_find_exp_assignment (etree_type *exp)
04925e1e 1550{
4ea42fb7 1551 bfd_boolean provide = FALSE;
04925e1e
AM
1552
1553 switch (exp->type.node_class)
252b5132 1554 {
04925e1e 1555 case etree_provide:
bded3693 1556 case etree_provided:
4ea42fb7 1557 provide = TRUE;
839b0b3f 1558 /* Fallthru */
4ea42fb7 1559 case etree_assign:
04925e1e
AM
1560 /* We call record_link_assignment even if the symbol is defined.
1561 This is because if it is defined by a dynamic object, we
1562 actually want to use the value defined by the linker script,
1563 not the value from the dynamic object (because we are setting
1564 symbols like etext). If the symbol is defined by a regular
1565 object, then, as it happens, calling record_link_assignment
1566 will do no harm. */
04925e1e 1567 if (strcmp (exp->assign.dst, ".") != 0)
252b5132 1568 {
f13a99db
AM
1569 if (!bfd_elf_record_link_assignment (link_info.output_bfd,
1570 &link_info,
fe21a8fc
L
1571 exp->assign.dst, provide,
1572 exp->assign.hidden))
04925e1e
AM
1573 einfo ("%P%F: failed to record assignment to %s: %E\n",
1574 exp->assign.dst);
252b5132 1575 }
04925e1e
AM
1576 gld${EMULATION_NAME}_find_exp_assignment (exp->assign.src);
1577 break;
252b5132 1578
04925e1e
AM
1579 case etree_binary:
1580 gld${EMULATION_NAME}_find_exp_assignment (exp->binary.lhs);
1581 gld${EMULATION_NAME}_find_exp_assignment (exp->binary.rhs);
1582 break;
252b5132 1583
04925e1e
AM
1584 case etree_trinary:
1585 gld${EMULATION_NAME}_find_exp_assignment (exp->trinary.cond);
1586 gld${EMULATION_NAME}_find_exp_assignment (exp->trinary.lhs);
1587 gld${EMULATION_NAME}_find_exp_assignment (exp->trinary.rhs);
1588 break;
252b5132 1589
04925e1e
AM
1590 case etree_unary:
1591 gld${EMULATION_NAME}_find_exp_assignment (exp->unary.child);
1592 break;
252b5132 1593
04925e1e
AM
1594 default:
1595 break;
252b5132
RH
1596 }
1597}
1598
04925e1e
AM
1599
1600/* This is called by the before_allocation routine via
1601 lang_for_each_statement. It locates any assignment statements, and
1602 tells the ELF backend about them, in case they are assignments to
1603 symbols which are referred to by dynamic objects. */
1604
1605static void
0c7a8e5a 1606gld${EMULATION_NAME}_find_statement_assignment (lang_statement_union_type *s)
04925e1e
AM
1607{
1608 if (s->header.type == lang_assignment_statement_enum)
1609 gld${EMULATION_NAME}_find_exp_assignment (s->assignment_statement.exp);
1610}
1611
41392f03
AM
1612EOF
1613
1614if test x"$LDEMUL_BEFORE_ALLOCATION" != xgld"$EMULATION_NAME"_before_allocation; then
57e6abd2
AO
1615 if test x"${ELF_INTERPRETER_NAME+set}" = xset; then
1616 ELF_INTERPRETER_SET_DEFAULT="
1617 if (sinterp != NULL)
1618 {
5718918d
AM
1619 sinterp->contents = (unsigned char *) ${ELF_INTERPRETER_NAME};
1620 sinterp->size = strlen ((char *) sinterp->contents) + 1;
57e6abd2
AO
1621 }
1622
1623"
1624 else
1625 ELF_INTERPRETER_SET_DEFAULT=
1626 fi
92b93329 1627fragment <<EOF
04925e1e 1628
7ee314fa 1629/* used by before_allocation and handle_option. */
4724d37e 1630static void
91d6fa6a 1631gld${EMULATION_NAME}_append_to_separated_string (char **to, char *op_arg)
7ee314fa
AM
1632{
1633 if (*to == NULL)
91d6fa6a 1634 *to = xstrdup (op_arg);
7ee314fa
AM
1635 else
1636 {
1637 size_t to_len = strlen (*to);
91d6fa6a 1638 size_t op_arg_len = strlen (op_arg);
7ee314fa
AM
1639 char *buf;
1640 char *cp = *to;
1641
1642 /* First see whether OPTARG is already in the path. */
1643 do
1644 {
91d6fa6a
NC
1645 if (strncmp (op_arg, cp, op_arg_len) == 0
1646 && (cp[op_arg_len] == 0
1647 || cp[op_arg_len] == config.rpath_separator))
7ee314fa
AM
1648 /* We found it. */
1649 break;
1650
1651 /* Not yet found. */
1652 cp = strchr (cp, config.rpath_separator);
1653 if (cp != NULL)
1654 ++cp;
1655 }
1656 while (cp != NULL);
1657
1658 if (cp == NULL)
1659 {
91d6fa6a 1660 buf = xmalloc (to_len + op_arg_len + 2);
7ee314fa 1661 sprintf (buf, "%s%c%s", *to,
91d6fa6a 1662 config.rpath_separator, op_arg);
7ee314fa
AM
1663 free (*to);
1664 *to = buf;
1665 }
1666 }
1667}
1668
b6518b38
NC
1669#if defined(__GNUC__) && GCC_VERSION < 4006
1670 /* Work around a GCC uninitialized warning bug fixed in GCC 4.6. */
1671static struct bfd_link_hash_entry ehdr_start_empty;
1672#endif
1673
252b5132
RH
1674/* This is called after the sections have been attached to output
1675 sections, but before any sizes or addresses have been set. */
1676
1677static void
0c7a8e5a 1678gld${EMULATION_NAME}_before_allocation (void)
252b5132
RH
1679{
1680 const char *rpath;
1681 asection *sinterp;
7ee314fa 1682 bfd *abfd;
4199e3b8 1683 struct elf_link_hash_entry *ehdr_start = NULL;
a0bde398
L
1684#if defined(__GNUC__) && GCC_VERSION < 4006
1685 /* Work around a GCC uninitialized warning bug fixed in GCC 4.6. */
b6518b38 1686 struct bfd_link_hash_entry ehdr_start_save = ehdr_start_empty;
a0bde398 1687#else
4a0bc59e 1688 struct bfd_link_hash_entry ehdr_start_save;
a0bde398 1689#endif
252b5132 1690
b4d040b1 1691 if (is_elf_hash_table (link_info.hash))
a5382c42
MR
1692 {
1693 _bfd_elf_tls_setup (link_info.output_bfd, &link_info);
e1918d23 1694
cde7cb01
MR
1695 /* Make __ehdr_start hidden if it has been referenced, to
1696 prevent the symbol from being dynamic. */
0e1862bb 1697 if (!bfd_link_relocatable (&link_info))
c2763e27
RM
1698 {
1699 struct elf_link_hash_entry *h
1700 = elf_link_hash_lookup (elf_hash_table (&link_info), "__ehdr_start",
1701 FALSE, FALSE, TRUE);
1702
1703 /* Only adjust the export class if the symbol was referenced
1704 and not defined, otherwise leave it alone. */
1705 if (h != NULL
1706 && (h->root.type == bfd_link_hash_new
1707 || h->root.type == bfd_link_hash_undefined
1708 || h->root.type == bfd_link_hash_undefweak
1709 || h->root.type == bfd_link_hash_common))
1710 {
1711 _bfd_elf_link_hash_hide_symbol (&link_info, h, TRUE);
1712 if (ELF_ST_VISIBILITY (h->other) != STV_INTERNAL)
1713 h->other = (h->other & ~ELF_ST_VISIBILITY (-1)) | STV_HIDDEN;
4199e3b8
AM
1714 /* Don't leave the symbol undefined. Undefined hidden
1715 symbols typically won't have dynamic relocations, but
1716 we most likely will need dynamic relocations for
1717 __ehdr_start if we are building a PIE or shared
1718 library. */
1719 ehdr_start = h;
1720 ehdr_start_save = h->root;
1721 h->root.type = bfd_link_hash_defined;
1722 h->root.u.def.section = bfd_abs_section_ptr;
1723 h->root.u.def.value = 0;
c2763e27
RM
1724 }
1725 }
cde7cb01 1726
a5382c42
MR
1727 /* If we are going to make any variable assignments, we need to
1728 let the ELF backend know about them in case the variables are
1729 referred to by dynamic objects. */
1730 lang_for_each_statement (gld${EMULATION_NAME}_find_statement_assignment);
1731 }
252b5132
RH
1732
1733 /* Let the ELF backend work out the sizes of any sections required
1734 by dynamic linking. */
1735 rpath = command_line.rpath;
1736 if (rpath == NULL)
1737 rpath = (const char *) getenv ("LD_RUN_PATH");
7ee314fa 1738
c72f2fb2 1739 for (abfd = link_info.input_bfds; abfd; abfd = abfd->link.next)
8dd881b6
L
1740 if (bfd_get_flavour (abfd) == bfd_target_elf_flavour)
1741 {
1742 const char *audit_libs = elf_dt_audit (abfd);
7ee314fa 1743
4724d37e 1744 /* If the input bfd contains an audit entry, we need to add it as
8dd881b6
L
1745 a dep audit entry. */
1746 if (audit_libs && *audit_libs != '\0')
1747 {
1748 char *cp = xstrdup (audit_libs);
1749 do
1750 {
1751 int more = 0;
1752 char *cp2 = strchr (cp, config.rpath_separator);
7ee314fa 1753
8dd881b6
L
1754 if (cp2)
1755 {
1756 *cp2 = '\0';
1757 more = 1;
1758 }
7ee314fa 1759
8dd881b6
L
1760 if (cp != NULL && *cp != '\0')
1761 gld${EMULATION_NAME}_append_to_separated_string (&depaudit, cp);
1762
1763 cp = more ? ++cp2 : NULL;
1764 }
1765 while (cp != NULL);
1766 }
1767 }
7ee314fa 1768
5a580b3a 1769 if (! (bfd_elf_size_dynamic_sections
f13a99db 1770 (link_info.output_bfd, command_line.soname, rpath,
7ee314fa 1771 command_line.filter_shlib, audit, depaudit,
252b5132 1772 (const char * const *) command_line.auxiliary_filters,
fd91d419 1773 &link_info, &sinterp)))
252b5132 1774 einfo ("%P%F: failed to set dynamic section sizes: %E\n");
8423293d 1775
57e6abd2 1776${ELF_INTERPRETER_SET_DEFAULT}
252b5132
RH
1777 /* Let the user override the dynamic linker we are using. */
1778 if (command_line.interpreter != NULL
1779 && sinterp != NULL)
1780 {
1781 sinterp->contents = (bfd_byte *) command_line.interpreter;
eea6121a 1782 sinterp->size = strlen (command_line.interpreter) + 1;
252b5132
RH
1783 }
1784
1785 /* Look for any sections named .gnu.warning. As a GNU extensions,
1786 we treat such sections as containing warning messages. We print
1787 out the warning message, and then zero out the section size so
1788 that it does not get copied into the output file. */
1789
1790 {
1791 LANG_FOR_EACH_INPUT_STATEMENT (is)
1792 {
1793 asection *s;
1794 bfd_size_type sz;
1795 char *msg;
252b5132 1796
66be1055 1797 if (is->flags.just_syms)
252b5132
RH
1798 continue;
1799
1800 s = bfd_get_section_by_name (is->the_bfd, ".gnu.warning");
1801 if (s == NULL)
1802 continue;
1803
eea6121a 1804 sz = s->size;
1e9cc1c2 1805 msg = (char *) xmalloc ((size_t) (sz + 1));
bc251d50 1806 if (! bfd_get_section_contents (is->the_bfd, s, msg,
8c675694 1807 (file_ptr) 0, sz))
252b5132
RH
1808 einfo ("%F%B: Can't read contents of section .gnu.warning: %E\n",
1809 is->the_bfd);
bc251d50 1810 msg[sz] = '\0';
1a72702b
AM
1811 (*link_info.callbacks->warning) (&link_info, msg,
1812 (const char *) NULL, is->the_bfd,
1813 (asection *) NULL, (bfd_vma) 0);
252b5132
RH
1814 free (msg);
1815
9e3be61d
AM
1816 /* Clobber the section size, so that we don't waste space
1817 copying the warning into the output file. If we've already
1818 sized the output section, adjust its size. The adjustment
1819 is on rawsize because targets that size sections early will
1820 have called lang_reset_memory_regions after sizing. */
1821 if (s->output_section != NULL
1822 && s->output_section->rawsize >= s->size)
1823 s->output_section->rawsize -= s->size;
1824
eea6121a 1825 s->size = 0;
11d2f718 1826
9e3be61d
AM
1827 /* Also set SEC_EXCLUDE, so that local symbols defined in the
1828 warning section don't get copied to the output. */
a14a5de3 1829 s->flags |= SEC_EXCLUDE | SEC_KEEP;
252b5132
RH
1830 }
1831 }
8423293d 1832
1e035701 1833 before_allocation_default ();
8423293d 1834
f13a99db 1835 if (!bfd_elf_size_dynsym_hash_dynstr (link_info.output_bfd, &link_info))
8423293d 1836 einfo ("%P%F: failed to set dynamic section sizes: %E\n");
4199e3b8
AM
1837
1838 if (ehdr_start != NULL)
1839 {
1840 /* If we twiddled __ehdr_start to defined earlier, put it back
1841 as it was. */
1842 ehdr_start->root.type = ehdr_start_save.type;
1843 ehdr_start->root.u = ehdr_start_save.u;
1844 }
252b5132
RH
1845}
1846
41392f03
AM
1847EOF
1848fi
1849
1850if test x"$LDEMUL_OPEN_DYNAMIC_ARCHIVE" != xgld"$EMULATION_NAME"_open_dynamic_archive; then
92b93329 1851fragment <<EOF
252b5132 1852
04925e1e
AM
1853/* Try to open a dynamic archive. This is where we know that ELF
1854 dynamic libraries have an extension of .so (or .sl on oddball systems
1855 like hpux). */
1856
b34976b6 1857static bfd_boolean
0c7a8e5a
AM
1858gld${EMULATION_NAME}_open_dynamic_archive
1859 (const char *arch, search_dirs_type *search, lang_input_statement_type *entry)
252b5132 1860{
04925e1e
AM
1861 const char *filename;
1862 char *string;
d4ae5fb0
AM
1863 size_t len;
1864 bfd_boolean opened = FALSE;
252b5132 1865
66be1055 1866 if (! entry->flags.maybe_archive)
b34976b6 1867 return FALSE;
252b5132 1868
04925e1e 1869 filename = entry->filename;
d4ae5fb0
AM
1870 len = strlen (search->name) + strlen (filename);
1871 if (entry->flags.full_name_provided)
1872 {
1873 len += sizeof "/";
1874 string = (char *) xmalloc (len);
1875 sprintf (string, "%s/%s", search->name, filename);
1876 }
1877 else
1878 {
1879 size_t xlen = 0;
252b5132 1880
d4ae5fb0 1881 len += strlen (arch) + sizeof "/lib.so";
04925e1e 1882#ifdef EXTRA_SHLIB_EXTENSION
d4ae5fb0
AM
1883 xlen = (strlen (EXTRA_SHLIB_EXTENSION) > 3
1884 ? strlen (EXTRA_SHLIB_EXTENSION) - 3
1885 : 0);
04925e1e 1886#endif
d4ae5fb0
AM
1887 string = (char *) xmalloc (len + xlen);
1888 sprintf (string, "%s/lib%s%s.so", search->name, filename, arch);
04925e1e 1889#ifdef EXTRA_SHLIB_EXTENSION
d4ae5fb0
AM
1890 /* Try the .so extension first. If that fails build a new filename
1891 using EXTRA_SHLIB_EXTENSION. */
1892 opened = ldfile_try_open_bfd (string, entry);
1893 if (!opened)
1894 strcpy (string + len - 4, EXTRA_SHLIB_EXTENSION);
04925e1e 1895#endif
d4ae5fb0 1896 }
04925e1e 1897
d4ae5fb0 1898 if (!opened && !ldfile_try_open_bfd (string, entry))
252b5132 1899 {
04925e1e 1900 free (string);
b34976b6 1901 return FALSE;
04925e1e 1902 }
252b5132 1903
04925e1e 1904 entry->filename = string;
252b5132 1905
04925e1e
AM
1906 /* We have found a dynamic object to include in the link. The ELF
1907 backend linker will create a DT_NEEDED entry in the .dynamic
1908 section naming this file. If this file includes a DT_SONAME
1909 entry, it will be used. Otherwise, the ELF linker will just use
1910 the name of the file. For an archive found by searching, like
1911 this one, the DT_NEEDED entry should consist of just the name of
1912 the file, without the path information used to find it. Note
1913 that we only need to do this if we have a dynamic object; an
1914 archive will never be referenced by a DT_NEEDED entry.
252b5132 1915
04925e1e
AM
1916 FIXME: This approach--using bfd_elf_set_dt_needed_name--is not
1917 very pretty. I haven't been able to think of anything that is
1918 pretty, though. */
1919 if (bfd_check_format (entry->the_bfd, bfd_object)
1920 && (entry->the_bfd->flags & DYNAMIC) != 0)
1921 {
66be1055 1922 ASSERT (entry->flags.maybe_archive && entry->flags.search_dirs);
252b5132 1923
04925e1e 1924 /* Rather than duplicating the logic above. Just use the
1c9acd94 1925 filename we recorded earlier. */
04925e1e 1926
d4ae5fb0
AM
1927 if (!entry->flags.full_name_provided)
1928 filename = lbasename (entry->filename);
1c9acd94 1929 bfd_elf_set_dt_needed_name (entry->the_bfd, filename);
04925e1e
AM
1930 }
1931
b34976b6 1932 return TRUE;
04925e1e
AM
1933}
1934
41392f03
AM
1935EOF
1936fi
cde43e70
AM
1937
1938if test x"$LDEMUL_PLACE_ORPHAN" != xgld"$EMULATION_NAME"_place_orphan; then
92b93329 1939fragment <<EOF
41392f03 1940
afd7a018 1941/* A variant of lang_output_section_find used by place_orphan. */
04925e1e 1942
04925e1e 1943static lang_output_section_statement_type *
2a36a117 1944output_rel_find (asection *sec, int isdyn)
04925e1e 1945{
04925e1e 1946 lang_output_section_statement_type *lookup;
ba493122 1947 lang_output_section_statement_type *last = NULL;
2a36a117 1948 lang_output_section_statement_type *last_alloc = NULL;
48f2ff54 1949 lang_output_section_statement_type *last_ro_alloc = NULL;
ba493122
AM
1950 lang_output_section_statement_type *last_rel = NULL;
1951 lang_output_section_statement_type *last_rel_alloc = NULL;
24cdb50a 1952 int rela = sec->name[4] == 'a';
04925e1e 1953
afd7a018
AM
1954 for (lookup = &lang_output_section_statement.head->output_section_statement;
1955 lookup != NULL;
1956 lookup = lookup->next)
04925e1e 1957 {
66c103b7 1958 if (lookup->constraint >= 0
0112cd26 1959 && CONST_STRNEQ (lookup->name, ".rel"))
04925e1e 1960 {
24cdb50a 1961 int lookrela = lookup->name[4] == 'a';
ba493122 1962
2a36a117
AM
1963 /* .rel.dyn must come before all other reloc sections, to suit
1964 GNU ld.so. */
1965 if (isdyn)
1966 break;
1967
1968 /* Don't place after .rel.plt as doing so results in wrong
1969 dynamic tags. */
1970 if (strcmp (".plt", lookup->name + 4 + lookrela) == 0)
ba493122 1971 break;
2a36a117
AM
1972
1973 if (rela == lookrela || last_rel == NULL)
24cdb50a 1974 last_rel = lookup;
2a36a117
AM
1975 if ((rela == lookrela || last_rel_alloc == NULL)
1976 && lookup->bfd_section != NULL
ba493122
AM
1977 && (lookup->bfd_section->flags & SEC_ALLOC) != 0)
1978 last_rel_alloc = lookup;
04925e1e 1979 }
2a36a117
AM
1980
1981 last = lookup;
1982 if (lookup->bfd_section != NULL
1983 && (lookup->bfd_section->flags & SEC_ALLOC) != 0)
48f2ff54
AM
1984 {
1985 last_alloc = lookup;
1986 if ((lookup->bfd_section->flags & SEC_READONLY) != 0)
1987 last_ro_alloc = lookup;
1988 }
252b5132 1989 }
ba493122
AM
1990
1991 if (last_rel_alloc)
1992 return last_rel_alloc;
1993
1994 if (last_rel)
1995 return last_rel;
1996
48f2ff54
AM
1997 if (last_ro_alloc)
1998 return last_ro_alloc;
1999
2a36a117
AM
2000 if (last_alloc)
2001 return last_alloc;
2002
ba493122 2003 return last;
252b5132
RH
2004}
2005
2006/* Place an orphan section. We use this to put random SHF_ALLOC
2007 sections in the right segment. */
2008
c2edb4b8 2009static lang_output_section_statement_type *
8a99a385
AM
2010gld${EMULATION_NAME}_place_orphan (asection *s,
2011 const char *secname,
2012 int constraint)
252b5132 2013{
afd7a018
AM
2014 static struct orphan_save hold[] =
2015 {
2016 { ".text",
2017 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_READONLY | SEC_CODE,
2018 0, 0, 0, 0 },
2019 { ".rodata",
2020 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_READONLY | SEC_DATA,
2021 0, 0, 0, 0 },
d85e71fe
L
2022 { ".tdata",
2023 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_DATA | SEC_THREAD_LOCAL,
2024 0, 0, 0, 0 },
afd7a018
AM
2025 { ".data",
2026 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_DATA,
2027 0, 0, 0, 0 },
2028 { ".bss",
2029 SEC_ALLOC,
2030 0, 0, 0, 0 },
2031 { 0,
2032 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_READONLY | SEC_DATA,
2033 0, 0, 0, 0 },
2034 { ".interp",
2035 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_READONLY | SEC_DATA,
2036 0, 0, 0, 0 },
2037 { ".sdata",
2038 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_DATA | SEC_SMALL_DATA,
07890c07 2039 0, 0, 0, 0 },
175b7cd4 2040 { ".comment",
07890c07
AM
2041 SEC_HAS_CONTENTS,
2042 0, 0, 0, 0 },
afd7a018
AM
2043 };
2044 enum orphan_save_index
2045 {
2046 orphan_text = 0,
2047 orphan_rodata,
d85e71fe 2048 orphan_tdata,
afd7a018
AM
2049 orphan_data,
2050 orphan_bss,
2051 orphan_rel,
2052 orphan_interp,
07890c07
AM
2053 orphan_sdata,
2054 orphan_nonalloc
afd7a018
AM
2055 };
2056 static int orphan_init_done = 0;
6a345e87 2057 struct orphan_save *place;
afd7a018 2058 lang_output_section_statement_type *after;
252b5132 2059 lang_output_section_statement_type *os;
b5f14a6d 2060 lang_output_section_statement_type *match_by_name = NULL;
24cdb50a 2061 int isdyn = 0;
ecca9871
L
2062 int iself = s->owner->xvec->flavour == bfd_target_elf_flavour;
2063 unsigned int sh_type = iself ? elf_section_type (s) : SHT_NULL;
199af150
AM
2064 flagword flags;
2065 asection *nexts;
252b5132 2066
0e1862bb 2067 if (!bfd_link_relocatable (&link_info)
24cdb50a 2068 && link_info.combreloc
ecca9871 2069 && (s->flags & SEC_ALLOC))
24cdb50a 2070 {
ecca9871
L
2071 if (iself)
2072 switch (sh_type)
2073 {
2074 case SHT_RELA:
2075 secname = ".rela.dyn";
2076 isdyn = 1;
2077 break;
2078 case SHT_REL:
2079 secname = ".rel.dyn";
2080 isdyn = 1;
2081 break;
2082 default:
2083 break;
2084 }
0112cd26 2085 else if (CONST_STRNEQ (secname, ".rel"))
ecca9871
L
2086 {
2087 secname = secname[4] == 'a' ? ".rela.dyn" : ".rel.dyn";
2088 isdyn = 1;
2089 }
24cdb50a 2090 }
aea4bd9d 2091
bcacc0f5 2092 /* Look through the script to see where to place this section. */
d127ecce
AM
2093 if (constraint == 0)
2094 for (os = lang_output_section_find (secname);
2095 os != NULL;
2096 os = next_matching_output_section_statement (os, 0))
2097 {
2098 /* If we don't match an existing output section, tell
2099 lang_insert_orphan to create a new output section. */
2100 constraint = SPECIAL;
2101
93dc595d
L
2102 /* SEC_EXCLUDE is cleared when doing a relocatable link. But
2103 we can't merge 2 input sections with the same name when only
2104 one of them has SHF_EXCLUDE. */
d127ecce
AM
2105 if (os->bfd_section != NULL
2106 && (os->bfd_section->flags == 0
93dc595d 2107 || ((!bfd_link_relocatable (&link_info)
68c638d6
NC
2108 || (iself && (((elf_section_flags (s)
2109 ^ elf_section_flags (os->bfd_section))
2110 & SHF_EXCLUDE) == 0)))
93dc595d 2111 && ((s->flags ^ os->bfd_section->flags)
199af150
AM
2112 & (SEC_LOAD | SEC_ALLOC)) == 0
2113 && _bfd_elf_match_sections_by_type (link_info.output_bfd,
2114 os->bfd_section,
2115 s->owner, s))))
d127ecce
AM
2116 {
2117 /* We already have an output section statement with this
2118 name, and its bfd section has compatible flags.
2119 If the section already exists but does not have any flags
2120 set, then it has been created by the linker, probably as a
2121 result of a --section-start command line switch. */
b9c361e0 2122 lang_add_section (&os->children, s, NULL, os);
d127ecce
AM
2123 return os;
2124 }
b5f14a6d
DD
2125
2126 /* Save unused output sections in case we can match them
2127 against orphans later. */
2128 if (os->bfd_section == NULL)
2129 match_by_name = os;
d127ecce 2130 }
252b5132 2131
b5f14a6d
DD
2132 /* If we didn't match an active output section, see if we matched an
2133 unused one and use that. */
2134 if (match_by_name)
2135 {
b9c361e0 2136 lang_add_section (&match_by_name->children, s, NULL, match_by_name);
b5f14a6d
DD
2137 return match_by_name;
2138 }
2139
afd7a018
AM
2140 if (!orphan_init_done)
2141 {
2142 struct orphan_save *ho;
07890c07 2143
afd7a018
AM
2144 for (ho = hold; ho < hold + sizeof (hold) / sizeof (hold[0]); ++ho)
2145 if (ho->name != NULL)
2146 {
2147 ho->os = lang_output_section_find (ho->name);
2148 if (ho->os != NULL && ho->os->flags == 0)
2149 ho->os->flags = ho->flags;
2150 }
2151 orphan_init_done = 1;
2152 }
252b5132
RH
2153
2154 /* If this is a final link, then always put .gnu.warning.SYMBOL
2155 sections into the .text section to get them out of the way. */
0e1862bb 2156 if (bfd_link_executable (&link_info)
bcacc0f5 2157 && CONST_STRNEQ (s->name, ".gnu.warning.")
afd7a018 2158 && hold[orphan_text].os != NULL)
252b5132 2159 {
c2edb4b8 2160 os = hold[orphan_text].os;
b9c361e0 2161 lang_add_section (&os->children, s, NULL, os);
c2edb4b8 2162 return os;
252b5132
RH
2163 }
2164
077fcd6a
L
2165 flags = s->flags;
2166 if (!bfd_link_relocatable (&link_info))
2167 {
2168 nexts = s;
2169 while ((nexts = bfd_get_next_section_by_name (nexts->owner, nexts))
2170 != NULL)
2171 if (nexts->output_section == NULL
2172 && (nexts->flags & SEC_EXCLUDE) == 0
2173 && ((nexts->flags ^ flags) & (SEC_LOAD | SEC_ALLOC)) == 0
2174 && (nexts->owner->flags & DYNAMIC) == 0
2175 && nexts->owner->usrdata != NULL
2176 && !(((lang_input_statement_type *) nexts->owner->usrdata)
2177 ->flags.just_syms)
2178 && _bfd_elf_match_sections_by_type (nexts->owner, nexts,
2179 s->owner, s))
2180 flags = (((flags ^ SEC_READONLY)
2181 | (nexts->flags ^ SEC_READONLY))
2182 ^ SEC_READONLY);
2183 }
2184
252b5132
RH
2185 /* Decide which segment the section should go in based on the
2186 section name and section flags. We put loadable .note sections
2187 right after the .interp section, so that the PT_NOTE segment is
2188 stored right after the program headers where the OS can read it
2189 in the first page. */
aea4bd9d 2190
71bfc0ae 2191 place = NULL;
199af150 2192 if ((flags & (SEC_ALLOC | SEC_DEBUGGING)) == 0)
07890c07 2193 place = &hold[orphan_nonalloc];
199af150 2194 else if ((flags & SEC_ALLOC) == 0)
71bfc0ae 2195 ;
199af150 2196 else if ((flags & SEC_LOAD) != 0
ecca9871 2197 && ((iself && sh_type == SHT_NOTE)
0112cd26 2198 || (!iself && CONST_STRNEQ (secname, ".note"))))
afd7a018 2199 place = &hold[orphan_interp];
199af150 2200 else if ((flags & (SEC_LOAD | SEC_HAS_CONTENTS | SEC_THREAD_LOCAL)) == 0)
afd7a018 2201 place = &hold[orphan_bss];
199af150 2202 else if ((flags & SEC_SMALL_DATA) != 0)
afd7a018 2203 place = &hold[orphan_sdata];
199af150 2204 else if ((flags & SEC_THREAD_LOCAL) != 0)
d85e71fe 2205 place = &hold[orphan_tdata];
199af150 2206 else if ((flags & SEC_READONLY) == 0)
afd7a018 2207 place = &hold[orphan_data];
ecca9871 2208 else if (((iself && (sh_type == SHT_RELA || sh_type == SHT_REL))
0112cd26 2209 || (!iself && CONST_STRNEQ (secname, ".rel")))
199af150 2210 && (flags & SEC_LOAD) != 0)
afd7a018 2211 place = &hold[orphan_rel];
199af150 2212 else if ((flags & SEC_CODE) == 0)
afd7a018
AM
2213 place = &hold[orphan_rodata];
2214 else
2215 place = &hold[orphan_text];
71bfc0ae 2216
afd7a018 2217 after = NULL;
5ba47421 2218 if (place != NULL)
252b5132 2219 {
afd7a018 2220 if (place->os == NULL)
5ba47421 2221 {
afd7a018
AM
2222 if (place->name != NULL)
2223 place->os = lang_output_section_find (place->name);
2224 else
2225 place->os = output_rel_find (s, isdyn);
5ba47421 2226 }
afd7a018
AM
2227 after = place->os;
2228 if (after == NULL)
93638471
AM
2229 after
2230 = lang_output_section_find_by_flags (s, flags, &place->os,
2231 _bfd_elf_match_sections_by_type);
afd7a018
AM
2232 if (after == NULL)
2233 /* *ABS* is always the first output section statement. */
2234 after = &lang_output_section_statement.head->output_section_statement;
252b5132
RH
2235 }
2236
c2edb4b8 2237 return lang_insert_orphan (s, secname, constraint, after, place, NULL, NULL);
252b5132 2238}
c56feb2b
AM
2239EOF
2240fi
2241
eaeb0a9d 2242if test x"$LDEMUL_AFTER_ALLOCATION" != xgld"$EMULATION_NAME"_after_allocation; then
92b93329 2243fragment <<EOF
252b5132 2244
deb04cdb 2245static void
eaeb0a9d 2246gld${EMULATION_NAME}_after_allocation (void)
deb04cdb 2247{
75938853
AM
2248 int need_layout = bfd_elf_discard_info (link_info.output_bfd, &link_info);
2249
2250 if (need_layout < 0)
2251 einfo ("%X%P: .eh_frame/.stab edit: %E\n");
2252 else
2253 gld${EMULATION_NAME}_map_segments (need_layout);
73d074b4 2254}
41392f03
AM
2255EOF
2256fi
2257
2258if test x"$LDEMUL_GET_SCRIPT" != xgld"$EMULATION_NAME"_get_script; then
92b93329 2259fragment <<EOF
252b5132
RH
2260
2261static char *
0c7a8e5a 2262gld${EMULATION_NAME}_get_script (int *isfile)
252b5132
RH
2263EOF
2264
7225345d 2265if test x"$COMPILE_IN" = xyes
252b5132
RH
2266then
2267# Scripts compiled in.
2268
2269# sed commands to quote an ld script as a C string.
597e2591 2270sc="-f stringify.sed"
252b5132 2271
92b93329 2272fragment <<EOF
60bcf0fa 2273{
252b5132
RH
2274 *isfile = 0;
2275
0e1862bb 2276 if (bfd_link_relocatable (&link_info) && config.build_constructors)
597e2591 2277 return
252b5132 2278EOF
afd7a018 2279sed $sc ldscripts/${EMULATION_NAME}.xu >> e${EMULATION_NAME}.c
0e1862bb 2280echo ' ; else if (bfd_link_relocatable (&link_info)) return' >> e${EMULATION_NAME}.c
afd7a018
AM
2281sed $sc ldscripts/${EMULATION_NAME}.xr >> e${EMULATION_NAME}.c
2282echo ' ; else if (!config.text_read_only) return' >> e${EMULATION_NAME}.c
2283sed $sc ldscripts/${EMULATION_NAME}.xbn >> e${EMULATION_NAME}.c
61585df2 2284if cmp -s ldscripts/${EMULATION_NAME}.x ldscripts/${EMULATION_NAME}.xn; then : ; else
afd7a018
AM
2285echo ' ; else if (!config.magic_demand_paged) return' >> e${EMULATION_NAME}.c
2286sed $sc ldscripts/${EMULATION_NAME}.xn >> e${EMULATION_NAME}.c
db6751f2 2287fi
36af4a4e
JJ
2288if test -n "$GENERATE_PIE_SCRIPT" ; then
2289if test -n "$GENERATE_COMBRELOC_SCRIPT" ; then
0e1862bb
L
2290echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
2291echo ' && link_info.combreloc' >> e${EMULATION_NAME}.c
2292echo ' && link_info.relro' >> e${EMULATION_NAME}.c
fbfca19e 2293echo ' && (link_info.flags & DF_BIND_NOW)) return' >> e${EMULATION_NAME}.c
afd7a018 2294sed $sc ldscripts/${EMULATION_NAME}.xdw >> e${EMULATION_NAME}.c
0e1862bb
L
2295echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
2296echo ' && link_info.combreloc) return' >> e${EMULATION_NAME}.c
afd7a018 2297sed $sc ldscripts/${EMULATION_NAME}.xdc >> e${EMULATION_NAME}.c
36af4a4e 2298fi
0e1862bb 2299echo ' ; else if (bfd_link_pie (&link_info)) return' >> e${EMULATION_NAME}.c
afd7a018 2300sed $sc ldscripts/${EMULATION_NAME}.xd >> e${EMULATION_NAME}.c
36af4a4e 2301fi
252b5132 2302if test -n "$GENERATE_SHLIB_SCRIPT" ; then
82434356 2303if test -n "$GENERATE_COMBRELOC_SCRIPT" ; then
0e1862bb 2304echo ' ; else if (bfd_link_dll (&link_info) && link_info.combreloc' >> e${EMULATION_NAME}.c
8c37241b 2305echo ' && link_info.relro' >> e${EMULATION_NAME}.c
fbfca19e 2306echo ' && (link_info.flags & DF_BIND_NOW)) return' >> e${EMULATION_NAME}.c
afd7a018 2307sed $sc ldscripts/${EMULATION_NAME}.xsw >> e${EMULATION_NAME}.c
0e1862bb 2308echo ' ; else if (bfd_link_dll (&link_info) && link_info.combreloc) return' >> e${EMULATION_NAME}.c
afd7a018 2309sed $sc ldscripts/${EMULATION_NAME}.xsc >> e${EMULATION_NAME}.c
82434356 2310fi
0e1862bb 2311echo ' ; else if (bfd_link_dll (&link_info)) return' >> e${EMULATION_NAME}.c
afd7a018 2312sed $sc ldscripts/${EMULATION_NAME}.xs >> e${EMULATION_NAME}.c
252b5132 2313fi
82434356 2314if test -n "$GENERATE_COMBRELOC_SCRIPT" ; then
8c37241b 2315echo ' ; else if (link_info.combreloc && link_info.relro' >> e${EMULATION_NAME}.c
fbfca19e 2316echo ' && (link_info.flags & DF_BIND_NOW)) return' >> e${EMULATION_NAME}.c
afd7a018
AM
2317sed $sc ldscripts/${EMULATION_NAME}.xw >> e${EMULATION_NAME}.c
2318echo ' ; else if (link_info.combreloc) return' >> e${EMULATION_NAME}.c
2319sed $sc ldscripts/${EMULATION_NAME}.xc >> e${EMULATION_NAME}.c
82434356 2320fi
afd7a018
AM
2321echo ' ; else return' >> e${EMULATION_NAME}.c
2322sed $sc ldscripts/${EMULATION_NAME}.x >> e${EMULATION_NAME}.c
2323echo '; }' >> e${EMULATION_NAME}.c
252b5132
RH
2324
2325else
2326# Scripts read from the filesystem.
2327
92b93329 2328fragment <<EOF
60bcf0fa 2329{
252b5132
RH
2330 *isfile = 1;
2331
0e1862bb 2332 if (bfd_link_relocatable (&link_info) && config.build_constructors)
252b5132 2333 return "ldscripts/${EMULATION_NAME}.xu";
0e1862bb 2334 else if (bfd_link_relocatable (&link_info))
252b5132
RH
2335 return "ldscripts/${EMULATION_NAME}.xr";
2336 else if (!config.text_read_only)
2337 return "ldscripts/${EMULATION_NAME}.xbn";
a060b769
AM
2338EOF
2339if cmp -s ldscripts/${EMULATION_NAME}.x ldscripts/${EMULATION_NAME}.xn; then :
2340else
92b93329 2341fragment <<EOF
252b5132
RH
2342 else if (!config.magic_demand_paged)
2343 return "ldscripts/${EMULATION_NAME}.xn";
a060b769
AM
2344EOF
2345fi
36af4a4e
JJ
2346if test -n "$GENERATE_PIE_SCRIPT" ; then
2347if test -n "$GENERATE_COMBRELOC_SCRIPT" ; then
92b93329 2348fragment <<EOF
0e1862bb
L
2349 else if (bfd_link_pie (&link_info)
2350 && link_info.combreloc
2351 && link_info.relro
2352 && (link_info.flags & DF_BIND_NOW))
8c37241b 2353 return "ldscripts/${EMULATION_NAME}.xdw";
0e1862bb
L
2354 else if (bfd_link_pie (&link_info)
2355 && link_info.combreloc)
36af4a4e
JJ
2356 return "ldscripts/${EMULATION_NAME}.xdc";
2357EOF
2358fi
92b93329 2359fragment <<EOF
0e1862bb 2360 else if (bfd_link_pie (&link_info))
36af4a4e
JJ
2361 return "ldscripts/${EMULATION_NAME}.xd";
2362EOF
2363fi
a060b769
AM
2364if test -n "$GENERATE_SHLIB_SCRIPT" ; then
2365if test -n "$GENERATE_COMBRELOC_SCRIPT" ; then
92b93329 2366fragment <<EOF
0e1862bb 2367 else if (bfd_link_dll (&link_info) && link_info.combreloc
fbfca19e 2368 && link_info.relro && (link_info.flags & DF_BIND_NOW))
8c37241b 2369 return "ldscripts/${EMULATION_NAME}.xsw";
0e1862bb 2370 else if (bfd_link_dll (&link_info) && link_info.combreloc)
a060b769
AM
2371 return "ldscripts/${EMULATION_NAME}.xsc";
2372EOF
2373fi
92b93329 2374fragment <<EOF
0e1862bb 2375 else if (bfd_link_dll (&link_info))
252b5132 2376 return "ldscripts/${EMULATION_NAME}.xs";
a060b769
AM
2377EOF
2378fi
2379if test -n "$GENERATE_COMBRELOC_SCRIPT" ; then
92b93329 2380fragment <<EOF
8c37241b 2381 else if (link_info.combreloc && link_info.relro
fbfca19e 2382 && (link_info.flags & DF_BIND_NOW))
8c37241b 2383 return "ldscripts/${EMULATION_NAME}.xw";
a060b769
AM
2384 else if (link_info.combreloc)
2385 return "ldscripts/${EMULATION_NAME}.xc";
2386EOF
2387fi
92b93329 2388fragment <<EOF
252b5132
RH
2389 else
2390 return "ldscripts/${EMULATION_NAME}.x";
2391}
252b5132 2392
3b108066 2393EOF
41392f03
AM
2394fi
2395fi
3b108066 2396
e0ee487b 2397if test -n "$PARSE_AND_LIST_PROLOGUE" ; then
92b93329 2398fragment <<EOF
e0ee487b
L
2399 $PARSE_AND_LIST_PROLOGUE
2400EOF
2401fi
2402
92b93329 2403fragment <<EOF
e0ee487b 2404
29063f8b
NC
2405enum elf_options
2406{
2407 OPTION_DISABLE_NEW_DTAGS = 400,
2408 OPTION_ENABLE_NEW_DTAGS,
2409 OPTION_GROUP,
2410 OPTION_EH_FRAME_HDR,
2411 OPTION_NO_EH_FRAME_HDR,
2412 OPTION_EXCLUDE_LIBS,
2413 OPTION_HASH_STYLE,
2414 OPTION_BUILD_ID,
2415 OPTION_AUDIT,
2416 OPTION_COMPRESS_DEBUG
2417};
e13629bc 2418
3bcf5557 2419static void
0c7a8e5a
AM
2420gld${EMULATION_NAME}_add_options
2421 (int ns, char **shortopts, int nl, struct option **longopts,
2422 int nrl ATTRIBUTE_UNUSED, struct option **really_longopts ATTRIBUTE_UNUSED)
e0ee487b 2423{
fb42df5e
AM
2424EOF
2425if test x"$GENERATE_SHLIB_SCRIPT" = xyes; then
2426fragment <<EOF
7ee314fa 2427 static const char xtra_short[] = "${PARSE_AND_LIST_SHORTOPTS}z:P:";
fb42df5e
AM
2428EOF
2429else
2430fragment <<EOF
2431 static const char xtra_short[] = "${PARSE_AND_LIST_SHORTOPTS}z:";
2432EOF
2433fi
2434fragment <<EOF
3bcf5557 2435 static const struct option xtra_long[] = {
fb42df5e
AM
2436EOF
2437if test x"$GENERATE_SHLIB_SCRIPT" = xyes; then
2438fragment <<EOF
7ee314fa 2439 {"audit", required_argument, NULL, OPTION_AUDIT},
fb42df5e
AM
2440 {"Bgroup", no_argument, NULL, OPTION_GROUP},
2441EOF
2442fi
2443fragment <<EOF
2444 {"build-id", optional_argument, NULL, OPTION_BUILD_ID},
0ce398f1 2445 {"compress-debug-sections", required_argument, NULL, OPTION_COMPRESS_DEBUG},
e0ee487b 2446EOF
e0ee487b 2447if test x"$GENERATE_SHLIB_SCRIPT" = xyes; then
92b93329 2448fragment <<EOF
fb42df5e 2449 {"depaudit", required_argument, NULL, 'P'},
3bcf5557
AM
2450 {"disable-new-dtags", no_argument, NULL, OPTION_DISABLE_NEW_DTAGS},
2451 {"enable-new-dtags", no_argument, NULL, OPTION_ENABLE_NEW_DTAGS},
2452 {"eh-frame-hdr", no_argument, NULL, OPTION_EH_FRAME_HDR},
29063f8b 2453 {"no-eh-frame-hdr", no_argument, NULL, OPTION_NO_EH_FRAME_HDR},
b58f81ae 2454 {"exclude-libs", required_argument, NULL, OPTION_EXCLUDE_LIBS},
fdc90cb4 2455 {"hash-style", required_argument, NULL, OPTION_HASH_STYLE},
e0ee487b
L
2456EOF
2457fi
e0ee487b 2458if test -n "$PARSE_AND_LIST_LONGOPTS" ; then
92b93329 2459fragment <<EOF
3bcf5557 2460 $PARSE_AND_LIST_LONGOPTS
e0ee487b
L
2461EOF
2462fi
92b93329 2463fragment <<EOF
3bcf5557
AM
2464 {NULL, no_argument, NULL, 0}
2465 };
2466
2467 *shortopts = (char *) xrealloc (*shortopts, ns + sizeof (xtra_short));
2468 memcpy (*shortopts + ns, &xtra_short, sizeof (xtra_short));
2469 *longopts = (struct option *)
2470 xrealloc (*longopts, nl * sizeof (struct option) + sizeof (xtra_long));
2471 memcpy (*longopts + nl, &xtra_long, sizeof (xtra_long));
2472}
04925e1e 2473
24382dca 2474#define DEFAULT_BUILD_ID_STYLE "sha1"
c0065db7 2475
3bcf5557 2476static bfd_boolean
0c7a8e5a 2477gld${EMULATION_NAME}_handle_option (int optc)
e0ee487b 2478{
e0ee487b
L
2479 switch (optc)
2480 {
2481 default:
3bcf5557 2482 return FALSE;
6c1439be 2483
c0065db7 2484 case OPTION_BUILD_ID:
30e8ee25 2485 if (emit_note_gnu_build_id != NULL)
c0065db7 2486 {
30e8ee25
AM
2487 free ((char *) emit_note_gnu_build_id);
2488 emit_note_gnu_build_id = NULL;
c0065db7
RM
2489 }
2490 if (optarg == NULL)
2491 optarg = DEFAULT_BUILD_ID_STYLE;
2492 if (strcmp (optarg, "none"))
30e8ee25 2493 emit_note_gnu_build_id = xstrdup (optarg);
c0065db7 2494 break;
fb42df5e 2495
0ce398f1
L
2496 case OPTION_COMPRESS_DEBUG:
2497 if (strcasecmp (optarg, "none") == 0)
2498 link_info.compress_debug = COMPRESS_DEBUG_NONE;
2499 else if (strcasecmp (optarg, "zlib") == 0)
19a7fe52 2500 link_info.compress_debug = COMPRESS_DEBUG_GABI_ZLIB;
0ce398f1
L
2501 else if (strcasecmp (optarg, "zlib-gnu") == 0)
2502 link_info.compress_debug = COMPRESS_DEBUG_GNU_ZLIB;
2503 else if (strcasecmp (optarg, "zlib-gabi") == 0)
2504 link_info.compress_debug = COMPRESS_DEBUG_GABI_ZLIB;
2505 else
2506 einfo (_("%P%F: invalid --compress-debug-sections option: \`%s'\n"),
2507 optarg);
2508 break;
fb42df5e
AM
2509EOF
2510
2511if test x"$GENERATE_SHLIB_SCRIPT" = xyes; then
2512fragment <<EOF
7ee314fa 2513 case OPTION_AUDIT:
4724d37e 2514 gld${EMULATION_NAME}_append_to_separated_string (&audit, optarg);
7ee314fa 2515 break;
fb42df5e 2516
7ee314fa
AM
2517 case 'P':
2518 gld${EMULATION_NAME}_append_to_separated_string (&depaudit, optarg);
2519 break;
c0065db7 2520
6c1439be 2521 case OPTION_DISABLE_NEW_DTAGS:
b34976b6 2522 link_info.new_dtags = FALSE;
6c1439be
L
2523 break;
2524
2525 case OPTION_ENABLE_NEW_DTAGS:
b34976b6 2526 link_info.new_dtags = TRUE;
6c1439be
L
2527 break;
2528
65765700 2529 case OPTION_EH_FRAME_HDR:
2f0c68f2 2530 link_info.eh_frame_hdr_type = DWARF2_EH_HDR;
65765700
JJ
2531 break;
2532
29063f8b
NC
2533 case OPTION_NO_EH_FRAME_HDR:
2534 link_info.eh_frame_hdr_type = 0;
2535 break;
2536
a1ab1d2a
UD
2537 case OPTION_GROUP:
2538 link_info.flags_1 |= (bfd_vma) DF_1_GROUP;
2539 /* Groups must be self-contained. */
560e09e9
NC
2540 link_info.unresolved_syms_in_objects = RM_GENERATE_ERROR;
2541 link_info.unresolved_syms_in_shared_libs = RM_GENERATE_ERROR;
a1ab1d2a
UD
2542 break;
2543
b58f81ae
DJ
2544 case OPTION_EXCLUDE_LIBS:
2545 add_excluded_libs (optarg);
2546 break;
2547
fdc90cb4
JJ
2548 case OPTION_HASH_STYLE:
2549 link_info.emit_hash = FALSE;
2550 link_info.emit_gnu_hash = FALSE;
2551 if (strcmp (optarg, "sysv") == 0)
2552 link_info.emit_hash = TRUE;
2553 else if (strcmp (optarg, "gnu") == 0)
2554 link_info.emit_gnu_hash = TRUE;
2555 else if (strcmp (optarg, "both") == 0)
2556 {
2557 link_info.emit_hash = TRUE;
2558 link_info.emit_gnu_hash = TRUE;
2559 }
2560 else
2561 einfo (_("%P%F: invalid hash style \`%s'\n"), optarg);
2562 break;
2563
fb42df5e
AM
2564EOF
2565fi
2566fragment <<EOF
e0ee487b 2567 case 'z':
fb42df5e
AM
2568 if (strcmp (optarg, "defs") == 0)
2569 link_info.unresolved_syms_in_objects = RM_GENERATE_ERROR;
2570 else if (strcmp (optarg, "muldefs") == 0)
2571 link_info.allow_multiple_definition = TRUE;
2572 else if (CONST_STRNEQ (optarg, "max-page-size="))
2573 {
2574 char *end;
2575
2576 config.maxpagesize = strtoul (optarg + 14, &end, 0);
2577 if (*end || (config.maxpagesize & (config.maxpagesize - 1)) != 0)
2578 einfo (_("%P%F: invalid maxium page size \`%s'\n"),
2579 optarg + 14);
2580 }
2581 else if (CONST_STRNEQ (optarg, "common-page-size="))
2582 {
2583 char *end;
2584 config.commonpagesize = strtoul (optarg + 17, &end, 0);
2585 if (*end
2586 || (config.commonpagesize & (config.commonpagesize - 1)) != 0)
2587 einfo (_("%P%F: invalid common page size \`%s'\n"),
2588 optarg + 17);
2589 }
04c3a755
NS
2590 else if (CONST_STRNEQ (optarg, "stack-size="))
2591 {
2592 char *end;
2593 link_info.stacksize = strtoul (optarg + 11, &end, 0);
2594 if (*end || link_info.stacksize < 0)
2595 einfo (_("%P%F: invalid stack size \`%s'\n"), optarg + 11);
2596 if (!link_info.stacksize)
2597 /* Use -1 for explicit no-stack, because zero means
2598 'default'. */
2599 link_info.stacksize = -1;
2600 }
fb42df5e
AM
2601 else if (strcmp (optarg, "execstack") == 0)
2602 {
2603 link_info.execstack = TRUE;
2604 link_info.noexecstack = FALSE;
2605 }
2606 else if (strcmp (optarg, "noexecstack") == 0)
2607 {
2608 link_info.noexecstack = TRUE;
2609 link_info.execstack = FALSE;
2610 }
2611EOF
d258b828 2612
fb42df5e
AM
2613if test x"$GENERATE_SHLIB_SCRIPT" = xyes; then
2614fragment <<EOF
b039ef04
L
2615 else if (strcmp (optarg, "global") == 0)
2616 link_info.flags_1 |= (bfd_vma) DF_1_GLOBAL;
fb42df5e 2617 else if (strcmp (optarg, "initfirst") == 0)
e0ee487b
L
2618 link_info.flags_1 |= (bfd_vma) DF_1_INITFIRST;
2619 else if (strcmp (optarg, "interpose") == 0)
2620 link_info.flags_1 |= (bfd_vma) DF_1_INTERPOSE;
2621 else if (strcmp (optarg, "loadfltr") == 0)
2622 link_info.flags_1 |= (bfd_vma) DF_1_LOADFLTR;
2623 else if (strcmp (optarg, "nodefaultlib") == 0)
2624 link_info.flags_1 |= (bfd_vma) DF_1_NODEFLIB;
2625 else if (strcmp (optarg, "nodelete") == 0)
2626 link_info.flags_1 |= (bfd_vma) DF_1_NODELETE;
2627 else if (strcmp (optarg, "nodlopen") == 0)
2628 link_info.flags_1 |= (bfd_vma) DF_1_NOOPEN;
2629 else if (strcmp (optarg, "nodump") == 0)
2630 link_info.flags_1 |= (bfd_vma) DF_1_NODUMP;
2631 else if (strcmp (optarg, "now") == 0)
2632 {
2633 link_info.flags |= (bfd_vma) DF_BIND_NOW;
2634 link_info.flags_1 |= (bfd_vma) DF_1_NOW;
2635 }
5fa222e4
AM
2636 else if (strcmp (optarg, "lazy") == 0)
2637 {
2638 link_info.flags &= ~(bfd_vma) DF_BIND_NOW;
2639 link_info.flags_1 &= ~(bfd_vma) DF_1_NOW;
2640 }
e0ee487b
L
2641 else if (strcmp (optarg, "origin") == 0)
2642 {
2643 link_info.flags |= (bfd_vma) DF_ORIGIN;
2644 link_info.flags_1 |= (bfd_vma) DF_1_ORIGIN;
2645 }
db6751f2 2646 else if (strcmp (optarg, "combreloc") == 0)
b34976b6 2647 link_info.combreloc = TRUE;
db6751f2 2648 else if (strcmp (optarg, "nocombreloc") == 0)
b34976b6 2649 link_info.combreloc = FALSE;
8bd621d8 2650 else if (strcmp (optarg, "nocopyreloc") == 0)
0c7a8e5a 2651 link_info.nocopyreloc = TRUE;
8c37241b
JJ
2652 else if (strcmp (optarg, "relro") == 0)
2653 link_info.relro = TRUE;
2654 else if (strcmp (optarg, "norelro") == 0)
2655 link_info.relro = FALSE;
b8871f35
L
2656 else if (strcmp (optarg, "common") == 0)
2657 link_info.elf_stt_common = elf_stt_common;
2658 else if (strcmp (optarg, "nocommon") == 0)
2659 link_info.elf_stt_common = no_elf_stt_common;
c192a133
AM
2660 else if (strcmp (optarg, "text") == 0)
2661 link_info.error_textrel = TRUE;
2662 else if (strcmp (optarg, "notext") == 0)
2663 link_info.error_textrel = FALSE;
2664 else if (strcmp (optarg, "textoff") == 0)
2665 link_info.error_textrel = FALSE;
88b882e9 2666EOF
fb42df5e 2667fi
88b882e9 2668
eba27bd7
L
2669if test -n "$PARSE_AND_LIST_ARGS_CASE_Z" ; then
2670fragment <<EOF
2671 $PARSE_AND_LIST_ARGS_CASE_Z
2672EOF
2673fi
2674
92b93329 2675fragment <<EOF
fb42df5e
AM
2676 else
2677 einfo (_("%P: warning: -z %s ignored.\n"), optarg);
6c1439be 2678 break;
e0ee487b 2679EOF
e0ee487b
L
2680
2681if test -n "$PARSE_AND_LIST_ARGS_CASES" ; then
92b93329 2682fragment <<EOF
e0ee487b
L
2683 $PARSE_AND_LIST_ARGS_CASES
2684EOF
2685fi
2686
92b93329 2687fragment <<EOF
e0ee487b
L
2688 }
2689
3bcf5557 2690 return TRUE;
e0ee487b
L
2691}
2692
41392f03 2693EOF
41392f03 2694
4b209b22 2695if test x"$LDEMUL_LIST_OPTIONS" != xgld"$EMULATION_NAME"_list_options; then
c58212ea 2696gld_list_options="gld${EMULATION_NAME}_list_options"
eba27bd7 2697if test -n "$PARSE_AND_LIST_OPTIONS"; then
92b93329 2698fragment <<EOF
41392f03 2699
e0ee487b 2700static void
0c7a8e5a 2701gld${EMULATION_NAME}_list_options (FILE * file)
e0ee487b 2702{
fb42df5e 2703EOF
e0ee487b
L
2704
2705if test -n "$PARSE_AND_LIST_OPTIONS" ; then
92b93329 2706fragment <<EOF
e0ee487b
L
2707 $PARSE_AND_LIST_OPTIONS
2708EOF
2709fi
2710
92b93329 2711fragment <<EOF
e0ee487b
L
2712}
2713EOF
c58212ea
L
2714else
2715 gld_list_options="NULL"
2716fi
e0ee487b
L
2717
2718if test -n "$PARSE_AND_LIST_EPILOGUE" ; then
92b93329 2719fragment <<EOF
e0ee487b
L
2720 $PARSE_AND_LIST_EPILOGUE
2721EOF
2722fi
41392f03 2723fi
e0ee487b 2724
92b93329 2725fragment <<EOF
252b5132 2726
60bcf0fa 2727struct ld_emulation_xfer_struct ld_${EMULATION_NAME}_emulation =
252b5132 2728{
41392f03
AM
2729 ${LDEMUL_BEFORE_PARSE-gld${EMULATION_NAME}_before_parse},
2730 ${LDEMUL_SYSLIB-syslib_default},
2731 ${LDEMUL_HLL-hll_default},
5fe2850d 2732 ${LDEMUL_AFTER_PARSE-gld${EMULATION_NAME}_after_parse},
41392f03 2733 ${LDEMUL_AFTER_OPEN-gld${EMULATION_NAME}_after_open},
eaeb0a9d 2734 ${LDEMUL_AFTER_ALLOCATION-gld${EMULATION_NAME}_after_allocation},
41392f03
AM
2735 ${LDEMUL_SET_OUTPUT_ARCH-set_output_arch_default},
2736 ${LDEMUL_CHOOSE_TARGET-ldemul_default_target},
2737 ${LDEMUL_BEFORE_ALLOCATION-gld${EMULATION_NAME}_before_allocation},
2738 ${LDEMUL_GET_SCRIPT-gld${EMULATION_NAME}_get_script},
252b5132
RH
2739 "${EMULATION_NAME}",
2740 "${OUTPUT_FORMAT}",
eaeb0a9d 2741 ${LDEMUL_FINISH-finish_default},
41392f03
AM
2742 ${LDEMUL_CREATE_OUTPUT_SECTION_STATEMENTS-NULL},
2743 ${LDEMUL_OPEN_DYNAMIC_ARCHIVE-gld${EMULATION_NAME}_open_dynamic_archive},
2744 ${LDEMUL_PLACE_ORPHAN-gld${EMULATION_NAME}_place_orphan},
2745 ${LDEMUL_SET_SYMBOLS-NULL},
3bcf5557
AM
2746 ${LDEMUL_PARSE_ARGS-NULL},
2747 gld${EMULATION_NAME}_add_options,
2748 gld${EMULATION_NAME}_handle_option,
41392f03 2749 ${LDEMUL_UNRECOGNIZED_FILE-NULL},
c58212ea 2750 ${LDEMUL_LIST_OPTIONS-${gld_list_options}},
4a43e768 2751 ${LDEMUL_RECOGNIZED_FILE-gld${EMULATION_NAME}_load_symbols},
41392f03 2752 ${LDEMUL_FIND_POTENTIAL_LIBRARIES-NULL},
7a2f2d82
DD
2753 ${LDEMUL_NEW_VERS_PATTERN-NULL},
2754 ${LDEMUL_EXTRA_MAP_FILE_TEXT-NULL}
252b5132
RH
2755};
2756EOF
This page took 0.934323 seconds and 4 git commands to generate.