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