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