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