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