OSDN Git Service

2009-06-16 H.J. Lu <hongjiu.lu@intel.com>
[pf3gnuchains/pf3gnuchains3x.git] / bfd / elf-bfd.h
1 /* BFD back-end data structures for ELF files.
2    Copyright 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001,
3    2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
4    Free Software Foundation, Inc.
5    Written by Cygnus Support.
6
7    This file is part of BFD, the Binary File Descriptor library.
8
9    This program is free software; you can redistribute it and/or modify
10    it under the terms of the GNU General Public License as published by
11    the Free Software Foundation; either version 3 of the License, or
12    (at your option) any later version.
13
14    This program is distributed in the hope that it will be useful,
15    but WITHOUT ANY WARRANTY; without even the implied warranty of
16    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17    GNU General Public License for more details.
18
19    You should have received a copy of the GNU General Public License
20    along with this program; if not, write to the Free Software
21    Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
22    MA 02110-1301, USA.  */
23
24 #ifndef _LIBELF_H_
25 #define _LIBELF_H_ 1
26
27 #include "elf/common.h"
28 #include "elf/external.h"
29 #include "elf/internal.h"
30 #include "bfdlink.h"
31
32 /* The number of entries in a section is its size divided by the size
33    of a single entry.  This is normally only applicable to reloc and
34    symbol table sections.
35    PR 9934: It is possible to have relocations that do not refer to
36    symbols, thus it is also possible to have a relocation section in
37    an object file, but no symbol table.  */
38 #define NUM_SHDR_ENTRIES(shdr) ((shdr)->sh_entsize > 0 ? (shdr)->sh_size / (shdr)->sh_entsize : 0)
39
40 /* If size isn't specified as 64 or 32, NAME macro should fail.  */
41 #ifndef NAME
42 #if ARCH_SIZE == 64
43 #define NAME(x, y) x ## 64 ## _ ## y
44 #endif
45 #if ARCH_SIZE == 32
46 #define NAME(x, y) x ## 32 ## _ ## y
47 #endif
48 #endif
49
50 #ifndef NAME
51 #define NAME(x, y) x ## NOSIZE ## _ ## y
52 #endif
53
54 #define ElfNAME(X)      NAME(Elf,X)
55 #define elfNAME(X)      NAME(elf,X)
56
57 /* Information held for an ELF symbol.  The first field is the
58    corresponding asymbol.  Every symbol is an ELF file is actually a
59    pointer to this structure, although it is often handled as a
60    pointer to an asymbol.  */
61
62 typedef struct
63 {
64   /* The BFD symbol.  */
65   asymbol symbol;
66   /* ELF symbol information.  */
67   Elf_Internal_Sym internal_elf_sym;
68   /* Backend specific information.  */
69   union
70     {
71       unsigned int hppa_arg_reloc;
72       void *mips_extr;
73       void *any;
74     }
75   tc_data;
76
77   /* Version information.  This is from an Elf_Internal_Versym
78      structure in a SHT_GNU_versym section.  It is zero if there is no
79      version information.  */
80   unsigned short version;
81
82 } elf_symbol_type;
83 \f
84 struct elf_strtab_hash;
85 struct got_entry;
86 struct plt_entry;
87
88 /* ELF linker hash table entries.  */
89
90 struct elf_link_hash_entry
91 {
92   struct bfd_link_hash_entry root;
93
94   /* Symbol index in output file.  This is initialized to -1.  It is
95      set to -2 if the symbol is used by a reloc.  */
96   long indx;
97
98   /* Symbol index as a dynamic symbol.  Initialized to -1, and remains
99      -1 if this is not a dynamic symbol.  */
100   /* ??? Note that this is consistently used as a synonym for tests
101      against whether we can perform various simplifying transformations
102      to the code.  (E.g. changing a pc-relative jump to a PLT entry
103      into a pc-relative jump to the target function.)  That test, which
104      is often relatively complex, and someplaces wrong or incomplete,
105      should really be replaced by a predicate in elflink.c.
106
107      End result: this field -1 does not indicate that the symbol is
108      not in the dynamic symbol table, but rather that the symbol is
109      not visible outside this DSO.  */
110   long dynindx;
111
112   /* If this symbol requires an entry in the global offset table, the
113      processor specific backend uses this field to track usage and
114      final offset.  Two schemes are supported:  The first assumes that
115      a symbol may only have one GOT entry, and uses REFCOUNT until
116      size_dynamic_sections, at which point the contents of the .got is
117      fixed.  Afterward, if OFFSET is -1, then the symbol does not
118      require a global offset table entry.  The second scheme allows
119      multiple GOT entries per symbol, managed via a linked list
120      pointed to by GLIST.  */
121   union gotplt_union
122     {
123       bfd_signed_vma refcount;
124       bfd_vma offset;
125       struct got_entry *glist;
126       struct plt_entry *plist;
127     } got;
128
129   /* Same, but tracks a procedure linkage table entry.  */
130   union gotplt_union plt;
131
132   /* Symbol size.  */
133   bfd_size_type size;
134
135   /* Symbol type (STT_NOTYPE, STT_OBJECT, etc.).  */
136   unsigned int type : 8;
137
138   /* Symbol st_other value, symbol visibility.  */
139   unsigned int other : 8;
140
141   /* Symbol is referenced by a non-shared object.  */
142   unsigned int ref_regular : 1;
143   /* Symbol is defined by a non-shared object.  */
144   unsigned int def_regular : 1;
145   /* Symbol is referenced by a shared object.  */
146   unsigned int ref_dynamic : 1;
147   /* Symbol is defined by a shared object.  */
148   unsigned int def_dynamic : 1;
149   /* Symbol has a non-weak reference from a non-shared object.  */
150   unsigned int ref_regular_nonweak : 1;
151   /* Dynamic symbol has been adjustd.  */
152   unsigned int dynamic_adjusted : 1;
153   /* Symbol needs a copy reloc.  */
154   unsigned int needs_copy : 1;
155   /* Symbol needs a procedure linkage table entry.  */
156   unsigned int needs_plt : 1;
157   /* Symbol appears in a non-ELF input file.  */
158   unsigned int non_elf : 1;
159   /* Symbol should be marked as hidden in the version information.  */
160   unsigned int hidden : 1;
161   /* Symbol was forced to local scope due to a version script file.  */
162   unsigned int forced_local : 1;
163   /* Symbol was forced to be dynamic due to a version script file.  */
164   unsigned int dynamic : 1;
165   /* Symbol was marked during garbage collection.  */
166   unsigned int mark : 1;
167   /* Symbol is referenced by a non-GOT/non-PLT relocation.  This is
168      not currently set by all the backends.  */
169   unsigned int non_got_ref : 1;
170   /* Symbol has a definition in a shared object.
171      FIXME: There is no real need for this field if def_dynamic is never
172      cleared and all places that test def_dynamic also test def_regular.  */
173   unsigned int dynamic_def : 1;
174   /* Symbol is weak in all shared objects.  */
175   unsigned int dynamic_weak : 1;
176   /* Symbol is referenced with a relocation where C/C++ pointer equality
177      matters.  */
178   unsigned int pointer_equality_needed : 1;
179
180   /* String table index in .dynstr if this is a dynamic symbol.  */
181   unsigned long dynstr_index;
182
183   union
184   {
185     /* If this is a weak defined symbol from a dynamic object, this
186        field points to a defined symbol with the same value, if there is
187        one.  Otherwise it is NULL.  */
188     struct elf_link_hash_entry *weakdef;
189
190     /* Hash value of the name computed using the ELF hash function.
191        Used part way through size_dynamic_sections, after we've finished
192        with weakdefs.  */
193     unsigned long elf_hash_value;
194   } u;
195
196   /* Version information.  */
197   union
198   {
199     /* This field is used for a symbol which is not defined in a
200        regular object.  It points to the version information read in
201        from the dynamic object.  */
202     Elf_Internal_Verdef *verdef;
203     /* This field is used for a symbol which is defined in a regular
204        object.  It is set up in size_dynamic_sections.  It points to
205        the version information we should write out for this symbol.  */
206     struct bfd_elf_version_tree *vertree;
207   } verinfo;
208
209   struct
210   {
211     /* Virtual table entry use information.  This array is nominally of size
212        size/sizeof(target_void_pointer), though we have to be able to assume
213        and track a size while the symbol is still undefined.  It is indexed
214        via offset/sizeof(target_void_pointer).  */
215     size_t size;
216     bfd_boolean *used;
217
218     /* Virtual table derivation info.  */
219     struct elf_link_hash_entry *parent;
220   } *vtable;
221 };
222
223 /* Will references to this symbol always reference the symbol
224    in this object?  STV_PROTECTED is excluded from the visibility test
225    here so that function pointer comparisons work properly.  Since
226    function symbols not defined in an app are set to their .plt entry,
227    it's necessary for shared libs to also reference the .plt even
228    though the symbol is really local to the shared lib.  */
229 #define SYMBOL_REFERENCES_LOCAL(INFO, H) \
230   _bfd_elf_symbol_refs_local_p (H, INFO, 0)
231
232 /* Will _calls_ to this symbol always call the version in this object?  */
233 #define SYMBOL_CALLS_LOCAL(INFO, H) \
234   _bfd_elf_symbol_refs_local_p (H, INFO, 1)
235
236 /* Common symbols that are turned into definitions don't have the
237    DEF_REGULAR flag set, so they might appear to be undefined.  */
238 #define ELF_COMMON_DEF_P(H) \
239   (!(H)->def_regular                                                    \
240    && !(H)->def_dynamic                                                 \
241    && (H)->root.type == bfd_link_hash_defined)
242
243 /* Records local symbols to be emitted in the dynamic symbol table.  */
244
245 struct elf_link_local_dynamic_entry
246 {
247   struct elf_link_local_dynamic_entry *next;
248
249   /* The input bfd this symbol came from.  */
250   bfd *input_bfd;
251
252   /* The index of the local symbol being copied.  */
253   long input_indx;
254
255   /* The index in the outgoing dynamic symbol table.  */
256   long dynindx;
257
258   /* A copy of the input symbol.  */
259   Elf_Internal_Sym isym;
260 };
261
262 struct elf_link_loaded_list
263 {
264   struct elf_link_loaded_list *next;
265   bfd *abfd;
266 };
267
268 /* Structures used by the eh_frame optimization code.  */
269 struct eh_cie_fde
270 {
271   union {
272     struct {
273       /* If REMOVED == 1, this is the CIE that the FDE originally used.
274          The CIE belongs to the same .eh_frame input section as the FDE.
275
276          If REMOVED == 0, this is the CIE that we have chosen to use for
277          the output FDE.  The CIE's REMOVED field is also 0, but the CIE
278          might belong to a different .eh_frame input section from the FDE.  */
279       struct eh_cie_fde *cie_inf;
280       struct eh_cie_fde *next_for_section;
281     } fde;
282     struct {
283       /* CIEs have three states:
284
285          - REMOVED && !MERGED: Slated for removal because we haven't yet
286            proven that an FDE needs it.  FULL_CIE, if nonnull, points to
287            more detailed information about the CIE.
288
289          - REMOVED && MERGED: We have merged this CIE with MERGED_WITH,
290            which may not belong to the same input section.
291
292          - !REMOVED: We have decided to keep this CIE.  SEC is the
293            .eh_frame input section that contains the CIE.  */
294       union {
295         struct cie *full_cie;
296         struct eh_cie_fde *merged_with;
297         asection *sec;
298       } u;
299
300       /* True if we have marked relocations associated with this CIE.  */
301       unsigned int gc_mark : 1;
302
303       /* True if we have decided to turn an absolute LSDA encoding into
304          a PC-relative one.  */
305       unsigned int make_lsda_relative : 1;
306
307       /* True if the CIE contains personality data and if that data
308          uses a PC-relative encoding.  */
309       unsigned int per_encoding_relative : 1;
310
311       /* True if we need to add an 'R' (FDE encoding) entry to the
312          CIE's augmentation data.  */
313       unsigned int add_fde_encoding : 1;
314
315       /* True if we have merged this CIE with another.  */
316       unsigned int merged : 1;
317     } cie;
318   } u;
319   unsigned int reloc_index;
320   unsigned int size;
321   unsigned int offset;
322   unsigned int new_offset;
323   unsigned int fde_encoding : 8;
324   unsigned int lsda_encoding : 8;
325   unsigned int lsda_offset : 8;
326
327   /* True if this entry represents a CIE, false if it represents an FDE.  */
328   unsigned int cie : 1;
329
330   /* True if this entry is currently marked for removal.  */
331   unsigned int removed : 1;
332
333   /* True if we need to add a 'z' (augmentation size) entry to the CIE's
334      augmentation data, and an associated byte to each of the CIE's FDEs.  */
335   unsigned int add_augmentation_size : 1;
336
337   /* True if we have decided to convert absolute FDE relocations into
338      relative ones.  This applies to the first relocation in the FDE,
339      which is against the code that the FDE describes.  */
340   unsigned int make_relative : 1;
341
342   /* Unused bits.  */
343   unsigned int pad1 : 4;
344
345   unsigned int *set_loc;
346 };
347
348 struct eh_frame_sec_info
349 {
350   unsigned int count;
351   struct cie *cies;
352   struct eh_cie_fde entry[1];
353 };
354
355 struct eh_frame_array_ent
356 {
357   bfd_vma initial_loc;
358   bfd_vma fde;
359 };
360
361 struct htab;
362
363 struct eh_frame_hdr_info
364 {
365   struct htab *cies;
366   asection *hdr_sec;
367   unsigned int fde_count, array_count;
368   struct eh_frame_array_ent *array;
369   /* TRUE if we should try to merge CIEs between input sections.  */
370   bfd_boolean merge_cies;
371   /* TRUE if all .eh_frames have been parsd.  */
372   bfd_boolean parsed_eh_frames;
373   /* TRUE if .eh_frame_hdr should contain the sorted search table.
374      We build it if we successfully read all .eh_frame input sections
375      and recognize them.  */
376   bfd_boolean table;
377 };
378
379 /* ELF linker hash table.  */
380
381 struct elf_link_hash_table
382 {
383   struct bfd_link_hash_table root;
384
385   /* Whether we have created the special dynamic sections required
386      when linking against or generating a shared object.  */
387   bfd_boolean dynamic_sections_created;
388
389   /* True if this target has relocatable executables, so needs dynamic
390      section symbols.  */
391   bfd_boolean is_relocatable_executable;
392
393   /* The BFD used to hold special sections created by the linker.
394      This will be the first BFD found which requires these sections to
395      be created.  */
396   bfd *dynobj;
397
398   /* The value to use when initialising got.refcount/offset and
399      plt.refcount/offset in an elf_link_hash_entry.  Set to zero when
400      the values are refcounts.  Set to init_got_offset/init_plt_offset
401      in size_dynamic_sections when the values may be offsets.  */
402   union gotplt_union init_got_refcount;
403   union gotplt_union init_plt_refcount;
404
405   /* The value to use for got.refcount/offset and plt.refcount/offset
406      when the values may be offsets.  Normally (bfd_vma) -1.  */
407   union gotplt_union init_got_offset;
408   union gotplt_union init_plt_offset;
409
410   /* The number of symbols found in the link which must be put into
411      the .dynsym section.  */
412   bfd_size_type dynsymcount;
413
414   /* The string table of dynamic symbols, which becomes the .dynstr
415      section.  */
416   struct elf_strtab_hash *dynstr;
417
418   /* The number of buckets in the hash table in the .hash section.
419      This is based on the number of dynamic symbols.  */
420   bfd_size_type bucketcount;
421
422   /* A linked list of DT_NEEDED names found in dynamic objects
423      included in the link.  */
424   struct bfd_link_needed_list *needed;
425
426   /* Sections in the output bfd that provides a section symbol
427      to be used by relocations emitted against local symbols.
428      Most targets will not use data_index_section.  */
429   asection *text_index_section;
430   asection *data_index_section;
431
432   /* The _GLOBAL_OFFSET_TABLE_ symbol.  */
433   struct elf_link_hash_entry *hgot;
434
435   /* The _PROCEDURE_LINKAGE_TABLE_ symbol.  */
436   struct elf_link_hash_entry *hplt;
437
438   /* A pointer to information used to merge SEC_MERGE sections.  */
439   void *merge_info;
440
441   /* Used to link stabs in sections.  */
442   struct stab_info stab_info;
443
444   /* Used by eh_frame code when editing .eh_frame.  */
445   struct eh_frame_hdr_info eh_info;
446
447   /* A linked list of local symbols to be added to .dynsym.  */
448   struct elf_link_local_dynamic_entry *dynlocal;
449
450   /* A linked list of DT_RPATH/DT_RUNPATH names found in dynamic
451      objects included in the link.  */
452   struct bfd_link_needed_list *runpath;
453
454   /* Cached first output tls section and size of PT_TLS segment.  */
455   asection *tls_sec;
456   bfd_size_type tls_size;
457
458   /* A linked list of BFD's loaded in the link.  */
459   struct elf_link_loaded_list *loaded;
460
461   /* Short-cuts to get to dynamic linker sections.  */
462   asection *sgot;
463   asection *sgotplt;
464   asection *srelgot;
465   asection *splt;
466   asection *srelplt;
467   asection *igotplt;
468   asection *iplt;
469   asection *irelplt;
470   asection *irelifunc;
471 };
472
473 /* Look up an entry in an ELF linker hash table.  */
474
475 #define elf_link_hash_lookup(table, string, create, copy, follow)       \
476   ((struct elf_link_hash_entry *)                                       \
477    bfd_link_hash_lookup (&(table)->root, (string), (create),            \
478                          (copy), (follow)))
479
480 /* Traverse an ELF linker hash table.  */
481
482 #define elf_link_hash_traverse(table, func, info)                       \
483   (bfd_link_hash_traverse                                               \
484    (&(table)->root,                                                     \
485     (bfd_boolean (*) (struct bfd_link_hash_entry *, void *)) (func),    \
486     (info)))
487
488 /* Get the ELF linker hash table from a link_info structure.  */
489
490 #define elf_hash_table(p) ((struct elf_link_hash_table *) ((p)->hash))
491
492 /* Returns TRUE if the hash table is a struct elf_link_hash_table.  */
493 #define is_elf_hash_table(htab)                                         \
494   (((struct bfd_link_hash_table *) (htab))->type == bfd_link_elf_hash_table)
495
496 /* Used by bfd_section_from_r_symndx to cache a small number of local
497    symbol to section mappings.  */
498 #define LOCAL_SYM_CACHE_SIZE 32
499 struct sym_sec_cache
500 {
501   bfd *abfd;
502   unsigned long indx[LOCAL_SYM_CACHE_SIZE];
503   unsigned int shndx[LOCAL_SYM_CACHE_SIZE];
504 };
505 \f
506 /* Constant information held for an ELF backend.  */
507
508 struct elf_size_info {
509   unsigned char sizeof_ehdr, sizeof_phdr, sizeof_shdr;
510   unsigned char sizeof_rel, sizeof_rela, sizeof_sym, sizeof_dyn, sizeof_note;
511
512   /* The size of entries in the .hash section.  */
513   unsigned char sizeof_hash_entry;
514
515   /* The number of internal relocations to allocate per external
516      relocation entry.  */
517   unsigned char int_rels_per_ext_rel;
518   /* We use some fixed size arrays.  This should be large enough to
519      handle all back-ends.  */
520 #define MAX_INT_RELS_PER_EXT_REL 3
521
522   unsigned char arch_size, log_file_align;
523   unsigned char elfclass, ev_current;
524   int (*write_out_phdrs)
525     (bfd *, const Elf_Internal_Phdr *, unsigned int);
526   bfd_boolean
527     (*write_shdrs_and_ehdr) (bfd *);
528   bfd_boolean (*checksum_contents)
529     (bfd * , void (*) (const void *, size_t, void *), void *);
530   void (*write_relocs)
531     (bfd *, asection *, void *);
532   bfd_boolean (*swap_symbol_in)
533     (bfd *, const void *, const void *, Elf_Internal_Sym *);
534   void (*swap_symbol_out)
535     (bfd *, const Elf_Internal_Sym *, void *, void *);
536   bfd_boolean (*slurp_reloc_table)
537     (bfd *, asection *, asymbol **, bfd_boolean);
538   long (*slurp_symbol_table)
539     (bfd *, asymbol **, bfd_boolean);
540   void (*swap_dyn_in)
541     (bfd *, const void *, Elf_Internal_Dyn *);
542   void (*swap_dyn_out)
543     (bfd *, const Elf_Internal_Dyn *, void *);
544
545   /* This function is called to swap in a REL relocation.  If an
546      external relocation corresponds to more than one internal
547      relocation, then all relocations are swapped in at once.  */
548   void (*swap_reloc_in)
549     (bfd *, const bfd_byte *, Elf_Internal_Rela *);
550
551   /* This function is called to swap out a REL relocation.  */
552   void (*swap_reloc_out)
553     (bfd *, const Elf_Internal_Rela *, bfd_byte *);
554
555   /* This function is called to swap in a RELA relocation.  If an
556      external relocation corresponds to more than one internal
557      relocation, then all relocations are swapped in at once.  */
558   void (*swap_reloca_in)
559     (bfd *, const bfd_byte *, Elf_Internal_Rela *);
560
561   /* This function is called to swap out a RELA relocation.  */
562   void (*swap_reloca_out)
563     (bfd *, const Elf_Internal_Rela *, bfd_byte *);
564 };
565
566 #define elf_symbol_from(ABFD,S) \
567         (((S)->the_bfd->xvec->flavour == bfd_target_elf_flavour \
568           && (S)->the_bfd->tdata.elf_obj_data != 0) \
569          ? (elf_symbol_type *) (S) \
570          : 0)
571
572 enum elf_reloc_type_class {
573   reloc_class_normal,
574   reloc_class_relative,
575   reloc_class_plt,
576   reloc_class_copy
577 };
578
579 struct elf_reloc_cookie
580 {
581   Elf_Internal_Rela *rels, *rel, *relend;
582   Elf_Internal_Sym *locsyms;
583   bfd *abfd;
584   size_t locsymcount;
585   size_t extsymoff;
586   struct elf_link_hash_entry **sym_hashes;
587   int r_sym_shift;
588   bfd_boolean bad_symtab;
589 };
590
591 /* The level of IRIX compatibility we're striving for.  */
592
593 typedef enum {
594   ict_none,
595   ict_irix5,
596   ict_irix6
597 } irix_compat_t;
598
599 /* Mapping of ELF section names and types.  */
600 struct bfd_elf_special_section
601 {
602   const char *prefix;
603   int prefix_length;
604   /* 0 means name must match PREFIX exactly.
605      -1 means name must start with PREFIX followed by an arbitrary string.
606      -2 means name must match PREFIX exactly or consist of PREFIX followed
607      by a dot then anything.
608      > 0 means name must start with the first PREFIX_LENGTH chars of
609      PREFIX and finish with the last SUFFIX_LENGTH chars of PREFIX.  */
610   int suffix_length;
611   int type;
612   bfd_vma attr;
613 };
614
615 enum action_discarded
616   {
617     COMPLAIN = 1,
618     PRETEND = 2
619   };
620
621 typedef asection * (*elf_gc_mark_hook_fn)
622   (asection *, struct bfd_link_info *, Elf_Internal_Rela *,
623    struct elf_link_hash_entry *, Elf_Internal_Sym *);
624
625 struct elf_backend_data
626 {
627   /* The architecture for this backend.  */
628   enum bfd_architecture arch;
629
630   /* The ELF machine code (EM_xxxx) for this backend.  */
631   int elf_machine_code;
632
633   /* EI_OSABI. */
634   int elf_osabi;
635
636   /* The maximum page size for this backend.  */
637   bfd_vma maxpagesize;
638
639   /* The minimum page size for this backend.  An input object will not be
640      considered page aligned unless its sections are correctly aligned for
641      pages at least this large.  May be smaller than maxpagesize.  */
642   bfd_vma minpagesize;
643
644   /* The common page size for this backend.  */
645   bfd_vma commonpagesize;
646
647   /* The BFD flags applied to sections created for dynamic linking.  */
648   flagword dynamic_sec_flags;
649
650   /* A function to translate an ELF RELA relocation to a BFD arelent
651      structure.  */
652   void (*elf_info_to_howto)
653     (bfd *, arelent *, Elf_Internal_Rela *);
654
655   /* A function to translate an ELF REL relocation to a BFD arelent
656      structure.  */
657   void (*elf_info_to_howto_rel)
658     (bfd *, arelent *, Elf_Internal_Rela *);
659
660   /* A function to determine whether a symbol is global when
661      partitioning the symbol table into local and global symbols.
662      This should be NULL for most targets, in which case the correct
663      thing will be done.  MIPS ELF, at least on the Irix 5, has
664      special requirements.  */
665   bfd_boolean (*elf_backend_sym_is_global)
666     (bfd *, asymbol *);
667
668   /* The remaining functions are hooks which are called only if they
669      are not NULL.  */
670
671   /* A function to permit a backend specific check on whether a
672      particular BFD format is relevant for an object file, and to
673      permit the backend to set any global information it wishes.  When
674      this is called elf_elfheader is set, but anything else should be
675      used with caution.  If this returns FALSE, the check_format
676      routine will return a bfd_error_wrong_format error.  */
677   bfd_boolean (*elf_backend_object_p)
678     (bfd *);
679
680   /* A function to do additional symbol processing when reading the
681      ELF symbol table.  This is where any processor-specific special
682      section indices are handled.  */
683   void (*elf_backend_symbol_processing)
684     (bfd *, asymbol *);
685
686   /* A function to do additional symbol processing after reading the
687      entire ELF symbol table.  */
688   bfd_boolean (*elf_backend_symbol_table_processing)
689     (bfd *, elf_symbol_type *, unsigned int);
690
691   /* A function to set the type of the info field.  Processor-specific
692      types should be handled here.  */
693   int (*elf_backend_get_symbol_type)
694     (Elf_Internal_Sym *, int);
695
696   /* A function to return the linker hash table entry of a symbol that
697      might be satisfied by an archive symbol.  */
698   struct elf_link_hash_entry * (*elf_backend_archive_symbol_lookup)
699     (bfd *, struct bfd_link_info *, const char *);
700
701   /* Return true if local section symbols should have a non-null st_name.
702      NULL implies false.  */
703   bfd_boolean (*elf_backend_name_local_section_symbols)
704     (bfd *);
705
706   /* A function to do additional processing on the ELF section header
707      just before writing it out.  This is used to set the flags and
708      type fields for some sections, or to actually write out data for
709      unusual sections.  */
710   bfd_boolean (*elf_backend_section_processing)
711     (bfd *, Elf_Internal_Shdr *);
712
713   /* A function to handle unusual section types when creating BFD
714      sections from ELF sections.  */
715   bfd_boolean (*elf_backend_section_from_shdr)
716     (bfd *, Elf_Internal_Shdr *, const char *, int);
717
718   /* A function to convert machine dependent ELF section header flags to
719      BFD internal section header flags.  */
720   bfd_boolean (*elf_backend_section_flags)
721     (flagword *, const Elf_Internal_Shdr *);
722
723   /* A function that returns a struct containing ELF section flags and
724      type for the given BFD section.   */
725   const struct bfd_elf_special_section * (*get_sec_type_attr)
726     (bfd *, asection *);
727
728   /* A function to handle unusual program segment types when creating BFD
729      sections from ELF program segments.  */
730   bfd_boolean (*elf_backend_section_from_phdr)
731     (bfd *, Elf_Internal_Phdr *, int, const char *);
732
733   /* A function to set up the ELF section header for a BFD section in
734      preparation for writing it out.  This is where the flags and type
735      fields are set for unusual sections.  */
736   bfd_boolean (*elf_backend_fake_sections)
737     (bfd *, Elf_Internal_Shdr *, asection *);
738
739   /* A function to get the ELF section index for a BFD section.  If
740      this returns TRUE, the section was found.  If it is a normal ELF
741      section, *RETVAL should be left unchanged.  If it is not a normal
742      ELF section *RETVAL should be set to the SHN_xxxx index.  */
743   bfd_boolean (*elf_backend_section_from_bfd_section)
744     (bfd *, asection *, int *retval);
745
746   /* If this field is not NULL, it is called by the add_symbols phase
747      of a link just before adding a symbol to the global linker hash
748      table.  It may modify any of the fields as it wishes.  If *NAME
749      is set to NULL, the symbol will be skipped rather than being
750      added to the hash table.  This function is responsible for
751      handling all processor dependent symbol bindings and section
752      indices, and must set at least *FLAGS and *SEC for each processor
753      dependent case; failure to do so will cause a link error.  */
754   bfd_boolean (*elf_add_symbol_hook)
755     (bfd *abfd, struct bfd_link_info *info, Elf_Internal_Sym *,
756      const char **name, flagword *flags, asection **sec, bfd_vma *value);
757
758   /* If this field is not NULL, it is called by the elf_link_output_sym
759      phase of a link for each symbol which will appear in the object file.
760      On error, this function returns 0.  1 is returned when the symbol
761      should be output, 2 is returned when the symbol should be discarded.  */
762   int (*elf_backend_link_output_symbol_hook)
763     (struct bfd_link_info *info, const char *, Elf_Internal_Sym *,
764      asection *, struct elf_link_hash_entry *);
765
766   /* The CREATE_DYNAMIC_SECTIONS function is called by the ELF backend
767      linker the first time it encounters a dynamic object in the link.
768      This function must create any sections required for dynamic
769      linking.  The ABFD argument is a dynamic object.  The .interp,
770      .dynamic, .dynsym, .dynstr, and .hash functions have already been
771      created, and this function may modify the section flags if
772      desired.  This function will normally create the .got and .plt
773      sections, but different backends have different requirements.  */
774   bfd_boolean (*elf_backend_create_dynamic_sections)
775     (bfd *abfd, struct bfd_link_info *info);
776
777   /* When creating a shared library, determine whether to omit the
778      dynamic symbol for the section.  */
779   bfd_boolean (*elf_backend_omit_section_dynsym)
780     (bfd *output_bfd, struct bfd_link_info *info, asection *osec);
781
782   /* Return TRUE if relocations of targets are compatible to the extent
783      that CHECK_RELOCS will properly process them.  PR 4424.  */
784   bfd_boolean (*relocs_compatible) (const bfd_target *, const bfd_target *);
785
786   /* The CHECK_RELOCS function is called by the add_symbols phase of
787      the ELF backend linker.  It is called once for each section with
788      relocs of an object file, just after the symbols for the object
789      file have been added to the global linker hash table.  The
790      function must look through the relocs and do any special handling
791      required.  This generally means allocating space in the global
792      offset table, and perhaps allocating space for a reloc.  The
793      relocs are always passed as Rela structures; if the section
794      actually uses Rel structures, the r_addend field will always be
795      zero.  */
796   bfd_boolean (*check_relocs)
797     (bfd *abfd, struct bfd_link_info *info, asection *o,
798      const Elf_Internal_Rela *relocs);
799
800   /* The CHECK_DIRECTIVES function is called once per input file by
801      the add_symbols phase of the ELF backend linker.  The function
802      must inspect the bfd and create any additional symbols according
803      to any custom directives in the bfd.  */
804   bfd_boolean (*check_directives)
805     (bfd *abfd, struct bfd_link_info *info);
806
807   /* The AS_NEEDED_CLEANUP function is called once per --as-needed
808      input file that was not needed by the add_symbols phase of the
809      ELF backend linker.  The function must undo any target specific
810      changes in the symbol hash table.  */
811   bfd_boolean (*as_needed_cleanup)
812     (bfd *abfd, struct bfd_link_info *info);
813
814   /* The ADJUST_DYNAMIC_SYMBOL function is called by the ELF backend
815      linker for every symbol which is defined by a dynamic object and
816      referenced by a regular object.  This is called after all the
817      input files have been seen, but before the SIZE_DYNAMIC_SECTIONS
818      function has been called.  The hash table entry should be
819      bfd_link_hash_defined ore bfd_link_hash_defweak, and it should be
820      defined in a section from a dynamic object.  Dynamic object
821      sections are not included in the final link, and this function is
822      responsible for changing the value to something which the rest of
823      the link can deal with.  This will normally involve adding an
824      entry to the .plt or .got or some such section, and setting the
825      symbol to point to that.  */
826   bfd_boolean (*elf_backend_adjust_dynamic_symbol)
827     (struct bfd_link_info *info, struct elf_link_hash_entry *h);
828
829   /* The ALWAYS_SIZE_SECTIONS function is called by the backend linker
830      after all the linker input files have been seen but before the
831      section sizes have been set.  This is called after
832      ADJUST_DYNAMIC_SYMBOL, but before SIZE_DYNAMIC_SECTIONS.  */
833   bfd_boolean (*elf_backend_always_size_sections)
834     (bfd *output_bfd, struct bfd_link_info *info);
835
836   /* The SIZE_DYNAMIC_SECTIONS function is called by the ELF backend
837      linker after all the linker input files have been seen but before
838      the sections sizes have been set.  This is called after
839      ADJUST_DYNAMIC_SYMBOL has been called on all appropriate symbols.
840      It is only called when linking against a dynamic object.  It must
841      set the sizes of the dynamic sections, and may fill in their
842      contents as well.  The generic ELF linker can handle the .dynsym,
843      .dynstr and .hash sections.  This function must handle the
844      .interp section and any sections created by the
845      CREATE_DYNAMIC_SECTIONS entry point.  */
846   bfd_boolean (*elf_backend_size_dynamic_sections)
847     (bfd *output_bfd, struct bfd_link_info *info);
848
849   /* Set TEXT_INDEX_SECTION and DATA_INDEX_SECTION, the output sections
850      we keep to use as a base for relocs and symbols.  */
851   void (*elf_backend_init_index_section)
852     (bfd *output_bfd, struct bfd_link_info *info);
853
854   /* The RELOCATE_SECTION function is called by the ELF backend linker
855      to handle the relocations for a section.
856
857      The relocs are always passed as Rela structures; if the section
858      actually uses Rel structures, the r_addend field will always be
859      zero.
860
861      This function is responsible for adjust the section contents as
862      necessary, and (if using Rela relocs and generating a
863      relocatable output file) adjusting the reloc addend as
864      necessary.
865
866      This function does not have to worry about setting the reloc
867      address or the reloc symbol index.
868
869      LOCAL_SYMS is a pointer to the swapped in local symbols.
870
871      LOCAL_SECTIONS is an array giving the section in the input file
872      corresponding to the st_shndx field of each local symbol.
873
874      The global hash table entry for the global symbols can be found
875      via elf_sym_hashes (input_bfd).
876
877      When generating relocatable output, this function must handle
878      STB_LOCAL/STT_SECTION symbols specially.  The output symbol is
879      going to be the section symbol corresponding to the output
880      section, which means that the addend must be adjusted
881      accordingly.
882
883      Returns FALSE on error, TRUE on success, 2 if successful and
884      relocations should be written for this section.  */
885   int (*elf_backend_relocate_section)
886     (bfd *output_bfd, struct bfd_link_info *info, bfd *input_bfd,
887      asection *input_section, bfd_byte *contents, Elf_Internal_Rela *relocs,
888      Elf_Internal_Sym *local_syms, asection **local_sections);
889
890   /* The FINISH_DYNAMIC_SYMBOL function is called by the ELF backend
891      linker just before it writes a symbol out to the .dynsym section.
892      The processor backend may make any required adjustment to the
893      symbol.  It may also take the opportunity to set contents of the
894      dynamic sections.  Note that FINISH_DYNAMIC_SYMBOL is called on
895      all .dynsym symbols, while ADJUST_DYNAMIC_SYMBOL is only called
896      on those symbols which are defined by a dynamic object.  */
897   bfd_boolean (*elf_backend_finish_dynamic_symbol)
898     (bfd *output_bfd, struct bfd_link_info *info,
899      struct elf_link_hash_entry *h, Elf_Internal_Sym *sym);
900
901   /* The FINISH_DYNAMIC_SECTIONS function is called by the ELF backend
902      linker just before it writes all the dynamic sections out to the
903      output file.  The FINISH_DYNAMIC_SYMBOL will have been called on
904      all dynamic symbols.  */
905   bfd_boolean (*elf_backend_finish_dynamic_sections)
906     (bfd *output_bfd, struct bfd_link_info *info);
907
908   /* A function to do any beginning processing needed for the ELF file
909      before building the ELF headers and computing file positions.  */
910   void (*elf_backend_begin_write_processing)
911     (bfd *, struct bfd_link_info *);
912
913   /* A function to do any final processing needed for the ELF file
914      before writing it out.  The LINKER argument is TRUE if this BFD
915      was created by the ELF backend linker.  */
916   void (*elf_backend_final_write_processing)
917     (bfd *, bfd_boolean linker);
918
919   /* This function is called by get_program_header_size.  It should
920      return the number of additional program segments which this BFD
921      will need.  It should return -1 on error.  */
922   int (*elf_backend_additional_program_headers)
923     (bfd *, struct bfd_link_info *);
924
925   /* This function is called to modify an existing segment map in a
926      backend specific fashion.  */
927   bfd_boolean (*elf_backend_modify_segment_map)
928     (bfd *, struct bfd_link_info *);
929
930   /* This function is called to modify program headers just before
931      they are written.  */
932   bfd_boolean (*elf_backend_modify_program_headers)
933     (bfd *, struct bfd_link_info *);
934
935   /* This function is called before section garbage collection to
936      mark entry symbol sections.  */
937   void (*gc_keep)
938     (struct bfd_link_info *);
939
940   /* This function is called during section garbage collection to
941      mark sections that define global symbols.  */
942   bfd_boolean (*gc_mark_dynamic_ref)
943     (struct elf_link_hash_entry *, void *);
944
945   /* This function is called during section gc to discover the section a
946      particular relocation refers to.  */
947   elf_gc_mark_hook_fn gc_mark_hook;
948
949   /* This function, if defined, is called after the first gc marking pass
950      to allow the backend to mark additional sections.  */
951   bfd_boolean (*gc_mark_extra_sections)
952     (struct bfd_link_info *, elf_gc_mark_hook_fn);
953
954   /* This function, if defined, is called during the sweep phase of gc
955      in order that a backend might update any data structures it might
956      be maintaining.  */
957   bfd_boolean (*gc_sweep_hook)
958     (bfd *, struct bfd_link_info *, asection *, const Elf_Internal_Rela *);
959
960   /* This function, if defined, is called after the ELF headers have
961      been created.  This allows for things like the OS and ABI versions
962      to be changed.  */
963   void (*elf_backend_post_process_headers)
964     (bfd *, struct bfd_link_info *);
965
966   /* This function, if defined, prints a symbol to file and returns the
967      name of the symbol to be printed.  It should return NULL to fall
968      back to default symbol printing.  */
969   const char *(*elf_backend_print_symbol_all)
970     (bfd *, void *, asymbol *);
971
972   /* This function, if defined, is called after all local symbols and
973      global symbols converted to locals are emitted into the symtab
974      section.  It allows the backend to emit special local symbols
975      not handled in the hash table.  */
976   bfd_boolean (*elf_backend_output_arch_local_syms)
977     (bfd *, struct bfd_link_info *, void *,
978      bfd_boolean (*) (void *, const char *, Elf_Internal_Sym *, asection *,
979                       struct elf_link_hash_entry *));
980
981   /* This function, if defined, is called after all symbols are emitted
982      into the symtab section.  It allows the backend to emit special
983      global symbols not handled in the hash table.  */
984   bfd_boolean (*elf_backend_output_arch_syms)
985     (bfd *, struct bfd_link_info *, void *,
986      bfd_boolean (*) (void *, const char *, Elf_Internal_Sym *, asection *,
987                       struct elf_link_hash_entry *));
988
989   /* Copy any information related to dynamic linking from a pre-existing
990      symbol to a newly created symbol.  Also called to copy flags and
991      other back-end info to a weakdef, in which case the symbol is not
992      newly created and plt/got refcounts and dynamic indices should not
993      be copied.  */
994   void (*elf_backend_copy_indirect_symbol)
995     (struct bfd_link_info *, struct elf_link_hash_entry *,
996      struct elf_link_hash_entry *);
997
998   /* Modify any information related to dynamic linking such that the
999      symbol is not exported.  */
1000   void (*elf_backend_hide_symbol)
1001     (struct bfd_link_info *, struct elf_link_hash_entry *, bfd_boolean);
1002
1003   /* A function to do additional symbol fixup, called by
1004      _bfd_elf_fix_symbol_flags.  */
1005   bfd_boolean (*elf_backend_fixup_symbol)
1006     (struct bfd_link_info *, struct elf_link_hash_entry *);
1007
1008   /* Merge the backend specific symbol attribute.  */
1009   void (*elf_backend_merge_symbol_attribute)
1010     (struct elf_link_hash_entry *, const Elf_Internal_Sym *, bfd_boolean,
1011      bfd_boolean);
1012
1013   /* This function, if defined, will return a string containing the
1014      name of a target-specific dynamic tag.  */
1015   char *(*elf_backend_get_target_dtag)
1016     (bfd_vma);
1017
1018   /* Decide whether an undefined symbol is special and can be ignored.
1019      This is the case for OPTIONAL symbols on IRIX.  */
1020   bfd_boolean (*elf_backend_ignore_undef_symbol)
1021     (struct elf_link_hash_entry *);
1022
1023   /* Emit relocations.  Overrides default routine for emitting relocs,
1024      except during a relocatable link, or if all relocs are being emitted.  */
1025   bfd_boolean (*elf_backend_emit_relocs)
1026     (bfd *, asection *, Elf_Internal_Shdr *, Elf_Internal_Rela *,
1027      struct elf_link_hash_entry **);
1028
1029   /* Count relocations.  Not called for relocatable links
1030      or if all relocs are being preserved in the output.  */
1031   unsigned int (*elf_backend_count_relocs)
1032     (struct bfd_link_info *, asection *);
1033
1034   /* This function, if defined, is called when an NT_PRSTATUS note is found
1035      in a core file.  */
1036   bfd_boolean (*elf_backend_grok_prstatus)
1037     (bfd *, Elf_Internal_Note *);
1038
1039   /* This function, if defined, is called when an NT_PSINFO or NT_PRPSINFO
1040      note is found in a core file.  */
1041   bfd_boolean (*elf_backend_grok_psinfo)
1042     (bfd *, Elf_Internal_Note *);
1043
1044   /* This function, if defined, is called to write a note to a corefile.  */
1045   char *(*elf_backend_write_core_note)
1046     (bfd *abfd, char *buf, int *bufsiz, int note_type, ...);
1047
1048   /* This function returns class of a reloc type.  */
1049   enum elf_reloc_type_class (*elf_backend_reloc_type_class)
1050     (const Elf_Internal_Rela *);
1051
1052   /* This function, if defined, removes information about discarded functions
1053      from other sections which mention them.  */
1054   bfd_boolean (*elf_backend_discard_info)
1055     (bfd *, struct elf_reloc_cookie *, struct bfd_link_info *);
1056
1057   /* This function, if defined, signals that the function above has removed
1058      the discarded relocations for this section.  */
1059   bfd_boolean (*elf_backend_ignore_discarded_relocs)
1060     (asection *);
1061
1062   /* What to do when ld finds relocations against symbols defined in
1063      discarded sections.  */
1064   unsigned int (*action_discarded)
1065     (asection *);
1066
1067   /* This function returns the width of FDE pointers in bytes, or 0 if
1068      that can't be determined for some reason.  The default definition
1069      goes by the bfd's EI_CLASS.  */
1070   unsigned int (*elf_backend_eh_frame_address_size)
1071     (bfd *, asection *);
1072
1073   /* These functions tell elf-eh-frame whether to attempt to turn
1074      absolute or lsda encodings into pc-relative ones.  The default
1075      definition enables these transformations.  */
1076   bfd_boolean (*elf_backend_can_make_relative_eh_frame)
1077      (bfd *, struct bfd_link_info *, asection *);
1078   bfd_boolean (*elf_backend_can_make_lsda_relative_eh_frame)
1079      (bfd *, struct bfd_link_info *, asection *);
1080
1081   /* This function returns an encoding after computing the encoded
1082      value (and storing it in ENCODED) for the given OFFSET into OSEC,
1083      to be stored in at LOC_OFFSET into the LOC_SEC input section.
1084      The default definition chooses a 32-bit PC-relative encoding.  */
1085   bfd_byte (*elf_backend_encode_eh_address)
1086      (bfd *abfd, struct bfd_link_info *info,
1087       asection *osec, bfd_vma offset,
1088       asection *loc_sec, bfd_vma loc_offset,
1089       bfd_vma *encoded);
1090
1091   /* This function, if defined, may write out the given section.
1092      Returns TRUE if it did so and FALSE if the caller should.  */
1093   bfd_boolean (*elf_backend_write_section)
1094     (bfd *, struct bfd_link_info *, asection *, bfd_byte *);
1095
1096   /* The level of IRIX compatibility we're striving for.
1097      MIPS ELF specific function.  */
1098   irix_compat_t (*elf_backend_mips_irix_compat)
1099     (bfd *);
1100
1101   reloc_howto_type *(*elf_backend_mips_rtype_to_howto)
1102     (unsigned int, bfd_boolean);
1103
1104   /* The swapping table to use when dealing with ECOFF information.
1105      Used for the MIPS ELF .mdebug section.  */
1106   const struct ecoff_debug_swap *elf_backend_ecoff_debug_swap;
1107
1108   /* This function implements `bfd_elf_bfd_from_remote_memory';
1109      see elf.c, elfcode.h.  */
1110   bfd *(*elf_backend_bfd_from_remote_memory)
1111      (bfd *templ, bfd_vma ehdr_vma, bfd_vma *loadbasep,
1112       int (*target_read_memory) (bfd_vma vma, bfd_byte *myaddr, int len));
1113
1114   /* This function is used by `_bfd_elf_get_synthetic_symtab';
1115      see elf.c.  */
1116   bfd_vma (*plt_sym_val) (bfd_vma, const asection *, const arelent *);
1117
1118   /* Is symbol defined in common section?  */
1119   bfd_boolean (*common_definition) (Elf_Internal_Sym *);
1120
1121   /* Return a common section index for section.  */
1122   unsigned int (*common_section_index) (asection *);
1123
1124   /* Return a common section for section.  */
1125   asection *(*common_section) (asection *);
1126
1127   /* Return TRUE if we can merge 2 definitions.  */
1128   bfd_boolean (*merge_symbol) (struct bfd_link_info *,
1129                                struct elf_link_hash_entry **,
1130                                struct elf_link_hash_entry *,
1131                                Elf_Internal_Sym *, asection **,
1132                                bfd_vma *, unsigned int *,
1133                                bfd_boolean *, bfd_boolean *,
1134                                bfd_boolean *, bfd_boolean *,
1135                                bfd_boolean *, bfd_boolean *,
1136                                bfd_boolean *, bfd_boolean *,
1137                                bfd *, asection **,
1138                                bfd_boolean *, bfd_boolean *,
1139                                bfd_boolean *, bfd_boolean *,
1140                                bfd *, asection **);
1141
1142   /* Return TRUE if symbol should be hashed in the `.gnu.hash' section.  */
1143   bfd_boolean (*elf_hash_symbol) (struct elf_link_hash_entry *);
1144
1145   /* Return TRUE if type is a function symbol type.  */
1146   bfd_boolean (*is_function_type) (unsigned int type);
1147
1148   /* Used to handle bad SHF_LINK_ORDER input.  */
1149   bfd_error_handler_type link_order_error_handler;
1150
1151   /* Name of the PLT relocation section.  */
1152   const char *relplt_name;
1153
1154   /* Alternate EM_xxxx machine codes for this backend.  */
1155   int elf_machine_alt1;
1156   int elf_machine_alt2;
1157
1158   const struct elf_size_info *s;
1159
1160   /* An array of target specific special sections.  */
1161   const struct bfd_elf_special_section *special_sections;
1162
1163   /* The size in bytes of the header for the GOT.  This includes the
1164      so-called reserved entries on some systems.  */
1165   bfd_vma got_header_size;
1166
1167   /* The size of the GOT entry for the symbol pointed to by H if non-NULL,
1168      otherwise by the local symbol with index SYMNDX in IBFD.  */
1169   bfd_vma (*got_elt_size) (bfd *, struct bfd_link_info *,
1170                            struct elf_link_hash_entry *h,
1171                            bfd *ibfd, unsigned long symndx);
1172
1173   /* The vendor name to use for a processor-standard attributes section.  */
1174   const char *obj_attrs_vendor;
1175
1176   /* The section name to use for a processor-standard attributes section.  */
1177   const char *obj_attrs_section;
1178
1179   /* Return 1, 2 or 3 to indicate what type of arguments a
1180      processor-specific tag takes.  */
1181   int (*obj_attrs_arg_type) (int);
1182
1183   /* The section type to use for an attributes section.  */
1184   unsigned int obj_attrs_section_type;
1185
1186   /* This function determines the order in which any attributes are written.
1187      It must be defined for input in the range 4..NUM_KNOWN_OBJ_ATTRIBUTES-1
1188      (this range is used in order to make unity easy).  The returned value is
1189      the actual tag number to place in the input position.  */
1190   int (*obj_attrs_order) (int);
1191
1192   /* This is TRUE if the linker should act like collect and gather
1193      global constructors and destructors by name.  This is TRUE for
1194      MIPS ELF because the Irix 5 tools can not handle the .init
1195      section.  */
1196   unsigned collect : 1;
1197
1198   /* This is TRUE if the linker should ignore changes to the type of a
1199      symbol.  This is TRUE for MIPS ELF because some Irix 5 objects
1200      record undefined functions as STT_OBJECT although the definitions
1201      are STT_FUNC.  */
1202   unsigned type_change_ok : 1;
1203
1204   /* Whether the backend may use REL relocations.  (Some backends use
1205      both REL and RELA relocations, and this flag is set for those
1206      backends.)  */
1207   unsigned may_use_rel_p : 1;
1208
1209   /* Whether the backend may use RELA relocations.  (Some backends use
1210      both REL and RELA relocations, and this flag is set for those
1211      backends.)  */
1212   unsigned may_use_rela_p : 1;
1213
1214   /* Whether the default relocation type is RELA.  If a backend with
1215      this flag set wants REL relocations for a particular section,
1216      it must note that explicitly.  Similarly, if this flag is clear,
1217      and the backend wants RELA relocations for a particular
1218      section.  */
1219   unsigned default_use_rela_p : 1;
1220
1221   /* True if PLT and copy relocations should be RELA by default.  */
1222   unsigned rela_plts_and_copies_p : 1;
1223
1224   /* Set if RELA relocations for a relocatable link can be handled by
1225      generic code.  Backends that set this flag need do nothing in the
1226      backend relocate_section routine for relocatable linking.  */
1227   unsigned rela_normal : 1;
1228
1229   /* TRUE if addresses "naturally" sign extend.  This is used when
1230      swapping in from Elf32 when BFD64.  */
1231   unsigned sign_extend_vma : 1;
1232
1233   unsigned want_got_plt : 1;
1234   unsigned plt_readonly : 1;
1235   unsigned want_plt_sym : 1;
1236   unsigned plt_not_loaded : 1;
1237   unsigned plt_alignment : 4;
1238   unsigned can_gc_sections : 1;
1239   unsigned can_refcount : 1;
1240   unsigned want_got_sym : 1;
1241   unsigned want_dynbss : 1;
1242
1243   /* Targets which do not support physical addressing often require
1244      that the p_paddr field in the section header to be set to zero.
1245      This field indicates whether this behavior is required.  */
1246   unsigned want_p_paddr_set_to_zero : 1;
1247
1248   /* True if an object file lacking a .note.GNU-stack section
1249      should be assumed to be requesting exec stack.  At least one
1250      other file in the link needs to have a .note.GNU-stack section
1251      for a PT_GNU_STACK segment to be created.  */
1252   unsigned default_execstack : 1;
1253 };
1254
1255 /* Information stored for each BFD section in an ELF file.  This
1256    structure is allocated by elf_new_section_hook.  */
1257
1258 struct bfd_elf_section_data
1259 {
1260   /* The ELF header for this section.  */
1261   Elf_Internal_Shdr this_hdr;
1262
1263   /* The ELF header for the reloc section associated with this
1264      section, if any.  */
1265   Elf_Internal_Shdr rel_hdr;
1266
1267   /* If there is a second reloc section associated with this section,
1268      as can happen on Irix 6, this field points to the header.  */
1269   Elf_Internal_Shdr *rel_hdr2;
1270
1271   /* The number of relocations currently assigned to REL_HDR.  */
1272   unsigned int rel_count;
1273
1274   /* The number of relocations currently assigned to REL_HDR2.  */
1275   unsigned int rel_count2;
1276
1277   /* The ELF section number of this section.  */
1278   int this_idx;
1279
1280   /* The ELF section number of the reloc section indicated by
1281      REL_HDR if any.  Only used for an output file.  */
1282   int rel_idx;
1283
1284   /* The ELF section number of the reloc section indicated by
1285      REL_HDR2 if any.  Only used for an output file.  */
1286   int rel_idx2;
1287
1288   /* Used by the backend linker when generating a shared library to
1289      record the dynamic symbol index for a section symbol
1290      corresponding to this section.  A value of 0 means that there is
1291      no dynamic symbol for this section.  */
1292   int dynindx;
1293
1294   /* A pointer to the linked-to section for SHF_LINK_ORDER.  */
1295   asection *linked_to;
1296
1297   /* Used by the backend linker to store the symbol hash table entries
1298      associated with relocs against global symbols.  */
1299   struct elf_link_hash_entry **rel_hashes;
1300
1301   /* A pointer to the swapped relocs.  If the section uses REL relocs,
1302      rather than RELA, all the r_addend fields will be zero.  This
1303      pointer may be NULL.  It is used by the backend linker.  */
1304   Elf_Internal_Rela *relocs;
1305
1306   /* A pointer to a linked list tracking dynamic relocs copied for
1307      local symbols.  */
1308   void *local_dynrel;
1309
1310   /* A pointer to the bfd section used for dynamic relocs.  */
1311   asection *sreloc;
1312
1313   union {
1314     /* Group name, if this section is a member of a group.  */
1315     const char *name;
1316
1317     /* Group signature sym, if this is the SHT_GROUP section.  */
1318     struct bfd_symbol *id;
1319   } group;
1320
1321   /* For a member of a group, points to the SHT_GROUP section.
1322      NULL for the SHT_GROUP section itself and non-group sections.  */
1323   asection *sec_group;
1324
1325   /* A linked list of member sections in the group.  Circular when used by
1326      the linker.  For the SHT_GROUP section, points at first member.  */
1327   asection *next_in_group;
1328
1329   /* The FDEs associated with this section.  The u.fde.next_in_section
1330      field acts as a chain pointer.  */
1331   struct eh_cie_fde *fde_list;
1332
1333   /* A pointer used for various section optimizations.  */
1334   void *sec_info;
1335 };
1336
1337 #define elf_section_data(sec)  ((struct bfd_elf_section_data*)(sec)->used_by_bfd)
1338 #define elf_linked_to_section(sec) (elf_section_data(sec)->linked_to)
1339 #define elf_section_type(sec)  (elf_section_data(sec)->this_hdr.sh_type)
1340 #define elf_section_flags(sec) (elf_section_data(sec)->this_hdr.sh_flags)
1341 #define elf_group_name(sec)    (elf_section_data(sec)->group.name)
1342 #define elf_group_id(sec)      (elf_section_data(sec)->group.id)
1343 #define elf_next_in_group(sec) (elf_section_data(sec)->next_in_group)
1344 #define elf_fde_list(sec)      (elf_section_data(sec)->fde_list)
1345 #define elf_sec_group(sec)      (elf_section_data(sec)->sec_group)
1346
1347 #define xvec_get_elf_backend_data(xvec) \
1348   ((const struct elf_backend_data *) (xvec)->backend_data)
1349
1350 #define get_elf_backend_data(abfd) \
1351    xvec_get_elf_backend_data ((abfd)->xvec)
1352
1353 /* The maximum number of known object attributes for any target.  */
1354 #define NUM_KNOWN_OBJ_ATTRIBUTES 71
1355
1356 /* The value of an object attribute.  The type indicates whether the attribute
1357    holds and integer, a string, or both.  It can also indicate that there can
1358    be no default (i.e. all values must be written to file, even zero).  */
1359
1360 typedef struct obj_attribute
1361 {
1362 #define ATTR_TYPE_FLAG_INT_VAL    (1 << 0)
1363 #define ATTR_TYPE_FLAG_STR_VAL    (1 << 1)
1364 #define ATTR_TYPE_FLAG_NO_DEFAULT (1 << 2)
1365
1366 #define ATTR_TYPE_HAS_INT_VAL(TYPE)     ((TYPE) & ATTR_TYPE_FLAG_INT_VAL)
1367 #define ATTR_TYPE_HAS_STR_VAL(TYPE)     ((TYPE) & ATTR_TYPE_FLAG_STR_VAL)
1368 #define ATTR_TYPE_HAS_NO_DEFAULT(TYPE)  ((TYPE) & ATTR_TYPE_FLAG_NO_DEFAULT)
1369
1370   int type;
1371   unsigned int i;
1372   char *s;
1373 } obj_attribute;
1374
1375 typedef struct obj_attribute_list
1376 {
1377   struct obj_attribute_list *next;
1378   int tag;
1379   obj_attribute attr;
1380 } obj_attribute_list;
1381
1382 /* Object attributes may either be defined by the processor ABI, index
1383    OBJ_ATTR_PROC in the *_obj_attributes arrays, or be GNU-specific
1384    (and possibly also processor-specific), index OBJ_ATTR_GNU.  */
1385 #define OBJ_ATTR_PROC 0
1386 #define OBJ_ATTR_GNU 1
1387 #define OBJ_ATTR_FIRST OBJ_ATTR_PROC
1388 #define OBJ_ATTR_LAST OBJ_ATTR_GNU
1389
1390 /* The following object attribute tags are taken as generic, for all
1391    targets and for "gnu" where there is no target standard.  */
1392 enum
1393 {
1394   Tag_NULL = 0,
1395   Tag_File = 1,
1396   Tag_Section = 2,
1397   Tag_Symbol = 3,
1398   Tag_compatibility = 32
1399 };
1400
1401 /* Enum used to identify target specific extensions to the elf_obj_tdata
1402    structure.  Note the enums deliberately start from 1 so that we can
1403    detect an uninitialized field.  The generic value is last so that
1404    additions to this enum do not need to modify more than one line.  */
1405 enum elf_object_id
1406 {
1407   ALPHA_ELF_TDATA = 1,
1408   ARM_ELF_TDATA,
1409   HPPA_ELF_TDATA,
1410   I386_ELF_TDATA,
1411   MIPS_ELF_TDATA,
1412   PPC32_ELF_TDATA,
1413   PPC64_ELF_TDATA,
1414   S390_ELF_TDATA,
1415   SH_ELF_TDATA,
1416   SPARC_ELF_TDATA,
1417   X86_64_ELF_TDATA,
1418   XTENSA_ELF_TDATA,
1419   GENERIC_ELF_TDATA
1420 };
1421
1422 /* Some private data is stashed away for future use using the tdata pointer
1423    in the bfd structure.  */
1424
1425 struct elf_obj_tdata
1426 {
1427   Elf_Internal_Ehdr elf_header[1];      /* Actual data, but ref like ptr */
1428   Elf_Internal_Shdr **elf_sect_ptr;
1429   Elf_Internal_Phdr *phdr;
1430   struct elf_segment_map *segment_map;
1431   struct elf_strtab_hash *strtab_ptr;
1432   int num_locals;
1433   int num_globals;
1434   unsigned int num_elf_sections;        /* elf_sect_ptr size */
1435   int num_section_syms;
1436   asymbol **section_syms;               /* STT_SECTION symbols for each section */
1437   Elf_Internal_Shdr symtab_hdr;
1438   Elf_Internal_Shdr shstrtab_hdr;
1439   Elf_Internal_Shdr strtab_hdr;
1440   Elf_Internal_Shdr dynsymtab_hdr;
1441   Elf_Internal_Shdr dynstrtab_hdr;
1442   Elf_Internal_Shdr dynversym_hdr;
1443   Elf_Internal_Shdr dynverref_hdr;
1444   Elf_Internal_Shdr dynverdef_hdr;
1445   Elf_Internal_Shdr symtab_shndx_hdr;
1446   unsigned int symtab_section, shstrtab_section;
1447   unsigned int strtab_section, dynsymtab_section;
1448   unsigned int symtab_shndx_section;
1449   unsigned int dynversym_section, dynverdef_section, dynverref_section;
1450   file_ptr next_file_pos;
1451   bfd_vma gp;                           /* The gp value */
1452   unsigned int gp_size;                 /* The gp size */
1453
1454   /* Information grabbed from an elf core file.  */
1455   int core_signal;
1456   int core_pid;
1457   int core_lwpid;
1458   char* core_program;
1459   char* core_command;
1460
1461   /* A mapping from external symbols to entries in the linker hash
1462      table, used when linking.  This is indexed by the symbol index
1463      minus the sh_info field of the symbol table header.  */
1464   struct elf_link_hash_entry **sym_hashes;
1465
1466   /* Track usage and final offsets of GOT entries for local symbols.
1467      This array is indexed by symbol index.  Elements are used
1468      identically to "got" in struct elf_link_hash_entry.  */
1469   union
1470     {
1471       bfd_signed_vma *refcounts;
1472       bfd_vma *offsets;
1473       struct got_entry **ents;
1474     } local_got;
1475
1476   /* The linker ELF emulation code needs to let the backend ELF linker
1477      know what filename should be used for a dynamic object if the
1478      dynamic object is found using a search.  The emulation code then
1479      sometimes needs to know what name was actually used.  Until the
1480      file has been added to the linker symbol table, this field holds
1481      the name the linker wants.  After it has been added, it holds the
1482      name actually used, which will be the DT_SONAME entry if there is
1483      one.  */
1484   const char *dt_name;
1485
1486   /* Records the result of `get_program_header_size'.  */
1487   bfd_size_type program_header_size;
1488
1489   /* Used by find_nearest_line entry point.  */
1490   void *line_info;
1491
1492   /* Used by MIPS ELF find_nearest_line entry point.  The structure
1493      could be included directly in this one, but there's no point to
1494      wasting the memory just for the infrequently called
1495      find_nearest_line.  */
1496   struct mips_elf_find_line *find_line_info;
1497
1498   /* A place to stash dwarf1 info for this bfd.  */
1499   struct dwarf1_debug *dwarf1_find_line_info;
1500
1501   /* A place to stash dwarf2 info for this bfd.  */
1502   void *dwarf2_find_line_info;
1503
1504   /* An array of stub sections indexed by symbol number, used by the
1505      MIPS ELF linker.  FIXME: We should figure out some way to only
1506      include this field for a MIPS ELF target.  */
1507   asection **local_stubs;
1508   asection **local_call_stubs;
1509
1510   /* Used to determine if PT_GNU_EH_FRAME segment header should be
1511      created.  */
1512   asection *eh_frame_hdr;
1513
1514   Elf_Internal_Shdr **group_sect_ptr;
1515   int num_group;
1516
1517   /* Number of symbol version definitions we are about to emit.  */
1518   unsigned int cverdefs;
1519
1520   /* Number of symbol version references we are about to emit.  */
1521   unsigned int cverrefs;
1522
1523   /* Segment flags for the PT_GNU_STACK segment.  */
1524   unsigned int stack_flags;
1525
1526   /* Symbol version definitions in external objects.  */
1527   Elf_Internal_Verdef *verdef;
1528
1529   /* Symbol version references to external objects.  */
1530   Elf_Internal_Verneed *verref;
1531
1532   /* The Irix 5 support uses two virtual sections, which represent
1533      text/data symbols defined in dynamic objects.  */
1534   asymbol *elf_data_symbol;
1535   asymbol *elf_text_symbol;
1536   asection *elf_data_section;
1537   asection *elf_text_section;
1538
1539   /* A pointer to the .eh_frame section.  */
1540   asection *eh_frame_section;
1541
1542   /* Whether a dyanmic object was specified normally on the linker
1543      command line, or was specified when --as-needed was in effect,
1544      or was found via a DT_NEEDED entry.  */
1545   enum dynamic_lib_link_class dyn_lib_class;
1546
1547   /* This is set to TRUE if the object was created by the backend
1548      linker.  */
1549   bfd_boolean linker;
1550
1551   /* Irix 5 often screws up the symbol table, sorting local symbols
1552      after global symbols.  This flag is set if the symbol table in
1553      this BFD appears to be screwed up.  If it is, we ignore the
1554      sh_info field in the symbol table header, and always read all the
1555      symbols.  */
1556   bfd_boolean bad_symtab;
1557
1558   /* Used to determine if the e_flags field has been initialized */
1559   bfd_boolean flags_init;
1560
1561   /* Symbol buffer.  */
1562   void *symbuf;
1563
1564   obj_attribute known_obj_attributes[2][NUM_KNOWN_OBJ_ATTRIBUTES];
1565   obj_attribute_list *other_obj_attributes[2];
1566
1567   /* Called at the end of _bfd_elf_write_object_contents if not NULL.  */
1568   bfd_boolean (*after_write_object_contents) (bfd *);
1569   void *after_write_object_contents_info;
1570
1571   /* NT_GNU_BUILD_ID note type.  */
1572   bfd_size_type build_id_size;
1573   bfd_byte *build_id;
1574
1575   /* True if the bfd contains symbols that have the STT_GNU_IFUNC
1576      symbol type.  Used to set the osabi field in the ELF header
1577      structure.  */
1578   bfd_boolean has_ifunc_symbols;
1579
1580   /* An identifier used to distinguish different target
1581      specific extensions to this structure.  */
1582   enum elf_object_id object_id;
1583 };
1584
1585 #define elf_tdata(bfd)          ((bfd) -> tdata.elf_obj_data)
1586
1587 #define elf_object_id(bfd)      (elf_tdata(bfd) -> object_id)
1588 #define elf_program_header_size(bfd) (elf_tdata(bfd) -> program_header_size)
1589 #define elf_elfheader(bfd)      (elf_tdata(bfd) -> elf_header)
1590 #define elf_elfsections(bfd)    (elf_tdata(bfd) -> elf_sect_ptr)
1591 #define elf_numsections(bfd)    (elf_tdata(bfd) -> num_elf_sections)
1592 #define elf_shstrtab(bfd)       (elf_tdata(bfd) -> strtab_ptr)
1593 #define elf_onesymtab(bfd)      (elf_tdata(bfd) -> symtab_section)
1594 #define elf_symtab_shndx(bfd)   (elf_tdata(bfd) -> symtab_shndx_section)
1595 #define elf_symtab_hdr(bfd)     (elf_tdata(bfd) -> symtab_hdr)
1596 #define elf_dynsymtab(bfd)      (elf_tdata(bfd) -> dynsymtab_section)
1597 #define elf_dynversym(bfd)      (elf_tdata(bfd) -> dynversym_section)
1598 #define elf_dynverdef(bfd)      (elf_tdata(bfd) -> dynverdef_section)
1599 #define elf_dynverref(bfd)      (elf_tdata(bfd) -> dynverref_section)
1600 #define elf_eh_frame_section(bfd) \
1601                                 (elf_tdata(bfd) -> eh_frame_section)
1602 #define elf_num_locals(bfd)     (elf_tdata(bfd) -> num_locals)
1603 #define elf_num_globals(bfd)    (elf_tdata(bfd) -> num_globals)
1604 #define elf_section_syms(bfd)   (elf_tdata(bfd) -> section_syms)
1605 #define elf_num_section_syms(bfd) (elf_tdata(bfd) -> num_section_syms)
1606 #define core_prpsinfo(bfd)      (elf_tdata(bfd) -> prpsinfo)
1607 #define core_prstatus(bfd)      (elf_tdata(bfd) -> prstatus)
1608 #define elf_gp(bfd)             (elf_tdata(bfd) -> gp)
1609 #define elf_gp_size(bfd)        (elf_tdata(bfd) -> gp_size)
1610 #define elf_sym_hashes(bfd)     (elf_tdata(bfd) -> sym_hashes)
1611 #define elf_local_got_refcounts(bfd) (elf_tdata(bfd) -> local_got.refcounts)
1612 #define elf_local_got_offsets(bfd) (elf_tdata(bfd) -> local_got.offsets)
1613 #define elf_local_got_ents(bfd) (elf_tdata(bfd) -> local_got.ents)
1614 #define elf_dt_name(bfd)        (elf_tdata(bfd) -> dt_name)
1615 #define elf_dyn_lib_class(bfd)  (elf_tdata(bfd) -> dyn_lib_class)
1616 #define elf_bad_symtab(bfd)     (elf_tdata(bfd) -> bad_symtab)
1617 #define elf_flags_init(bfd)     (elf_tdata(bfd) -> flags_init)
1618 #define elf_known_obj_attributes(bfd) (elf_tdata (bfd) -> known_obj_attributes)
1619 #define elf_other_obj_attributes(bfd) (elf_tdata (bfd) -> other_obj_attributes)
1620 #define elf_known_obj_attributes_proc(bfd) \
1621   (elf_known_obj_attributes (bfd) [OBJ_ATTR_PROC])
1622 #define elf_other_obj_attributes_proc(bfd) \
1623   (elf_other_obj_attributes (bfd) [OBJ_ATTR_PROC])
1624 \f
1625 extern void _bfd_elf_swap_verdef_in
1626   (bfd *, const Elf_External_Verdef *, Elf_Internal_Verdef *);
1627 extern void _bfd_elf_swap_verdef_out
1628   (bfd *, const Elf_Internal_Verdef *, Elf_External_Verdef *);
1629 extern void _bfd_elf_swap_verdaux_in
1630   (bfd *, const Elf_External_Verdaux *, Elf_Internal_Verdaux *);
1631 extern void _bfd_elf_swap_verdaux_out
1632   (bfd *, const Elf_Internal_Verdaux *, Elf_External_Verdaux *);
1633 extern void _bfd_elf_swap_verneed_in
1634   (bfd *, const Elf_External_Verneed *, Elf_Internal_Verneed *);
1635 extern void _bfd_elf_swap_verneed_out
1636   (bfd *, const Elf_Internal_Verneed *, Elf_External_Verneed *);
1637 extern void _bfd_elf_swap_vernaux_in
1638   (bfd *, const Elf_External_Vernaux *, Elf_Internal_Vernaux *);
1639 extern void _bfd_elf_swap_vernaux_out
1640   (bfd *, const Elf_Internal_Vernaux *, Elf_External_Vernaux *);
1641 extern void _bfd_elf_swap_versym_in
1642   (bfd *, const Elf_External_Versym *, Elf_Internal_Versym *);
1643 extern void _bfd_elf_swap_versym_out
1644   (bfd *, const Elf_Internal_Versym *, Elf_External_Versym *);
1645
1646 extern unsigned int _bfd_elf_section_from_bfd_section
1647   (bfd *, asection *);
1648 extern char *bfd_elf_string_from_elf_section
1649   (bfd *, unsigned, unsigned);
1650 extern Elf_Internal_Sym *bfd_elf_get_elf_syms
1651   (bfd *, Elf_Internal_Shdr *, size_t, size_t, Elf_Internal_Sym *, void *,
1652    Elf_External_Sym_Shndx *);
1653 extern const char *bfd_elf_sym_name
1654   (bfd *, Elf_Internal_Shdr *, Elf_Internal_Sym *, asection *);
1655
1656 extern bfd_boolean _bfd_elf_copy_private_bfd_data
1657   (bfd *, bfd *);
1658 extern bfd_boolean _bfd_elf_print_private_bfd_data
1659   (bfd *, void *);
1660 extern void bfd_elf_print_symbol
1661   (bfd *, void *, asymbol *, bfd_print_symbol_type);
1662
1663 extern unsigned int _bfd_elf_eh_frame_address_size
1664   (bfd *, asection *);
1665 extern bfd_byte _bfd_elf_encode_eh_address
1666   (bfd *abfd, struct bfd_link_info *info, asection *osec, bfd_vma offset,
1667    asection *loc_sec, bfd_vma loc_offset, bfd_vma *encoded);
1668 extern bfd_boolean _bfd_elf_can_make_relative
1669   (bfd *input_bfd, struct bfd_link_info *info, asection *eh_frame_section);
1670
1671 extern enum elf_reloc_type_class _bfd_elf_reloc_type_class
1672   (const Elf_Internal_Rela *);
1673 extern bfd_vma _bfd_elf_rela_local_sym
1674   (bfd *, Elf_Internal_Sym *, asection **, Elf_Internal_Rela *);
1675 extern bfd_vma _bfd_elf_rel_local_sym
1676   (bfd *, Elf_Internal_Sym *, asection **, bfd_vma);
1677 extern bfd_vma _bfd_elf_section_offset
1678   (bfd *, struct bfd_link_info *, asection *, bfd_vma);
1679
1680 extern unsigned long bfd_elf_hash
1681   (const char *);
1682 extern unsigned long bfd_elf_gnu_hash
1683   (const char *);
1684
1685 extern bfd_reloc_status_type bfd_elf_generic_reloc
1686   (bfd *, arelent *, asymbol *, void *, asection *, bfd *, char **);
1687 extern bfd_boolean bfd_elf_allocate_object
1688   (bfd *, size_t, enum elf_object_id);
1689 extern bfd_boolean bfd_elf_make_generic_object
1690   (bfd *);
1691 extern bfd_boolean bfd_elf_mkcorefile
1692   (bfd *);
1693 extern bfd_boolean _bfd_elf_make_section_from_shdr
1694   (bfd *, Elf_Internal_Shdr *, const char *, int);
1695 extern bfd_boolean _bfd_elf_make_section_from_phdr
1696   (bfd *, Elf_Internal_Phdr *, int, const char *);
1697 extern struct bfd_hash_entry *_bfd_elf_link_hash_newfunc
1698   (struct bfd_hash_entry *, struct bfd_hash_table *, const char *);
1699 extern struct bfd_link_hash_table *_bfd_elf_link_hash_table_create
1700   (bfd *);
1701 extern void _bfd_elf_link_hash_copy_indirect
1702   (struct bfd_link_info *, struct elf_link_hash_entry *,
1703    struct elf_link_hash_entry *);
1704 extern void _bfd_elf_link_hash_hide_symbol
1705   (struct bfd_link_info *, struct elf_link_hash_entry *, bfd_boolean);
1706 extern bfd_boolean _bfd_elf_link_hash_fixup_symbol
1707   (struct bfd_link_info *, struct elf_link_hash_entry *);
1708 extern bfd_boolean _bfd_elf_link_hash_table_init
1709   (struct elf_link_hash_table *, bfd *,
1710    struct bfd_hash_entry *(*)
1711      (struct bfd_hash_entry *, struct bfd_hash_table *, const char *),
1712    unsigned int);
1713 extern bfd_boolean _bfd_elf_slurp_version_tables
1714   (bfd *, bfd_boolean);
1715 extern bfd_boolean _bfd_elf_merge_sections
1716   (bfd *, struct bfd_link_info *);
1717 extern bfd_boolean _bfd_elf_match_sections_by_type
1718   (bfd *, const asection *, bfd *, const asection *);
1719 extern bfd_boolean bfd_elf_is_group_section
1720   (bfd *, const struct bfd_section *);
1721 extern void _bfd_elf_section_already_linked
1722   (bfd *, struct bfd_section *, struct bfd_link_info *);
1723 extern void bfd_elf_set_group_contents
1724   (bfd *, asection *, void *);
1725 extern asection *_bfd_elf_check_kept_section
1726   (asection *, struct bfd_link_info *);
1727 extern void _bfd_elf_link_just_syms
1728   (asection *, struct bfd_link_info *);
1729 extern bfd_boolean _bfd_elf_copy_private_header_data
1730   (bfd *, bfd *);
1731 extern bfd_boolean _bfd_elf_copy_private_symbol_data
1732   (bfd *, asymbol *, bfd *, asymbol *);
1733 #define _bfd_generic_init_private_section_data \
1734   _bfd_elf_init_private_section_data
1735 extern bfd_boolean _bfd_elf_init_private_section_data
1736   (bfd *, asection *, bfd *, asection *, struct bfd_link_info *);
1737 extern bfd_boolean _bfd_elf_copy_private_section_data
1738   (bfd *, asection *, bfd *, asection *);
1739 extern bfd_boolean _bfd_elf_write_object_contents
1740   (bfd *);
1741 extern bfd_boolean _bfd_elf_write_corefile_contents
1742   (bfd *);
1743 extern bfd_boolean _bfd_elf_set_section_contents
1744   (bfd *, sec_ptr, const void *, file_ptr, bfd_size_type);
1745 extern long _bfd_elf_get_symtab_upper_bound
1746   (bfd *);
1747 extern long _bfd_elf_canonicalize_symtab
1748   (bfd *, asymbol **);
1749 extern long _bfd_elf_get_dynamic_symtab_upper_bound
1750   (bfd *);
1751 extern long _bfd_elf_canonicalize_dynamic_symtab
1752   (bfd *, asymbol **);
1753 extern long _bfd_elf_get_synthetic_symtab
1754   (bfd *, long, asymbol **, long, asymbol **, asymbol **);
1755 extern long _bfd_elf_get_reloc_upper_bound
1756   (bfd *, sec_ptr);
1757 extern long _bfd_elf_canonicalize_reloc
1758   (bfd *, sec_ptr, arelent **, asymbol **);
1759 extern asection * _bfd_elf_get_dynamic_reloc_section
1760   (bfd *, asection *, bfd_boolean);
1761 extern asection * _bfd_elf_make_dynamic_reloc_section
1762   (asection *, bfd *, unsigned int, bfd *, bfd_boolean);
1763 extern long _bfd_elf_get_dynamic_reloc_upper_bound
1764   (bfd *);
1765 extern long _bfd_elf_canonicalize_dynamic_reloc
1766   (bfd *, arelent **, asymbol **);
1767 extern asymbol *_bfd_elf_make_empty_symbol
1768   (bfd *);
1769 extern void _bfd_elf_get_symbol_info
1770   (bfd *, asymbol *, symbol_info *);
1771 extern bfd_boolean _bfd_elf_is_local_label_name
1772   (bfd *, const char *);
1773 extern alent *_bfd_elf_get_lineno
1774   (bfd *, asymbol *);
1775 extern bfd_boolean _bfd_elf_set_arch_mach
1776   (bfd *, enum bfd_architecture, unsigned long);
1777 extern bfd_boolean _bfd_elf_find_nearest_line
1778   (bfd *, asection *, asymbol **, bfd_vma, const char **, const char **,
1779    unsigned int *);
1780 extern bfd_boolean _bfd_elf_find_line
1781   (bfd *, asymbol **, asymbol *, const char **, unsigned int *);
1782 #define _bfd_generic_find_line _bfd_elf_find_line
1783 extern bfd_boolean _bfd_elf_find_inliner_info
1784   (bfd *, const char **, const char **, unsigned int *);
1785 #define _bfd_elf_read_minisymbols _bfd_generic_read_minisymbols
1786 #define _bfd_elf_minisymbol_to_symbol _bfd_generic_minisymbol_to_symbol
1787 extern int _bfd_elf_sizeof_headers
1788   (bfd *, struct bfd_link_info *);
1789 extern bfd_boolean _bfd_elf_new_section_hook
1790   (bfd *, asection *);
1791 extern bfd_boolean _bfd_elf_init_reloc_shdr
1792   (bfd *, Elf_Internal_Shdr *, asection *, bfd_boolean);
1793 extern const struct bfd_elf_special_section *_bfd_elf_get_special_section
1794   (const char *, const struct bfd_elf_special_section *, unsigned int);
1795 extern const struct bfd_elf_special_section *_bfd_elf_get_sec_type_attr
1796   (bfd *, asection *);
1797
1798 /* If the target doesn't have reloc handling written yet:  */
1799 extern void _bfd_elf_no_info_to_howto
1800   (bfd *, arelent *, Elf_Internal_Rela *);
1801
1802 extern bfd_boolean bfd_section_from_shdr
1803   (bfd *, unsigned int shindex);
1804 extern bfd_boolean bfd_section_from_phdr
1805   (bfd *, Elf_Internal_Phdr *, int);
1806
1807 extern int _bfd_elf_symbol_from_bfd_symbol
1808   (bfd *, asymbol **);
1809
1810 extern asection *bfd_section_from_r_symndx
1811   (bfd *, struct sym_sec_cache *, asection *, unsigned long);
1812 extern asection *bfd_section_from_elf_index
1813   (bfd *, unsigned int);
1814 extern struct bfd_strtab_hash *_bfd_elf_stringtab_init
1815   (void);
1816
1817 extern struct elf_strtab_hash * _bfd_elf_strtab_init
1818   (void);
1819 extern void _bfd_elf_strtab_free
1820   (struct elf_strtab_hash *);
1821 extern bfd_size_type _bfd_elf_strtab_add
1822   (struct elf_strtab_hash *, const char *, bfd_boolean);
1823 extern void _bfd_elf_strtab_addref
1824   (struct elf_strtab_hash *, bfd_size_type);
1825 extern void _bfd_elf_strtab_delref
1826   (struct elf_strtab_hash *, bfd_size_type);
1827 extern void _bfd_elf_strtab_clear_all_refs
1828   (struct elf_strtab_hash *);
1829 extern bfd_size_type _bfd_elf_strtab_size
1830   (struct elf_strtab_hash *);
1831 extern bfd_size_type _bfd_elf_strtab_offset
1832   (struct elf_strtab_hash *, bfd_size_type);
1833 extern bfd_boolean _bfd_elf_strtab_emit
1834   (bfd *, struct elf_strtab_hash *);
1835 extern void _bfd_elf_strtab_finalize
1836   (struct elf_strtab_hash *);
1837
1838 extern void _bfd_elf_begin_eh_frame_parsing
1839   (struct bfd_link_info *info);
1840 extern void _bfd_elf_parse_eh_frame
1841   (bfd *, struct bfd_link_info *, asection *, struct elf_reloc_cookie *);
1842 extern void _bfd_elf_end_eh_frame_parsing
1843   (struct bfd_link_info *info);
1844
1845 extern bfd_boolean _bfd_elf_discard_section_eh_frame
1846   (bfd *, struct bfd_link_info *, asection *,
1847    bfd_boolean (*) (bfd_vma, void *), struct elf_reloc_cookie *);
1848 extern bfd_boolean _bfd_elf_discard_section_eh_frame_hdr
1849   (bfd *, struct bfd_link_info *);
1850 extern bfd_vma _bfd_elf_eh_frame_section_offset
1851   (bfd *, struct bfd_link_info *, asection *, bfd_vma);
1852 extern bfd_boolean _bfd_elf_write_section_eh_frame
1853   (bfd *, struct bfd_link_info *, asection *, bfd_byte *);
1854 extern bfd_boolean _bfd_elf_write_section_eh_frame_hdr
1855   (bfd *, struct bfd_link_info *);
1856 extern bfd_boolean _bfd_elf_maybe_strip_eh_frame_hdr
1857   (struct bfd_link_info *);
1858
1859 extern bfd_boolean _bfd_elf_merge_symbol
1860   (bfd *, struct bfd_link_info *, const char *, Elf_Internal_Sym *,
1861    asection **, bfd_vma *, unsigned int *,
1862    struct elf_link_hash_entry **, bfd_boolean *,
1863    bfd_boolean *, bfd_boolean *, bfd_boolean *);
1864
1865 extern bfd_boolean _bfd_elf_hash_symbol (struct elf_link_hash_entry *);
1866
1867 extern long _bfd_elf_link_lookup_local_dynindx
1868   (struct bfd_link_info *, bfd *, long);
1869 extern bfd_boolean _bfd_elf_compute_section_file_positions
1870   (bfd *, struct bfd_link_info *);
1871 extern void _bfd_elf_assign_file_positions_for_relocs
1872   (bfd *);
1873 extern file_ptr _bfd_elf_assign_file_position_for_section
1874   (Elf_Internal_Shdr *, file_ptr, bfd_boolean);
1875
1876 extern bfd_boolean _bfd_elf_validate_reloc
1877   (bfd *, arelent *);
1878
1879 extern bfd_boolean _bfd_elf_link_create_dynamic_sections
1880   (bfd *, struct bfd_link_info *);
1881 extern bfd_boolean _bfd_elf_link_omit_section_dynsym
1882   (bfd *, struct bfd_link_info *, asection *);
1883 extern bfd_boolean _bfd_elf_create_dynamic_sections
1884   (bfd *, struct bfd_link_info *);
1885 extern bfd_boolean _bfd_elf_create_got_section
1886   (bfd *, struct bfd_link_info *);
1887 extern struct elf_link_hash_entry *_bfd_elf_define_linkage_sym
1888   (bfd *, struct bfd_link_info *, asection *, const char *);
1889 extern void _bfd_elf_init_1_index_section
1890   (bfd *, struct bfd_link_info *);
1891 extern void _bfd_elf_init_2_index_sections
1892   (bfd *, struct bfd_link_info *);
1893
1894 extern bfd_boolean _bfd_elfcore_make_pseudosection
1895   (bfd *, char *, size_t, ufile_ptr);
1896 extern char *_bfd_elfcore_strndup
1897   (bfd *, char *, size_t);
1898
1899 extern Elf_Internal_Rela *_bfd_elf_link_read_relocs
1900   (bfd *, asection *, void *, Elf_Internal_Rela *, bfd_boolean);
1901
1902 extern bfd_boolean _bfd_elf_link_output_relocs
1903   (bfd *, asection *, Elf_Internal_Shdr *, Elf_Internal_Rela *,
1904    struct elf_link_hash_entry **);
1905
1906 extern bfd_boolean _bfd_elf_adjust_dynamic_copy
1907   (struct elf_link_hash_entry *, asection *);
1908
1909 extern bfd_boolean _bfd_elf_dynamic_symbol_p
1910   (struct elf_link_hash_entry *, struct bfd_link_info *, bfd_boolean);
1911
1912 extern bfd_boolean _bfd_elf_symbol_refs_local_p
1913   (struct elf_link_hash_entry *, struct bfd_link_info *, bfd_boolean);
1914
1915 extern bfd_reloc_status_type bfd_elf_perform_complex_relocation
1916   (bfd *, asection *, bfd_byte *, Elf_Internal_Rela *, bfd_vma);
1917
1918 extern bfd_boolean _bfd_elf_setup_sections
1919   (bfd *);
1920
1921 extern void _bfd_elf_set_osabi (bfd * , struct bfd_link_info *);
1922
1923 extern const bfd_target *bfd_elf32_object_p
1924   (bfd *);
1925 extern const bfd_target *bfd_elf32_core_file_p
1926   (bfd *);
1927 extern char *bfd_elf32_core_file_failing_command
1928   (bfd *);
1929 extern int bfd_elf32_core_file_failing_signal
1930   (bfd *);
1931 extern bfd_boolean bfd_elf32_core_file_matches_executable_p
1932   (bfd *, bfd *);
1933
1934 extern bfd_boolean bfd_elf32_swap_symbol_in
1935   (bfd *, const void *, const void *, Elf_Internal_Sym *);
1936 extern void bfd_elf32_swap_symbol_out
1937   (bfd *, const Elf_Internal_Sym *, void *, void *);
1938 extern void bfd_elf32_swap_reloc_in
1939   (bfd *, const bfd_byte *, Elf_Internal_Rela *);
1940 extern void bfd_elf32_swap_reloc_out
1941   (bfd *, const Elf_Internal_Rela *, bfd_byte *);
1942 extern void bfd_elf32_swap_reloca_in
1943   (bfd *, const bfd_byte *, Elf_Internal_Rela *);
1944 extern void bfd_elf32_swap_reloca_out
1945   (bfd *, const Elf_Internal_Rela *, bfd_byte *);
1946 extern void bfd_elf32_swap_phdr_in
1947   (bfd *, const Elf32_External_Phdr *, Elf_Internal_Phdr *);
1948 extern void bfd_elf32_swap_phdr_out
1949   (bfd *, const Elf_Internal_Phdr *, Elf32_External_Phdr *);
1950 extern void bfd_elf32_swap_dyn_in
1951   (bfd *, const void *, Elf_Internal_Dyn *);
1952 extern void bfd_elf32_swap_dyn_out
1953   (bfd *, const Elf_Internal_Dyn *, void *);
1954 extern long bfd_elf32_slurp_symbol_table
1955   (bfd *, asymbol **, bfd_boolean);
1956 extern bfd_boolean bfd_elf32_write_shdrs_and_ehdr
1957   (bfd *);
1958 extern int bfd_elf32_write_out_phdrs
1959   (bfd *, const Elf_Internal_Phdr *, unsigned int);
1960 extern bfd_boolean bfd_elf32_checksum_contents
1961   (bfd * , void (*) (const void *, size_t, void *), void *);
1962 extern void bfd_elf32_write_relocs
1963   (bfd *, asection *, void *);
1964 extern bfd_boolean bfd_elf32_slurp_reloc_table
1965   (bfd *, asection *, asymbol **, bfd_boolean);
1966
1967 extern const bfd_target *bfd_elf64_object_p
1968   (bfd *);
1969 extern const bfd_target *bfd_elf64_core_file_p
1970   (bfd *);
1971 extern char *bfd_elf64_core_file_failing_command
1972   (bfd *);
1973 extern int bfd_elf64_core_file_failing_signal
1974   (bfd *);
1975 extern bfd_boolean bfd_elf64_core_file_matches_executable_p
1976   (bfd *, bfd *);
1977
1978 extern bfd_boolean bfd_elf64_swap_symbol_in
1979   (bfd *, const void *, const void *, Elf_Internal_Sym *);
1980 extern void bfd_elf64_swap_symbol_out
1981   (bfd *, const Elf_Internal_Sym *, void *, void *);
1982 extern void bfd_elf64_swap_reloc_in
1983   (bfd *, const bfd_byte *, Elf_Internal_Rela *);
1984 extern void bfd_elf64_swap_reloc_out
1985   (bfd *, const Elf_Internal_Rela *, bfd_byte *);
1986 extern void bfd_elf64_swap_reloca_in
1987   (bfd *, const bfd_byte *, Elf_Internal_Rela *);
1988 extern void bfd_elf64_swap_reloca_out
1989   (bfd *, const Elf_Internal_Rela *, bfd_byte *);
1990 extern void bfd_elf64_swap_phdr_in
1991   (bfd *, const Elf64_External_Phdr *, Elf_Internal_Phdr *);
1992 extern void bfd_elf64_swap_phdr_out
1993   (bfd *, const Elf_Internal_Phdr *, Elf64_External_Phdr *);
1994 extern void bfd_elf64_swap_dyn_in
1995   (bfd *, const void *, Elf_Internal_Dyn *);
1996 extern void bfd_elf64_swap_dyn_out
1997   (bfd *, const Elf_Internal_Dyn *, void *);
1998 extern long bfd_elf64_slurp_symbol_table
1999   (bfd *, asymbol **, bfd_boolean);
2000 extern bfd_boolean bfd_elf64_write_shdrs_and_ehdr
2001   (bfd *);
2002 extern int bfd_elf64_write_out_phdrs
2003   (bfd *, const Elf_Internal_Phdr *, unsigned int);
2004 extern bfd_boolean bfd_elf64_checksum_contents
2005   (bfd * , void (*) (const void *, size_t, void *), void *);
2006 extern void bfd_elf64_write_relocs
2007   (bfd *, asection *, void *);
2008 extern bfd_boolean bfd_elf64_slurp_reloc_table
2009   (bfd *, asection *, asymbol **, bfd_boolean);
2010
2011 extern bfd_boolean _bfd_elf_default_relocs_compatible
2012   (const bfd_target *, const bfd_target *);
2013
2014 extern bfd_boolean _bfd_elf_relocs_compatible
2015   (const bfd_target *, const bfd_target *);
2016
2017 extern struct elf_link_hash_entry *_bfd_elf_archive_symbol_lookup
2018   (bfd *, struct bfd_link_info *, const char *);
2019 extern bfd_boolean bfd_elf_link_add_symbols
2020   (bfd *, struct bfd_link_info *);
2021 extern bfd_boolean _bfd_elf_add_dynamic_entry
2022   (struct bfd_link_info *, bfd_vma, bfd_vma);
2023
2024 extern bfd_boolean bfd_elf_link_record_dynamic_symbol
2025   (struct bfd_link_info *, struct elf_link_hash_entry *);
2026
2027 extern int bfd_elf_link_record_local_dynamic_symbol
2028   (struct bfd_link_info *, bfd *, long);
2029
2030 extern bfd_boolean _bfd_elf_close_and_cleanup
2031   (bfd *);
2032
2033 extern bfd_boolean _bfd_elf_common_definition
2034   (Elf_Internal_Sym *);
2035
2036 extern unsigned int _bfd_elf_common_section_index
2037   (asection *);
2038
2039 extern asection *_bfd_elf_common_section
2040   (asection *);
2041
2042 extern void _bfd_dwarf2_cleanup_debug_info
2043   (bfd *);
2044
2045 extern bfd_vma _bfd_elf_default_got_elt_size
2046 (bfd *, struct bfd_link_info *, struct elf_link_hash_entry *, bfd *,
2047  unsigned long);
2048
2049 extern bfd_reloc_status_type _bfd_elf_rel_vtable_reloc_fn
2050   (bfd *, arelent *, struct bfd_symbol *, void *,
2051    asection *, bfd *, char **);
2052
2053 extern bfd_boolean bfd_elf_final_link
2054   (bfd *, struct bfd_link_info *);
2055
2056 extern void _bfd_elf_gc_keep
2057   (struct bfd_link_info *info);
2058
2059 extern bfd_boolean bfd_elf_gc_mark_dynamic_ref_symbol
2060   (struct elf_link_hash_entry *h, void *inf);
2061
2062 extern bfd_boolean bfd_elf_gc_sections
2063   (bfd *, struct bfd_link_info *);
2064
2065 extern bfd_boolean bfd_elf_gc_record_vtinherit
2066   (bfd *, asection *, struct elf_link_hash_entry *, bfd_vma);
2067
2068 extern bfd_boolean bfd_elf_gc_record_vtentry
2069   (bfd *, asection *, struct elf_link_hash_entry *, bfd_vma);
2070
2071 extern asection *_bfd_elf_gc_mark_hook
2072   (asection *, struct bfd_link_info *, Elf_Internal_Rela *,
2073    struct elf_link_hash_entry *, Elf_Internal_Sym *);
2074
2075 extern asection *_bfd_elf_gc_mark_rsec
2076   (struct bfd_link_info *, asection *, elf_gc_mark_hook_fn,
2077    struct elf_reloc_cookie *);
2078
2079 extern bfd_boolean _bfd_elf_gc_mark_reloc
2080   (struct bfd_link_info *, asection *, elf_gc_mark_hook_fn,
2081    struct elf_reloc_cookie *);
2082
2083 extern bfd_boolean _bfd_elf_gc_mark_fdes
2084   (struct bfd_link_info *, asection *, asection *, elf_gc_mark_hook_fn,
2085    struct elf_reloc_cookie *);
2086
2087 extern bfd_boolean _bfd_elf_gc_mark
2088   (struct bfd_link_info *, asection *, elf_gc_mark_hook_fn);
2089
2090 extern bfd_boolean bfd_elf_gc_common_finalize_got_offsets
2091   (bfd *, struct bfd_link_info *);
2092
2093 extern bfd_boolean bfd_elf_gc_common_final_link
2094   (bfd *, struct bfd_link_info *);
2095
2096 extern bfd_boolean bfd_elf_reloc_symbol_deleted_p
2097   (bfd_vma, void *);
2098
2099 extern struct elf_segment_map * _bfd_elf_make_dynamic_segment
2100   (bfd *, asection *);
2101
2102 extern bfd_boolean _bfd_elf_map_sections_to_segments
2103   (bfd *, struct bfd_link_info *);
2104
2105 extern bfd_boolean _bfd_elf_is_function_type (unsigned int);
2106
2107 extern Elf_Internal_Phdr * _bfd_elf_find_segment_containing_section
2108   (bfd * abfd, asection * section);
2109
2110 /* Exported interface for writing elf corefile notes. */
2111 extern char *elfcore_write_note
2112   (bfd *, char *, int *, const char *, int, const void *, int);
2113 extern char *elfcore_write_prpsinfo
2114   (bfd *, char *, int *, const char *, const char *);
2115 extern char *elfcore_write_prstatus
2116   (bfd *, char *, int *, long, int, const void *);
2117 extern char * elfcore_write_pstatus
2118   (bfd *, char *, int *, long, int, const void *);
2119 extern char *elfcore_write_prfpreg
2120   (bfd *, char *, int *, const void *, int);
2121 extern char *elfcore_write_prxfpreg
2122   (bfd *, char *, int *, const void *, int);
2123 extern char *elfcore_write_ppc_vmx
2124   (bfd *, char *, int *, const void *, int);
2125 extern char *elfcore_write_ppc_vsx
2126   (bfd *, char *, int *, const void *, int);
2127 extern char *elfcore_write_lwpstatus
2128   (bfd *, char *, int *, long, int, const void *);
2129 extern char *elfcore_write_register_note
2130   (bfd *, char *, int *, const char *, const void *, int);
2131
2132 extern bfd *_bfd_elf32_bfd_from_remote_memory
2133   (bfd *templ, bfd_vma ehdr_vma, bfd_vma *loadbasep,
2134    int (*target_read_memory) (bfd_vma, bfd_byte *, int));
2135 extern bfd *_bfd_elf64_bfd_from_remote_memory
2136   (bfd *templ, bfd_vma ehdr_vma, bfd_vma *loadbasep,
2137    int (*target_read_memory) (bfd_vma, bfd_byte *, int));
2138
2139 extern bfd_vma bfd_elf_obj_attr_size (bfd *);
2140 extern void bfd_elf_set_obj_attr_contents (bfd *, bfd_byte *, bfd_vma);
2141 extern int bfd_elf_get_obj_attr_int (bfd *, int, int);
2142 extern void bfd_elf_add_obj_attr_int (bfd *, int, int, unsigned int);
2143 #define bfd_elf_add_proc_attr_int(BFD, TAG, VALUE) \
2144   bfd_elf_add_obj_attr_int ((BFD), OBJ_ATTR_PROC, (TAG), (VALUE))
2145 extern void bfd_elf_add_obj_attr_string (bfd *, int, int, const char *);
2146 #define bfd_elf_add_proc_attr_string(BFD, TAG, VALUE) \
2147   bfd_elf_add_obj_attr_string ((BFD), OBJ_ATTR_PROC, (TAG), (VALUE))
2148 extern void bfd_elf_add_obj_attr_int_string (bfd *, int, int, unsigned int,
2149                                              const char *);
2150 #define bfd_elf_add_proc_attr_int_string(BFD, TAG, INTVAL, STRVAL) \
2151   bfd_elf_add_obj_attr_int_string ((BFD), OBJ_ATTR_PROC, (TAG), \
2152                                    (INTVAL), (STRVAL))
2153
2154 extern char *_bfd_elf_attr_strdup (bfd *, const char *);
2155 extern void _bfd_elf_copy_obj_attributes (bfd *, bfd *);
2156 extern int _bfd_elf_obj_attrs_arg_type (bfd *, int, int);
2157 extern void _bfd_elf_parse_attributes (bfd *, Elf_Internal_Shdr *);
2158 extern bfd_boolean _bfd_elf_merge_object_attributes (bfd *, bfd *);
2159
2160 extern bfd_boolean _bfd_elf_create_ifunc_sections
2161   (bfd *, struct bfd_link_info *);
2162
2163 /* Large common section.  */
2164 extern asection _bfd_elf_large_com_section;
2165
2166 /* This is the condition under which finish_dynamic_symbol will be called.
2167    If our finish_dynamic_symbol isn't called, we'll need to do something
2168    about initializing any .plt and .got entries in relocate_section.  */
2169 #define WILL_CALL_FINISH_DYNAMIC_SYMBOL(DYN, SHARED, H) \
2170   ((DYN)                                                                \
2171    && ((SHARED) || !(H)->forced_local)                                  \
2172    && ((H)->dynindx != -1 || (H)->forced_local))
2173
2174 /* This macro is to avoid lots of duplicated code in the body
2175    of xxx_relocate_section() in the various elfxx-xxxx.c files.  */
2176 #define RELOC_FOR_GLOBAL_SYMBOL(info, input_bfd, input_section, rel,    \
2177                                 r_symndx, symtab_hdr, sym_hashes,       \
2178                                 h, sec, relocation,                     \
2179                                 unresolved_reloc, warned)               \
2180   do                                                                    \
2181     {                                                                   \
2182       /* It seems this can happen with erroneous or unsupported         \
2183          input (mixing a.out and elf in an archive, for example.)  */   \
2184       if (sym_hashes == NULL)                                           \
2185         return FALSE;                                                   \
2186                                                                         \
2187       h = sym_hashes[r_symndx - symtab_hdr->sh_info];                   \
2188                                                                         \
2189       while (h->root.type == bfd_link_hash_indirect                     \
2190              || h->root.type == bfd_link_hash_warning)                  \
2191         h = (struct elf_link_hash_entry *) h->root.u.i.link;            \
2192                                                                         \
2193       warned = FALSE;                                                   \
2194       unresolved_reloc = FALSE;                                         \
2195       relocation = 0;                                                   \
2196       if (h->root.type == bfd_link_hash_defined                         \
2197           || h->root.type == bfd_link_hash_defweak)                     \
2198         {                                                               \
2199           sec = h->root.u.def.section;                                  \
2200           if (sec == NULL                                               \
2201               || sec->output_section == NULL)                           \
2202             /* Set a flag that will be cleared later if we find a       \
2203                relocation value for this symbol.  output_section        \
2204                is typically NULL for symbols satisfied by a shared      \
2205                library.  */                                             \
2206             unresolved_reloc = TRUE;                                    \
2207           else                                                          \
2208             relocation = (h->root.u.def.value                           \
2209                           + sec->output_section->vma                    \
2210                           + sec->output_offset);                        \
2211         }                                                               \
2212       else if (h->root.type == bfd_link_hash_undefweak)                 \
2213         ;                                                               \
2214       else if (info->unresolved_syms_in_objects == RM_IGNORE            \
2215                && ELF_ST_VISIBILITY (h->other) == STV_DEFAULT)          \
2216         ;                                                               \
2217       else if (!info->relocatable)                                      \
2218         {                                                               \
2219           bfd_boolean err;                                              \
2220           err = (info->unresolved_syms_in_objects == RM_GENERATE_ERROR  \
2221                  || ELF_ST_VISIBILITY (h->other) != STV_DEFAULT);       \
2222           if (!info->callbacks->undefined_symbol (info,                 \
2223                                                   h->root.root.string,  \
2224                                                   input_bfd,            \
2225                                                   input_section,        \
2226                                                   rel->r_offset, err))  \
2227             return FALSE;                                               \
2228           warned = TRUE;                                                \
2229         }                                                               \
2230     }                                                                   \
2231   while (0)
2232
2233 /* Will a symbol be bound to the the definition within the shared
2234    library, if any.  */
2235 #define SYMBOLIC_BIND(INFO, H) \
2236     ((INFO)->symbolic || ((INFO)->dynamic && !(H)->dynamic))
2237
2238 #endif /* _LIBELF_H_ */