]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - bfd/elf-bfd.h
Avoid testcase build failures with -Wunused-value
[thirdparty/binutils-gdb.git] / bfd / elf-bfd.h
CommitLineData
252b5132 1/* BFD back-end data structures for ELF files.
b3adc24a 2 Copyright (C) 1992-2020 Free Software Foundation, Inc.
252b5132
RH
3 Written by Cygnus Support.
4
5e8d7549 5 This file is part of BFD, the Binary File Descriptor library.
252b5132 6
5e8d7549
NC
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
cd123cb7 9 the Free Software Foundation; either version 3 of the License, or
5e8d7549 10 (at your option) any later version.
252b5132 11
5e8d7549
NC
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
252b5132 16
5e8d7549
NC
17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software
cd123cb7
NC
19 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
20 MA 02110-1301, USA. */
252b5132
RH
21
22#ifndef _LIBELF_H_
23#define _LIBELF_H_ 1
24
25#include "elf/common.h"
252b5132 26#include "elf/external.h"
4fbb74a6 27#include "elf/internal.h"
252b5132
RH
28#include "bfdlink.h"
29
55172d69
PA
30#ifdef __cplusplus
31extern "C" {
32#endif
33
d9bc7a44 34/* The number of entries in a section is its size divided by the size
51b64d56 35 of a single entry. This is normally only applicable to reloc and
ce98a316
NC
36 symbol table sections.
37 PR 9934: It is possible to have relocations that do not refer to
38 symbols, thus it is also possible to have a relocation section in
39 an object file, but no symbol table. */
40#define NUM_SHDR_ENTRIES(shdr) ((shdr)->sh_entsize > 0 ? (shdr)->sh_size / (shdr)->sh_entsize : 0)
d9bc7a44 41
252b5132
RH
42/* If size isn't specified as 64 or 32, NAME macro should fail. */
43#ifndef NAME
c39a58e6
AM
44#if ARCH_SIZE == 64
45#define NAME(x, y) x ## 64 ## _ ## y
252b5132 46#endif
c39a58e6
AM
47#if ARCH_SIZE == 32
48#define NAME(x, y) x ## 32 ## _ ## y
252b5132
RH
49#endif
50#endif
51
52#ifndef NAME
c39a58e6 53#define NAME(x, y) x ## NOSIZE ## _ ## y
252b5132
RH
54#endif
55
56#define ElfNAME(X) NAME(Elf,X)
57#define elfNAME(X) NAME(elf,X)
58
59/* Information held for an ELF symbol. The first field is the
60 corresponding asymbol. Every symbol is an ELF file is actually a
61 pointer to this structure, although it is often handled as a
62 pointer to an asymbol. */
63
64typedef struct
65{
66 /* The BFD symbol. */
67 asymbol symbol;
68 /* ELF symbol information. */
69 Elf_Internal_Sym internal_elf_sym;
70 /* Backend specific information. */
71 union
72 {
73 unsigned int hppa_arg_reloc;
c39a58e6
AM
74 void *mips_extr;
75 void *any;
252b5132
RH
76 }
77 tc_data;
78
79 /* Version information. This is from an Elf_Internal_Versym
80 structure in a SHT_GNU_versym section. It is zero if there is no
81 version information. */
82 unsigned short version;
83
84} elf_symbol_type;
85\f
2b0f7ef9 86struct elf_strtab_hash;
5cab59f6
AM
87struct got_entry;
88struct plt_entry;
2b0f7ef9 89
a50b1753
NC
90union gotplt_union
91 {
92 bfd_signed_vma refcount;
93 bfd_vma offset;
94 struct got_entry *glist;
95 struct plt_entry *plist;
96 };
97
98struct elf_link_virtual_table_entry
99 {
100 /* Virtual table entry use information. This array is nominally of size
101 size/sizeof(target_void_pointer), though we have to be able to assume
102 and track a size while the symbol is still undefined. It is indexed
103 via offset/sizeof(target_void_pointer). */
104 size_t size;
105 bfd_boolean *used;
106
107 /* Virtual table derivation info. */
108 struct elf_link_hash_entry *parent;
109 };
110
422f1182
L
111/* ELF symbol version. */
112enum elf_symbol_version
113 {
114 unknown = 0,
115 unversioned,
116 versioned,
117 versioned_hidden
118 };
119
252b5132
RH
120/* ELF linker hash table entries. */
121
122struct elf_link_hash_entry
123{
124 struct bfd_link_hash_entry root;
125
126 /* Symbol index in output file. This is initialized to -1. It is
97196564
L
127 set to -2 if the symbol is used by a reloc. It is set to -3 if
128 this symbol is defined in a discarded section. */
252b5132
RH
129 long indx;
130
252b5132
RH
131 /* Symbol index as a dynamic symbol. Initialized to -1, and remains
132 -1 if this is not a dynamic symbol. */
30b30c21
RH
133 /* ??? Note that this is consistently used as a synonym for tests
134 against whether we can perform various simplifying transformations
135 to the code. (E.g. changing a pc-relative jump to a PLT entry
136 into a pc-relative jump to the target function.) That test, which
137 is often relatively complex, and someplaces wrong or incomplete,
138 should really be replaced by a predicate in elflink.c.
139
140 End result: this field -1 does not indicate that the symbol is
141 not in the dynamic symbol table, but rather that the symbol is
142 not visible outside this DSO. */
252b5132
RH
143 long dynindx;
144
a90b9fca
AM
145 /* If this symbol requires an entry in the global offset table, the
146 processor specific backend uses this field to track usage and
5cab59f6
AM
147 final offset. Two schemes are supported: The first assumes that
148 a symbol may only have one GOT entry, and uses REFCOUNT until
149 size_dynamic_sections, at which point the contents of the .got is
150 fixed. Afterward, if OFFSET is -1, then the symbol does not
151 require a global offset table entry. The second scheme allows
152 multiple GOT entries per symbol, managed via a linked list
153 pointed to by GLIST. */
a50b1753 154 union gotplt_union got;
a90b9fca
AM
155
156 /* Same, but tracks a procedure linkage table entry. */
5cab59f6 157 union gotplt_union plt;
a90b9fca 158
190eb1dd
L
159 /* Symbol size. NB: All fields starting from here are cleared by
160 _bfd_elf_link_hash_newfunc. */
a90b9fca
AM
161 bfd_size_type size;
162
190eb1dd
L
163 /* Track dynamic relocs copied for this symbol. */
164 struct elf_dyn_relocs *dyn_relocs;
165
252b5132 166 /* Symbol type (STT_NOTYPE, STT_OBJECT, etc.). */
f5385ebf 167 unsigned int type : 8;
252b5132 168
9b234ee9 169 /* Symbol st_other value, symbol visibility. */
f5385ebf 170 unsigned int other : 8;
252b5132 171
35fc36a8
RS
172 /* The symbol's st_target_internal value (see Elf_Internal_Sym). */
173 unsigned int target_internal : 8;
174
7ae26bc1
AM
175 /* Symbol is referenced by a non-shared object (other than the object
176 in which it is defined). */
f5385ebf 177 unsigned int ref_regular : 1;
252b5132 178 /* Symbol is defined by a non-shared object. */
f5385ebf 179 unsigned int def_regular : 1;
252b5132 180 /* Symbol is referenced by a shared object. */
f5385ebf 181 unsigned int ref_dynamic : 1;
252b5132 182 /* Symbol is defined by a shared object. */
f5385ebf 183 unsigned int def_dynamic : 1;
7ae26bc1
AM
184 /* Symbol has a non-weak reference from a non-shared object (other than
185 the object in which it is defined). */
f5385ebf 186 unsigned int ref_regular_nonweak : 1;
252b5132 187 /* Dynamic symbol has been adjustd. */
f5385ebf 188 unsigned int dynamic_adjusted : 1;
252b5132 189 /* Symbol needs a copy reloc. */
f5385ebf 190 unsigned int needs_copy : 1;
252b5132 191 /* Symbol needs a procedure linkage table entry. */
f5385ebf 192 unsigned int needs_plt : 1;
252b5132 193 /* Symbol appears in a non-ELF input file. */
f5385ebf 194 unsigned int non_elf : 1;
422f1182
L
195 /* Symbol version information. */
196 ENUM_BITFIELD (elf_symbol_version) versioned : 2;
252b5132 197 /* Symbol was forced to local scope due to a version script file. */
f5385ebf 198 unsigned int forced_local : 1;
55255dae
L
199 /* Symbol was forced to be dynamic due to a version script file. */
200 unsigned int dynamic : 1;
252b5132 201 /* Symbol was marked during garbage collection. */
f5385ebf 202 unsigned int mark : 1;
7843f00e
ILT
203 /* Symbol is referenced by a non-GOT/non-PLT relocation. This is
204 not currently set by all the backends. */
f5385ebf 205 unsigned int non_got_ref : 1;
f6e332e6
AM
206 /* Symbol has a definition in a shared object.
207 FIXME: There is no real need for this field if def_dynamic is never
208 cleared and all places that test def_dynamic also test def_regular. */
f5385ebf 209 unsigned int dynamic_def : 1;
ee659f1f
AM
210 /* Symbol has a non-weak reference from a shared object. */
211 unsigned int ref_dynamic_nonweak : 1;
c6585bbb
JJ
212 /* Symbol is referenced with a relocation where C/C++ pointer equality
213 matters. */
f5385ebf 214 unsigned int pointer_equality_needed : 1;
3e7a7d11
NC
215 /* Symbol is a unique global symbol. */
216 unsigned int unique_global : 1;
b8417128
AM
217 /* Symbol is defined by a shared library with non-default visibility
218 in a read/write section. */
6cabe1ea 219 unsigned int protected_def : 1;
cbd0eecf
L
220 /* Symbol is __start_SECNAME or __stop_SECNAME to mark section
221 SECNAME. */
222 unsigned int start_stop : 1;
60d67dc8
AM
223 /* Symbol is or was a weak defined symbol from a dynamic object with
224 a strong defined symbol alias. U.ALIAS points to a list of aliases,
225 the definition having is_weakalias clear. */
226 unsigned int is_weakalias : 1;
f6e332e6
AM
227
228 /* String table index in .dynstr if this is a dynamic symbol. */
229 unsigned long dynstr_index;
230
231 union
232 {
60d67dc8
AM
233 /* Points to a circular list of non-function symbol aliases. */
234 struct elf_link_hash_entry *alias;
f6e332e6
AM
235
236 /* Hash value of the name computed using the ELF hash function.
237 Used part way through size_dynamic_sections, after we've finished
60d67dc8 238 with aliases. */
f6e332e6
AM
239 unsigned long elf_hash_value;
240 } u;
241
242 /* Version information. */
243 union
244 {
245 /* This field is used for a symbol which is not defined in a
246 regular object. It points to the version information read in
247 from the dynamic object. */
248 Elf_Internal_Verdef *verdef;
249 /* This field is used for a symbol which is defined in a regular
250 object. It is set up in size_dynamic_sections. It points to
251 the version information we should write out for this symbol. */
252 struct bfd_elf_version_tree *vertree;
253 } verinfo;
254
cbd0eecf
L
255 union
256 {
257 /* For __start_SECNAME and __stop_SECNAME symbols, record the first
258 input section whose section name is SECNAME. */
259 asection *start_stop_section;
260
261 /* Vtable information. */
262 struct elf_link_virtual_table_entry *vtable;
263 } u2;
252b5132
RH
264};
265
60d67dc8
AM
266/* Return the strong definition for a weak symbol with aliases. */
267
268static inline struct elf_link_hash_entry *
269weakdef (struct elf_link_hash_entry *h)
270{
271 while (h->is_weakalias)
272 h = h->u.alias;
273 return h;
274}
275
586119b3 276/* Will references to this symbol always reference the symbol
2676a7d9 277 in this object? */
986a241f 278#define SYMBOL_REFERENCES_LOCAL(INFO, H) \
f6c52c13 279 _bfd_elf_symbol_refs_local_p (H, INFO, 0)
586119b3
AM
280
281/* Will _calls_ to this symbol always call the version in this object? */
986a241f 282#define SYMBOL_CALLS_LOCAL(INFO, H) \
f6c52c13 283 _bfd_elf_symbol_refs_local_p (H, INFO, 1)
586119b3 284
62cd30f1
L
285/* Whether an undefined weak symbol should resolve to its link-time
286 value, even in PIC or PIE objects. */
287#define UNDEFWEAK_NO_DYNAMIC_RELOC(INFO, H) \
288 ((H)->root.type == bfd_link_hash_undefweak \
289 && (ELF_ST_VISIBILITY ((H)->other) != STV_DEFAULT \
290 || (INFO)->dynamic_undefined_weak == 0))
291
7e2294f9 292/* Common symbols that are turned into definitions don't have the
c4621b33
AM
293 DEF_REGULAR flag set, so they might appear to be undefined.
294 Symbols defined in linker scripts also don't have DEF_REGULAR set. */
7e2294f9 295#define ELF_COMMON_DEF_P(H) \
f5385ebf
AM
296 (!(H)->def_regular \
297 && !(H)->def_dynamic \
7e2294f9
AO
298 && (H)->root.type == bfd_link_hash_defined)
299
30b30c21
RH
300/* Records local symbols to be emitted in the dynamic symbol table. */
301
302struct elf_link_local_dynamic_entry
303{
304 struct elf_link_local_dynamic_entry *next;
305
306 /* The input bfd this symbol came from. */
307 bfd *input_bfd;
308
309 /* The index of the local symbol being copied. */
310 long input_indx;
311
312 /* The index in the outgoing dynamic symbol table. */
313 long dynindx;
3e932841 314
30b30c21
RH
315 /* A copy of the input symbol. */
316 Elf_Internal_Sym isym;
317};
318
f5d44ba0
AM
319struct elf_link_loaded_list
320{
321 struct elf_link_loaded_list *next;
322 bfd *abfd;
323};
324
126495ed 325/* Structures used by the eh_frame optimization code. */
126495ed
AM
326struct eh_cie_fde
327{
155eaaa0
RS
328 union {
329 struct {
ca92cecb
RS
330 /* If REMOVED == 1, this is the CIE that the FDE originally used.
331 The CIE belongs to the same .eh_frame input section as the FDE.
332
333 If REMOVED == 0, this is the CIE that we have chosen to use for
334 the output FDE. The CIE's REMOVED field is also 0, but the CIE
c2aaac08
AM
335 might belong to a different .eh_frame input section from the FDE.
336
337 May be NULL to signify that the FDE should be discarded. */
155eaaa0 338 struct eh_cie_fde *cie_inf;
9d0a14d3 339 struct eh_cie_fde *next_for_section;
155eaaa0 340 } fde;
ca92cecb 341 struct {
184d07da 342 /* CIEs have three states:
fc802241 343
184d07da
RS
344 - REMOVED && !MERGED: Slated for removal because we haven't yet
345 proven that an FDE needs it. FULL_CIE, if nonnull, points to
346 more detailed information about the CIE.
fc802241 347
184d07da
RS
348 - REMOVED && MERGED: We have merged this CIE with MERGED_WITH,
349 which may not belong to the same input section.
350
351 - !REMOVED: We have decided to keep this CIE. SEC is the
352 .eh_frame input section that contains the CIE. */
fc802241 353 union {
184d07da 354 struct cie *full_cie;
07d6d2b8
AM
355 struct eh_cie_fde *merged_with;
356 asection *sec;
fc802241 357 } u;
9d0a14d3 358
18e04883
RS
359 /* The offset of the personality data from the start of the CIE,
360 or 0 if the CIE doesn't have any. */
361 unsigned int personality_offset : 8;
362
d7153c4a
AM
363 /* Length of augmentation. aug_str_len is the length of the
364 string including null terminator. aug_data_len is the length
365 of the rest up to the initial insns. */
366 unsigned int aug_str_len : 3;
367 unsigned int aug_data_len : 5;
368
9d0a14d3
RS
369 /* True if we have marked relocations associated with this CIE. */
370 unsigned int gc_mark : 1;
9f4b847e
RS
371
372 /* True if we have decided to turn an absolute LSDA encoding into
184d07da 373 a PC-relative one. */
9f4b847e 374 unsigned int make_lsda_relative : 1;
6b2cc140 375
18e04883
RS
376 /* True if we have decided to turn an absolute personality
377 encoding into a PC-relative one. */
378 unsigned int make_per_encoding_relative : 1;
379
380 /* True if the CIE contains personality data and if that
381 data uses a PC-relative encoding. Always true when
382 make_per_encoding_relative is. */
6b2cc140
RS
383 unsigned int per_encoding_relative : 1;
384
2e0ce1c8
AM
385 /* True if the CIE contains personality data aligned to a
386 multiple of eight bytes. */
387 unsigned int per_encoding_aligned8 : 1;
388
6b2cc140
RS
389 /* True if we need to add an 'R' (FDE encoding) entry to the
390 CIE's augmentation data. */
391 unsigned int add_fde_encoding : 1;
184d07da
RS
392
393 /* True if we have merged this CIE with another. */
394 unsigned int merged : 1;
18e04883
RS
395
396 /* Unused bits. */
d7153c4a 397 unsigned int pad1 : 9;
ca92cecb 398 } cie;
155eaaa0
RS
399 } u;
400 unsigned int reloc_index;
126495ed 401 unsigned int size;
fda3ecf2 402 unsigned int offset;
126495ed 403 unsigned int new_offset;
155eaaa0
RS
404 unsigned int fde_encoding : 8;
405 unsigned int lsda_encoding : 8;
406 unsigned int lsda_offset : 8;
6b2cc140
RS
407
408 /* True if this entry represents a CIE, false if it represents an FDE. */
822392ce 409 unsigned int cie : 1;
6b2cc140
RS
410
411 /* True if this entry is currently marked for removal. */
822392ce 412 unsigned int removed : 1;
6b2cc140
RS
413
414 /* True if we need to add a 'z' (augmentation size) entry to the CIE's
415 augmentation data, and an associated byte to each of the CIE's FDEs. */
353057a5 416 unsigned int add_augmentation_size : 1;
6b2cc140
RS
417
418 /* True if we have decided to convert absolute FDE relocations into
419 relative ones. This applies to the first relocation in the FDE,
420 which is against the code that the FDE describes. */
822392ce 421 unsigned int make_relative : 1;
6b2cc140
RS
422
423 /* Unused bits. */
424 unsigned int pad1 : 4;
425
ac685e6a 426 unsigned int *set_loc;
126495ed
AM
427};
428
429struct eh_frame_sec_info
430{
431 unsigned int count;
184d07da 432 struct cie *cies;
126495ed
AM
433 struct eh_cie_fde entry[1];
434};
435
436struct eh_frame_array_ent
437{
438 bfd_vma initial_loc;
ae6c7e33 439 bfd_size_type range;
126495ed
AM
440 bfd_vma fde;
441};
442
bce613b9
JJ
443struct htab;
444
2f0c68f2
CM
445#define DWARF2_EH_HDR 1
446#define COMPACT_EH_HDR 2
447
448/* Endian-neutral code indicating that a function cannot be unwound. */
449#define COMPACT_EH_CANT_UNWIND_OPCODE 0x015d5d01
450
451struct dwarf_eh_frame_hdr_info
126495ed 452{
bce613b9 453 struct htab *cies;
2f0c68f2 454 unsigned int fde_count;
126495ed
AM
455 /* TRUE if .eh_frame_hdr should contain the sorted search table.
456 We build it if we successfully read all .eh_frame input sections
457 and recognize them. */
b34976b6 458 bfd_boolean table;
2f0c68f2
CM
459 struct eh_frame_array_ent *array;
460};
461
462struct compact_eh_frame_hdr_info
463{
464 unsigned int allocated_entries;
465 /* eh_frame_entry fragments. */
466 asection **entries;
467};
468
469struct eh_frame_hdr_info
470{
471 asection *hdr_sec;
472 unsigned int array_count;
473 bfd_boolean frame_hdr_is_compact;
474 union
475 {
476 struct dwarf_eh_frame_hdr_info dwarf;
477 struct compact_eh_frame_hdr_info compact;
478 }
479 u;
126495ed
AM
480};
481
4dfe6ac6
NC
482/* Enum used to identify target specific extensions to the elf_obj_tdata
483 and elf_link_hash_table structures. Note the enums deliberately start
484 from 1 so that we can detect an uninitialized field. The generic value
485 is last so that additions to this enum do not need to modify more than
486 one line. */
487enum elf_target_id
488{
a06ea964
NC
489 AARCH64_ELF_DATA = 1,
490 ALPHA_ELF_DATA,
8a36df4d 491 ARC_ELF_DATA,
4dfe6ac6
NC
492 ARM_ELF_DATA,
493 AVR_ELF_DATA,
494 BFIN_ELF_DATA,
495 CRIS_ELF_DATA,
b8891f8d 496 CSKY_ELF_DATA,
4dfe6ac6
NC
497 FRV_ELF_DATA,
498 HPPA32_ELF_DATA,
499 HPPA64_ELF_DATA,
500 I386_ELF_DATA,
501 IA64_ELF_DATA,
502 LM32_ELF_DATA,
503 M32R_ELF_DATA,
504 M68HC11_ELF_DATA,
505 M68K_ELF_DATA,
a3c62988 506 METAG_ELF_DATA,
4dfe6ac6
NC
507 MICROBLAZE_ELF_DATA,
508 MIPS_ELF_DATA,
509 MN10300_ELF_DATA,
35c08157 510 NDS32_ELF_DATA,
36591ba1 511 NIOS2_ELF_DATA,
73589c9d 512 OR1K_ELF_DATA,
4dfe6ac6
NC
513 PPC32_ELF_DATA,
514 PPC64_ELF_DATA,
889294f6 515 PRU_ELF_DATA,
4dfe6ac6
NC
516 S390_ELF_DATA,
517 SH_ELF_DATA,
518 SPARC_ELF_DATA,
519 SPU_ELF_DATA,
41820509 520 TIC6X_ELF_DATA,
4dfe6ac6
NC
521 X86_64_ELF_DATA,
522 XTENSA_ELF_DATA,
aa137e4d
NC
523 TILEGX_ELF_DATA,
524 TILEPRO_ELF_DATA,
e23eba97 525 RISCV_ELF_DATA,
4dfe6ac6
NC
526 GENERIC_ELF_DATA
527};
528
ef10c3ac
L
529struct elf_sym_strtab
530{
531 Elf_Internal_Sym sym;
532 unsigned long dest_index;
533 unsigned long destshndx_index;
534};
535
0b4453c7
AM
536struct bfd_link_needed_list
537{
538 struct bfd_link_needed_list *next;
539 bfd *by;
540 const char *name;
541};
542
90c14f0c
L
543enum elf_target_os
544{
545 is_normal,
546 is_symbian, /* Symbian OS. */
547 is_solaris, /* Solaris. */
548 is_vxworks, /* VxWorks. */
549 is_nacl /* Native Client. */
550};
551
252b5132
RH
552/* ELF linker hash table. */
553
554struct elf_link_hash_table
555{
556 struct bfd_link_hash_table root;
51b64d56 557
4dfe6ac6
NC
558 /* An identifier used to distinguish different target
559 specific extensions to this structure. */
560 enum elf_target_id hash_table_id;
561
252b5132
RH
562 /* Whether we have created the special dynamic sections required
563 when linking against or generating a shared object. */
b34976b6 564 bfd_boolean dynamic_sections_created;
51b64d56 565
7f923b7f
AM
566 /* Whether dynamic relocations are present. */
567 bfd_boolean dynamic_relocs;
568
74541ad4
AM
569 /* True if this target has relocatable executables, so needs dynamic
570 section symbols. */
571 bfd_boolean is_relocatable_executable;
572
cebd6b8a
L
573 /* TRUE if there are IFUNC resolvers. */
574 bfd_boolean ifunc_resolvers;
575
252b5132
RH
576 /* The BFD used to hold special sections created by the linker.
577 This will be the first BFD found which requires these sections to
578 be created. */
579 bfd *dynobj;
51b64d56
AM
580
581 /* The value to use when initialising got.refcount/offset and
582 plt.refcount/offset in an elf_link_hash_entry. Set to zero when
a6aa5195
AM
583 the values are refcounts. Set to init_got_offset/init_plt_offset
584 in size_dynamic_sections when the values may be offsets. */
585 union gotplt_union init_got_refcount;
586 union gotplt_union init_plt_refcount;
5cab59f6
AM
587
588 /* The value to use for got.refcount/offset and plt.refcount/offset
589 when the values may be offsets. Normally (bfd_vma) -1. */
a6aa5195
AM
590 union gotplt_union init_got_offset;
591 union gotplt_union init_plt_offset;
51b64d56 592
d5486c43
L
593 /* The number of symbols found in the link which is intended for the
594 mandatory DT_SYMTAB tag (.dynsym section) in .dynamic section. */
252b5132 595 bfd_size_type dynsymcount;
90ac2420 596 bfd_size_type local_dynsymcount;
51b64d56 597
252b5132
RH
598 /* The string table of dynamic symbols, which becomes the .dynstr
599 section. */
2b0f7ef9 600 struct elf_strtab_hash *dynstr;
51b64d56 601
ef10c3ac
L
602 /* The number of symbol strings found in the link which must be put
603 into the .strtab section. */
604 bfd_size_type strtabcount;
605
606 /* The array size of the symbol string table, which becomes the
607 .strtab section. */
608 bfd_size_type strtabsize;
609
610 /* The array of strings, which becomes the .strtab section. */
611 struct elf_sym_strtab *strtab;
612
252b5132
RH
613 /* The number of buckets in the hash table in the .hash section.
614 This is based on the number of dynamic symbols. */
615 bfd_size_type bucketcount;
51b64d56 616
252b5132
RH
617 /* A linked list of DT_NEEDED names found in dynamic objects
618 included in the link. */
619 struct bfd_link_needed_list *needed;
51b64d56 620
74541ad4
AM
621 /* Sections in the output bfd that provides a section symbol
622 to be used by relocations emitted against local symbols.
623 Most targets will not use data_index_section. */
624 asection *text_index_section;
625 asection *data_index_section;
626
252b5132
RH
627 /* The _GLOBAL_OFFSET_TABLE_ symbol. */
628 struct elf_link_hash_entry *hgot;
51b64d56 629
7325306f
RS
630 /* The _PROCEDURE_LINKAGE_TABLE_ symbol. */
631 struct elf_link_hash_entry *hplt;
632
9637f6ef
L
633 /* The _DYNAMIC symbol. */
634 struct elf_link_hash_entry *hdynamic;
635
f5fa8ca2 636 /* A pointer to information used to merge SEC_MERGE sections. */
c39a58e6 637 void *merge_info;
51b64d56 638
3722b82f
AM
639 /* Used to link stabs in sections. */
640 struct stab_info stab_info;
641
126495ed
AM
642 /* Used by eh_frame code when editing .eh_frame. */
643 struct eh_frame_hdr_info eh_info;
644
30b30c21
RH
645 /* A linked list of local symbols to be added to .dynsym. */
646 struct elf_link_local_dynamic_entry *dynlocal;
51b64d56 647
a963dc6a
L
648 /* A linked list of DT_RPATH/DT_RUNPATH names found in dynamic
649 objects included in the link. */
650 struct bfd_link_needed_list *runpath;
13ae64f3 651
e1918d23
AM
652 /* Cached first output tls section and size of PT_TLS segment. */
653 asection *tls_sec;
66631823 654 bfd_size_type tls_size; /* Bytes. */
f5d44ba0 655
9bcc30e4
L
656 /* The offset into splt of the PLT entry for the TLS descriptor
657 resolver. Special values are 0, if not necessary (or not found
658 to be necessary yet), and -1 if needed but not determined
659 yet. */
660 bfd_vma tlsdesc_plt;
661
662 /* The GOT offset for the lazy trampoline. Communicated to the
663 loader via DT_TLSDESC_GOT. The magic value (bfd_vma) -1
664 indicates an offset is not allocated. */
665 bfd_vma tlsdesc_got;
666
90c14f0c
L
667 /* Target OS for linker output. */
668 enum elf_target_os target_os;
669
e310298c
AM
670 /* A linked list of dynamic BFD's loaded in the link. */
671 struct elf_link_loaded_list *dyn_loaded;
6de2ae4a
L
672
673 /* Short-cuts to get to dynamic linker sections. */
674 asection *sgot;
675 asection *sgotplt;
676 asection *srelgot;
677 asection *splt;
678 asection *srelplt;
9d19e4fd
AM
679 asection *sdynbss;
680 asection *srelbss;
5474d94f
AM
681 asection *sdynrelro;
682 asection *sreldynrelro;
6de2ae4a
L
683 asection *igotplt;
684 asection *iplt;
685 asection *irelplt;
686 asection *irelifunc;
cae1fbbb 687 asection *dynsym;
252b5132
RH
688};
689
690/* Look up an entry in an ELF linker hash table. */
691
692#define elf_link_hash_lookup(table, string, create, copy, follow) \
693 ((struct elf_link_hash_entry *) \
694 bfd_link_hash_lookup (&(table)->root, (string), (create), \
695 (copy), (follow)))
696
697/* Traverse an ELF linker hash table. */
698
699#define elf_link_hash_traverse(table, func, info) \
700 (bfd_link_hash_traverse \
701 (&(table)->root, \
c39a58e6 702 (bfd_boolean (*) (struct bfd_link_hash_entry *, void *)) (func), \
252b5132
RH
703 (info)))
704
705/* Get the ELF linker hash table from a link_info structure. */
706
707#define elf_hash_table(p) ((struct elf_link_hash_table *) ((p)->hash))
8ea2e4bd 708
4dfe6ac6
NC
709#define elf_hash_table_id(table) ((table) -> hash_table_id)
710
b34976b6 711/* Returns TRUE if the hash table is a struct elf_link_hash_table. */
07d6d2b8 712#define is_elf_hash_table(htab) \
0eddce27 713 (((struct bfd_link_hash_table *) (htab))->type == bfd_link_elf_hash_table)
ec338859 714
87d72d41
AM
715/* Used by bfd_sym_from_r_symndx to cache a small number of local
716 symbols. */
ec338859 717#define LOCAL_SYM_CACHE_SIZE 32
87d72d41 718struct sym_cache
ec338859
AM
719{
720 bfd *abfd;
721 unsigned long indx[LOCAL_SYM_CACHE_SIZE];
87d72d41 722 Elf_Internal_Sym sym[LOCAL_SYM_CACHE_SIZE];
ec338859 723};
252b5132
RH
724\f
725/* Constant information held for an ELF backend. */
726
727struct elf_size_info {
728 unsigned char sizeof_ehdr, sizeof_phdr, sizeof_shdr;
729 unsigned char sizeof_rel, sizeof_rela, sizeof_sym, sizeof_dyn, sizeof_note;
730
c7ac6ff8
MM
731 /* The size of entries in the .hash section. */
732 unsigned char sizeof_hash_entry;
733
734 /* The number of internal relocations to allocate per external
735 relocation entry. */
736 unsigned char int_rels_per_ext_rel;
947216bf
AM
737 /* We use some fixed size arrays. This should be large enough to
738 handle all back-ends. */
739#define MAX_INT_RELS_PER_EXT_REL 3
c7ac6ff8 740
45d6a902 741 unsigned char arch_size, log_file_align;
252b5132 742 unsigned char elfclass, ev_current;
dc810e39 743 int (*write_out_phdrs)
c39a58e6
AM
744 (bfd *, const Elf_Internal_Phdr *, unsigned int);
745 bfd_boolean
746 (*write_shdrs_and_ehdr) (bfd *);
20a761b5
RM
747 bfd_boolean (*checksum_contents)
748 (bfd * , void (*) (const void *, size_t, void *), void *);
dc810e39 749 void (*write_relocs)
c39a58e6 750 (bfd *, asection *, void *);
8384fb8f 751 bfd_boolean (*swap_symbol_in)
c39a58e6 752 (bfd *, const void *, const void *, Elf_Internal_Sym *);
dc810e39 753 void (*swap_symbol_out)
c39a58e6 754 (bfd *, const Elf_Internal_Sym *, void *, void *);
b34976b6 755 bfd_boolean (*slurp_reloc_table)
c39a58e6 756 (bfd *, asection *, asymbol **, bfd_boolean);
dc810e39 757 long (*slurp_symbol_table)
c39a58e6 758 (bfd *, asymbol **, bfd_boolean);
dc810e39 759 void (*swap_dyn_in)
c39a58e6 760 (bfd *, const void *, Elf_Internal_Dyn *);
dc810e39 761 void (*swap_dyn_out)
c39a58e6 762 (bfd *, const Elf_Internal_Dyn *, void *);
c7ac6ff8 763
947216bf
AM
764 /* This function is called to swap in a REL relocation. If an
765 external relocation corresponds to more than one internal
766 relocation, then all relocations are swapped in at once. */
c7ac6ff8 767 void (*swap_reloc_in)
c39a58e6 768 (bfd *, const bfd_byte *, Elf_Internal_Rela *);
c7ac6ff8 769
947216bf 770 /* This function is called to swap out a REL relocation. */
c7ac6ff8 771 void (*swap_reloc_out)
c39a58e6 772 (bfd *, const Elf_Internal_Rela *, bfd_byte *);
c7ac6ff8 773
947216bf
AM
774 /* This function is called to swap in a RELA relocation. If an
775 external relocation corresponds to more than one internal
776 relocation, then all relocations are swapped in at once. */
c7ac6ff8 777 void (*swap_reloca_in)
c39a58e6 778 (bfd *, const bfd_byte *, Elf_Internal_Rela *);
c7ac6ff8 779
947216bf 780 /* This function is called to swap out a RELA relocation. */
c7ac6ff8 781 void (*swap_reloca_out)
c39a58e6 782 (bfd *, const Elf_Internal_Rela *, bfd_byte *);
252b5132
RH
783};
784
785#define elf_symbol_from(ABFD,S) \
0ee5a0e4
AM
786 (((S)->the_bfd != NULL \
787 && (S)->the_bfd->xvec->flavour == bfd_target_elf_flavour \
788 && (S)->the_bfd->tdata.elf_obj_data != 0) \
789 ? (elf_symbol_type *) (S) \
790 : 0)
252b5132 791
db6751f2
JJ
792enum elf_reloc_type_class {
793 reloc_class_normal,
794 reloc_class_relative,
7e612e98 795 reloc_class_copy,
1997c994
AM
796 reloc_class_ifunc,
797 reloc_class_plt
db6751f2
JJ
798};
799
73d074b4
DJ
800struct elf_reloc_cookie
801{
802 Elf_Internal_Rela *rels, *rel, *relend;
6cdc0ccc 803 Elf_Internal_Sym *locsyms;
73d074b4
DJ
804 bfd *abfd;
805 size_t locsymcount;
806 size_t extsymoff;
807 struct elf_link_hash_entry **sym_hashes;
140f6c8e 808 int r_sym_shift;
b34976b6 809 bfd_boolean bad_symtab;
73d074b4
DJ
810};
811
c6e90b02
TS
812/* The level of IRIX compatibility we're striving for. */
813
814typedef enum {
815 ict_none,
816 ict_irix5,
817 ict_irix6
818} irix_compat_t;
819
2f89ff8d
L
820/* Mapping of ELF section names and types. */
821struct bfd_elf_special_section
822{
823 const char *prefix;
9fb71ee4 824 unsigned int prefix_length;
7dcb9820
AM
825 /* 0 means name must match PREFIX exactly.
826 -1 means name must start with PREFIX followed by an arbitrary string.
827 -2 means name must match PREFIX exactly or consist of PREFIX followed
828 by a dot then anything.
829 > 0 means name must start with the first PREFIX_LENGTH chars of
830 PREFIX and finish with the last SUFFIX_LENGTH chars of PREFIX. */
9fb71ee4
NC
831 signed int suffix_length;
832 unsigned int type;
01e1a5bc 833 bfd_vma attr;
2f89ff8d
L
834};
835
8a696751
AM
836enum action_discarded
837 {
838 COMPLAIN = 1,
839 PRETEND = 2
840 };
841
6a5bb875
PB
842typedef asection * (*elf_gc_mark_hook_fn)
843 (asection *, struct bfd_link_info *, Elf_Internal_Rela *,
844 struct elf_link_hash_entry *, Elf_Internal_Sym *);
845
46bed679
L
846enum elf_property_kind
847 {
848 /* A new property. */
849 property_unknown = 0,
850 /* A property ignored by backend. */
851 property_ignored,
852 /* A corrupt property reported by backend. */
853 property_corrupt,
854 /* A property should be removed due to property merge. */
855 property_remove,
856 /* A property which is a number. */
857 property_number
858 };
859
860typedef struct elf_property
861{
862 unsigned int pr_type;
863 unsigned int pr_datasz;
864 union
865 {
866 /* For property_number, this is a number. */
867 bfd_vma number;
868 /* Add a new one if elf_property_kind is updated. */
869 } u;
870 enum elf_property_kind pr_kind;
871} elf_property;
872
873typedef struct elf_property_list
874{
875 struct elf_property_list *next;
876 struct elf_property property;
877} elf_property_list;
878
9eaff861
AO
879struct bfd_elf_section_reloc_data;
880
252b5132
RH
881struct elf_backend_data
882{
252b5132
RH
883 /* The architecture for this backend. */
884 enum bfd_architecture arch;
885
ae95ffa6
L
886 /* An identifier used to distinguish different target specific
887 extensions to elf_obj_tdata and elf_link_hash_table structures. */
888 enum elf_target_id target_id;
889
90c14f0c
L
890 /* Target OS. */
891 enum elf_target_os target_os;
892
252b5132
RH
893 /* The ELF machine code (EM_xxxx) for this backend. */
894 int elf_machine_code;
895
9eaff861 896 /* EI_OSABI. */
d1036acb
L
897 int elf_osabi;
898
252b5132
RH
899 /* The maximum page size for this backend. */
900 bfd_vma maxpagesize;
901
b1342370
DJ
902 /* The minimum page size for this backend. An input object will not be
903 considered page aligned unless its sections are correctly aligned for
904 pages at least this large. May be smaller than maxpagesize. */
905 bfd_vma minpagesize;
906
24718e3b
L
907 /* The common page size for this backend. */
908 bfd_vma commonpagesize;
909
702d1671
AM
910 /* The value of commonpagesize to use when -z relro for this backend. */
911 bfd_vma relropagesize;
912
e5a52504
MM
913 /* The BFD flags applied to sections created for dynamic linking. */
914 flagword dynamic_sec_flags;
915
23209a78
RM
916 /* Architecture-specific data for this backend.
917 This is actually a pointer to some type like struct elf_ARCH_data. */
918 const void *arch_data;
919
252b5132 920 /* A function to translate an ELF RELA relocation to a BFD arelent
f3185997
NC
921 structure. Returns TRUE upon success, FALSE otherwise. */
922 bfd_boolean (*elf_info_to_howto)
c39a58e6 923 (bfd *, arelent *, Elf_Internal_Rela *);
252b5132
RH
924
925 /* A function to translate an ELF REL relocation to a BFD arelent
f3185997
NC
926 structure. Returns TRUE upon success, FALSE otherwise. */
927 bfd_boolean (*elf_info_to_howto_rel)
c39a58e6 928 (bfd *, arelent *, Elf_Internal_Rela *);
252b5132
RH
929
930 /* A function to determine whether a symbol is global when
931 partitioning the symbol table into local and global symbols.
932 This should be NULL for most targets, in which case the correct
933 thing will be done. MIPS ELF, at least on the Irix 5, has
934 special requirements. */
b34976b6 935 bfd_boolean (*elf_backend_sym_is_global)
c39a58e6 936 (bfd *, asymbol *);
252b5132
RH
937
938 /* The remaining functions are hooks which are called only if they
939 are not NULL. */
940
941 /* A function to permit a backend specific check on whether a
942 particular BFD format is relevant for an object file, and to
943 permit the backend to set any global information it wishes. When
944 this is called elf_elfheader is set, but anything else should be
b34976b6 945 used with caution. If this returns FALSE, the check_format
252b5132 946 routine will return a bfd_error_wrong_format error. */
b34976b6 947 bfd_boolean (*elf_backend_object_p)
c39a58e6 948 (bfd *);
252b5132
RH
949
950 /* A function to do additional symbol processing when reading the
951 ELF symbol table. This is where any processor-specific special
952 section indices are handled. */
dc810e39 953 void (*elf_backend_symbol_processing)
c39a58e6 954 (bfd *, asymbol *);
252b5132
RH
955
956 /* A function to do additional symbol processing after reading the
957 entire ELF symbol table. */
b34976b6 958 bfd_boolean (*elf_backend_symbol_table_processing)
c39a58e6 959 (bfd *, elf_symbol_type *, unsigned int);
252b5132 960
8387904d 961 /* A function to set the type of the info field. Processor-specific
3e932841 962 types should be handled here. */
dc810e39 963 int (*elf_backend_get_symbol_type)
c39a58e6 964 (Elf_Internal_Sym *, int);
60bcf0fa 965
8387904d
AM
966 /* A function to return the linker hash table entry of a symbol that
967 might be satisfied by an archive symbol. */
968 struct elf_link_hash_entry * (*elf_backend_archive_symbol_lookup)
969 (bfd *, struct bfd_link_info *, const char *);
970
174fd7f9
RS
971 /* Return true if local section symbols should have a non-null st_name.
972 NULL implies false. */
973 bfd_boolean (*elf_backend_name_local_section_symbols)
974 (bfd *);
975
252b5132
RH
976 /* A function to do additional processing on the ELF section header
977 just before writing it out. This is used to set the flags and
978 type fields for some sections, or to actually write out data for
979 unusual sections. */
b34976b6 980 bfd_boolean (*elf_backend_section_processing)
c39a58e6 981 (bfd *, Elf_Internal_Shdr *);
252b5132
RH
982
983 /* A function to handle unusual section types when creating BFD
984 sections from ELF sections. */
b34976b6 985 bfd_boolean (*elf_backend_section_from_shdr)
6dc132d9 986 (bfd *, Elf_Internal_Shdr *, const char *, int);
252b5132 987
551b43fd 988 /* A function to convert machine dependent ELF section header flags to
fa152c49 989 BFD internal section header flags. */
b34976b6 990 bfd_boolean (*elf_backend_section_flags)
8c803a2d 991 (const Elf_Internal_Shdr *);
fa152c49 992
551b43fd
AM
993 /* A function that returns a struct containing ELF section flags and
994 type for the given BFD section. */
995 const struct bfd_elf_special_section * (*get_sec_type_attr)
996 (bfd *, asection *);
997
20cfcaae 998 /* A function to handle unusual program segment types when creating BFD
3e932841 999 sections from ELF program segments. */
b34976b6 1000 bfd_boolean (*elf_backend_section_from_phdr)
d27f5fa1 1001 (bfd *, Elf_Internal_Phdr *, int, const char *);
20cfcaae 1002
252b5132
RH
1003 /* A function to set up the ELF section header for a BFD section in
1004 preparation for writing it out. This is where the flags and type
1005 fields are set for unusual sections. */
b34976b6 1006 bfd_boolean (*elf_backend_fake_sections)
c39a58e6 1007 (bfd *, Elf_Internal_Shdr *, asection *);
252b5132
RH
1008
1009 /* A function to get the ELF section index for a BFD section. If
b34976b6 1010 this returns TRUE, the section was found. If it is a normal ELF
252b5132
RH
1011 section, *RETVAL should be left unchanged. If it is not a normal
1012 ELF section *RETVAL should be set to the SHN_xxxx index. */
b34976b6 1013 bfd_boolean (*elf_backend_section_from_bfd_section)
c39a58e6 1014 (bfd *, asection *, int *retval);
252b5132
RH
1015
1016 /* If this field is not NULL, it is called by the add_symbols phase
1017 of a link just before adding a symbol to the global linker hash
1018 table. It may modify any of the fields as it wishes. If *NAME
1019 is set to NULL, the symbol will be skipped rather than being
1020 added to the hash table. This function is responsible for
1021 handling all processor dependent symbol bindings and section
1022 indices, and must set at least *FLAGS and *SEC for each processor
1023 dependent case; failure to do so will cause a link error. */
b34976b6 1024 bfd_boolean (*elf_add_symbol_hook)
555cd476 1025 (bfd *abfd, struct bfd_link_info *info, Elf_Internal_Sym *,
c39a58e6 1026 const char **name, flagword *flags, asection **sec, bfd_vma *value);
252b5132
RH
1027
1028 /* If this field is not NULL, it is called by the elf_link_output_sym
6e0b88f1
AM
1029 phase of a link for each symbol which will appear in the object file.
1030 On error, this function returns 0. 1 is returned when the symbol
1031 should be output, 2 is returned when the symbol should be discarded. */
1032 int (*elf_backend_link_output_symbol_hook)
754021d0
AM
1033 (struct bfd_link_info *info, const char *, Elf_Internal_Sym *,
1034 asection *, struct elf_link_hash_entry *);
252b5132
RH
1035
1036 /* The CREATE_DYNAMIC_SECTIONS function is called by the ELF backend
1037 linker the first time it encounters a dynamic object in the link.
1038 This function must create any sections required for dynamic
1039 linking. The ABFD argument is a dynamic object. The .interp,
1040 .dynamic, .dynsym, .dynstr, and .hash functions have already been
1041 created, and this function may modify the section flags if
1042 desired. This function will normally create the .got and .plt
1043 sections, but different backends have different requirements. */
b34976b6 1044 bfd_boolean (*elf_backend_create_dynamic_sections)
c39a58e6 1045 (bfd *abfd, struct bfd_link_info *info);
252b5132 1046
aee6f5b4
AO
1047 /* When creating a shared library, determine whether to omit the
1048 dynamic symbol for the section. */
1049 bfd_boolean (*elf_backend_omit_section_dynsym)
1050 (bfd *output_bfd, struct bfd_link_info *info, asection *osec);
1051
13285a1b
AM
1052 /* Return TRUE if relocations of targets are compatible to the extent
1053 that CHECK_RELOCS will properly process them. PR 4424. */
1054 bfd_boolean (*relocs_compatible) (const bfd_target *, const bfd_target *);
1055
252b5132
RH
1056 /* The CHECK_RELOCS function is called by the add_symbols phase of
1057 the ELF backend linker. It is called once for each section with
1058 relocs of an object file, just after the symbols for the object
1059 file have been added to the global linker hash table. The
1060 function must look through the relocs and do any special handling
1061 required. This generally means allocating space in the global
1062 offset table, and perhaps allocating space for a reloc. The
1063 relocs are always passed as Rela structures; if the section
1064 actually uses Rel structures, the r_addend field will always be
1065 zero. */
b34976b6 1066 bfd_boolean (*check_relocs)
c39a58e6
AM
1067 (bfd *abfd, struct bfd_link_info *info, asection *o,
1068 const Elf_Internal_Rela *relocs);
252b5132 1069
85fbca6a
NC
1070 /* The CHECK_DIRECTIVES function is called once per input file by
1071 the add_symbols phase of the ELF backend linker. The function
1072 must inspect the bfd and create any additional symbols according
1073 to any custom directives in the bfd. */
1074 bfd_boolean (*check_directives)
1075 (bfd *abfd, struct bfd_link_info *info);
1076
e5034e59
AM
1077 /* The NOTICE_AS_NEEDED function is called as the linker is about to
1078 handle an as-needed lib (ACT = notice_as_needed), and after the
1079 linker has decided to keep the lib (ACT = notice_needed) or when
1080 the lib is not needed (ACT = notice_not_needed). */
1081 bfd_boolean (*notice_as_needed)
1082 (bfd *abfd, struct bfd_link_info *info, enum notice_asneeded_action act);
97fed1c9 1083
252b5132
RH
1084 /* The ADJUST_DYNAMIC_SYMBOL function is called by the ELF backend
1085 linker for every symbol which is defined by a dynamic object and
1086 referenced by a regular object. This is called after all the
1087 input files have been seen, but before the SIZE_DYNAMIC_SECTIONS
1088 function has been called. The hash table entry should be
1089 bfd_link_hash_defined ore bfd_link_hash_defweak, and it should be
1090 defined in a section from a dynamic object. Dynamic object
1091 sections are not included in the final link, and this function is
1092 responsible for changing the value to something which the rest of
1093 the link can deal with. This will normally involve adding an
1094 entry to the .plt or .got or some such section, and setting the
1095 symbol to point to that. */
b34976b6 1096 bfd_boolean (*elf_backend_adjust_dynamic_symbol)
c39a58e6 1097 (struct bfd_link_info *info, struct elf_link_hash_entry *h);
252b5132
RH
1098
1099 /* The ALWAYS_SIZE_SECTIONS function is called by the backend linker
1100 after all the linker input files have been seen but before the
1101 section sizes have been set. This is called after
1102 ADJUST_DYNAMIC_SYMBOL, but before SIZE_DYNAMIC_SECTIONS. */
b34976b6 1103 bfd_boolean (*elf_backend_always_size_sections)
c39a58e6 1104 (bfd *output_bfd, struct bfd_link_info *info);
252b5132
RH
1105
1106 /* The SIZE_DYNAMIC_SECTIONS function is called by the ELF backend
1107 linker after all the linker input files have been seen but before
1108 the sections sizes have been set. This is called after
1109 ADJUST_DYNAMIC_SYMBOL has been called on all appropriate symbols.
1110 It is only called when linking against a dynamic object. It must
1111 set the sizes of the dynamic sections, and may fill in their
1112 contents as well. The generic ELF linker can handle the .dynsym,
1113 .dynstr and .hash sections. This function must handle the
1114 .interp section and any sections created by the
1115 CREATE_DYNAMIC_SECTIONS entry point. */
b34976b6 1116 bfd_boolean (*elf_backend_size_dynamic_sections)
c39a58e6 1117 (bfd *output_bfd, struct bfd_link_info *info);
252b5132 1118
6f6fd151
L
1119 /* The STRIP_ZERO_SIZED_DYNAMIC_SECTIONS function is called by the
1120 ELF backend linker to strip zero-sized dynamic sections after
1121 the section sizes have been set. */
1122 bfd_boolean (*elf_backend_strip_zero_sized_dynamic_sections)
1123 (struct bfd_link_info *info);
1124
74541ad4
AM
1125 /* Set TEXT_INDEX_SECTION and DATA_INDEX_SECTION, the output sections
1126 we keep to use as a base for relocs and symbols. */
1127 void (*elf_backend_init_index_section)
1128 (bfd *output_bfd, struct bfd_link_info *info);
1129
252b5132
RH
1130 /* The RELOCATE_SECTION function is called by the ELF backend linker
1131 to handle the relocations for a section.
1132
1133 The relocs are always passed as Rela structures; if the section
1134 actually uses Rel structures, the r_addend field will always be
1135 zero.
1136
1137 This function is responsible for adjust the section contents as
1138 necessary, and (if using Rela relocs and generating a
1049f94e 1139 relocatable output file) adjusting the reloc addend as
252b5132
RH
1140 necessary.
1141
1142 This function does not have to worry about setting the reloc
1143 address or the reloc symbol index.
1144
1145 LOCAL_SYMS is a pointer to the swapped in local symbols.
1146
1147 LOCAL_SECTIONS is an array giving the section in the input file
1148 corresponding to the st_shndx field of each local symbol.
1149
1150 The global hash table entry for the global symbols can be found
1151 via elf_sym_hashes (input_bfd).
1152
1049f94e 1153 When generating relocatable output, this function must handle
252b5132
RH
1154 STB_LOCAL/STT_SECTION symbols specially. The output symbol is
1155 going to be the section symbol corresponding to the output
1156 section, which means that the addend must be adjusted
ece5ef60
AM
1157 accordingly.
1158
1159 Returns FALSE on error, TRUE on success, 2 if successful and
1160 relocations should be written for this section. */
1161 int (*elf_backend_relocate_section)
c39a58e6
AM
1162 (bfd *output_bfd, struct bfd_link_info *info, bfd *input_bfd,
1163 asection *input_section, bfd_byte *contents, Elf_Internal_Rela *relocs,
1164 Elf_Internal_Sym *local_syms, asection **local_sections);
252b5132
RH
1165
1166 /* The FINISH_DYNAMIC_SYMBOL function is called by the ELF backend
1167 linker just before it writes a symbol out to the .dynsym section.
1168 The processor backend may make any required adjustment to the
1169 symbol. It may also take the opportunity to set contents of the
1170 dynamic sections. Note that FINISH_DYNAMIC_SYMBOL is called on
1171 all .dynsym symbols, while ADJUST_DYNAMIC_SYMBOL is only called
1172 on those symbols which are defined by a dynamic object. */
b34976b6 1173 bfd_boolean (*elf_backend_finish_dynamic_symbol)
c39a58e6
AM
1174 (bfd *output_bfd, struct bfd_link_info *info,
1175 struct elf_link_hash_entry *h, Elf_Internal_Sym *sym);
252b5132
RH
1176
1177 /* The FINISH_DYNAMIC_SECTIONS function is called by the ELF backend
1178 linker just before it writes all the dynamic sections out to the
1179 output file. The FINISH_DYNAMIC_SYMBOL will have been called on
1180 all dynamic symbols. */
b34976b6 1181 bfd_boolean (*elf_backend_finish_dynamic_sections)
c39a58e6 1182 (bfd *output_bfd, struct bfd_link_info *info);
252b5132
RH
1183
1184 /* A function to do any beginning processing needed for the ELF file
1185 before building the ELF headers and computing file positions. */
1186 void (*elf_backend_begin_write_processing)
c39a58e6 1187 (bfd *, struct bfd_link_info *);
252b5132
RH
1188
1189 /* A function to do any final processing needed for the ELF file
cc364be6
AM
1190 before writing it out. */
1191 bfd_boolean (*elf_backend_final_write_processing)
1192 (bfd *);
252b5132
RH
1193
1194 /* This function is called by get_program_header_size. It should
1195 return the number of additional program segments which this BFD
1196 will need. It should return -1 on error. */
dc810e39 1197 int (*elf_backend_additional_program_headers)
a6b96beb 1198 (bfd *, struct bfd_link_info *);
252b5132
RH
1199
1200 /* This function is called to modify an existing segment map in a
1201 backend specific fashion. */
b34976b6 1202 bfd_boolean (*elf_backend_modify_segment_map)
c84fca4d 1203 (bfd *, struct bfd_link_info *);
252b5132 1204
e36284ab
AM
1205 /* This function is called to modify program headers just before
1206 they are written. */
6d6c25c8 1207 bfd_boolean (*elf_backend_modify_headers)
e36284ab
AM
1208 (bfd *, struct bfd_link_info *);
1209
1a9ccd70
NC
1210 /* This function is called to see if the PHDR header should be
1211 checked for validity. */
1212 bfd_boolean (*elf_backend_allow_non_load_phdr)
1213 (bfd *, const Elf_Internal_Phdr *, unsigned);
1214
74f0fb50
AM
1215 /* This function is called before section garbage collection to
1216 mark entry symbol sections. */
1217 void (*gc_keep)
1218 (struct bfd_link_info *);
1219
64d03ab5
AM
1220 /* This function is called during section garbage collection to
1221 mark sections that define global symbols. */
1222 bfd_boolean (*gc_mark_dynamic_ref)
74f0fb50 1223 (struct elf_link_hash_entry *, void *);
64d03ab5 1224
252b5132 1225 /* This function is called during section gc to discover the section a
1e2f5b6e 1226 particular relocation refers to. */
6a5bb875
PB
1227 elf_gc_mark_hook_fn gc_mark_hook;
1228
1229 /* This function, if defined, is called after the first gc marking pass
1230 to allow the backend to mark additional sections. */
1231 bfd_boolean (*gc_mark_extra_sections)
74f0fb50 1232 (struct bfd_link_info *, elf_gc_mark_hook_fn);
252b5132 1233
ed7e9d0b
AM
1234 /* This function is called to initialise ELF file header info.
1235 Customised versions can modify things like the OS and ABI version. */
1236 bfd_boolean (*elf_backend_init_file_header)
c39a58e6 1237 (bfd *, struct bfd_link_info *);
e6c51ed4 1238
587ff49e
RH
1239 /* This function, if defined, prints a symbol to file and returns the
1240 name of the symbol to be printed. It should return NULL to fall
1241 back to default symbol printing. */
1242 const char *(*elf_backend_print_symbol_all)
c39a58e6 1243 (bfd *, void *, asymbol *);
587ff49e
RH
1244
1245 /* This function, if defined, is called after all local symbols and
4cc11e76 1246 global symbols converted to locals are emitted into the symtab
4e617b1e 1247 section. It allows the backend to emit special local symbols
587ff49e 1248 not handled in the hash table. */
4e617b1e
PB
1249 bfd_boolean (*elf_backend_output_arch_local_syms)
1250 (bfd *, struct bfd_link_info *, void *,
1251 bfd_boolean (*) (void *, const char *, Elf_Internal_Sym *, asection *,
1252 struct elf_link_hash_entry *));
1253
1254 /* This function, if defined, is called after all symbols are emitted
1255 into the symtab section. It allows the backend to emit special
1256 global symbols not handled in the hash table. */
b34976b6 1257 bfd_boolean (*elf_backend_output_arch_syms)
c39a58e6 1258 (bfd *, struct bfd_link_info *, void *,
754021d0
AM
1259 bfd_boolean (*) (void *, const char *, Elf_Internal_Sym *, asection *,
1260 struct elf_link_hash_entry *));
587ff49e 1261
76359541
TP
1262 /* Filter what symbols of the output file to include in the import
1263 library if one is created. */
1264 unsigned int (*elf_backend_filter_implib_symbols)
1265 (bfd *, struct bfd_link_info *, asymbol **, long);
1266
d4c88bbb 1267 /* Copy any information related to dynamic linking from a pre-existing
0a991dfe
AM
1268 symbol to a newly created symbol. Also called to copy flags and
1269 other back-end info to a weakdef, in which case the symbol is not
1270 newly created and plt/got refcounts and dynamic indices should not
1271 be copied. */
c61b8717 1272 void (*elf_backend_copy_indirect_symbol)
fcfa13d2 1273 (struct bfd_link_info *, struct elf_link_hash_entry *,
c39a58e6 1274 struct elf_link_hash_entry *);
c61b8717
RH
1275
1276 /* Modify any information related to dynamic linking such that the
1277 symbol is not exported. */
1278 void (*elf_backend_hide_symbol)
c39a58e6 1279 (struct bfd_link_info *, struct elf_link_hash_entry *, bfd_boolean);
c61b8717 1280
508c3946
L
1281 /* A function to do additional symbol fixup, called by
1282 _bfd_elf_fix_symbol_flags. */
1283 bfd_boolean (*elf_backend_fixup_symbol)
1284 (struct bfd_link_info *, struct elf_link_hash_entry *);
1285
9bf7216d
KK
1286 /* Merge the backend specific symbol attribute. */
1287 void (*elf_backend_merge_symbol_attribute)
1288 (struct elf_link_hash_entry *, const Elf_Internal_Sym *, bfd_boolean,
1289 bfd_boolean);
1290
ad9563d6
CM
1291 /* This function, if defined, will return a string containing the
1292 name of a target-specific dynamic tag. */
1293 char *(*elf_backend_get_target_dtag)
1294 (bfd_vma);
1295
12ac1cf5
NC
1296 /* Decide whether an undefined symbol is special and can be ignored.
1297 This is the case for OPTIONAL symbols on IRIX. */
1298 bfd_boolean (*elf_backend_ignore_undef_symbol)
1299 (struct elf_link_hash_entry *);
1300
9317eacc
CM
1301 /* Emit relocations. Overrides default routine for emitting relocs,
1302 except during a relocatable link, or if all relocs are being emitted. */
b34976b6 1303 bfd_boolean (*elf_backend_emit_relocs)
eac338cf
PB
1304 (bfd *, asection *, Elf_Internal_Shdr *, Elf_Internal_Rela *,
1305 struct elf_link_hash_entry **);
9317eacc 1306
9eaff861
AO
1307 /* Update relocations. It is allowed to change the number and the order.
1308 In such a case hashes should be invalidated. */
1309 void (*elf_backend_update_relocs)
1310 (asection *, struct bfd_elf_section_reloc_data *);
1311
9317eacc
CM
1312 /* Count relocations. Not called for relocatable links
1313 or if all relocs are being preserved in the output. */
1314 unsigned int (*elf_backend_count_relocs)
58217f29 1315 (struct bfd_link_info *, asection *);
9317eacc 1316
491d01d3
YU
1317 /* Count additionals relocations. Called for relocatable links if
1318 additional relocations needs to be created. */
1319 unsigned int (*elf_backend_count_additional_relocs)
1320 (asection *);
1321
28dbcedc
AM
1322 /* Say whether to sort relocs output by ld -r and ld --emit-relocs,
1323 by r_offset. If NULL, default to true. */
1324 bfd_boolean (*sort_relocs_p)
1325 (asection *);
1326
bb0082d6 1327 /* This function, if defined, is called when an NT_PRSTATUS note is found
183e98be 1328 in a core file. */
b34976b6 1329 bfd_boolean (*elf_backend_grok_prstatus)
c39a58e6 1330 (bfd *, Elf_Internal_Note *);
bb0082d6
AM
1331
1332 /* This function, if defined, is called when an NT_PSINFO or NT_PRPSINFO
183e98be 1333 note is found in a core file. */
b34976b6 1334 bfd_boolean (*elf_backend_grok_psinfo)
c39a58e6 1335 (bfd *, Elf_Internal_Note *);
bb0082d6 1336
544c67cd
JB
1337 /* This function, if defined, is called when a "FreeBSD" NT_PRSTATUS
1338 note is found in a core file. */
1339 bfd_boolean (*elf_backend_grok_freebsd_prstatus)
1340 (bfd *, Elf_Internal_Note *);
1341
183e98be
AM
1342 /* This function, if defined, is called to write a note to a corefile. */
1343 char *(*elf_backend_write_core_note)
1344 (bfd *abfd, char *buf, int *bufsiz, int note_type, ...);
1345
ae17ab41
CM
1346 /* This function, if defined, is called to convert target-specific
1347 section flag names into hex values. */
1348 flagword (*elf_backend_lookup_section_flags_hook)
1349 (char *);
1350
db6751f2 1351 /* This function returns class of a reloc type. */
f51e552e 1352 enum elf_reloc_type_class (*elf_backend_reloc_type_class)
7e612e98 1353 (const struct bfd_link_info *, const asection *, const Elf_Internal_Rela *);
db6751f2 1354
73d074b4
DJ
1355 /* This function, if defined, removes information about discarded functions
1356 from other sections which mention them. */
b34976b6 1357 bfd_boolean (*elf_backend_discard_info)
c39a58e6 1358 (bfd *, struct elf_reloc_cookie *, struct bfd_link_info *);
73d074b4
DJ
1359
1360 /* This function, if defined, signals that the function above has removed
1361 the discarded relocations for this section. */
b34976b6 1362 bfd_boolean (*elf_backend_ignore_discarded_relocs)
c39a58e6 1363 (asection *);
73d074b4 1364
8a696751
AM
1365 /* What to do when ld finds relocations against symbols defined in
1366 discarded sections. */
1367 unsigned int (*action_discarded)
1368 (asection *);
1369
8c946ed5
RS
1370 /* This function returns the width of FDE pointers in bytes, or 0 if
1371 that can't be determined for some reason. The default definition
1372 goes by the bfd's EI_CLASS. */
1373 unsigned int (*elf_backend_eh_frame_address_size)
76c20d54 1374 (bfd *, const asection *);
8c946ed5 1375
ec3391e7
AO
1376 /* These functions tell elf-eh-frame whether to attempt to turn
1377 absolute or lsda encodings into pc-relative ones. The default
1378 definition enables these transformations. */
1379 bfd_boolean (*elf_backend_can_make_relative_eh_frame)
1380 (bfd *, struct bfd_link_info *, asection *);
1381 bfd_boolean (*elf_backend_can_make_lsda_relative_eh_frame)
1382 (bfd *, struct bfd_link_info *, asection *);
1383
1384 /* This function returns an encoding after computing the encoded
1385 value (and storing it in ENCODED) for the given OFFSET into OSEC,
1386 to be stored in at LOC_OFFSET into the LOC_SEC input section.
1387 The default definition chooses a 32-bit PC-relative encoding. */
1388 bfd_byte (*elf_backend_encode_eh_address)
1389 (bfd *abfd, struct bfd_link_info *info,
1390 asection *osec, bfd_vma offset,
1391 asection *loc_sec, bfd_vma loc_offset,
1392 bfd_vma *encoded);
1393
73d074b4 1394 /* This function, if defined, may write out the given section.
b34976b6
AM
1395 Returns TRUE if it did so and FALSE if the caller should. */
1396 bfd_boolean (*elf_backend_write_section)
c7b8f16e 1397 (bfd *, struct bfd_link_info *, asection *, bfd_byte *);
73d074b4 1398
c6e90b02
TS
1399 /* The level of IRIX compatibility we're striving for.
1400 MIPS ELF specific function. */
1401 irix_compat_t (*elf_backend_mips_irix_compat)
c39a58e6 1402 (bfd *);
c6e90b02
TS
1403
1404 reloc_howto_type *(*elf_backend_mips_rtype_to_howto)
0aa13fee 1405 (bfd *, unsigned int, bfd_boolean);
c6e90b02 1406
252b5132
RH
1407 /* The swapping table to use when dealing with ECOFF information.
1408 Used for the MIPS ELF .mdebug section. */
1409 const struct ecoff_debug_swap *elf_backend_ecoff_debug_swap;
1410
8d6337fe
RM
1411 /* This function implements `bfd_elf_bfd_from_remote_memory';
1412 see elf.c, elfcode.h. */
1413 bfd *(*elf_backend_bfd_from_remote_memory)
f0a5d95a 1414 (bfd *templ, bfd_vma ehdr_vma, bfd_size_type size, bfd_vma *loadbasep,
5979d6b6
AM
1415 int (*target_read_memory) (bfd_vma vma, bfd_byte *myaddr,
1416 bfd_size_type len));
8d6337fe 1417
864619bb
KS
1418 bfd_boolean (*elf_backend_core_find_build_id) (bfd *, bfd_vma);
1419
4c45e5c9
JJ
1420 /* This function is used by `_bfd_elf_get_synthetic_symtab';
1421 see elf.c. */
1422 bfd_vma (*plt_sym_val) (bfd_vma, const asection *, const arelent *);
1423
a4d8e49b
L
1424 /* Is symbol defined in common section? */
1425 bfd_boolean (*common_definition) (Elf_Internal_Sym *);
1426
1427 /* Return a common section index for section. */
1428 unsigned int (*common_section_index) (asection *);
1429
1430 /* Return a common section for section. */
1431 asection *(*common_section) (asection *);
1432
1433 /* Return TRUE if we can merge 2 definitions. */
5d13b3b3
AM
1434 bfd_boolean (*merge_symbol) (struct elf_link_hash_entry *,
1435 const Elf_Internal_Sym *, asection **,
1436 bfd_boolean, bfd_boolean,
1437 bfd *, const asection *);
a4d8e49b 1438
fdc90cb4
JJ
1439 /* Return TRUE if symbol should be hashed in the `.gnu.hash' section. */
1440 bfd_boolean (*elf_hash_symbol) (struct elf_link_hash_entry *);
1441
f16a9783
MS
1442 /* If non-NULL, called to register the location of XLAT_LOC within
1443 .MIPS.xhash at which real final dynindx for H will be written.
1444 If XLAT_LOC is zero, the symbol is not included in
1445 .MIPS.xhash and no dynindx will be written. */
1446 void (*record_xhash_symbol)
1447 (struct elf_link_hash_entry *h, bfd_vma xlat_loc);
1448
fcb93ecf
PB
1449 /* Return TRUE if type is a function symbol type. */
1450 bfd_boolean (*is_function_type) (unsigned int type);
1451
aef36ac1
AM
1452 /* If the ELF symbol SYM might be a function in SEC, return the
1453 function size and set *CODE_OFF to the function's entry point,
1454 otherwise return zero. */
1455 bfd_size_type (*maybe_function_sym) (const asymbol *sym, asection *sec,
1456 bfd_vma *code_off);
9f296da3 1457
bce964aa
AM
1458 /* Given NAME, the name of a relocation section stripped of its
1459 .rel/.rela prefix, return the section in ABFD to which the
1460 relocations apply. */
1461 asection *(*get_reloc_section) (bfd *abfd, const char *name);
bd53a53a 1462
5522f910
NC
1463 /* Called to set the sh_flags, sh_link and sh_info fields of OSECTION which
1464 has a type >= SHT_LOOS. Returns TRUE if the fields were initialised,
1465 FALSE otherwise. Can be called multiple times for a given section,
1466 until it returns TRUE. Most of the times it is called ISECTION will be
1467 set to an input section that might be associated with the output section.
1468 The last time that it is called, ISECTION will be set to NULL. */
1469 bfd_boolean (*elf_backend_copy_special_section_fields)
1470 (const bfd *ibfd, bfd *obfd, const Elf_Internal_Shdr *isection,
1471 Elf_Internal_Shdr *osection);
07d6d2b8 1472
185d09ad 1473 /* Used to handle bad SHF_LINK_ORDER input. */
52d45da3 1474 void (*link_order_error_handler) (const char *, ...);
185d09ad 1475
4c45e5c9
JJ
1476 /* Name of the PLT relocation section. */
1477 const char *relplt_name;
1478
252b5132
RH
1479 /* Alternate EM_xxxx machine codes for this backend. */
1480 int elf_machine_alt1;
1481 int elf_machine_alt2;
1482
1483 const struct elf_size_info *s;
1484
29ef7005
L
1485 /* An array of target specific special sections. */
1486 const struct bfd_elf_special_section *special_sections;
1487
6f2f2c9d
DJ
1488 /* The size in bytes of the header for the GOT. This includes the
1489 so-called reserved entries on some systems. */
252b5132 1490 bfd_vma got_header_size;
252b5132 1491
10455f89
HPN
1492 /* The size of the GOT entry for the symbol pointed to by H if non-NULL,
1493 otherwise by the local symbol with index SYMNDX in IBFD. */
1494 bfd_vma (*got_elt_size) (bfd *, struct bfd_link_info *,
1495 struct elf_link_hash_entry *h,
1496 bfd *ibfd, unsigned long symndx);
1497
104d59d1
JM
1498 /* The vendor name to use for a processor-standard attributes section. */
1499 const char *obj_attrs_vendor;
1500
1501 /* The section name to use for a processor-standard attributes section. */
1502 const char *obj_attrs_section;
1503
1504 /* Return 1, 2 or 3 to indicate what type of arguments a
1505 processor-specific tag takes. */
1506 int (*obj_attrs_arg_type) (int);
1507
1508 /* The section type to use for an attributes section. */
1509 unsigned int obj_attrs_section_type;
1510
3de4a297
JM
1511 /* This function determines the order in which any attributes are
1512 written. It must be defined for input in the range
1513 LEAST_KNOWN_OBJ_ATTRIBUTE..NUM_KNOWN_OBJ_ATTRIBUTES-1 (this range
1514 is used in order to make unity easy). The returned value is the
1515 actual tag number to place in the input position. */
5aa6ff7c
AS
1516 int (*obj_attrs_order) (int);
1517
e8b36cd1
JM
1518 /* Handle merging unknown attributes; either warn and return TRUE,
1519 or give an error and return FALSE. */
1520 bfd_boolean (*obj_attrs_handle_unknown) (bfd *, int);
1521
46bed679
L
1522 /* Parse GNU properties. Return the property kind. If the property
1523 is corrupt, issue an error message and return property_corrupt. */
1524 enum elf_property_kind (*parse_gnu_properties) (bfd *, unsigned int,
1525 bfd_byte *,
1526 unsigned int);
1527
1528 /* Merge GNU properties. Return TRUE if property is updated. */
4e539114 1529 bfd_boolean (*merge_gnu_properties) (struct bfd_link_info *, bfd *, bfd *,
5c3ce2bc 1530 elf_property *, elf_property *);
46bed679
L
1531
1532 /* Set up GNU properties. */
fba37edd 1533 bfd *(*setup_gnu_properties) (struct bfd_link_info *);
46bed679 1534
bfb1e8c1
L
1535 /* Fix up GNU properties. */
1536 void (*fixup_gnu_properties) (struct bfd_link_info *,
1537 elf_property_list **);
1538
2f0c68f2
CM
1539 /* Encoding used for compact EH tables. */
1540 int (*compact_eh_encoding) (struct bfd_link_info *);
1541
1542 /* Opcode representing no unwind. */
1543 int (*cant_unwind_opcode) (struct bfd_link_info *);
1544
00e49dff
NC
1545 /* Called when emitting an ELF symbol whoes input version had an
1546 ST_SHNDX field set to a value in the range SHN_LOPROC..SHN_HIOS.
1547 Returns the value to be installed in the ST_SHNDX field of the
1548 emitted symbol. If not defined, the value is left unchanged. */
1549 unsigned int (*symbol_section_index) (bfd *, elf_symbol_type *);
1550
a8e14f4c
NC
1551 /* Called when a section has extra reloc sections. */
1552 bfd_boolean (*init_secondary_reloc_section) (bfd *, Elf_Internal_Shdr *,
1553 const char *, unsigned int);
1554
1555 /* Called when after loading the normal relocs for a section. */
1556 bfd_boolean (*slurp_secondary_relocs) (bfd *, asection *, asymbol **);
1557
1558 /* Called after writing the normal relocs for a section. */
1559 bfd_boolean (*write_secondary_relocs) (bfd *, asection *);
1560
7dc98aea
RO
1561 /* This is non-zero if static TLS segments require a special alignment. */
1562 unsigned static_tls_alignment;
1563
9eaff861 1564 /* Alignment for the PT_GNU_STACK segment. */
04c3a755
NS
1565 unsigned stack_align;
1566
84865015
NC
1567 /* Flag bits to assign to a section of type SHT_STRTAB. */
1568 unsigned long elf_strtab_flags;
1569
b34976b6
AM
1570 /* This is TRUE if the linker should act like collect and gather
1571 global constructors and destructors by name. This is TRUE for
86dc0f79
RH
1572 MIPS ELF because the Irix 5 tools can not handle the .init
1573 section. */
1574 unsigned collect : 1;
1575
b34976b6
AM
1576 /* This is TRUE if the linker should ignore changes to the type of a
1577 symbol. This is TRUE for MIPS ELF because some Irix 5 objects
86dc0f79
RH
1578 record undefined functions as STT_OBJECT although the definitions
1579 are STT_FUNC. */
1580 unsigned type_change_ok : 1;
1581
bf572ba0
MM
1582 /* Whether the backend may use REL relocations. (Some backends use
1583 both REL and RELA relocations, and this flag is set for those
1584 backends.) */
1585 unsigned may_use_rel_p : 1;
60bcf0fa 1586
bf572ba0
MM
1587 /* Whether the backend may use RELA relocations. (Some backends use
1588 both REL and RELA relocations, and this flag is set for those
1589 backends.) */
1590 unsigned may_use_rela_p : 1;
1591
1592 /* Whether the default relocation type is RELA. If a backend with
1593 this flag set wants REL relocations for a particular section,
1594 it must note that explicitly. Similarly, if this flag is clear,
60bcf0fa
NC
1595 and the backend wants RELA relocations for a particular
1596 section. */
bf572ba0
MM
1597 unsigned default_use_rela_p : 1;
1598
d35fd659
RS
1599 /* True if PLT and copy relocations should be RELA by default. */
1600 unsigned rela_plts_and_copies_p : 1;
1601
b491616a
AM
1602 /* Set if RELA relocations for a relocatable link can be handled by
1603 generic code. Backends that set this flag need do nothing in the
1604 backend relocate_section routine for relocatable linking. */
1605 unsigned rela_normal : 1;
1606
64f52338
AM
1607 /* Set if DT_REL/DT_RELA/DT_RELSZ/DT_RELASZ should not include PLT
1608 relocations. */
1609 unsigned dtrel_excludes_plt : 1;
1610
b34976b6 1611 /* TRUE if addresses "naturally" sign extend. This is used when
86dc0f79
RH
1612 swapping in from Elf32 when BFD64. */
1613 unsigned sign_extend_vma : 1;
1614
252b5132
RH
1615 unsigned want_got_plt : 1;
1616 unsigned plt_readonly : 1;
1617 unsigned want_plt_sym : 1;
1618 unsigned plt_not_loaded : 1;
1619 unsigned plt_alignment : 4;
1620 unsigned can_gc_sections : 1;
51b64d56 1621 unsigned can_refcount : 1;
2517a57f 1622 unsigned want_got_sym : 1;
3018b441 1623 unsigned want_dynbss : 1;
5474d94f 1624 unsigned want_dynrelro : 1;
6bfdb61b
AM
1625
1626 /* Targets which do not support physical addressing often require
1627 that the p_paddr field in the section header to be set to zero.
1628 This field indicates whether this behavior is required. */
5e8d7549 1629 unsigned want_p_paddr_set_to_zero : 1;
6bfdb61b 1630
a8c75b76
AM
1631 /* Target has broken hardware and/or kernel that requires pages not
1632 to be mapped twice with different permissions. */
1633 unsigned no_page_alias : 1;
1634
6bfdb61b
AM
1635 /* True if an object file lacking a .note.GNU-stack section
1636 should be assumed to be requesting exec stack. At least one
1637 other file in the link needs to have a .note.GNU-stack section
1638 for a PT_GNU_STACK segment to be created. */
1639 unsigned default_execstack : 1;
53291d1f
AM
1640
1641 /* True if elf_section_data(sec)->this_hdr.contents is sec->rawsize
1642 in length rather than sec->size in length, if sec->rawsize is
1643 non-zero and smaller than sec->size. */
1644 unsigned caches_rawsize : 1;
f7483970
L
1645
1646 /* Address of protected data defined in the shared library may be
1647 external, i.e., due to copy relocation. */
1648 unsigned extern_protected_data : 1;
23ec1e32
MR
1649
1650 /* True if `_bfd_elf_link_renumber_dynsyms' must be called even for
1651 static binaries. */
1652 unsigned always_renumber_dynsyms : 1;
a2f63b2e
MR
1653
1654 /* True if the 32-bit Linux PRPSINFO structure's `pr_uid' and `pr_gid'
1655 members use a 16-bit data type. */
1656 unsigned linux_prpsinfo32_ugid16 : 1;
3c9a7b0d
MR
1657
1658 /* True if the 64-bit Linux PRPSINFO structure's `pr_uid' and `pr_gid'
1659 members use a 16-bit data type. */
1660 unsigned linux_prpsinfo64_ugid16 : 1;
252b5132
RH
1661};
1662
d4730f92
BS
1663/* Information about reloc sections associated with a bfd_elf_section_data
1664 structure. */
1665struct bfd_elf_section_reloc_data
1666{
1667 /* The ELF header for the reloc section associated with this
1668 section, if any. */
1669 Elf_Internal_Shdr *hdr;
1670 /* The number of relocations currently assigned to HDR. */
1671 unsigned int count;
1672 /* The ELF section number of the reloc section. Only used for an
1673 output file. */
1674 int idx;
1675 /* Used by the backend linker to store the symbol hash table entries
1676 associated with relocs against global symbols. */
1677 struct elf_link_hash_entry **hashes;
1678};
1679
252b5132
RH
1680/* Information stored for each BFD section in an ELF file. This
1681 structure is allocated by elf_new_section_hook. */
1682
1683struct bfd_elf_section_data
1684{
1685 /* The ELF header for this section. */
1686 Elf_Internal_Shdr this_hdr;
0c715baa 1687
b9c361e0
JL
1688 /* INPUT_SECTION_FLAGS if specified in the linker script. */
1689 struct flag_info *section_flag_info;
1690
d4730f92
BS
1691 /* Information about the REL and RELA reloc sections associated
1692 with this section, if any. */
1693 struct bfd_elf_section_reloc_data rel, rela;
0c715baa 1694
6dc132d9 1695 /* The ELF section number of this section. */
252b5132 1696 int this_idx;
0c715baa 1697
f0abc2a1
AM
1698 /* Used by the backend linker when generating a shared library to
1699 record the dynamic symbol index for a section symbol
1700 corresponding to this section. A value of 0 means that there is
1701 no dynamic symbol for this section. */
1702 int dynindx;
1703
38ce5b11
L
1704 /* A pointer to the linked-to section for SHF_LINK_ORDER. */
1705 asection *linked_to;
1706
252b5132
RH
1707 /* A pointer to the swapped relocs. If the section uses REL relocs,
1708 rather than RELA, all the r_addend fields will be zero. This
1709 pointer may be NULL. It is used by the backend linker. */
1710 Elf_Internal_Rela *relocs;
0c715baa 1711
f0abc2a1
AM
1712 /* A pointer to a linked list tracking dynamic relocs copied for
1713 local symbols. */
c39a58e6 1714 void *local_dynrel;
0c715baa 1715
f0abc2a1
AM
1716 /* A pointer to the bfd section used for dynamic relocs. */
1717 asection *sreloc;
0c715baa 1718
1126897b
AM
1719 union {
1720 /* Group name, if this section is a member of a group. */
1721 const char *name;
1722
1723 /* Group signature sym, if this is the SHT_GROUP section. */
fc0a2244 1724 struct bfd_symbol *id;
1126897b 1725 } group;
dbb410c3 1726
b0956e01
AM
1727 /* For a member of a group, points to the SHT_GROUP section.
1728 NULL for the SHT_GROUP section itself and non-group sections. */
3d7f7666
L
1729 asection *sec_group;
1730
b0956e01
AM
1731 /* A linked list of member sections in the group. Circular when used by
1732 the linker. For the SHT_GROUP section, points at first member. */
dbb410c3
AM
1733 asection *next_in_group;
1734
9d0a14d3
RS
1735 /* The FDEs associated with this section. The u.fde.next_in_section
1736 field acts as a chain pointer. */
1737 struct eh_cie_fde *fde_list;
1738
2f0c68f2
CM
1739 /* Link from a text section to its .eh_frame_entry section. */
1740 asection *eh_frame_entry;
1741
f0abc2a1 1742 /* A pointer used for various section optimizations. */
c39a58e6 1743 void *sec_info;
252b5132
RH
1744};
1745
9f296da3 1746#define elf_section_data(sec) ((struct bfd_elf_section_data*)(sec)->used_by_bfd)
38ce5b11 1747#define elf_linked_to_section(sec) (elf_section_data(sec)->linked_to)
9f296da3
AM
1748#define elf_section_type(sec) (elf_section_data(sec)->this_hdr.sh_type)
1749#define elf_section_flags(sec) (elf_section_data(sec)->this_hdr.sh_flags)
fe944acf 1750#define elf_section_info(sec) (elf_section_data(sec)->this_hdr.sh_info)
9f296da3
AM
1751#define elf_group_name(sec) (elf_section_data(sec)->group.name)
1752#define elf_group_id(sec) (elf_section_data(sec)->group.id)
1753#define elf_next_in_group(sec) (elf_section_data(sec)->next_in_group)
1754#define elf_fde_list(sec) (elf_section_data(sec)->fde_list)
3d7f7666 1755#define elf_sec_group(sec) (elf_section_data(sec)->sec_group)
2f0c68f2 1756#define elf_section_eh_frame_entry(sec) (elf_section_data(sec)->eh_frame_entry)
252b5132 1757
24718e3b 1758#define xvec_get_elf_backend_data(xvec) \
f7231afc 1759 ((const struct elf_backend_data *) (xvec)->backend_data)
24718e3b 1760
252b5132 1761#define get_elf_backend_data(abfd) \
24718e3b 1762 xvec_get_elf_backend_data ((abfd)->xvec)
252b5132 1763
3de4a297
JM
1764/* The least object attributes (within an attributes subsection) known
1765 for any target. Some code assumes that the value 0 is not used and
1766 the field for that attribute can instead be used as a marker to
1767 indicate that attributes have been initialized. */
59e6276b 1768#define LEAST_KNOWN_OBJ_ATTRIBUTE 2
3de4a297 1769
104d59d1 1770/* The maximum number of known object attributes for any target. */
91e22acd 1771#define NUM_KNOWN_OBJ_ATTRIBUTES 71
104d59d1 1772
3483fe2e
AS
1773/* The value of an object attribute. The type indicates whether the attribute
1774 holds and integer, a string, or both. It can also indicate that there can
8d2c8c3d
AM
1775 be no default (i.e. all values must be written to file, even zero), or
1776 that the value is in error and should not be written to file. */
104d59d1
JM
1777
1778typedef struct obj_attribute
1779{
3483fe2e
AS
1780#define ATTR_TYPE_FLAG_INT_VAL (1 << 0)
1781#define ATTR_TYPE_FLAG_STR_VAL (1 << 1)
1782#define ATTR_TYPE_FLAG_NO_DEFAULT (1 << 2)
8d2c8c3d 1783#define ATTR_TYPE_FLAG_ERROR (1 << 3)
3483fe2e
AS
1784
1785#define ATTR_TYPE_HAS_INT_VAL(TYPE) ((TYPE) & ATTR_TYPE_FLAG_INT_VAL)
1786#define ATTR_TYPE_HAS_STR_VAL(TYPE) ((TYPE) & ATTR_TYPE_FLAG_STR_VAL)
1787#define ATTR_TYPE_HAS_NO_DEFAULT(TYPE) ((TYPE) & ATTR_TYPE_FLAG_NO_DEFAULT)
8d2c8c3d 1788#define ATTR_TYPE_HAS_ERROR(TYPE) ((TYPE) & ATTR_TYPE_FLAG_ERROR)
3483fe2e 1789
104d59d1
JM
1790 int type;
1791 unsigned int i;
1792 char *s;
1793} obj_attribute;
1794
1795typedef struct obj_attribute_list
1796{
1797 struct obj_attribute_list *next;
5ee4a1ca 1798 unsigned int tag;
104d59d1
JM
1799 obj_attribute attr;
1800} obj_attribute_list;
1801
1802/* Object attributes may either be defined by the processor ABI, index
1803 OBJ_ATTR_PROC in the *_obj_attributes arrays, or be GNU-specific
1804 (and possibly also processor-specific), index OBJ_ATTR_GNU. */
1805#define OBJ_ATTR_PROC 0
1806#define OBJ_ATTR_GNU 1
1807#define OBJ_ATTR_FIRST OBJ_ATTR_PROC
1808#define OBJ_ATTR_LAST OBJ_ATTR_GNU
1809
1810/* The following object attribute tags are taken as generic, for all
1811 targets and for "gnu" where there is no target standard. */
1812enum
1813{
1814 Tag_NULL = 0,
1815 Tag_File = 1,
1816 Tag_Section = 2,
1817 Tag_Symbol = 3,
1818 Tag_compatibility = 32
1819};
1820
e21e5835
NC
1821/* The following struct stores information about every SystemTap section
1822 found in the object file. */
1823struct sdt_note
1824{
1825 struct sdt_note *next;
1826 bfd_size_type size;
1827 bfd_byte data[1];
1828};
1829
228e534f
AM
1830/* tdata information grabbed from an elf core file. */
1831struct core_elf_obj_tdata
1832{
1833 int signal;
1834 int pid;
1835 int lwpid;
1836 char* program;
1837 char* command;
1838};
1839
c0355132
AM
1840/* Extra tdata information held for output ELF BFDs. */
1841struct output_elf_obj_tdata
1842{
1843 struct elf_segment_map *seg_map;
1844 struct elf_strtab_hash *strtab_ptr;
1845
1846 /* STT_SECTION symbols for each section */
1847 asymbol **section_syms;
1848
1849 /* Used to determine if PT_GNU_EH_FRAME segment header should be
1850 created. */
1851 asection *eh_frame_hdr;
1852
1853 /* NT_GNU_BUILD_ID note type info. */
1854 struct
1855 {
1856 bfd_boolean (*after_write_object_contents) (bfd *);
1857 const char *style;
1858 asection *sec;
1859 } build_id;
1860
1861 /* Records the result of `get_program_header_size'. */
1862 bfd_size_type program_header_size;
1863
1864 /* Used when laying out sections. */
1865 file_ptr next_file_pos;
1866
1867 int num_section_syms;
1868 unsigned int shstrtab_section, strtab_section;
1869
1870 /* Segment flags for the PT_GNU_STACK segment. */
1871 unsigned int stack_flags;
1872
c0355132
AM
1873 /* Used to determine if the e_flags field has been initialized */
1874 bfd_boolean flags_init;
1875};
1876
df3a023b
AM
1877/* Indicate if the bfd contains SHF_GNU_MBIND sections or symbols that
1878 have the STT_GNU_IFUNC symbol type or STB_GNU_UNIQUE binding. Used
1879 to set the osabi field in the ELF header structure. */
06f44071 1880enum elf_gnu_osabi
9eaff861 1881{
df3a023b 1882 elf_gnu_osabi_mbind = 1 << 0,
06f44071
AM
1883 elf_gnu_osabi_ifunc = 1 << 1,
1884 elf_gnu_osabi_unique = 1 << 2,
9eaff861 1885};
13a2df29 1886
6a40cf0c
NC
1887typedef struct elf_section_list
1888{
07d6d2b8
AM
1889 Elf_Internal_Shdr hdr;
1890 unsigned int ndx;
6a40cf0c
NC
1891 struct elf_section_list * next;
1892} elf_section_list;
9eaff861 1893
0b4453c7
AM
1894enum dynamic_lib_link_class {
1895 DYN_NORMAL = 0,
1896 DYN_AS_NEEDED = 1,
1897 DYN_DT_NEEDED = 2,
1898 DYN_NO_ADD_NEEDED = 4,
1899 DYN_NO_NEEDED = 8
1900};
1901
252b5132
RH
1902/* Some private data is stashed away for future use using the tdata pointer
1903 in the bfd structure. */
1904
1905struct elf_obj_tdata
1906{
1907 Elf_Internal_Ehdr elf_header[1]; /* Actual data, but ref like ptr */
1908 Elf_Internal_Shdr **elf_sect_ptr;
1909 Elf_Internal_Phdr *phdr;
252b5132
RH
1910 Elf_Internal_Shdr symtab_hdr;
1911 Elf_Internal_Shdr shstrtab_hdr;
1912 Elf_Internal_Shdr strtab_hdr;
1913 Elf_Internal_Shdr dynsymtab_hdr;
1914 Elf_Internal_Shdr dynstrtab_hdr;
1915 Elf_Internal_Shdr dynversym_hdr;
1916 Elf_Internal_Shdr dynverref_hdr;
1917 Elf_Internal_Shdr dynverdef_hdr;
6a40cf0c 1918 elf_section_list * symtab_shndx_list;
dbb410c3
AM
1919 bfd_vma gp; /* The gp value */
1920 unsigned int gp_size; /* The gp size */
c0355132 1921 unsigned int num_elf_sections; /* elf_sect_ptr size */
dbb410c3 1922
252b5132
RH
1923 /* A mapping from external symbols to entries in the linker hash
1924 table, used when linking. This is indexed by the symbol index
1925 minus the sh_info field of the symbol table header. */
1926 struct elf_link_hash_entry **sym_hashes;
1927
5cab59f6
AM
1928 /* Track usage and final offsets of GOT entries for local symbols.
1929 This array is indexed by symbol index. Elements are used
1930 identically to "got" in struct elf_link_hash_entry. */
252b5132
RH
1931 union
1932 {
1933 bfd_signed_vma *refcounts;
1934 bfd_vma *offsets;
5cab59f6 1935 struct got_entry **ents;
252b5132
RH
1936 } local_got;
1937
252b5132
RH
1938 /* The linker ELF emulation code needs to let the backend ELF linker
1939 know what filename should be used for a dynamic object if the
1940 dynamic object is found using a search. The emulation code then
1941 sometimes needs to know what name was actually used. Until the
1942 file has been added to the linker symbol table, this field holds
1943 the name the linker wants. After it has been added, it holds the
1944 name actually used, which will be the DT_SONAME entry if there is
1945 one. */
1946 const char *dt_name;
1947
7ee314fa 1948 /* The linker emulation needs to know what audit libs
23209a78 1949 are used by a dynamic object. */
7ee314fa
AM
1950 const char *dt_audit;
1951
252b5132 1952 /* Used by find_nearest_line entry point. */
c39a58e6 1953 void *line_info;
252b5132 1954
3e932841 1955 /* A place to stash dwarf1 info for this bfd. */
252b5132
RH
1956 struct dwarf1_debug *dwarf1_find_line_info;
1957
3e932841 1958 /* A place to stash dwarf2 info for this bfd. */
c39a58e6 1959 void *dwarf2_find_line_info;
252b5132 1960
619a703e
AM
1961 /* Stash away info for yet another find line/function variant. */
1962 void *elf_find_function_cache;
1963
252b5132
RH
1964 /* Number of symbol version definitions we are about to emit. */
1965 unsigned int cverdefs;
1966
1967 /* Number of symbol version references we are about to emit. */
1968 unsigned int cverrefs;
1969
1970 /* Symbol version definitions in external objects. */
1971 Elf_Internal_Verdef *verdef;
1972
1973 /* Symbol version references to external objects. */
1974 Elf_Internal_Verneed *verref;
1975
9d0a14d3
RS
1976 /* A pointer to the .eh_frame section. */
1977 asection *eh_frame_section;
1978
c0f00686 1979 /* Symbol buffer. */
c15f73f9 1980 void *symbuf;
104d59d1 1981
46bed679
L
1982 /* List of GNU properties. Will be updated by setup_gnu_properties
1983 after all input GNU properties are merged for output. */
1984 elf_property_list *properties;
1985
104d59d1
JM
1986 obj_attribute known_obj_attributes[2][NUM_KNOWN_OBJ_ATTRIBUTES];
1987 obj_attribute_list *other_obj_attributes[2];
20a761b5 1988
e21e5835
NC
1989 /* Linked-list containing information about every Systemtap section
1990 found in the object file. Each section corresponds to one entry
1991 in the list. */
1992 struct sdt_note *sdt_note_head;
1993
c0355132 1994 Elf_Internal_Shdr **group_sect_ptr;
cda7e560 1995 unsigned int num_group;
c0355132 1996
564e11c9
JW
1997 /* Index into group_sect_ptr, updated by setup_group when finding a
1998 section's group. Used to optimize subsequent group searches. */
1999 unsigned int group_search_offset;
2000
6a40cf0c 2001 unsigned int symtab_section, dynsymtab_section;
c0355132 2002 unsigned int dynversym_section, dynverdef_section, dynverref_section;
d8045f23 2003
0ffa91dd
NC
2004 /* An identifier used to distinguish different target
2005 specific extensions to this structure. */
a5b4ee94 2006 ENUM_BITFIELD (elf_target_id) object_id : 6;
228e534f 2007
c0355132
AM
2008 /* Whether a dyanmic object was specified normally on the linker
2009 command line, or was specified when --as-needed was in effect,
2010 or was found via a DT_NEEDED entry. */
a5b4ee94
L
2011 ENUM_BITFIELD (dynamic_lib_link_class) dyn_lib_class : 4;
2012
06f44071
AM
2013 /* Whether the bfd uses OS specific bits that require ELFOSABI_GNU. */
2014 ENUM_BITFIELD (elf_gnu_osabi) has_gnu_osabi : 3;
a5b4ee94
L
2015
2016 /* Whether if the bfd contains the GNU_PROPERTY_NO_COPY_ON_PROTECTED
2017 property. */
2018 unsigned int has_no_copy_on_protected : 1;
c0355132
AM
2019
2020 /* Irix 5 often screws up the symbol table, sorting local symbols
2021 after global symbols. This flag is set if the symbol table in
2022 this BFD appears to be screwed up. If it is, we ignore the
2023 sh_info field in the symbol table header, and always read all the
2024 symbols. */
a5b4ee94 2025 unsigned int bad_symtab : 1;
c0355132 2026
228e534f
AM
2027 /* Information grabbed from an elf core file. */
2028 struct core_elf_obj_tdata *core;
c0355132
AM
2029
2030 /* More information held for output ELF BFDs. */
2031 struct output_elf_obj_tdata *o;
252b5132
RH
2032};
2033
2034#define elf_tdata(bfd) ((bfd) -> tdata.elf_obj_data)
0ffa91dd
NC
2035
2036#define elf_object_id(bfd) (elf_tdata(bfd) -> object_id)
c0355132 2037#define elf_program_header_size(bfd) (elf_tdata(bfd) -> o->program_header_size)
252b5132
RH
2038#define elf_elfheader(bfd) (elf_tdata(bfd) -> elf_header)
2039#define elf_elfsections(bfd) (elf_tdata(bfd) -> elf_sect_ptr)
9ad5cbcf 2040#define elf_numsections(bfd) (elf_tdata(bfd) -> num_elf_sections)
c0355132
AM
2041#define elf_seg_map(bfd) (elf_tdata(bfd) -> o->seg_map)
2042#define elf_next_file_pos(bfd) (elf_tdata(bfd) -> o->next_file_pos)
2043#define elf_eh_frame_hdr(bfd) (elf_tdata(bfd) -> o->eh_frame_hdr)
c0355132
AM
2044#define elf_stack_flags(bfd) (elf_tdata(bfd) -> o->stack_flags)
2045#define elf_shstrtab(bfd) (elf_tdata(bfd) -> o->strtab_ptr)
252b5132 2046#define elf_onesymtab(bfd) (elf_tdata(bfd) -> symtab_section)
6a40cf0c 2047#define elf_symtab_shndx_list(bfd) (elf_tdata(bfd) -> symtab_shndx_list)
c0355132
AM
2048#define elf_strtab_sec(bfd) (elf_tdata(bfd) -> o->strtab_section)
2049#define elf_shstrtab_sec(bfd) (elf_tdata(bfd) -> o->shstrtab_section)
0ffa91dd 2050#define elf_symtab_hdr(bfd) (elf_tdata(bfd) -> symtab_hdr)
252b5132
RH
2051#define elf_dynsymtab(bfd) (elf_tdata(bfd) -> dynsymtab_section)
2052#define elf_dynversym(bfd) (elf_tdata(bfd) -> dynversym_section)
2053#define elf_dynverdef(bfd) (elf_tdata(bfd) -> dynverdef_section)
2054#define elf_dynverref(bfd) (elf_tdata(bfd) -> dynverref_section)
9d0a14d3
RS
2055#define elf_eh_frame_section(bfd) \
2056 (elf_tdata(bfd) -> eh_frame_section)
c0355132
AM
2057#define elf_section_syms(bfd) (elf_tdata(bfd) -> o->section_syms)
2058#define elf_num_section_syms(bfd) (elf_tdata(bfd) -> o->num_section_syms)
252b5132
RH
2059#define core_prpsinfo(bfd) (elf_tdata(bfd) -> prpsinfo)
2060#define core_prstatus(bfd) (elf_tdata(bfd) -> prstatus)
2061#define elf_gp(bfd) (elf_tdata(bfd) -> gp)
2062#define elf_gp_size(bfd) (elf_tdata(bfd) -> gp_size)
2063#define elf_sym_hashes(bfd) (elf_tdata(bfd) -> sym_hashes)
2064#define elf_local_got_refcounts(bfd) (elf_tdata(bfd) -> local_got.refcounts)
2065#define elf_local_got_offsets(bfd) (elf_tdata(bfd) -> local_got.offsets)
5cab59f6 2066#define elf_local_got_ents(bfd) (elf_tdata(bfd) -> local_got.ents)
252b5132 2067#define elf_dt_name(bfd) (elf_tdata(bfd) -> dt_name)
7ee314fa 2068#define elf_dt_audit(bfd) (elf_tdata(bfd) -> dt_audit)
4a43e768 2069#define elf_dyn_lib_class(bfd) (elf_tdata(bfd) -> dyn_lib_class)
252b5132 2070#define elf_bad_symtab(bfd) (elf_tdata(bfd) -> bad_symtab)
c0355132 2071#define elf_flags_init(bfd) (elf_tdata(bfd) -> o->flags_init)
104d59d1
JM
2072#define elf_known_obj_attributes(bfd) (elf_tdata (bfd) -> known_obj_attributes)
2073#define elf_other_obj_attributes(bfd) (elf_tdata (bfd) -> other_obj_attributes)
2074#define elf_known_obj_attributes_proc(bfd) \
2075 (elf_known_obj_attributes (bfd) [OBJ_ATTR_PROC])
2076#define elf_other_obj_attributes_proc(bfd) \
2077 (elf_other_obj_attributes (bfd) [OBJ_ATTR_PROC])
46bed679 2078#define elf_properties(bfd) (elf_tdata (bfd) -> properties)
a5b4ee94
L
2079#define elf_has_no_copy_on_protected(bfd) \
2080 (elf_tdata(bfd) -> has_no_copy_on_protected)
252b5132
RH
2081\f
2082extern void _bfd_elf_swap_verdef_in
c39a58e6 2083 (bfd *, const Elf_External_Verdef *, Elf_Internal_Verdef *);
252b5132 2084extern void _bfd_elf_swap_verdef_out
c39a58e6 2085 (bfd *, const Elf_Internal_Verdef *, Elf_External_Verdef *);
252b5132 2086extern void _bfd_elf_swap_verdaux_in
c39a58e6 2087 (bfd *, const Elf_External_Verdaux *, Elf_Internal_Verdaux *);
252b5132 2088extern void _bfd_elf_swap_verdaux_out
c39a58e6 2089 (bfd *, const Elf_Internal_Verdaux *, Elf_External_Verdaux *);
252b5132 2090extern void _bfd_elf_swap_verneed_in
c39a58e6 2091 (bfd *, const Elf_External_Verneed *, Elf_Internal_Verneed *);
252b5132 2092extern void _bfd_elf_swap_verneed_out
c39a58e6 2093 (bfd *, const Elf_Internal_Verneed *, Elf_External_Verneed *);
252b5132 2094extern void _bfd_elf_swap_vernaux_in
c39a58e6 2095 (bfd *, const Elf_External_Vernaux *, Elf_Internal_Vernaux *);
252b5132 2096extern void _bfd_elf_swap_vernaux_out
c39a58e6 2097 (bfd *, const Elf_Internal_Vernaux *, Elf_External_Vernaux *);
252b5132 2098extern void _bfd_elf_swap_versym_in
c39a58e6 2099 (bfd *, const Elf_External_Versym *, Elf_Internal_Versym *);
252b5132 2100extern void _bfd_elf_swap_versym_out
c39a58e6 2101 (bfd *, const Elf_Internal_Versym *, Elf_External_Versym *);
252b5132 2102
cb33740c 2103extern unsigned int _bfd_elf_section_from_bfd_section
c39a58e6 2104 (bfd *, asection *);
252b5132 2105extern char *bfd_elf_string_from_elf_section
c39a58e6 2106 (bfd *, unsigned, unsigned);
6cdc0ccc 2107extern Elf_Internal_Sym *bfd_elf_get_elf_syms
c39a58e6
AM
2108 (bfd *, Elf_Internal_Shdr *, size_t, size_t, Elf_Internal_Sym *, void *,
2109 Elf_External_Sym_Shndx *);
6d5944fc 2110extern char * bfd_elf_get_str_section (bfd *, unsigned int);
0e2cfdce 2111extern const char *bfd_elf_sym_name
26c61ae5 2112 (bfd *, Elf_Internal_Shdr *, Elf_Internal_Sym *, asection *);
252b5132 2113
b34976b6 2114extern bfd_boolean _bfd_elf_copy_private_bfd_data
c39a58e6 2115 (bfd *, bfd *);
b34976b6 2116extern bfd_boolean _bfd_elf_print_private_bfd_data
c39a58e6 2117 (bfd *, void *);
60bb06bc 2118const char * _bfd_elf_get_symbol_version_string
7e6e972f 2119 (bfd *, asymbol *, bfd_boolean, bfd_boolean *);
dc810e39 2120extern void bfd_elf_print_symbol
c39a58e6 2121 (bfd *, void *, asymbol *, bfd_print_symbol_type);
dc810e39 2122
8c946ed5 2123extern unsigned int _bfd_elf_eh_frame_address_size
76c20d54 2124 (bfd *, const asection *);
ec3391e7
AO
2125extern bfd_byte _bfd_elf_encode_eh_address
2126 (bfd *abfd, struct bfd_link_info *info, asection *osec, bfd_vma offset,
2127 asection *loc_sec, bfd_vma loc_offset, bfd_vma *encoded);
2128extern bfd_boolean _bfd_elf_can_make_relative
2129 (bfd *input_bfd, struct bfd_link_info *info, asection *eh_frame_section);
2130
dc810e39 2131extern enum elf_reloc_type_class _bfd_elf_reloc_type_class
7e612e98
AM
2132 (const struct bfd_link_info *, const asection *,
2133 const Elf_Internal_Rela *);
f8df10f4 2134extern bfd_vma _bfd_elf_rela_local_sym
8517fae7 2135 (bfd *, Elf_Internal_Sym *, asection **, Elf_Internal_Rela *);
c629eae0 2136extern bfd_vma _bfd_elf_rel_local_sym
c39a58e6 2137 (bfd *, Elf_Internal_Sym *, asection **, bfd_vma);
c629eae0 2138extern bfd_vma _bfd_elf_section_offset
c39a58e6 2139 (bfd *, struct bfd_link_info *, asection *, bfd_vma);
db6751f2 2140
dc810e39 2141extern unsigned long bfd_elf_hash
c39a58e6 2142 (const char *);
fdc90cb4
JJ
2143extern unsigned long bfd_elf_gnu_hash
2144 (const char *);
252b5132 2145
dc810e39 2146extern bfd_reloc_status_type bfd_elf_generic_reloc
c39a58e6 2147 (bfd *, arelent *, asymbol *, void *, asection *, bfd *, char **);
0ffa91dd 2148extern bfd_boolean bfd_elf_allocate_object
4dfe6ac6 2149 (bfd *, size_t, enum elf_target_id);
ae95ffa6 2150extern bfd_boolean bfd_elf_make_object
c39a58e6 2151 (bfd *);
b34976b6 2152extern bfd_boolean bfd_elf_mkcorefile
c39a58e6 2153 (bfd *);
b34976b6 2154extern bfd_boolean _bfd_elf_make_section_from_shdr
6dc132d9 2155 (bfd *, Elf_Internal_Shdr *, const char *, int);
b34976b6 2156extern bfd_boolean _bfd_elf_make_section_from_phdr
c39a58e6 2157 (bfd *, Elf_Internal_Phdr *, int, const char *);
252b5132 2158extern struct bfd_hash_entry *_bfd_elf_link_hash_newfunc
c39a58e6 2159 (struct bfd_hash_entry *, struct bfd_hash_table *, const char *);
252b5132 2160extern struct bfd_link_hash_table *_bfd_elf_link_hash_table_create
c39a58e6 2161 (bfd *);
9f7c3e5e 2162extern void _bfd_elf_link_hash_table_free
d495ab0d 2163 (bfd *);
c61b8717 2164extern void _bfd_elf_link_hash_copy_indirect
fcfa13d2 2165 (struct bfd_link_info *, struct elf_link_hash_entry *,
c39a58e6 2166 struct elf_link_hash_entry *);
c61b8717 2167extern void _bfd_elf_link_hash_hide_symbol
c39a58e6 2168 (struct bfd_link_info *, struct elf_link_hash_entry *, bfd_boolean);
34a87bb0
L
2169extern void _bfd_elf_link_hide_symbol
2170 (bfd *, struct bfd_link_info *, struct bfd_link_hash_entry *);
508c3946
L
2171extern bfd_boolean _bfd_elf_link_hash_fixup_symbol
2172 (struct bfd_link_info *, struct elf_link_hash_entry *);
b34976b6 2173extern bfd_boolean _bfd_elf_link_hash_table_init
c39a58e6
AM
2174 (struct elf_link_hash_table *, bfd *,
2175 struct bfd_hash_entry *(*)
66eb6687 2176 (struct bfd_hash_entry *, struct bfd_hash_table *, const char *),
4dfe6ac6 2177 unsigned int, enum elf_target_id);
b34976b6 2178extern bfd_boolean _bfd_elf_slurp_version_tables
fc0e6df6 2179 (bfd *, bfd_boolean);
b34976b6 2180extern bfd_boolean _bfd_elf_merge_sections
c39a58e6 2181 (bfd *, struct bfd_link_info *);
ecca9871
L
2182extern bfd_boolean _bfd_elf_match_sections_by_type
2183 (bfd *, const asection *, bfd *, const asection *);
72adc230
AM
2184extern bfd_boolean bfd_elf_is_group_section
2185 (bfd *, const struct bfd_section *);
cb7f4b29
AM
2186extern const char *bfd_elf_group_name
2187 (bfd *, const struct bfd_section *);
43e1669b 2188extern bfd_boolean _bfd_elf_section_already_linked
c77ec726 2189 (bfd *, asection *, struct bfd_link_info *);
1126897b 2190extern void bfd_elf_set_group_contents
c39a58e6 2191 (bfd *, asection *, void *);
76359541
TP
2192extern unsigned int _bfd_elf_filter_global_symbols
2193 (bfd *, struct bfd_link_info *, asymbol **, long);
01b3c8ab 2194extern asection *_bfd_elf_check_kept_section
c0f00686 2195 (asection *, struct bfd_link_info *);
dbaa2011 2196#define _bfd_elf_link_just_syms _bfd_generic_link_just_syms
1338dd10
PB
2197extern void _bfd_elf_copy_link_hash_symbol_type
2198 (bfd *, struct bfd_link_hash_entry *, struct bfd_link_hash_entry *);
d0bf826b
AM
2199extern bfd_boolean _bfd_elf_size_group_sections
2200 (struct bfd_link_info *);
2201extern bfd_boolean _bfd_elf_fixup_group_sections
2202(bfd *, asection *);
80fccad2
BW
2203extern bfd_boolean _bfd_elf_copy_private_header_data
2204 (bfd *, bfd *);
b34976b6 2205extern bfd_boolean _bfd_elf_copy_private_symbol_data
c39a58e6 2206 (bfd *, asymbol *, bfd *, asymbol *);
ccd2ec6a
L
2207#define _bfd_generic_init_private_section_data \
2208 _bfd_elf_init_private_section_data
2209extern bfd_boolean _bfd_elf_init_private_section_data
2210 (bfd *, asection *, bfd *, asection *, struct bfd_link_info *);
b34976b6 2211extern bfd_boolean _bfd_elf_copy_private_section_data
c39a58e6 2212 (bfd *, asection *, bfd *, asection *);
b34976b6 2213extern bfd_boolean _bfd_elf_write_object_contents
c39a58e6 2214 (bfd *);
b34976b6 2215extern bfd_boolean _bfd_elf_write_corefile_contents
c39a58e6 2216 (bfd *);
b34976b6 2217extern bfd_boolean _bfd_elf_set_section_contents
0f867abe 2218 (bfd *, sec_ptr, const void *, file_ptr, bfd_size_type);
dc810e39 2219extern long _bfd_elf_get_symtab_upper_bound
c39a58e6 2220 (bfd *);
6cee3f79 2221extern long _bfd_elf_canonicalize_symtab
c39a58e6 2222 (bfd *, asymbol **);
dc810e39 2223extern long _bfd_elf_get_dynamic_symtab_upper_bound
c39a58e6 2224 (bfd *);
dc810e39 2225extern long _bfd_elf_canonicalize_dynamic_symtab
c39a58e6 2226 (bfd *, asymbol **);
4c45e5c9 2227extern long _bfd_elf_get_synthetic_symtab
c9727e01 2228 (bfd *, long, asymbol **, long, asymbol **, asymbol **);
dc810e39 2229extern long _bfd_elf_get_reloc_upper_bound
c39a58e6 2230 (bfd *, sec_ptr);
dc810e39 2231extern long _bfd_elf_canonicalize_reloc
c39a58e6 2232 (bfd *, sec_ptr, arelent **, asymbol **);
83bac4b0
NC
2233extern asection * _bfd_elf_get_dynamic_reloc_section
2234 (bfd *, asection *, bfd_boolean);
2235extern asection * _bfd_elf_make_dynamic_reloc_section
2236 (asection *, bfd *, unsigned int, bfd *, bfd_boolean);
dc810e39 2237extern long _bfd_elf_get_dynamic_reloc_upper_bound
c39a58e6 2238 (bfd *);
dc810e39 2239extern long _bfd_elf_canonicalize_dynamic_reloc
c39a58e6 2240 (bfd *, arelent **, asymbol **);
dc810e39 2241extern asymbol *_bfd_elf_make_empty_symbol
c39a58e6 2242 (bfd *);
dc810e39 2243extern void _bfd_elf_get_symbol_info
c39a58e6 2244 (bfd *, asymbol *, symbol_info *);
b34976b6 2245extern bfd_boolean _bfd_elf_is_local_label_name
c39a58e6 2246 (bfd *, const char *);
dc810e39 2247extern alent *_bfd_elf_get_lineno
c39a58e6 2248 (bfd *, asymbol *);
b34976b6 2249extern bfd_boolean _bfd_elf_set_arch_mach
c39a58e6 2250 (bfd *, enum bfd_architecture, unsigned long);
b34976b6 2251extern bfd_boolean _bfd_elf_find_nearest_line
fb167eb2
AM
2252 (bfd *, asymbol **, asection *, bfd_vma,
2253 const char **, const char **, unsigned int *, unsigned int *);
5420f73d
L
2254extern bfd_boolean _bfd_elf_find_line
2255 (bfd *, asymbol **, asymbol *, const char **, unsigned int *);
4ab527b0
FF
2256extern bfd_boolean _bfd_elf_find_inliner_info
2257 (bfd *, const char **, const char **, unsigned int *);
923b198a 2258extern asymbol *_bfd_elf_find_function
e00e8198 2259 (bfd *, asymbol **, asection *, bfd_vma, const char **, const char **);
252b5132
RH
2260#define _bfd_elf_read_minisymbols _bfd_generic_read_minisymbols
2261#define _bfd_elf_minisymbol_to_symbol _bfd_generic_minisymbol_to_symbol
dc810e39 2262extern int _bfd_elf_sizeof_headers
a6b96beb 2263 (bfd *, struct bfd_link_info *);
b34976b6 2264extern bfd_boolean _bfd_elf_new_section_hook
c39a58e6 2265 (bfd *, asection *);
551b43fd
AM
2266extern const struct bfd_elf_special_section *_bfd_elf_get_special_section
2267 (const char *, const struct bfd_elf_special_section *, unsigned int);
7dcb9820 2268extern const struct bfd_elf_special_section *_bfd_elf_get_sec_type_attr
551b43fd 2269 (bfd *, asection *);
252b5132 2270
099bb8fb
L
2271extern bfd_boolean _bfd_elf_link_hide_sym_by_version
2272 (struct bfd_link_info *, struct elf_link_hash_entry *);
2273
252b5132 2274/* If the target doesn't have reloc handling written yet: */
f3185997 2275extern bfd_boolean _bfd_elf_no_info_to_howto
c39a58e6 2276 (bfd *, arelent *, Elf_Internal_Rela *);
dc810e39 2277
b34976b6 2278extern bfd_boolean bfd_section_from_shdr
c39a58e6 2279 (bfd *, unsigned int shindex);
b34976b6 2280extern bfd_boolean bfd_section_from_phdr
c39a58e6 2281 (bfd *, Elf_Internal_Phdr *, int);
dc810e39
AM
2282
2283extern int _bfd_elf_symbol_from_bfd_symbol
c39a58e6 2284 (bfd *, asymbol **);
dc810e39 2285
23209a78 2286extern Elf_Internal_Sym *bfd_sym_from_r_symndx
87d72d41 2287 (struct sym_cache *, bfd *, unsigned long);
dc810e39 2288extern asection *bfd_section_from_elf_index
c39a58e6 2289 (bfd *, unsigned int);
2b0f7ef9
JJ
2290
2291extern struct elf_strtab_hash * _bfd_elf_strtab_init
c39a58e6 2292 (void);
2b0f7ef9 2293extern void _bfd_elf_strtab_free
c39a58e6 2294 (struct elf_strtab_hash *);
ef53be89 2295extern size_t _bfd_elf_strtab_add
c39a58e6 2296 (struct elf_strtab_hash *, const char *, bfd_boolean);
2b0f7ef9 2297extern void _bfd_elf_strtab_addref
ef53be89 2298 (struct elf_strtab_hash *, size_t);
2b0f7ef9 2299extern void _bfd_elf_strtab_delref
ef53be89 2300 (struct elf_strtab_hash *, size_t);
02be4619 2301extern unsigned int _bfd_elf_strtab_refcount
ef53be89 2302 (struct elf_strtab_hash *, size_t);
d45f8bda 2303extern void _bfd_elf_strtab_clear_all_refs
5b677558
AM
2304 (struct elf_strtab_hash *);
2305extern void *_bfd_elf_strtab_save
2306 (struct elf_strtab_hash *);
2307extern void _bfd_elf_strtab_restore
2308 (struct elf_strtab_hash *, void *);
2b0f7ef9 2309extern bfd_size_type _bfd_elf_strtab_size
c39a58e6 2310 (struct elf_strtab_hash *);
22ccb849
NA
2311extern bfd_size_type _bfd_elf_strtab_len
2312 (struct elf_strtab_hash *);
2b0f7ef9 2313extern bfd_size_type _bfd_elf_strtab_offset
ef53be89 2314 (struct elf_strtab_hash *, size_t);
22ccb849 2315extern const char * _bfd_elf_strtab_str
1ff6de03 2316 (struct elf_strtab_hash *, size_t idx, bfd_size_type *offset);
b34976b6 2317extern bfd_boolean _bfd_elf_strtab_emit
c39a58e6 2318 (bfd *, struct elf_strtab_hash *);
2b0f7ef9 2319extern void _bfd_elf_strtab_finalize
c39a58e6 2320 (struct elf_strtab_hash *);
2b0f7ef9 2321
2f0c68f2
CM
2322extern bfd_boolean bfd_elf_parse_eh_frame_entries
2323 (bfd *, struct bfd_link_info *);
2324extern bfd_boolean _bfd_elf_parse_eh_frame_entry
2325 (struct bfd_link_info *, asection *, struct elf_reloc_cookie *);
ca92cecb
RS
2326extern void _bfd_elf_parse_eh_frame
2327 (bfd *, struct bfd_link_info *, asection *, struct elf_reloc_cookie *);
2f0c68f2
CM
2328extern bfd_boolean _bfd_elf_end_eh_frame_parsing
2329 (struct bfd_link_info *info);
2330
b34976b6 2331extern bfd_boolean _bfd_elf_discard_section_eh_frame
c39a58e6
AM
2332 (bfd *, struct bfd_link_info *, asection *,
2333 bfd_boolean (*) (bfd_vma, void *), struct elf_reloc_cookie *);
d7153c4a
AM
2334extern bfd_boolean _bfd_elf_adjust_eh_frame_global_symbol
2335 (struct elf_link_hash_entry *, void *);
b34976b6 2336extern bfd_boolean _bfd_elf_discard_section_eh_frame_hdr
c39a58e6 2337 (bfd *, struct bfd_link_info *);
65765700 2338extern bfd_vma _bfd_elf_eh_frame_section_offset
92e4ec35 2339 (bfd *, struct bfd_link_info *, asection *, bfd_vma);
b34976b6 2340extern bfd_boolean _bfd_elf_write_section_eh_frame
c39a58e6 2341 (bfd *, struct bfd_link_info *, asection *, bfd_byte *);
2f0c68f2
CM
2342bfd_boolean _bfd_elf_write_section_eh_frame_entry
2343 (bfd *, struct bfd_link_info *, asection *, bfd_byte *);
2344extern bfd_boolean _bfd_elf_fixup_eh_frame_hdr (struct bfd_link_info *);
b34976b6 2345extern bfd_boolean _bfd_elf_write_section_eh_frame_hdr
c39a58e6 2346 (bfd *, struct bfd_link_info *);
9a2a56cc
AM
2347extern bfd_boolean _bfd_elf_eh_frame_present
2348 (struct bfd_link_info *);
2f0c68f2
CM
2349extern bfd_boolean _bfd_elf_eh_frame_entry_present
2350 (struct bfd_link_info *);
b34976b6 2351extern bfd_boolean _bfd_elf_maybe_strip_eh_frame_hdr
c39a58e6 2352 (struct bfd_link_info *);
65765700 2353
fdc90cb4
JJ
2354extern bfd_boolean _bfd_elf_hash_symbol (struct elf_link_hash_entry *);
2355
dc810e39 2356extern long _bfd_elf_link_lookup_local_dynindx
c39a58e6 2357 (struct bfd_link_info *, bfd *, long);
b34976b6 2358extern bfd_boolean _bfd_elf_compute_section_file_positions
c39a58e6 2359 (bfd *, struct bfd_link_info *);
dc810e39 2360extern file_ptr _bfd_elf_assign_file_position_for_section
c39a58e6 2361 (Elf_Internal_Shdr *, file_ptr, bfd_boolean);
6d6c25c8
AM
2362extern bfd_boolean _bfd_elf_modify_headers
2363 (bfd *, struct bfd_link_info *);
dc810e39 2364
b34976b6 2365extern bfd_boolean _bfd_elf_validate_reloc
c39a58e6 2366 (bfd *, arelent *);
dc810e39 2367
0b4453c7
AM
2368extern bfd_boolean bfd_elf_record_link_assignment
2369 (bfd *, struct bfd_link_info *, const char *, bfd_boolean,
2370 bfd_boolean);
2371extern bfd_boolean bfd_elf_stack_segment_size (bfd *, struct bfd_link_info *,
2372 const char *, bfd_vma);
2373extern bfd_boolean bfd_elf_size_dynamic_sections
2374 (bfd *, const char *, const char *, const char *, const char *, const char *,
2375 const char * const *, struct bfd_link_info *, struct bfd_section **);
2376extern bfd_boolean bfd_elf_size_dynsym_hash_dynstr
2377 (bfd *, struct bfd_link_info *);
2378extern bfd_boolean bfd_elf_get_bfd_needed_list
2379 (bfd *, struct bfd_link_needed_list **);
2380extern struct bfd_link_needed_list *bfd_elf_get_needed_list
2381 (bfd *, struct bfd_link_info *);
2382extern void bfd_elf_set_dt_needed_name
2383 (bfd *, const char *);
2384extern const char *bfd_elf_get_dt_soname
2385 (bfd *);
2386extern void bfd_elf_set_dyn_lib_class
2387 (bfd *, enum dynamic_lib_link_class);
2388extern int bfd_elf_get_dyn_lib_class
2389 (bfd *);
2390extern struct bfd_link_needed_list *bfd_elf_get_runpath_list
2391 (bfd *, struct bfd_link_info *);
2392extern int bfd_elf_discard_info
2393 (bfd *, struct bfd_link_info *);
2394extern unsigned int _bfd_elf_default_action_discarded
2395 (struct bfd_section *);
2396extern struct bfd_section *_bfd_elf_tls_setup
2397 (bfd *, struct bfd_link_info *);
2398
45d6a902 2399extern bfd_boolean _bfd_elf_link_create_dynamic_sections
c39a58e6 2400 (bfd *, struct bfd_link_info *);
d00dd7dc
AM
2401extern bfd_boolean _bfd_elf_omit_section_dynsym_default
2402 (bfd *, struct bfd_link_info *, asection *);
2403extern bfd_boolean _bfd_elf_omit_section_dynsym_all
aee6f5b4 2404 (bfd *, struct bfd_link_info *, asection *);
b34976b6 2405extern bfd_boolean _bfd_elf_create_dynamic_sections
c39a58e6 2406 (bfd *, struct bfd_link_info *);
b34976b6 2407extern bfd_boolean _bfd_elf_create_got_section
c39a58e6 2408 (bfd *, struct bfd_link_info *);
2f0c68f2
CM
2409extern asection *_bfd_elf_section_for_symbol
2410 (struct elf_reloc_cookie *, unsigned long, bfd_boolean);
d98685ac
AM
2411extern struct elf_link_hash_entry *_bfd_elf_define_linkage_sym
2412 (bfd *, struct bfd_link_info *, asection *, const char *);
74541ad4
AM
2413extern void _bfd_elf_init_1_index_section
2414 (bfd *, struct bfd_link_info *);
2415extern void _bfd_elf_init_2_index_sections
2416 (bfd *, struct bfd_link_info *);
dc810e39 2417
b34976b6 2418extern bfd_boolean _bfd_elfcore_make_pseudosection
c39a58e6 2419 (bfd *, char *, size_t, ufile_ptr);
dc810e39 2420extern char *_bfd_elfcore_strndup
c39a58e6 2421 (bfd *, char *, size_t);
dc810e39 2422
45d6a902 2423extern Elf_Internal_Rela *_bfd_elf_link_read_relocs
c39a58e6 2424 (bfd *, asection *, void *, Elf_Internal_Rela *, bfd_boolean);
45d6a902 2425
45d6a902 2426extern bfd_boolean _bfd_elf_link_output_relocs
eac338cf
PB
2427 (bfd *, asection *, Elf_Internal_Shdr *, Elf_Internal_Rela *,
2428 struct elf_link_hash_entry **);
45d6a902 2429
027297b7 2430extern bfd_boolean _bfd_elf_adjust_dynamic_copy
6cabe1ea 2431 (struct bfd_link_info *, struct elf_link_hash_entry *, asection *);
027297b7 2432
986a241f 2433extern bfd_boolean _bfd_elf_dynamic_symbol_p
c39a58e6 2434 (struct elf_link_hash_entry *, struct bfd_link_info *, bfd_boolean);
f6c52c13
AM
2435
2436extern bfd_boolean _bfd_elf_symbol_refs_local_p
c39a58e6 2437 (struct elf_link_hash_entry *, struct bfd_link_info *, bfd_boolean);
986a241f 2438
cdfeee4f 2439extern bfd_reloc_status_type bfd_elf_perform_complex_relocation
0f02bbd9 2440 (bfd *, asection *, bfd_byte *, Elf_Internal_Rela *, bfd_vma);
d9352518 2441
dd863624 2442extern bfd_boolean _bfd_elf_setup_sections
3d7f7666
L
2443 (bfd *);
2444
7dba9362
AM
2445extern struct bfd_link_hash_entry *bfd_elf_define_start_stop
2446 (struct bfd_link_info *, const char *, asection *);
2447
ed7e9d0b 2448extern bfd_boolean _bfd_elf_init_file_header (bfd *, struct bfd_link_info *);
06f44071 2449
cc364be6 2450extern bfd_boolean _bfd_elf_final_write_processing (bfd *);
d1036acb 2451
cb001c0d 2452extern bfd_cleanup bfd_elf32_object_p
c39a58e6 2453 (bfd *);
cb001c0d 2454extern bfd_cleanup bfd_elf32_core_file_p
c39a58e6 2455 (bfd *);
dc810e39 2456extern char *bfd_elf32_core_file_failing_command
c39a58e6 2457 (bfd *);
dc810e39 2458extern int bfd_elf32_core_file_failing_signal
c39a58e6 2459 (bfd *);
b34976b6 2460extern bfd_boolean bfd_elf32_core_file_matches_executable_p
c39a58e6 2461 (bfd *, bfd *);
261b8d08
PA
2462extern int bfd_elf32_core_file_pid
2463 (bfd *);
864619bb
KS
2464extern bfd_boolean _bfd_elf32_core_find_build_id
2465 (bfd *, bfd_vma);
252b5132 2466
8384fb8f 2467extern bfd_boolean bfd_elf32_swap_symbol_in
c39a58e6 2468 (bfd *, const void *, const void *, Elf_Internal_Sym *);
252b5132 2469extern void bfd_elf32_swap_symbol_out
c39a58e6 2470 (bfd *, const Elf_Internal_Sym *, void *, void *);
252b5132 2471extern void bfd_elf32_swap_reloc_in
c39a58e6 2472 (bfd *, const bfd_byte *, Elf_Internal_Rela *);
252b5132 2473extern void bfd_elf32_swap_reloc_out
c39a58e6 2474 (bfd *, const Elf_Internal_Rela *, bfd_byte *);
252b5132 2475extern void bfd_elf32_swap_reloca_in
c39a58e6 2476 (bfd *, const bfd_byte *, Elf_Internal_Rela *);
252b5132 2477extern void bfd_elf32_swap_reloca_out
c39a58e6 2478 (bfd *, const Elf_Internal_Rela *, bfd_byte *);
252b5132 2479extern void bfd_elf32_swap_phdr_in
c39a58e6 2480 (bfd *, const Elf32_External_Phdr *, Elf_Internal_Phdr *);
252b5132 2481extern void bfd_elf32_swap_phdr_out
c39a58e6 2482 (bfd *, const Elf_Internal_Phdr *, Elf32_External_Phdr *);
252b5132 2483extern void bfd_elf32_swap_dyn_in
c39a58e6 2484 (bfd *, const void *, Elf_Internal_Dyn *);
252b5132 2485extern void bfd_elf32_swap_dyn_out
c39a58e6 2486 (bfd *, const Elf_Internal_Dyn *, void *);
252b5132 2487extern long bfd_elf32_slurp_symbol_table
c39a58e6 2488 (bfd *, asymbol **, bfd_boolean);
b34976b6 2489extern bfd_boolean bfd_elf32_write_shdrs_and_ehdr
c39a58e6 2490 (bfd *);
252b5132 2491extern int bfd_elf32_write_out_phdrs
c39a58e6 2492 (bfd *, const Elf_Internal_Phdr *, unsigned int);
20a761b5
RM
2493extern bfd_boolean bfd_elf32_checksum_contents
2494 (bfd * , void (*) (const void *, size_t, void *), void *);
b9f66672 2495extern void bfd_elf32_write_relocs
c39a58e6 2496 (bfd *, asection *, void *);
b34976b6 2497extern bfd_boolean bfd_elf32_slurp_reloc_table
c39a58e6 2498 (bfd *, asection *, asymbol **, bfd_boolean);
252b5132 2499
cb001c0d 2500extern bfd_cleanup bfd_elf64_object_p
c39a58e6 2501 (bfd *);
cb001c0d 2502extern bfd_cleanup bfd_elf64_core_file_p
c39a58e6 2503 (bfd *);
dc810e39 2504extern char *bfd_elf64_core_file_failing_command
c39a58e6 2505 (bfd *);
dc810e39 2506extern int bfd_elf64_core_file_failing_signal
c39a58e6 2507 (bfd *);
b34976b6 2508extern bfd_boolean bfd_elf64_core_file_matches_executable_p
c39a58e6 2509 (bfd *, bfd *);
261b8d08
PA
2510extern int bfd_elf64_core_file_pid
2511 (bfd *);
864619bb
KS
2512extern bfd_boolean _bfd_elf64_core_find_build_id
2513 (bfd *, bfd_vma);
252b5132 2514
8384fb8f 2515extern bfd_boolean bfd_elf64_swap_symbol_in
c39a58e6 2516 (bfd *, const void *, const void *, Elf_Internal_Sym *);
252b5132 2517extern void bfd_elf64_swap_symbol_out
c39a58e6 2518 (bfd *, const Elf_Internal_Sym *, void *, void *);
252b5132 2519extern void bfd_elf64_swap_reloc_in
c39a58e6 2520 (bfd *, const bfd_byte *, Elf_Internal_Rela *);
252b5132 2521extern void bfd_elf64_swap_reloc_out
c39a58e6 2522 (bfd *, const Elf_Internal_Rela *, bfd_byte *);
252b5132 2523extern void bfd_elf64_swap_reloca_in
c39a58e6 2524 (bfd *, const bfd_byte *, Elf_Internal_Rela *);
252b5132 2525extern void bfd_elf64_swap_reloca_out
c39a58e6 2526 (bfd *, const Elf_Internal_Rela *, bfd_byte *);
252b5132 2527extern void bfd_elf64_swap_phdr_in
c39a58e6 2528 (bfd *, const Elf64_External_Phdr *, Elf_Internal_Phdr *);
252b5132 2529extern void bfd_elf64_swap_phdr_out
c39a58e6 2530 (bfd *, const Elf_Internal_Phdr *, Elf64_External_Phdr *);
252b5132 2531extern void bfd_elf64_swap_dyn_in
c39a58e6 2532 (bfd *, const void *, Elf_Internal_Dyn *);
252b5132 2533extern void bfd_elf64_swap_dyn_out
c39a58e6 2534 (bfd *, const Elf_Internal_Dyn *, void *);
252b5132 2535extern long bfd_elf64_slurp_symbol_table
c39a58e6 2536 (bfd *, asymbol **, bfd_boolean);
b34976b6 2537extern bfd_boolean bfd_elf64_write_shdrs_and_ehdr
c39a58e6 2538 (bfd *);
252b5132 2539extern int bfd_elf64_write_out_phdrs
c39a58e6 2540 (bfd *, const Elf_Internal_Phdr *, unsigned int);
20a761b5
RM
2541extern bfd_boolean bfd_elf64_checksum_contents
2542 (bfd * , void (*) (const void *, size_t, void *), void *);
b9f66672 2543extern void bfd_elf64_write_relocs
c39a58e6 2544 (bfd *, asection *, void *);
b34976b6 2545extern bfd_boolean bfd_elf64_slurp_reloc_table
c39a58e6 2546 (bfd *, asection *, asymbol **, bfd_boolean);
5a580b3a 2547
13285a1b
AM
2548extern bfd_boolean _bfd_elf_default_relocs_compatible
2549 (const bfd_target *, const bfd_target *);
2550
2551extern bfd_boolean _bfd_elf_relocs_compatible
2552 (const bfd_target *, const bfd_target *);
e5034e59
AM
2553extern bfd_boolean _bfd_elf_notice_as_needed
2554 (bfd *, struct bfd_link_info *, enum notice_asneeded_action);
13285a1b 2555
8387904d
AM
2556extern struct elf_link_hash_entry *_bfd_elf_archive_symbol_lookup
2557 (bfd *, struct bfd_link_info *, const char *);
4ad4eba5
AM
2558extern bfd_boolean bfd_elf_link_add_symbols
2559 (bfd *, struct bfd_link_info *);
5a580b3a 2560extern bfd_boolean _bfd_elf_add_dynamic_entry
c39a58e6 2561 (struct bfd_link_info *, bfd_vma, bfd_vma);
6f6fd151
L
2562extern bfd_boolean _bfd_elf_strip_zero_sized_dynamic_sections
2563 (struct bfd_link_info *);
e310298c
AM
2564extern int bfd_elf_add_dt_needed_tag
2565 (bfd *, struct bfd_link_info *);
d9689752
L
2566extern bfd_boolean _bfd_elf_link_check_relocs
2567 (bfd *, struct bfd_link_info *);
252b5132 2568
c152c796
AM
2569extern bfd_boolean bfd_elf_link_record_dynamic_symbol
2570 (struct bfd_link_info *, struct elf_link_hash_entry *);
30b30c21 2571
c152c796 2572extern int bfd_elf_link_record_local_dynamic_symbol
c39a58e6 2573 (struct bfd_link_info *, bfd *, long);
252b5132 2574
b34976b6 2575extern bfd_boolean _bfd_elf_close_and_cleanup
c39a58e6 2576 (bfd *);
35330cce 2577
a4d8e49b
L
2578extern bfd_boolean _bfd_elf_common_definition
2579 (Elf_Internal_Sym *);
2580
2581extern unsigned int _bfd_elf_common_section_index
2582 (asection *);
2583
2584extern asection *_bfd_elf_common_section
2585 (asection *);
2586
10455f89
HPN
2587extern bfd_vma _bfd_elf_default_got_elt_size
2588(bfd *, struct bfd_link_info *, struct elf_link_hash_entry *, bfd *,
2589 unsigned long);
2590
252b5132 2591extern bfd_reloc_status_type _bfd_elf_rel_vtable_reloc_fn
fc0a2244 2592 (bfd *, arelent *, struct bfd_symbol *, void *,
c39a58e6 2593 asection *, bfd *, char **);
252b5132 2594
c152c796 2595extern bfd_boolean bfd_elf_final_link
c39a58e6 2596 (bfd *, struct bfd_link_info *);
c152c796 2597
74f0fb50
AM
2598extern void _bfd_elf_gc_keep
2599 (struct bfd_link_info *info);
2600
64d03ab5
AM
2601extern bfd_boolean bfd_elf_gc_mark_dynamic_ref_symbol
2602 (struct elf_link_hash_entry *h, void *inf);
2603
c152c796 2604extern bfd_boolean bfd_elf_gc_sections
c39a58e6 2605 (bfd *, struct bfd_link_info *);
c152c796
AM
2606
2607extern bfd_boolean bfd_elf_gc_record_vtinherit
c39a58e6 2608 (bfd *, asection *, struct elf_link_hash_entry *, bfd_vma);
c152c796
AM
2609
2610extern bfd_boolean bfd_elf_gc_record_vtentry
c39a58e6 2611 (bfd *, asection *, struct elf_link_hash_entry *, bfd_vma);
252b5132 2612
07adf181
AM
2613extern asection *_bfd_elf_gc_mark_hook
2614 (asection *, struct bfd_link_info *, Elf_Internal_Rela *,
2615 struct elf_link_hash_entry *, Elf_Internal_Sym *);
2616
5241d853
RS
2617extern asection *_bfd_elf_gc_mark_rsec
2618 (struct bfd_link_info *, asection *, elf_gc_mark_hook_fn,
1cce69b9 2619 struct elf_reloc_cookie *, bfd_boolean *);
5241d853
RS
2620
2621extern bfd_boolean _bfd_elf_gc_mark_reloc
2622 (struct bfd_link_info *, asection *, elf_gc_mark_hook_fn,
9d0a14d3
RS
2623 struct elf_reloc_cookie *);
2624
2625extern bfd_boolean _bfd_elf_gc_mark_fdes
2626 (struct bfd_link_info *, asection *, asection *, elf_gc_mark_hook_fn,
2627 struct elf_reloc_cookie *);
5241d853 2628
ccfa59ea 2629extern bfd_boolean _bfd_elf_gc_mark
5241d853 2630 (struct bfd_link_info *, asection *, elf_gc_mark_hook_fn);
ccfa59ea 2631
7f6ab9f8
AM
2632extern bfd_boolean _bfd_elf_gc_mark_extra_sections
2633 (struct bfd_link_info *, elf_gc_mark_hook_fn);
2634
c152c796 2635extern bfd_boolean bfd_elf_gc_common_finalize_got_offsets
c39a58e6 2636 (bfd *, struct bfd_link_info *);
c152c796
AM
2637
2638extern bfd_boolean bfd_elf_gc_common_final_link
c39a58e6 2639 (bfd *, struct bfd_link_info *);
252b5132 2640
c152c796 2641extern bfd_boolean bfd_elf_reloc_symbol_deleted_p
c39a58e6 2642 (bfd_vma, void *);
73d074b4 2643
8ded5a0f 2644extern struct elf_segment_map * _bfd_elf_make_dynamic_segment
229fcec5
MM
2645 (bfd *, asection *);
2646
8ded5a0f
AM
2647extern bfd_boolean _bfd_elf_map_sections_to_segments
2648 (bfd *, struct bfd_link_info *);
2649
fcb93ecf
PB
2650extern bfd_boolean _bfd_elf_is_function_type (unsigned int);
2651
aef36ac1
AM
2652extern bfd_size_type _bfd_elf_maybe_function_sym (const asymbol *, asection *,
2653 bfd_vma *);
9f296da3 2654
bce964aa 2655extern asection *_bfd_elf_plt_get_reloc_section (bfd *, const char *);
bd53a53a 2656
94be91de
JB
2657extern int bfd_elf_get_default_section_type (flagword);
2658
b9c361e0
JL
2659extern bfd_boolean bfd_elf_lookup_section_flags
2660 (struct bfd_link_info *, struct flag_info *, asection *);
ae17ab41 2661
2ea37f1c
NC
2662extern Elf_Internal_Phdr * _bfd_elf_find_segment_containing_section
2663 (bfd * abfd, asection * section);
2664
14b57c7c
AM
2665/* PowerPC @tls opcode transform/validate. */
2666extern unsigned int _bfd_elf_ppc_at_tls_transform
2667 (unsigned int, unsigned int);
2668/* PowerPC @tprel opcode transform/validate. */
2669extern unsigned int _bfd_elf_ppc_at_tprel_transform
2670 (unsigned int, unsigned int);
2671/* PowerPC elf_object_p tweak. */
2672extern bfd_boolean _bfd_elf_ppc_set_arch (bfd *);
005d79fd 2673/* PowerPC .gnu.attributes handling common to both 32-bit and 64-bit. */
4a91d0ba
AM
2674extern bfd_boolean _bfd_elf_ppc_merge_fp_attributes
2675 (bfd *, struct bfd_link_info *);
14b57c7c 2676
0b4453c7
AM
2677/* Return an upper bound on the number of bytes required to store a
2678 copy of ABFD's program header table entries. Return -1 if an error
2679 occurs; bfd_get_error will return an appropriate code. */
2680extern long bfd_get_elf_phdr_upper_bound
2681 (bfd *abfd);
2682
2683/* Copy ABFD's program header table entries to *PHDRS. The entries
2684 will be stored as an array of Elf_Internal_Phdr structures, as
2685 defined in include/elf/internal.h. To find out how large the
2686 buffer needs to be, call bfd_get_elf_phdr_upper_bound.
2687
2688 Return the number of program header table entries read, or -1 if an
2689 error occurs; bfd_get_error will return an appropriate code. */
2690extern int bfd_get_elf_phdrs
2691 (bfd *abfd, void *phdrs);
2692
9eaff861 2693/* Exported interface for writing elf corefile notes. */
d4c88bbb 2694extern char *elfcore_write_note
c39a58e6 2695 (bfd *, char *, int *, const char *, int, const void *, int);
d4c88bbb 2696extern char *elfcore_write_prpsinfo
c39a58e6 2697 (bfd *, char *, int *, const char *, const char *);
d4c88bbb 2698extern char *elfcore_write_prstatus
c39a58e6 2699 (bfd *, char *, int *, long, int, const void *);
d4c88bbb 2700extern char * elfcore_write_pstatus
c39a58e6 2701 (bfd *, char *, int *, long, int, const void *);
d4c88bbb 2702extern char *elfcore_write_prfpreg
c39a58e6 2703 (bfd *, char *, int *, const void *, int);
d4c88bbb 2704extern char *elfcore_write_prxfpreg
c39a58e6 2705 (bfd *, char *, int *, const void *, int);
4339cae0
L
2706extern char *elfcore_write_xstatereg
2707 (bfd *, char *, int *, const void *, int);
97753bd5
AM
2708extern char *elfcore_write_ppc_vmx
2709 (bfd *, char *, int *, const void *, int);
89eeb0bc
LM
2710extern char *elfcore_write_ppc_vsx
2711 (bfd *, char *, int *, const void *, int);
cb2366c1
EBM
2712extern char *elfcore_write_ppc_tar
2713 (bfd *, char *, int *, const void *, int);
2714extern char *elfcore_write_ppc_ppr
2715 (bfd *, char *, int *, const void *, int);
2716extern char *elfcore_write_ppc_dscr
2717 (bfd *, char *, int *, const void *, int);
2718extern char *elfcore_write_ppc_ebb
2719 (bfd *, char *, int *, const void *, int);
2720extern char *elfcore_write_ppc_pmu
2721 (bfd *, char *, int *, const void *, int);
2722extern char *elfcore_write_ppc_tm_cgpr
2723 (bfd *, char *, int *, const void *, int);
2724extern char *elfcore_write_ppc_tm_cfpr
2725 (bfd *, char *, int *, const void *, int);
2726extern char *elfcore_write_ppc_tm_cvmx
2727 (bfd *, char *, int *, const void *, int);
2728extern char *elfcore_write_ppc_tm_cvsx
2729 (bfd *, char *, int *, const void *, int);
2730extern char *elfcore_write_ppc_tm_spr
2731 (bfd *, char *, int *, const void *, int);
2732extern char *elfcore_write_ppc_tm_ctar
2733 (bfd *, char *, int *, const void *, int);
2734extern char *elfcore_write_ppc_tm_cppr
2735 (bfd *, char *, int *, const void *, int);
2736extern char *elfcore_write_ppc_tm_cdscr
2737 (bfd *, char *, int *, const void *, int);
d7eeb400
MS
2738extern char *elfcore_write_s390_timer
2739 (bfd *, char *, int *, const void *, int);
2740extern char *elfcore_write_s390_todcmp
2741 (bfd *, char *, int *, const void *, int);
2742extern char *elfcore_write_s390_todpreg
2743 (bfd *, char *, int *, const void *, int);
2744extern char *elfcore_write_s390_ctrs
2745 (bfd *, char *, int *, const void *, int);
2746extern char *elfcore_write_s390_prefix
2747 (bfd *, char *, int *, const void *, int);
355b81d9
UW
2748extern char *elfcore_write_s390_last_break
2749 (bfd *, char *, int *, const void *, int);
2750extern char *elfcore_write_s390_system_call
2751 (bfd *, char *, int *, const void *, int);
abb3f6cc
NC
2752extern char *elfcore_write_s390_tdb
2753 (bfd *, char *, int *, const void *, int);
4ef9f41a
AA
2754extern char *elfcore_write_s390_vxrs_low
2755 (bfd *, char *, int *, const void *, int);
2756extern char *elfcore_write_s390_vxrs_high
2757 (bfd *, char *, int *, const void *, int);
88ab90e8
AA
2758extern char *elfcore_write_s390_gs_cb
2759 (bfd *, char *, int *, const void *, int);
2760extern char *elfcore_write_s390_gs_bc
2761 (bfd *, char *, int *, const void *, int);
faa9a424
UW
2762extern char *elfcore_write_arm_vfp
2763 (bfd *, char *, int *, const void *, int);
652451f8
YZ
2764extern char *elfcore_write_aarch_tls
2765 (bfd *, char *, int *, const void *, int);
2766extern char *elfcore_write_aarch_hw_break
2767 (bfd *, char *, int *, const void *, int);
2768extern char *elfcore_write_aarch_hw_watch
2769 (bfd *, char *, int *, const void *, int);
ad1cc4e4
AH
2770extern char *elfcore_write_aarch_sve
2771 (bfd *, char *, int *, const void *, int);
e6c3b5bf
AH
2772extern char *elfcore_write_aarch_pauth
2773 (bfd *, char *, int *, const void *, int);
27456742
AK
2774extern char *elfcore_write_arc_v2
2775 (bfd *, char *, int *, const void *, int);
d4c88bbb 2776extern char *elfcore_write_lwpstatus
c39a58e6 2777 (bfd *, char *, int *, long, int, const void *);
bb864ac1
CES
2778extern char *elfcore_write_register_note
2779 (bfd *, char *, int *, const char *, const void *, int);
7c76fa91 2780
70a38d42
SDJ
2781/* Internal structure which holds information to be included in the
2782 PRPSINFO section of Linux core files.
2783
2784 This is an "internal" structure in the sense that it should be used
2785 to pass information to BFD (via the `elfcore_write_linux_prpsinfo'
2786 function), so things like endianess shouldn't be an issue. This
2787 structure will eventually be converted in one of the
2788 `elf_external_linux_*' structures and written out to an output bfd
2789 by one of the functions declared below. */
2790
2791struct elf_internal_linux_prpsinfo
2792 {
2793 char pr_state; /* Numeric process state. */
2794 char pr_sname; /* Char for pr_state. */
2795 char pr_zomb; /* Zombie. */
2796 char pr_nice; /* Nice val. */
2797 unsigned long pr_flag; /* Flags. */
2798 unsigned int pr_uid;
2799 unsigned int pr_gid;
2800 int pr_pid, pr_ppid, pr_pgrp, pr_sid;
2801 char pr_fname[16 + 1]; /* Filename of executable. */
2802 char pr_psargs[80 + 1]; /* Initial part of arg list. */
2803 };
2804
2805/* Linux/most 32-bit archs. */
2806extern char *elfcore_write_linux_prpsinfo32
2807 (bfd *, char *, int *, const struct elf_internal_linux_prpsinfo *);
2808
2809/* Linux/most 64-bit archs. */
2810extern char *elfcore_write_linux_prpsinfo64
2811 (bfd *, char *, int *, const struct elf_internal_linux_prpsinfo *);
2812
8d6337fe 2813extern bfd *_bfd_elf32_bfd_from_remote_memory
f0a5d95a 2814 (bfd *templ, bfd_vma ehdr_vma, bfd_size_type size, bfd_vma *loadbasep,
fe78531d 2815 int (*target_read_memory) (bfd_vma, bfd_byte *, bfd_size_type));
8d6337fe 2816extern bfd *_bfd_elf64_bfd_from_remote_memory
f0a5d95a 2817 (bfd *templ, bfd_vma ehdr_vma, bfd_size_type size, bfd_vma *loadbasep,
fe78531d 2818 int (*target_read_memory) (bfd_vma, bfd_byte *, bfd_size_type));
8d6337fe 2819
104d59d1
JM
2820extern bfd_vma bfd_elf_obj_attr_size (bfd *);
2821extern void bfd_elf_set_obj_attr_contents (bfd *, bfd_byte *, bfd_vma);
5ee4a1ca
NC
2822extern int bfd_elf_get_obj_attr_int (bfd *, int, unsigned int);
2823extern void bfd_elf_add_obj_attr_int (bfd *, int, unsigned int, unsigned int);
104d59d1
JM
2824#define bfd_elf_add_proc_attr_int(BFD, TAG, VALUE) \
2825 bfd_elf_add_obj_attr_int ((BFD), OBJ_ATTR_PROC, (TAG), (VALUE))
5ee4a1ca 2826extern void bfd_elf_add_obj_attr_string (bfd *, int, unsigned int, const char *);
104d59d1
JM
2827#define bfd_elf_add_proc_attr_string(BFD, TAG, VALUE) \
2828 bfd_elf_add_obj_attr_string ((BFD), OBJ_ATTR_PROC, (TAG), (VALUE))
5ee4a1ca
NC
2829extern void bfd_elf_add_obj_attr_int_string (bfd *, int, unsigned int,
2830 unsigned int, const char *);
7b86a9fa
AS
2831#define bfd_elf_add_proc_attr_int_string(BFD, TAG, INTVAL, STRVAL) \
2832 bfd_elf_add_obj_attr_int_string ((BFD), OBJ_ATTR_PROC, (TAG), \
2833 (INTVAL), (STRVAL))
104d59d1
JM
2834
2835extern char *_bfd_elf_attr_strdup (bfd *, const char *);
2836extern void _bfd_elf_copy_obj_attributes (bfd *, bfd *);
5ee4a1ca 2837extern int _bfd_elf_obj_attrs_arg_type (bfd *, int, unsigned int);
104d59d1 2838extern void _bfd_elf_parse_attributes (bfd *, Elf_Internal_Shdr *);
50e03d47
AM
2839extern bfd_boolean _bfd_elf_merge_object_attributes
2840 (bfd *, struct bfd_link_info *);
e8b36cd1
JM
2841extern bfd_boolean _bfd_elf_merge_unknown_attribute_low (bfd *, bfd *, int);
2842extern bfd_boolean _bfd_elf_merge_unknown_attribute_list (bfd *, bfd *);
d4730f92 2843extern Elf_Internal_Shdr *_bfd_elf_single_rel_hdr (asection *sec);
864619bb 2844extern bfd_boolean elf_read_notes (bfd *, file_ptr, bfd_size_type, size_t);
104d59d1 2845
46bed679
L
2846extern bfd_boolean _bfd_elf_parse_gnu_properties
2847 (bfd *, Elf_Internal_Note *);
2848extern elf_property * _bfd_elf_get_property
2849 (bfd *, unsigned int, unsigned int);
fba37edd 2850extern bfd *_bfd_elf_link_setup_gnu_properties
46bed679 2851 (struct bfd_link_info *);
6404ab99
L
2852extern bfd_size_type _bfd_elf_convert_gnu_property_size
2853 (bfd *, bfd *);
2854extern bfd_boolean _bfd_elf_convert_gnu_properties
2855 (bfd *, asection *, bfd *, bfd_byte **, bfd_size_type *);
46bed679 2856
6061a67d 2857/* The linker may need to keep track of the number of relocs that it
e03a8ed8
L
2858 decides to copy as dynamic relocs in check_relocs for each symbol.
2859 This is so that it can later discard them if they are found to be
2860 unnecessary. We can store the information in a field extending the
2861 regular ELF linker hash table. */
2862
2863struct elf_dyn_relocs
2864{
2865 struct elf_dyn_relocs *next;
2866
2867 /* The input section of the reloc. */
2868 asection *sec;
2869
2870 /* Total number of relocs copied for the input section. */
2871 bfd_size_type count;
2872
2873 /* Number of pc-relative relocs copied for the input section. */
2874 bfd_size_type pc_count;
2875};
2876
2a81c24a 2877extern bfd_boolean _bfd_elf_create_ifunc_sections
3aa14d16 2878 (bfd *, struct bfd_link_info *);
e03a8ed8
L
2879extern bfd_boolean _bfd_elf_allocate_ifunc_dyn_relocs
2880 (struct bfd_link_info *, struct elf_link_hash_entry *,
cebd6b8a
L
2881 struct elf_dyn_relocs **, unsigned int, unsigned int,
2882 unsigned int, bfd_boolean);
d8045f23 2883
351f65ca
L
2884extern void elf_append_rela (bfd *, asection *, Elf_Internal_Rela *);
2885extern void elf_append_rel (bfd *, asection *, Elf_Internal_Rela *);
2886
2887extern bfd_vma elf64_r_info (bfd_vma, bfd_vma);
2888extern bfd_vma elf64_r_sym (bfd_vma);
2889extern bfd_vma elf32_r_info (bfd_vma, bfd_vma);
2890extern bfd_vma elf32_r_sym (bfd_vma);
2891
1faa385f
NC
2892extern bfd_boolean is_debuginfo_file (bfd *);
2893
a8e14f4c
NC
2894
2895extern bfd_boolean _bfd_elf_init_secondary_reloc_section
2896 (bfd *, Elf_Internal_Shdr *, const char *, unsigned int);
2897extern bfd_boolean _bfd_elf_slurp_secondary_reloc_section
2898 (bfd *, asection *, asymbol **);
2899extern bfd_boolean _bfd_elf_copy_special_section_fields
2900 (const bfd *, bfd *, const Elf_Internal_Shdr *, Elf_Internal_Shdr *);
2901extern bfd_boolean _bfd_elf_write_secondary_reloc_section
2902 (bfd *, asection *);
2903extern unsigned int _bfd_elf_symbol_section_index
2904 (bfd *, elf_symbol_type *);
2905
5dbc8b37
L
2906extern asection *_bfd_elf_readonly_dynrelocs
2907 (struct elf_link_hash_entry *);
d49e5065
L
2908extern bfd_boolean _bfd_elf_maybe_set_textrel
2909 (struct elf_link_hash_entry *, void *);
a8e14f4c 2910
3b22753a
L
2911/* Large common section. */
2912extern asection _bfd_elf_large_com_section;
2913
d2149d72
L
2914/* Hash for local symbol with the first section id, ID, in the input
2915 file and the local symbol index, SYM. */
2916#define ELF_LOCAL_SYMBOL_HASH(ID, SYM) \
2365f8d7
AM
2917 (((((ID) & 0xffU) << 24) | (((ID) & 0xff00) << 8)) \
2918 ^ (SYM) ^ (((ID) & 0xffff0000U) >> 16))
d2149d72 2919
c152c796
AM
2920/* This is the condition under which finish_dynamic_symbol will be called.
2921 If our finish_dynamic_symbol isn't called, we'll need to do something
2922 about initializing any .plt and .got entries in relocate_section. */
2923#define WILL_CALL_FINISH_DYNAMIC_SYMBOL(DYN, SHARED, H) \
2924 ((DYN) \
f5385ebf
AM
2925 && ((SHARED) || !(H)->forced_local) \
2926 && ((H)->dynindx != -1 || (H)->forced_local))
c152c796 2927
560e09e9
NC
2928/* This macro is to avoid lots of duplicated code in the body
2929 of xxx_relocate_section() in the various elfxx-xxxx.c files. */
b2a8e766
AM
2930#define RELOC_FOR_GLOBAL_SYMBOL(info, input_bfd, input_section, rel, \
2931 r_symndx, symtab_hdr, sym_hashes, \
2932 h, sec, relocation, \
62d887d4 2933 unresolved_reloc, warned, ignored) \
b2a8e766
AM
2934 do \
2935 { \
2936 /* It seems this can happen with erroneous or unsupported \
2937 input (mixing a.out and elf in an archive, for example.) */ \
2938 if (sym_hashes == NULL) \
2939 return FALSE; \
2940 \
2941 h = sym_hashes[r_symndx - symtab_hdr->sh_info]; \
2942 \
8a5da09b
AM
2943 if (info->wrap_hash != NULL \
2944 && (input_section->flags & SEC_DEBUGGING) != 0) \
2945 h = ((struct elf_link_hash_entry *) \
2946 unwrap_hash_lookup (info, input_bfd, &h->root)); \
2947 \
b2a8e766
AM
2948 while (h->root.type == bfd_link_hash_indirect \
2949 || h->root.type == bfd_link_hash_warning) \
2950 h = (struct elf_link_hash_entry *) h->root.u.i.link; \
2951 \
2952 warned = FALSE; \
62d887d4 2953 ignored = FALSE; \
b2a8e766
AM
2954 unresolved_reloc = FALSE; \
2955 relocation = 0; \
2956 if (h->root.type == bfd_link_hash_defined \
2957 || h->root.type == bfd_link_hash_defweak) \
2958 { \
2959 sec = h->root.u.def.section; \
2960 if (sec == NULL \
2961 || sec->output_section == NULL) \
2962 /* Set a flag that will be cleared later if we find a \
2963 relocation value for this symbol. output_section \
2964 is typically NULL for symbols satisfied by a shared \
2965 library. */ \
2966 unresolved_reloc = TRUE; \
2967 else \
2968 relocation = (h->root.u.def.value \
2969 + sec->output_section->vma \
2970 + sec->output_offset); \
2971 } \
2972 else if (h->root.type == bfd_link_hash_undefweak) \
2973 ; \
2974 else if (info->unresolved_syms_in_objects == RM_IGNORE \
2975 && ELF_ST_VISIBILITY (h->other) == STV_DEFAULT) \
62d887d4 2976 ignored = TRUE; \
0e1862bb 2977 else if (!bfd_link_relocatable (info)) \
b2a8e766 2978 { \
5a580b3a 2979 bfd_boolean err; \
95a51568
FS
2980 err = (info->unresolved_syms_in_objects == RM_DIAGNOSE && \
2981 !info->warn_unresolved_syms) \
2982 || ELF_ST_VISIBILITY (h->other) != STV_DEFAULT; \
1a72702b
AM
2983 (*info->callbacks->undefined_symbol) (info, \
2984 h->root.root.string, \
2985 input_bfd, \
2986 input_section, \
2987 rel->r_offset, err); \
b2a8e766
AM
2988 warned = TRUE; \
2989 } \
c7e2358a
AM
2990 (void) unresolved_reloc; \
2991 (void) warned; \
62d887d4 2992 (void) ignored; \
b2a8e766 2993 } \
560e09e9
NC
2994 while (0)
2995
0672748a
L
2996/* This macro is to avoid lots of duplicated code in the body of the
2997 loop over relocations in xxx_relocate_section() in the various
2998 elfxx-xxxx.c files.
23209a78 2999
0672748a
L
3000 Handle relocations against symbols from removed linkonce sections,
3001 or sections discarded by a linker script. When doing a relocatable
3002 link, we remove such relocations. Otherwise, we just want the
3003 section contents zeroed and avoid any special processing. */
3004#define RELOC_AGAINST_DISCARDED_SECTION(info, input_bfd, input_section, \
545fd46b
MR
3005 rel, count, relend, \
3006 howto, index, contents) \
0672748a 3007 { \
a134cc9b 3008 int i_; \
e4067dbb 3009 _bfd_clear_contents (howto, input_bfd, input_section, \
0930cb30 3010 contents, rel[index].r_offset); \
e4067dbb 3011 \
0e1862bb 3012 if (bfd_link_relocatable (info) \
0672748a
L
3013 && (input_section->flags & SEC_DEBUGGING)) \
3014 { \
3015 /* Only remove relocations in debug sections since other \
3016 sections may require relocations. */ \
3017 Elf_Internal_Shdr *rel_hdr; \
3018 \
d4730f92 3019 rel_hdr = _bfd_elf_single_rel_hdr (input_section->output_section); \
0672748a
L
3020 \
3021 /* Avoid empty output section. */ \
86f7d49b 3022 if (rel_hdr->sh_size > rel_hdr->sh_entsize) \
0672748a 3023 { \
86f7d49b 3024 rel_hdr->sh_size -= rel_hdr->sh_entsize; \
d4730f92 3025 rel_hdr = _bfd_elf_single_rel_hdr (input_section); \
86f7d49b 3026 rel_hdr->sh_size -= rel_hdr->sh_entsize; \
0672748a 3027 \
545fd46b
MR
3028 memmove (rel, rel + count, \
3029 (relend - rel - count) * sizeof (*rel)); \
0672748a 3030 \
056bafd4 3031 input_section->reloc_count -= count; \
545fd46b 3032 relend -= count; \
0672748a
L
3033 rel--; \
3034 continue; \
3035 } \
3036 } \
3037 \
a134cc9b 3038 for (i_ = 0; i_ < count; i_++) \
545fd46b 3039 { \
a134cc9b
HPN
3040 rel[i_].r_info = 0; \
3041 rel[i_].r_addend = 0; \
545fd46b
MR
3042 } \
3043 rel += count - 1; \
0672748a
L
3044 continue; \
3045 }
3046
a8685210 3047/* Will a symbol be bound to the definition within the shared
6f8bcf84 3048 library, if any. A unique symbol can never be bound locally. */
55255dae 3049#define SYMBOLIC_BIND(INFO, H) \
6f8bcf84 3050 (!(H)->unique_global \
487b6440
AM
3051 && ((INFO)->symbolic \
3052 || (H)->start_stop \
3053 || ((INFO)->dynamic && !(H)->dynamic)))
55255dae 3054
1ff6de03
NA
3055/* Determine if a section contains CTF data, using its name. */
3056static inline bfd_boolean
3057bfd_section_is_ctf (const asection *sec)
3058{
3059 const char *name = bfd_section_name (sec);
3060 return strncmp (name, ".ctf", 4) == 0 && (name[4] == 0 || name[4] == '.');
3061}
3062
55172d69
PA
3063#ifdef __cplusplus
3064}
3065#endif
252b5132 3066#endif /* _LIBELF_H_ */