* elf-bfd.h (struct elf_link_hash_entry): Replace elf_link_hash_flags
[deliverable/binutils-gdb.git] / bfd / elf-bfd.h
CommitLineData
252b5132 1/* BFD back-end data structures for ELF files.
e5094212 2 Copyright 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001,
4a43e768 3 2002, 2003, 2004 Free Software Foundation, Inc.
252b5132
RH
4 Written by Cygnus Support.
5
5e8d7549 6 This file is part of BFD, the Binary File Descriptor library.
252b5132 7
5e8d7549
NC
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version.
252b5132 12
5e8d7549
NC
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
252b5132 17
5e8d7549
NC
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
252b5132
RH
21
22#ifndef _LIBELF_H_
23#define _LIBELF_H_ 1
24
25#include "elf/common.h"
26#include "elf/internal.h"
27#include "elf/external.h"
28#include "bfdlink.h"
29
d9bc7a44 30/* The number of entries in a section is its size divided by the size
51b64d56 31 of a single entry. This is normally only applicable to reloc and
d9bc7a44
NC
32 symbol table sections. */
33#define NUM_SHDR_ENTRIES(shdr) ((shdr)->sh_size / (shdr)->sh_entsize)
34
252b5132
RH
35/* If size isn't specified as 64 or 32, NAME macro should fail. */
36#ifndef NAME
c39a58e6
AM
37#if ARCH_SIZE == 64
38#define NAME(x, y) x ## 64 ## _ ## y
252b5132 39#endif
c39a58e6
AM
40#if ARCH_SIZE == 32
41#define NAME(x, y) x ## 32 ## _ ## y
252b5132
RH
42#endif
43#endif
44
45#ifndef NAME
c39a58e6 46#define NAME(x, y) x ## NOSIZE ## _ ## y
252b5132
RH
47#endif
48
49#define ElfNAME(X) NAME(Elf,X)
50#define elfNAME(X) NAME(elf,X)
51
52/* Information held for an ELF symbol. The first field is the
53 corresponding asymbol. Every symbol is an ELF file is actually a
54 pointer to this structure, although it is often handled as a
55 pointer to an asymbol. */
56
57typedef struct
58{
59 /* The BFD symbol. */
60 asymbol symbol;
61 /* ELF symbol information. */
62 Elf_Internal_Sym internal_elf_sym;
63 /* Backend specific information. */
64 union
65 {
66 unsigned int hppa_arg_reloc;
c39a58e6
AM
67 void *mips_extr;
68 void *any;
252b5132
RH
69 }
70 tc_data;
71
72 /* Version information. This is from an Elf_Internal_Versym
73 structure in a SHT_GNU_versym section. It is zero if there is no
74 version information. */
75 unsigned short version;
76
77} elf_symbol_type;
78\f
2b0f7ef9 79struct elf_strtab_hash;
5cab59f6
AM
80struct got_entry;
81struct plt_entry;
2b0f7ef9 82
252b5132
RH
83/* ELF linker hash table entries. */
84
85struct elf_link_hash_entry
86{
87 struct bfd_link_hash_entry root;
88
89 /* Symbol index in output file. This is initialized to -1. It is
90 set to -2 if the symbol is used by a reloc. */
91 long indx;
92
252b5132
RH
93 /* Symbol index as a dynamic symbol. Initialized to -1, and remains
94 -1 if this is not a dynamic symbol. */
30b30c21
RH
95 /* ??? Note that this is consistently used as a synonym for tests
96 against whether we can perform various simplifying transformations
97 to the code. (E.g. changing a pc-relative jump to a PLT entry
98 into a pc-relative jump to the target function.) That test, which
99 is often relatively complex, and someplaces wrong or incomplete,
100 should really be replaced by a predicate in elflink.c.
101
102 End result: this field -1 does not indicate that the symbol is
103 not in the dynamic symbol table, but rather that the symbol is
104 not visible outside this DSO. */
252b5132
RH
105 long dynindx;
106
107 /* String table index in .dynstr if this is a dynamic symbol. */
108 unsigned long dynstr_index;
109
a90b9fca
AM
110 /* Hash value of the name computed using the ELF hash function. */
111 unsigned long elf_hash_value;
112
252b5132
RH
113 /* If this is a weak defined symbol from a dynamic object, this
114 field points to a defined symbol with the same value, if there is
115 one. Otherwise it is NULL. */
116 struct elf_link_hash_entry *weakdef;
117
252b5132
RH
118 /* Version information. */
119 union
120 {
121 /* This field is used for a symbol which is not defined in a
122 regular object. It points to the version information read in
123 from the dynamic object. */
124 Elf_Internal_Verdef *verdef;
125 /* This field is used for a symbol which is defined in a regular
126 object. It is set up in size_dynamic_sections. It points to
127 the version information we should write out for this symbol. */
128 struct bfd_elf_version_tree *vertree;
129 } verinfo;
130
131 /* Virtual table entry use information. This array is nominally of size
132 size/sizeof(target_void_pointer), though we have to be able to assume
133 and track a size while the symbol is still undefined. It is indexed
134 via offset/sizeof(target_void_pointer). */
135 size_t vtable_entries_size;
b34976b6 136 bfd_boolean *vtable_entries_used;
252b5132
RH
137
138 /* Virtual table derivation info. */
139 struct elf_link_hash_entry *vtable_parent;
140
a90b9fca
AM
141 /* If this symbol requires an entry in the global offset table, the
142 processor specific backend uses this field to track usage and
5cab59f6
AM
143 final offset. Two schemes are supported: The first assumes that
144 a symbol may only have one GOT entry, and uses REFCOUNT until
145 size_dynamic_sections, at which point the contents of the .got is
146 fixed. Afterward, if OFFSET is -1, then the symbol does not
147 require a global offset table entry. The second scheme allows
148 multiple GOT entries per symbol, managed via a linked list
149 pointed to by GLIST. */
150 union gotplt_union
a90b9fca
AM
151 {
152 bfd_signed_vma refcount;
153 bfd_vma offset;
5cab59f6
AM
154 struct got_entry *glist;
155 struct plt_entry *plist;
a90b9fca
AM
156 } got;
157
158 /* Same, but tracks a procedure linkage table entry. */
5cab59f6 159 union gotplt_union plt;
a90b9fca
AM
160
161 /* Symbol size. */
162 bfd_size_type size;
163
252b5132 164 /* Symbol type (STT_NOTYPE, STT_OBJECT, etc.). */
f5385ebf 165 unsigned int type : 8;
252b5132 166
9b234ee9 167 /* Symbol st_other value, symbol visibility. */
f5385ebf 168 unsigned int other : 8;
252b5132 169
252b5132 170 /* Symbol is referenced by a non-shared object. */
f5385ebf 171 unsigned int ref_regular : 1;
252b5132 172 /* Symbol is defined by a non-shared object. */
f5385ebf 173 unsigned int def_regular : 1;
252b5132 174 /* Symbol is referenced by a shared object. */
f5385ebf 175 unsigned int ref_dynamic : 1;
252b5132 176 /* Symbol is defined by a shared object. */
f5385ebf 177 unsigned int def_dynamic : 1;
252b5132 178 /* Symbol has a non-weak reference from a non-shared object. */
f5385ebf 179 unsigned int ref_regular_nonweak : 1;
252b5132 180 /* Dynamic symbol has been adjustd. */
f5385ebf 181 unsigned int dynamic_adjusted : 1;
252b5132 182 /* Symbol needs a copy reloc. */
f5385ebf 183 unsigned int needs_copy : 1;
252b5132 184 /* Symbol needs a procedure linkage table entry. */
f5385ebf 185 unsigned int needs_plt : 1;
252b5132 186 /* Symbol appears in a non-ELF input file. */
f5385ebf 187 unsigned int non_elf : 1;
252b5132 188 /* Symbol should be marked as hidden in the version information. */
f5385ebf 189 unsigned int hidden : 1;
252b5132 190 /* Symbol was forced to local scope due to a version script file. */
f5385ebf 191 unsigned int forced_local : 1;
252b5132 192 /* Symbol was marked during garbage collection. */
f5385ebf 193 unsigned int mark : 1;
7843f00e
ILT
194 /* Symbol is referenced by a non-GOT/non-PLT relocation. This is
195 not currently set by all the backends. */
f5385ebf 196 unsigned int non_got_ref : 1;
1b1fe8fe 197 /* Symbol has a definition in a shared object. */
f5385ebf 198 unsigned int dynamic_def : 1;
1b1fe8fe 199 /* Symbol is weak in all shared objects. */
f5385ebf 200 unsigned int dynamic_weak : 1;
c6585bbb
JJ
201 /* Symbol is referenced with a relocation where C/C++ pointer equality
202 matters. */
f5385ebf 203 unsigned int pointer_equality_needed : 1;
252b5132
RH
204};
205
586119b3
AM
206/* Will references to this symbol always reference the symbol
207 in this object? STV_PROTECTED is excluded from the visibility test
208 here so that function pointer comparisons work properly. Since
209 function symbols not defined in an app are set to their .plt entry,
210 it's necessary for shared libs to also reference the .plt even
211 though the symbol is really local to the shared lib. */
986a241f 212#define SYMBOL_REFERENCES_LOCAL(INFO, H) \
f6c52c13 213 _bfd_elf_symbol_refs_local_p (H, INFO, 0)
586119b3
AM
214
215/* Will _calls_ to this symbol always call the version in this object? */
986a241f 216#define SYMBOL_CALLS_LOCAL(INFO, H) \
f6c52c13 217 _bfd_elf_symbol_refs_local_p (H, INFO, 1)
586119b3 218
7e2294f9
AO
219/* Common symbols that are turned into definitions don't have the
220 DEF_REGULAR flag set, so they might appear to be undefined. */
221#define ELF_COMMON_DEF_P(H) \
f5385ebf
AM
222 (!(H)->def_regular \
223 && !(H)->def_dynamic \
7e2294f9
AO
224 && (H)->root.type == bfd_link_hash_defined)
225
30b30c21
RH
226/* Records local symbols to be emitted in the dynamic symbol table. */
227
228struct elf_link_local_dynamic_entry
229{
230 struct elf_link_local_dynamic_entry *next;
231
232 /* The input bfd this symbol came from. */
233 bfd *input_bfd;
234
235 /* The index of the local symbol being copied. */
236 long input_indx;
237
238 /* The index in the outgoing dynamic symbol table. */
239 long dynindx;
3e932841 240
30b30c21
RH
241 /* A copy of the input symbol. */
242 Elf_Internal_Sym isym;
243};
244
f5d44ba0
AM
245struct elf_link_loaded_list
246{
247 struct elf_link_loaded_list *next;
248 bfd *abfd;
249};
250
126495ed
AM
251/* Structures used by the eh_frame optimization code. */
252struct cie_header
253{
254 unsigned int length;
255 unsigned int id;
256};
257
258struct cie
259{
260 struct cie_header hdr;
261 unsigned char version;
262 unsigned char augmentation[20];
263 unsigned int code_align;
264 int data_align;
265 unsigned int ra_column;
266 unsigned int augmentation_size;
267 struct elf_link_hash_entry *personality;
268 unsigned char per_encoding;
269 unsigned char lsda_encoding;
270 unsigned char fde_encoding;
271 unsigned char initial_insn_length;
272 unsigned char make_relative;
273 unsigned char make_lsda_relative;
274 unsigned char initial_instructions[50];
275};
276
277struct eh_cie_fde
278{
279 unsigned int offset;
280 unsigned int size;
281 asection *sec;
282 unsigned int new_offset;
283 unsigned char fde_encoding;
284 unsigned char lsda_encoding;
285 unsigned char lsda_offset;
822392ce
DJ
286 unsigned int cie : 1;
287 unsigned int removed : 1;
288 unsigned int make_relative : 1;
289 unsigned int make_lsda_relative : 1;
290 unsigned int per_encoding_relative : 1;
126495ed
AM
291};
292
293struct eh_frame_sec_info
294{
295 unsigned int count;
296 unsigned int alloced;
297 struct eh_cie_fde entry[1];
298};
299
300struct eh_frame_array_ent
301{
302 bfd_vma initial_loc;
303 bfd_vma fde;
304};
305
306struct eh_frame_hdr_info
307{
308 struct cie last_cie;
309 asection *last_cie_sec;
310 asection *hdr_sec;
311 unsigned int last_cie_offset;
312 unsigned int fde_count, array_count;
313 struct eh_frame_array_ent *array;
314 /* TRUE if .eh_frame_hdr should contain the sorted search table.
315 We build it if we successfully read all .eh_frame input sections
316 and recognize them. */
b34976b6 317 bfd_boolean table;
126495ed
AM
318};
319
252b5132
RH
320/* ELF linker hash table. */
321
322struct elf_link_hash_table
323{
324 struct bfd_link_hash_table root;
51b64d56 325
252b5132
RH
326 /* Whether we have created the special dynamic sections required
327 when linking against or generating a shared object. */
b34976b6 328 bfd_boolean dynamic_sections_created;
51b64d56 329
252b5132
RH
330 /* The BFD used to hold special sections created by the linker.
331 This will be the first BFD found which requires these sections to
332 be created. */
333 bfd *dynobj;
51b64d56
AM
334
335 /* The value to use when initialising got.refcount/offset and
336 plt.refcount/offset in an elf_link_hash_entry. Set to zero when
5cab59f6
AM
337 the values are refcounts. Set to init_offset in
338 size_dynamic_sections when the values may be offsets. */
339 union gotplt_union init_refcount;
340
341 /* The value to use for got.refcount/offset and plt.refcount/offset
342 when the values may be offsets. Normally (bfd_vma) -1. */
343 union gotplt_union init_offset;
51b64d56 344
252b5132
RH
345 /* The number of symbols found in the link which must be put into
346 the .dynsym section. */
347 bfd_size_type dynsymcount;
51b64d56 348
252b5132
RH
349 /* The string table of dynamic symbols, which becomes the .dynstr
350 section. */
2b0f7ef9 351 struct elf_strtab_hash *dynstr;
51b64d56 352
252b5132
RH
353 /* The number of buckets in the hash table in the .hash section.
354 This is based on the number of dynamic symbols. */
355 bfd_size_type bucketcount;
51b64d56 356
252b5132
RH
357 /* A linked list of DT_NEEDED names found in dynamic objects
358 included in the link. */
359 struct bfd_link_needed_list *needed;
51b64d56 360
252b5132
RH
361 /* The _GLOBAL_OFFSET_TABLE_ symbol. */
362 struct elf_link_hash_entry *hgot;
51b64d56 363
f5fa8ca2 364 /* A pointer to information used to merge SEC_MERGE sections. */
c39a58e6 365 void *merge_info;
51b64d56 366
3722b82f
AM
367 /* Used to link stabs in sections. */
368 struct stab_info stab_info;
369
126495ed
AM
370 /* Used by eh_frame code when editing .eh_frame. */
371 struct eh_frame_hdr_info eh_info;
372
30b30c21
RH
373 /* A linked list of local symbols to be added to .dynsym. */
374 struct elf_link_local_dynamic_entry *dynlocal;
51b64d56 375
a963dc6a
L
376 /* A linked list of DT_RPATH/DT_RUNPATH names found in dynamic
377 objects included in the link. */
378 struct bfd_link_needed_list *runpath;
13ae64f3 379
e1918d23
AM
380 /* Cached first output tls section and size of PT_TLS segment. */
381 asection *tls_sec;
382 bfd_size_type tls_size;
f5d44ba0
AM
383
384 /* A linked list of BFD's loaded in the link. */
385 struct elf_link_loaded_list *loaded;
252b5132
RH
386};
387
388/* Look up an entry in an ELF linker hash table. */
389
390#define elf_link_hash_lookup(table, string, create, copy, follow) \
391 ((struct elf_link_hash_entry *) \
392 bfd_link_hash_lookup (&(table)->root, (string), (create), \
393 (copy), (follow)))
394
395/* Traverse an ELF linker hash table. */
396
397#define elf_link_hash_traverse(table, func, info) \
398 (bfd_link_hash_traverse \
399 (&(table)->root, \
c39a58e6 400 (bfd_boolean (*) (struct bfd_link_hash_entry *, void *)) (func), \
252b5132
RH
401 (info)))
402
403/* Get the ELF linker hash table from a link_info structure. */
404
405#define elf_hash_table(p) ((struct elf_link_hash_table *) ((p)->hash))
8ea2e4bd 406
b34976b6 407/* Returns TRUE if the hash table is a struct elf_link_hash_table. */
0eddce27
AM
408#define is_elf_hash_table(htab) \
409 (((struct bfd_link_hash_table *) (htab))->type == bfd_link_elf_hash_table)
ec338859
AM
410
411/* Used by bfd_section_from_r_symndx to cache a small number of local
412 symbol to section mappings. */
413#define LOCAL_SYM_CACHE_SIZE 32
414struct sym_sec_cache
415{
416 bfd *abfd;
417 unsigned long indx[LOCAL_SYM_CACHE_SIZE];
418 asection *sec[LOCAL_SYM_CACHE_SIZE];
419};
252b5132
RH
420\f
421/* Constant information held for an ELF backend. */
422
423struct elf_size_info {
424 unsigned char sizeof_ehdr, sizeof_phdr, sizeof_shdr;
425 unsigned char sizeof_rel, sizeof_rela, sizeof_sym, sizeof_dyn, sizeof_note;
426
c7ac6ff8
MM
427 /* The size of entries in the .hash section. */
428 unsigned char sizeof_hash_entry;
429
430 /* The number of internal relocations to allocate per external
431 relocation entry. */
432 unsigned char int_rels_per_ext_rel;
947216bf
AM
433 /* We use some fixed size arrays. This should be large enough to
434 handle all back-ends. */
435#define MAX_INT_RELS_PER_EXT_REL 3
c7ac6ff8 436
45d6a902 437 unsigned char arch_size, log_file_align;
252b5132 438 unsigned char elfclass, ev_current;
dc810e39 439 int (*write_out_phdrs)
c39a58e6
AM
440 (bfd *, const Elf_Internal_Phdr *, unsigned int);
441 bfd_boolean
442 (*write_shdrs_and_ehdr) (bfd *);
dc810e39 443 void (*write_relocs)
c39a58e6 444 (bfd *, asection *, void *);
73ff0d56 445 void (*swap_symbol_in)
c39a58e6 446 (bfd *, const void *, const void *, Elf_Internal_Sym *);
dc810e39 447 void (*swap_symbol_out)
c39a58e6 448 (bfd *, const Elf_Internal_Sym *, void *, void *);
b34976b6 449 bfd_boolean (*slurp_reloc_table)
c39a58e6 450 (bfd *, asection *, asymbol **, bfd_boolean);
dc810e39 451 long (*slurp_symbol_table)
c39a58e6 452 (bfd *, asymbol **, bfd_boolean);
dc810e39 453 void (*swap_dyn_in)
c39a58e6 454 (bfd *, const void *, Elf_Internal_Dyn *);
dc810e39 455 void (*swap_dyn_out)
c39a58e6 456 (bfd *, const Elf_Internal_Dyn *, void *);
c7ac6ff8 457
947216bf
AM
458 /* This function is called to swap in a REL relocation. If an
459 external relocation corresponds to more than one internal
460 relocation, then all relocations are swapped in at once. */
c7ac6ff8 461 void (*swap_reloc_in)
c39a58e6 462 (bfd *, const bfd_byte *, Elf_Internal_Rela *);
c7ac6ff8 463
947216bf 464 /* This function is called to swap out a REL relocation. */
c7ac6ff8 465 void (*swap_reloc_out)
c39a58e6 466 (bfd *, const Elf_Internal_Rela *, bfd_byte *);
c7ac6ff8 467
947216bf
AM
468 /* This function is called to swap in a RELA relocation. If an
469 external relocation corresponds to more than one internal
470 relocation, then all relocations are swapped in at once. */
c7ac6ff8 471 void (*swap_reloca_in)
c39a58e6 472 (bfd *, const bfd_byte *, Elf_Internal_Rela *);
c7ac6ff8 473
947216bf 474 /* This function is called to swap out a RELA relocation. */
c7ac6ff8 475 void (*swap_reloca_out)
c39a58e6 476 (bfd *, const Elf_Internal_Rela *, bfd_byte *);
252b5132
RH
477};
478
479#define elf_symbol_from(ABFD,S) \
480 (((S)->the_bfd->xvec->flavour == bfd_target_elf_flavour \
481 && (S)->the_bfd->tdata.elf_obj_data != 0) \
482 ? (elf_symbol_type *) (S) \
483 : 0)
484
db6751f2
JJ
485enum elf_reloc_type_class {
486 reloc_class_normal,
487 reloc_class_relative,
488 reloc_class_plt,
489 reloc_class_copy
490};
491
73d074b4
DJ
492struct elf_reloc_cookie
493{
494 Elf_Internal_Rela *rels, *rel, *relend;
6cdc0ccc 495 Elf_Internal_Sym *locsyms;
73d074b4
DJ
496 bfd *abfd;
497 size_t locsymcount;
498 size_t extsymoff;
499 struct elf_link_hash_entry **sym_hashes;
140f6c8e 500 int r_sym_shift;
b34976b6 501 bfd_boolean bad_symtab;
73d074b4
DJ
502};
503
c6e90b02
TS
504/* The level of IRIX compatibility we're striving for. */
505
506typedef enum {
507 ict_none,
508 ict_irix5,
509 ict_irix6
510} irix_compat_t;
511
2f89ff8d
L
512/* Mapping of ELF section names and types. */
513struct bfd_elf_special_section
514{
515 const char *prefix;
7dcb9820
AM
516 int prefix_length;
517 /* 0 means name must match PREFIX exactly.
518 -1 means name must start with PREFIX followed by an arbitrary string.
519 -2 means name must match PREFIX exactly or consist of PREFIX followed
520 by a dot then anything.
521 > 0 means name must start with the first PREFIX_LENGTH chars of
522 PREFIX and finish with the last SUFFIX_LENGTH chars of PREFIX. */
523 int suffix_length;
2f89ff8d 524 int type;
7dcb9820 525 int attr;
2f89ff8d
L
526};
527
252b5132
RH
528struct elf_backend_data
529{
252b5132
RH
530 /* The architecture for this backend. */
531 enum bfd_architecture arch;
532
533 /* The ELF machine code (EM_xxxx) for this backend. */
534 int elf_machine_code;
535
536 /* The maximum page size for this backend. */
537 bfd_vma maxpagesize;
538
e5a52504
MM
539 /* The BFD flags applied to sections created for dynamic linking. */
540 flagword dynamic_sec_flags;
541
252b5132
RH
542 /* A function to translate an ELF RELA relocation to a BFD arelent
543 structure. */
dc810e39 544 void (*elf_info_to_howto)
c39a58e6 545 (bfd *, arelent *, Elf_Internal_Rela *);
252b5132
RH
546
547 /* A function to translate an ELF REL relocation to a BFD arelent
548 structure. */
dc810e39 549 void (*elf_info_to_howto_rel)
c39a58e6 550 (bfd *, arelent *, Elf_Internal_Rela *);
252b5132
RH
551
552 /* A function to determine whether a symbol is global when
553 partitioning the symbol table into local and global symbols.
554 This should be NULL for most targets, in which case the correct
555 thing will be done. MIPS ELF, at least on the Irix 5, has
556 special requirements. */
b34976b6 557 bfd_boolean (*elf_backend_sym_is_global)
c39a58e6 558 (bfd *, asymbol *);
252b5132
RH
559
560 /* The remaining functions are hooks which are called only if they
561 are not NULL. */
562
563 /* A function to permit a backend specific check on whether a
564 particular BFD format is relevant for an object file, and to
565 permit the backend to set any global information it wishes. When
566 this is called elf_elfheader is set, but anything else should be
b34976b6 567 used with caution. If this returns FALSE, the check_format
252b5132 568 routine will return a bfd_error_wrong_format error. */
b34976b6 569 bfd_boolean (*elf_backend_object_p)
c39a58e6 570 (bfd *);
252b5132
RH
571
572 /* A function to do additional symbol processing when reading the
573 ELF symbol table. This is where any processor-specific special
574 section indices are handled. */
dc810e39 575 void (*elf_backend_symbol_processing)
c39a58e6 576 (bfd *, asymbol *);
252b5132
RH
577
578 /* A function to do additional symbol processing after reading the
579 entire ELF symbol table. */
b34976b6 580 bfd_boolean (*elf_backend_symbol_table_processing)
c39a58e6 581 (bfd *, elf_symbol_type *, unsigned int);
252b5132 582
8387904d 583 /* A function to set the type of the info field. Processor-specific
3e932841 584 types should be handled here. */
dc810e39 585 int (*elf_backend_get_symbol_type)
c39a58e6 586 (Elf_Internal_Sym *, int);
60bcf0fa 587
8387904d
AM
588 /* A function to return the linker hash table entry of a symbol that
589 might be satisfied by an archive symbol. */
590 struct elf_link_hash_entry * (*elf_backend_archive_symbol_lookup)
591 (bfd *, struct bfd_link_info *, const char *);
592
174fd7f9
RS
593 /* Return true if local section symbols should have a non-null st_name.
594 NULL implies false. */
595 bfd_boolean (*elf_backend_name_local_section_symbols)
596 (bfd *);
597
252b5132
RH
598 /* A function to do additional processing on the ELF section header
599 just before writing it out. This is used to set the flags and
600 type fields for some sections, or to actually write out data for
601 unusual sections. */
b34976b6 602 bfd_boolean (*elf_backend_section_processing)
c39a58e6 603 (bfd *, Elf_Internal_Shdr *);
252b5132
RH
604
605 /* A function to handle unusual section types when creating BFD
606 sections from ELF sections. */
b34976b6 607 bfd_boolean (*elf_backend_section_from_shdr)
c39a58e6 608 (bfd *, Elf_Internal_Shdr *, const char *);
252b5132 609
fa152c49
JW
610 /* A function to convert machine dependent section header flags to
611 BFD internal section header flags. */
b34976b6 612 bfd_boolean (*elf_backend_section_flags)
1829f4b2 613 (flagword *, const Elf_Internal_Shdr *);
fa152c49 614
20cfcaae 615 /* A function to handle unusual program segment types when creating BFD
3e932841 616 sections from ELF program segments. */
b34976b6 617 bfd_boolean (*elf_backend_section_from_phdr)
c39a58e6 618 (bfd *, Elf_Internal_Phdr *, int);
20cfcaae 619
252b5132
RH
620 /* A function to set up the ELF section header for a BFD section in
621 preparation for writing it out. This is where the flags and type
622 fields are set for unusual sections. */
b34976b6 623 bfd_boolean (*elf_backend_fake_sections)
c39a58e6 624 (bfd *, Elf_Internal_Shdr *, asection *);
252b5132
RH
625
626 /* A function to get the ELF section index for a BFD section. If
b34976b6 627 this returns TRUE, the section was found. If it is a normal ELF
252b5132
RH
628 section, *RETVAL should be left unchanged. If it is not a normal
629 ELF section *RETVAL should be set to the SHN_xxxx index. */
b34976b6 630 bfd_boolean (*elf_backend_section_from_bfd_section)
c39a58e6 631 (bfd *, asection *, int *retval);
252b5132
RH
632
633 /* If this field is not NULL, it is called by the add_symbols phase
634 of a link just before adding a symbol to the global linker hash
635 table. It may modify any of the fields as it wishes. If *NAME
636 is set to NULL, the symbol will be skipped rather than being
637 added to the hash table. This function is responsible for
638 handling all processor dependent symbol bindings and section
639 indices, and must set at least *FLAGS and *SEC for each processor
640 dependent case; failure to do so will cause a link error. */
b34976b6 641 bfd_boolean (*elf_add_symbol_hook)
555cd476 642 (bfd *abfd, struct bfd_link_info *info, Elf_Internal_Sym *,
c39a58e6 643 const char **name, flagword *flags, asection **sec, bfd_vma *value);
252b5132
RH
644
645 /* If this field is not NULL, it is called by the elf_link_output_sym
646 phase of a link for each symbol which will appear in the object file. */
b34976b6 647 bfd_boolean (*elf_backend_link_output_symbol_hook)
754021d0
AM
648 (struct bfd_link_info *info, const char *, Elf_Internal_Sym *,
649 asection *, struct elf_link_hash_entry *);
252b5132
RH
650
651 /* The CREATE_DYNAMIC_SECTIONS function is called by the ELF backend
652 linker the first time it encounters a dynamic object in the link.
653 This function must create any sections required for dynamic
654 linking. The ABFD argument is a dynamic object. The .interp,
655 .dynamic, .dynsym, .dynstr, and .hash functions have already been
656 created, and this function may modify the section flags if
657 desired. This function will normally create the .got and .plt
658 sections, but different backends have different requirements. */
b34976b6 659 bfd_boolean (*elf_backend_create_dynamic_sections)
c39a58e6 660 (bfd *abfd, struct bfd_link_info *info);
252b5132 661
aee6f5b4
AO
662 /* When creating a shared library, determine whether to omit the
663 dynamic symbol for the section. */
664 bfd_boolean (*elf_backend_omit_section_dynsym)
665 (bfd *output_bfd, struct bfd_link_info *info, asection *osec);
666
252b5132
RH
667 /* The CHECK_RELOCS function is called by the add_symbols phase of
668 the ELF backend linker. It is called once for each section with
669 relocs of an object file, just after the symbols for the object
670 file have been added to the global linker hash table. The
671 function must look through the relocs and do any special handling
672 required. This generally means allocating space in the global
673 offset table, and perhaps allocating space for a reloc. The
674 relocs are always passed as Rela structures; if the section
675 actually uses Rel structures, the r_addend field will always be
676 zero. */
b34976b6 677 bfd_boolean (*check_relocs)
c39a58e6
AM
678 (bfd *abfd, struct bfd_link_info *info, asection *o,
679 const Elf_Internal_Rela *relocs);
252b5132 680
85fbca6a
NC
681 /* The CHECK_DIRECTIVES function is called once per input file by
682 the add_symbols phase of the ELF backend linker. The function
683 must inspect the bfd and create any additional symbols according
684 to any custom directives in the bfd. */
685 bfd_boolean (*check_directives)
686 (bfd *abfd, struct bfd_link_info *info);
687
252b5132
RH
688 /* The ADJUST_DYNAMIC_SYMBOL function is called by the ELF backend
689 linker for every symbol which is defined by a dynamic object and
690 referenced by a regular object. This is called after all the
691 input files have been seen, but before the SIZE_DYNAMIC_SECTIONS
692 function has been called. The hash table entry should be
693 bfd_link_hash_defined ore bfd_link_hash_defweak, and it should be
694 defined in a section from a dynamic object. Dynamic object
695 sections are not included in the final link, and this function is
696 responsible for changing the value to something which the rest of
697 the link can deal with. This will normally involve adding an
698 entry to the .plt or .got or some such section, and setting the
699 symbol to point to that. */
b34976b6 700 bfd_boolean (*elf_backend_adjust_dynamic_symbol)
c39a58e6 701 (struct bfd_link_info *info, struct elf_link_hash_entry *h);
252b5132
RH
702
703 /* The ALWAYS_SIZE_SECTIONS function is called by the backend linker
704 after all the linker input files have been seen but before the
705 section sizes have been set. This is called after
706 ADJUST_DYNAMIC_SYMBOL, but before SIZE_DYNAMIC_SECTIONS. */
b34976b6 707 bfd_boolean (*elf_backend_always_size_sections)
c39a58e6 708 (bfd *output_bfd, struct bfd_link_info *info);
252b5132
RH
709
710 /* The SIZE_DYNAMIC_SECTIONS function is called by the ELF backend
711 linker after all the linker input files have been seen but before
712 the sections sizes have been set. This is called after
713 ADJUST_DYNAMIC_SYMBOL has been called on all appropriate symbols.
714 It is only called when linking against a dynamic object. It must
715 set the sizes of the dynamic sections, and may fill in their
716 contents as well. The generic ELF linker can handle the .dynsym,
717 .dynstr and .hash sections. This function must handle the
718 .interp section and any sections created by the
719 CREATE_DYNAMIC_SECTIONS entry point. */
b34976b6 720 bfd_boolean (*elf_backend_size_dynamic_sections)
c39a58e6 721 (bfd *output_bfd, struct bfd_link_info *info);
252b5132
RH
722
723 /* The RELOCATE_SECTION function is called by the ELF backend linker
724 to handle the relocations for a section.
725
726 The relocs are always passed as Rela structures; if the section
727 actually uses Rel structures, the r_addend field will always be
728 zero.
729
730 This function is responsible for adjust the section contents as
731 necessary, and (if using Rela relocs and generating a
1049f94e 732 relocatable output file) adjusting the reloc addend as
252b5132
RH
733 necessary.
734
735 This function does not have to worry about setting the reloc
736 address or the reloc symbol index.
737
738 LOCAL_SYMS is a pointer to the swapped in local symbols.
739
740 LOCAL_SECTIONS is an array giving the section in the input file
741 corresponding to the st_shndx field of each local symbol.
742
743 The global hash table entry for the global symbols can be found
744 via elf_sym_hashes (input_bfd).
745
1049f94e 746 When generating relocatable output, this function must handle
252b5132
RH
747 STB_LOCAL/STT_SECTION symbols specially. The output symbol is
748 going to be the section symbol corresponding to the output
749 section, which means that the addend must be adjusted
750 accordingly. */
b34976b6 751 bfd_boolean (*elf_backend_relocate_section)
c39a58e6
AM
752 (bfd *output_bfd, struct bfd_link_info *info, bfd *input_bfd,
753 asection *input_section, bfd_byte *contents, Elf_Internal_Rela *relocs,
754 Elf_Internal_Sym *local_syms, asection **local_sections);
252b5132
RH
755
756 /* The FINISH_DYNAMIC_SYMBOL function is called by the ELF backend
757 linker just before it writes a symbol out to the .dynsym section.
758 The processor backend may make any required adjustment to the
759 symbol. It may also take the opportunity to set contents of the
760 dynamic sections. Note that FINISH_DYNAMIC_SYMBOL is called on
761 all .dynsym symbols, while ADJUST_DYNAMIC_SYMBOL is only called
762 on those symbols which are defined by a dynamic object. */
b34976b6 763 bfd_boolean (*elf_backend_finish_dynamic_symbol)
c39a58e6
AM
764 (bfd *output_bfd, struct bfd_link_info *info,
765 struct elf_link_hash_entry *h, Elf_Internal_Sym *sym);
252b5132
RH
766
767 /* The FINISH_DYNAMIC_SECTIONS function is called by the ELF backend
768 linker just before it writes all the dynamic sections out to the
769 output file. The FINISH_DYNAMIC_SYMBOL will have been called on
770 all dynamic symbols. */
b34976b6 771 bfd_boolean (*elf_backend_finish_dynamic_sections)
c39a58e6 772 (bfd *output_bfd, struct bfd_link_info *info);
252b5132
RH
773
774 /* A function to do any beginning processing needed for the ELF file
775 before building the ELF headers and computing file positions. */
776 void (*elf_backend_begin_write_processing)
c39a58e6 777 (bfd *, struct bfd_link_info *);
252b5132
RH
778
779 /* A function to do any final processing needed for the ELF file
b34976b6 780 before writing it out. The LINKER argument is TRUE if this BFD
252b5132
RH
781 was created by the ELF backend linker. */
782 void (*elf_backend_final_write_processing)
c39a58e6 783 (bfd *, bfd_boolean linker);
252b5132
RH
784
785 /* This function is called by get_program_header_size. It should
786 return the number of additional program segments which this BFD
787 will need. It should return -1 on error. */
dc810e39 788 int (*elf_backend_additional_program_headers)
c39a58e6 789 (bfd *);
252b5132
RH
790
791 /* This function is called to modify an existing segment map in a
792 backend specific fashion. */
b34976b6 793 bfd_boolean (*elf_backend_modify_segment_map)
c84fca4d 794 (bfd *, struct bfd_link_info *);
252b5132
RH
795
796 /* This function is called during section gc to discover the section a
1e2f5b6e 797 particular relocation refers to. */
252b5132 798 asection * (*gc_mark_hook)
c39a58e6
AM
799 (asection *sec, struct bfd_link_info *, Elf_Internal_Rela *,
800 struct elf_link_hash_entry *h, Elf_Internal_Sym *);
252b5132
RH
801
802 /* This function, if defined, is called during the sweep phase of gc
803 in order that a backend might update any data structures it might
804 be maintaining. */
b34976b6 805 bfd_boolean (*gc_sweep_hook)
c39a58e6
AM
806 (bfd *abfd, struct bfd_link_info *info, asection *o,
807 const Elf_Internal_Rela *relocs);
252b5132 808
e6c51ed4
NC
809 /* This function, if defined, is called after the ELF headers have
810 been created. This allows for things like the OS and ABI versions
811 to be changed. */
812 void (*elf_backend_post_process_headers)
c39a58e6 813 (bfd *, struct bfd_link_info *);
e6c51ed4 814
587ff49e
RH
815 /* This function, if defined, prints a symbol to file and returns the
816 name of the symbol to be printed. It should return NULL to fall
817 back to default symbol printing. */
818 const char *(*elf_backend_print_symbol_all)
c39a58e6 819 (bfd *, void *, asymbol *);
587ff49e
RH
820
821 /* This function, if defined, is called after all local symbols and
4cc11e76 822 global symbols converted to locals are emitted into the symtab
587ff49e
RH
823 section. It allows the backend to emit special global symbols
824 not handled in the hash table. */
b34976b6 825 bfd_boolean (*elf_backend_output_arch_syms)
c39a58e6 826 (bfd *, struct bfd_link_info *, void *,
754021d0
AM
827 bfd_boolean (*) (void *, const char *, Elf_Internal_Sym *, asection *,
828 struct elf_link_hash_entry *));
587ff49e 829
d4c88bbb 830 /* Copy any information related to dynamic linking from a pre-existing
0a991dfe
AM
831 symbol to a newly created symbol. Also called to copy flags and
832 other back-end info to a weakdef, in which case the symbol is not
833 newly created and plt/got refcounts and dynamic indices should not
834 be copied. */
c61b8717 835 void (*elf_backend_copy_indirect_symbol)
9c5bfbb7 836 (const struct elf_backend_data *, struct elf_link_hash_entry *,
c39a58e6 837 struct elf_link_hash_entry *);
c61b8717
RH
838
839 /* Modify any information related to dynamic linking such that the
840 symbol is not exported. */
841 void (*elf_backend_hide_symbol)
c39a58e6 842 (struct bfd_link_info *, struct elf_link_hash_entry *, bfd_boolean);
c61b8717 843
9bf7216d
KK
844 /* Merge the backend specific symbol attribute. */
845 void (*elf_backend_merge_symbol_attribute)
846 (struct elf_link_hash_entry *, const Elf_Internal_Sym *, bfd_boolean,
847 bfd_boolean);
848
9317eacc
CM
849 /* Emit relocations. Overrides default routine for emitting relocs,
850 except during a relocatable link, or if all relocs are being emitted. */
b34976b6 851 bfd_boolean (*elf_backend_emit_relocs)
c39a58e6 852 (bfd *, asection *, Elf_Internal_Shdr *, Elf_Internal_Rela *);
9317eacc
CM
853
854 /* Count relocations. Not called for relocatable links
855 or if all relocs are being preserved in the output. */
856 unsigned int (*elf_backend_count_relocs)
c39a58e6 857 (asection *, Elf_Internal_Rela *);
9317eacc 858
bb0082d6
AM
859 /* This function, if defined, is called when an NT_PRSTATUS note is found
860 in a core file. */
b34976b6 861 bfd_boolean (*elf_backend_grok_prstatus)
c39a58e6 862 (bfd *, Elf_Internal_Note *);
bb0082d6
AM
863
864 /* This function, if defined, is called when an NT_PSINFO or NT_PRPSINFO
865 note is found in a core file. */
b34976b6 866 bfd_boolean (*elf_backend_grok_psinfo)
c39a58e6 867 (bfd *, Elf_Internal_Note *);
bb0082d6 868
db6751f2 869 /* Functions to print VMAs. Special code to handle 64 bit ELF files. */
dc810e39 870 void (* elf_backend_sprintf_vma)
c39a58e6 871 (bfd *, char *, bfd_vma);
dc810e39 872 void (* elf_backend_fprintf_vma)
c39a58e6 873 (bfd *, void *, bfd_vma);
4e771d61 874
db6751f2 875 /* This function returns class of a reloc type. */
f51e552e 876 enum elf_reloc_type_class (*elf_backend_reloc_type_class)
c39a58e6 877 (const Elf_Internal_Rela *);
db6751f2 878
73d074b4
DJ
879 /* This function, if defined, removes information about discarded functions
880 from other sections which mention them. */
b34976b6 881 bfd_boolean (*elf_backend_discard_info)
c39a58e6 882 (bfd *, struct elf_reloc_cookie *, struct bfd_link_info *);
73d074b4
DJ
883
884 /* This function, if defined, signals that the function above has removed
885 the discarded relocations for this section. */
b34976b6 886 bfd_boolean (*elf_backend_ignore_discarded_relocs)
c39a58e6 887 (asection *);
73d074b4 888
ec3391e7
AO
889 /* These functions tell elf-eh-frame whether to attempt to turn
890 absolute or lsda encodings into pc-relative ones. The default
891 definition enables these transformations. */
892 bfd_boolean (*elf_backend_can_make_relative_eh_frame)
893 (bfd *, struct bfd_link_info *, asection *);
894 bfd_boolean (*elf_backend_can_make_lsda_relative_eh_frame)
895 (bfd *, struct bfd_link_info *, asection *);
896
897 /* This function returns an encoding after computing the encoded
898 value (and storing it in ENCODED) for the given OFFSET into OSEC,
899 to be stored in at LOC_OFFSET into the LOC_SEC input section.
900 The default definition chooses a 32-bit PC-relative encoding. */
901 bfd_byte (*elf_backend_encode_eh_address)
902 (bfd *abfd, struct bfd_link_info *info,
903 asection *osec, bfd_vma offset,
904 asection *loc_sec, bfd_vma loc_offset,
905 bfd_vma *encoded);
906
73d074b4 907 /* This function, if defined, may write out the given section.
b34976b6
AM
908 Returns TRUE if it did so and FALSE if the caller should. */
909 bfd_boolean (*elf_backend_write_section)
c39a58e6 910 (bfd *, asection *, bfd_byte *);
73d074b4 911
c6e90b02
TS
912 /* The level of IRIX compatibility we're striving for.
913 MIPS ELF specific function. */
914 irix_compat_t (*elf_backend_mips_irix_compat)
c39a58e6 915 (bfd *);
c6e90b02
TS
916
917 reloc_howto_type *(*elf_backend_mips_rtype_to_howto)
c39a58e6 918 (unsigned int, bfd_boolean);
c6e90b02 919
252b5132
RH
920 /* The swapping table to use when dealing with ECOFF information.
921 Used for the MIPS ELF .mdebug section. */
922 const struct ecoff_debug_swap *elf_backend_ecoff_debug_swap;
923
8d6337fe
RM
924 /* This function implements `bfd_elf_bfd_from_remote_memory';
925 see elf.c, elfcode.h. */
926 bfd *(*elf_backend_bfd_from_remote_memory)
c39a58e6
AM
927 (bfd *templ, bfd_vma ehdr_vma, bfd_vma *loadbasep,
928 int (*target_read_memory) (bfd_vma vma, char *myaddr, int len));
8d6337fe 929
4c45e5c9
JJ
930 /* This function is used by `_bfd_elf_get_synthetic_symtab';
931 see elf.c. */
932 bfd_vma (*plt_sym_val) (bfd_vma, const asection *, const arelent *);
933
185d09ad
L
934 /* Used to handle bad SHF_LINK_ORDER input. */
935 bfd_error_handler_type link_order_error_handler;
936
4c45e5c9
JJ
937 /* Name of the PLT relocation section. */
938 const char *relplt_name;
939
252b5132
RH
940 /* Alternate EM_xxxx machine codes for this backend. */
941 int elf_machine_alt1;
942 int elf_machine_alt2;
943
944 const struct elf_size_info *s;
945
2f89ff8d
L
946 /* An array of target specific special section map. */
947 const struct bfd_elf_special_section *special_sections;
948
252b5132
RH
949 /* offset of the _GLOBAL_OFFSET_TABLE_ symbol from the start of the
950 .got section */
951 bfd_vma got_symbol_offset;
952
6f2f2c9d
DJ
953 /* The size in bytes of the header for the GOT. This includes the
954 so-called reserved entries on some systems. */
252b5132 955 bfd_vma got_header_size;
252b5132 956
b34976b6
AM
957 /* This is TRUE if the linker should act like collect and gather
958 global constructors and destructors by name. This is TRUE for
86dc0f79
RH
959 MIPS ELF because the Irix 5 tools can not handle the .init
960 section. */
961 unsigned collect : 1;
962
b34976b6
AM
963 /* This is TRUE if the linker should ignore changes to the type of a
964 symbol. This is TRUE for MIPS ELF because some Irix 5 objects
86dc0f79
RH
965 record undefined functions as STT_OBJECT although the definitions
966 are STT_FUNC. */
967 unsigned type_change_ok : 1;
968
bf572ba0
MM
969 /* Whether the backend may use REL relocations. (Some backends use
970 both REL and RELA relocations, and this flag is set for those
971 backends.) */
972 unsigned may_use_rel_p : 1;
60bcf0fa 973
bf572ba0
MM
974 /* Whether the backend may use RELA relocations. (Some backends use
975 both REL and RELA relocations, and this flag is set for those
976 backends.) */
977 unsigned may_use_rela_p : 1;
978
979 /* Whether the default relocation type is RELA. If a backend with
980 this flag set wants REL relocations for a particular section,
981 it must note that explicitly. Similarly, if this flag is clear,
60bcf0fa
NC
982 and the backend wants RELA relocations for a particular
983 section. */
bf572ba0
MM
984 unsigned default_use_rela_p : 1;
985
b491616a
AM
986 /* Set if RELA relocations for a relocatable link can be handled by
987 generic code. Backends that set this flag need do nothing in the
988 backend relocate_section routine for relocatable linking. */
989 unsigned rela_normal : 1;
990
b34976b6 991 /* TRUE if addresses "naturally" sign extend. This is used when
86dc0f79
RH
992 swapping in from Elf32 when BFD64. */
993 unsigned sign_extend_vma : 1;
994
252b5132
RH
995 unsigned want_got_plt : 1;
996 unsigned plt_readonly : 1;
997 unsigned want_plt_sym : 1;
998 unsigned plt_not_loaded : 1;
999 unsigned plt_alignment : 4;
1000 unsigned can_gc_sections : 1;
51b64d56 1001 unsigned can_refcount : 1;
2517a57f 1002 unsigned want_got_sym : 1;
3018b441 1003 unsigned want_dynbss : 1;
5e8d7549
NC
1004 /* Targets which do not support physical addressing often require
1005 that the p_paddr field in the section header to be set to zero.
1006 This field indicates whether this behavior is required. */
1007 unsigned want_p_paddr_set_to_zero : 1;
252b5132
RH
1008};
1009
1010/* Information stored for each BFD section in an ELF file. This
1011 structure is allocated by elf_new_section_hook. */
1012
1013struct bfd_elf_section_data
1014{
1015 /* The ELF header for this section. */
1016 Elf_Internal_Shdr this_hdr;
0c715baa 1017
252b5132
RH
1018 /* The ELF header for the reloc section associated with this
1019 section, if any. */
1020 Elf_Internal_Shdr rel_hdr;
0c715baa 1021
252b5132
RH
1022 /* If there is a second reloc section associated with this section,
1023 as can happen on Irix 6, this field points to the header. */
1024 Elf_Internal_Shdr *rel_hdr2;
0c715baa 1025
23bc299b
MM
1026 /* The number of relocations currently assigned to REL_HDR. */
1027 unsigned int rel_count;
0c715baa 1028
23bc299b
MM
1029 /* The number of relocations currently assigned to REL_HDR2. */
1030 unsigned int rel_count2;
0c715baa 1031
252b5132
RH
1032 /* The ELF section number of this section. Only used for an output
1033 file. */
1034 int this_idx;
0c715baa 1035
23bc299b
MM
1036 /* The ELF section number of the reloc section indicated by
1037 REL_HDR if any. Only used for an output file. */
252b5132 1038 int rel_idx;
0c715baa 1039
23bc299b
MM
1040 /* The ELF section number of the reloc section indicated by
1041 REL_HDR2 if any. Only used for an output file. */
1042 int rel_idx2;
0c715baa 1043
f0abc2a1
AM
1044 /* Used by the backend linker when generating a shared library to
1045 record the dynamic symbol index for a section symbol
1046 corresponding to this section. A value of 0 means that there is
1047 no dynamic symbol for this section. */
1048 int dynindx;
1049
38ce5b11
L
1050 /* A pointer to the linked-to section for SHF_LINK_ORDER. */
1051 asection *linked_to;
1052
252b5132
RH
1053 /* Used by the backend linker to store the symbol hash table entries
1054 associated with relocs against global symbols. */
1055 struct elf_link_hash_entry **rel_hashes;
0c715baa 1056
252b5132
RH
1057 /* A pointer to the swapped relocs. If the section uses REL relocs,
1058 rather than RELA, all the r_addend fields will be zero. This
1059 pointer may be NULL. It is used by the backend linker. */
1060 Elf_Internal_Rela *relocs;
0c715baa 1061
f0abc2a1
AM
1062 /* A pointer to a linked list tracking dynamic relocs copied for
1063 local symbols. */
c39a58e6 1064 void *local_dynrel;
0c715baa 1065
f0abc2a1
AM
1066 /* A pointer to the bfd section used for dynamic relocs. */
1067 asection *sreloc;
0c715baa 1068
1126897b
AM
1069 union {
1070 /* Group name, if this section is a member of a group. */
1071 const char *name;
1072
1073 /* Group signature sym, if this is the SHT_GROUP section. */
fc0a2244 1074 struct bfd_symbol *id;
1126897b 1075 } group;
dbb410c3 1076
3d7f7666
L
1077 /* Optional information about section group; NULL if it doesn't
1078 belongs to any section group. */
1079 asection *sec_group;
1080
dbb410c3
AM
1081 /* A linked list of sections in the group. Circular when used by
1082 the linker. */
1083 asection *next_in_group;
1084
f0abc2a1 1085 /* A pointer used for various section optimizations. */
c39a58e6 1086 void *sec_info;
252b5132
RH
1087};
1088
1089#define elf_section_data(sec) ((struct bfd_elf_section_data*)sec->used_by_bfd)
38ce5b11 1090#define elf_linked_to_section(sec) (elf_section_data(sec)->linked_to)
2f89ff8d
L
1091#define elf_section_type(sec) (elf_section_data(sec)->this_hdr.sh_type)
1092#define elf_section_flags(sec) (elf_section_data(sec)->this_hdr.sh_flags)
1126897b
AM
1093#define elf_group_name(sec) (elf_section_data(sec)->group.name)
1094#define elf_group_id(sec) (elf_section_data(sec)->group.id)
945906ff 1095#define elf_next_in_group(sec) (elf_section_data(sec)->next_in_group)
3d7f7666 1096#define elf_sec_group(sec) (elf_section_data(sec)->sec_group)
252b5132 1097
b34976b6 1098/* Return TRUE if section has been discarded. */
68bfbfcc
AM
1099#define elf_discarded_section(sec) \
1100 (!bfd_is_abs_section (sec) \
1101 && bfd_is_abs_section ((sec)->output_section) \
cdd3575c
AM
1102 && (sec)->sec_info_type != ELF_INFO_TYPE_MERGE \
1103 && (sec)->sec_info_type != ELF_INFO_TYPE_JUST_SYMS)
ed4de5e2 1104
252b5132 1105#define get_elf_backend_data(abfd) \
9c5bfbb7 1106 ((const struct elf_backend_data *) (abfd)->xvec->backend_data)
252b5132 1107
45d6a902
AM
1108/* This struct is used to pass information to routines called via
1109 elf_link_hash_traverse which must return failure. */
1110
1111struct elf_info_failed
1112{
1113 bfd_boolean failed;
1114 struct bfd_link_info *info;
1115 struct bfd_elf_version_tree *verdefs;
1116};
1117
1118/* This structure is used to pass information to
1119 _bfd_elf_link_assign_sym_version. */
1120
1121struct elf_assign_sym_version_info
1122{
1123 /* Output BFD. */
1124 bfd *output_bfd;
1125 /* General link information. */
1126 struct bfd_link_info *info;
1127 /* Version tree. */
1128 struct bfd_elf_version_tree *verdefs;
1129 /* Whether we had a failure. */
1130 bfd_boolean failed;
1131};
1132
1133/* This structure is used to pass information to
1134 _bfd_elf_link_find_version_dependencies. */
1135
1136struct elf_find_verdep_info
1137{
1138 /* Output BFD. */
1139 bfd *output_bfd;
1140 /* General link information. */
1141 struct bfd_link_info *info;
1142 /* The number of dependencies. */
1143 unsigned int vers;
1144 /* Whether we had a failure. */
1145 bfd_boolean failed;
1146};
1147
252b5132
RH
1148/* Some private data is stashed away for future use using the tdata pointer
1149 in the bfd structure. */
1150
1151struct elf_obj_tdata
1152{
1153 Elf_Internal_Ehdr elf_header[1]; /* Actual data, but ref like ptr */
1154 Elf_Internal_Shdr **elf_sect_ptr;
1155 Elf_Internal_Phdr *phdr;
1156 struct elf_segment_map *segment_map;
2b0f7ef9 1157 struct elf_strtab_hash *strtab_ptr;
252b5132
RH
1158 int num_locals;
1159 int num_globals;
9ad5cbcf 1160 unsigned int num_elf_sections; /* elf_sect_ptr size */
4e89ac30 1161 int num_section_syms;
252b5132
RH
1162 asymbol **section_syms; /* STT_SECTION symbols for each section */
1163 Elf_Internal_Shdr symtab_hdr;
1164 Elf_Internal_Shdr shstrtab_hdr;
1165 Elf_Internal_Shdr strtab_hdr;
1166 Elf_Internal_Shdr dynsymtab_hdr;
1167 Elf_Internal_Shdr dynstrtab_hdr;
1168 Elf_Internal_Shdr dynversym_hdr;
1169 Elf_Internal_Shdr dynverref_hdr;
1170 Elf_Internal_Shdr dynverdef_hdr;
9ad5cbcf 1171 Elf_Internal_Shdr symtab_shndx_hdr;
252b5132
RH
1172 unsigned int symtab_section, shstrtab_section;
1173 unsigned int strtab_section, dynsymtab_section;
9ad5cbcf 1174 unsigned int symtab_shndx_section;
252b5132
RH
1175 unsigned int dynversym_section, dynverdef_section, dynverref_section;
1176 file_ptr next_file_pos;
dbb410c3
AM
1177 bfd_vma gp; /* The gp value */
1178 unsigned int gp_size; /* The gp size */
1179
3e932841 1180 /* Information grabbed from an elf core file. */
252b5132
RH
1181 int core_signal;
1182 int core_pid;
1183 int core_lwpid;
1184 char* core_program;
1185 char* core_command;
1186
252b5132
RH
1187 /* A mapping from external symbols to entries in the linker hash
1188 table, used when linking. This is indexed by the symbol index
1189 minus the sh_info field of the symbol table header. */
1190 struct elf_link_hash_entry **sym_hashes;
1191
5cab59f6
AM
1192 /* Track usage and final offsets of GOT entries for local symbols.
1193 This array is indexed by symbol index. Elements are used
1194 identically to "got" in struct elf_link_hash_entry. */
252b5132
RH
1195 union
1196 {
1197 bfd_signed_vma *refcounts;
1198 bfd_vma *offsets;
5cab59f6 1199 struct got_entry **ents;
252b5132
RH
1200 } local_got;
1201
252b5132
RH
1202 /* The linker ELF emulation code needs to let the backend ELF linker
1203 know what filename should be used for a dynamic object if the
1204 dynamic object is found using a search. The emulation code then
1205 sometimes needs to know what name was actually used. Until the
1206 file has been added to the linker symbol table, this field holds
1207 the name the linker wants. After it has been added, it holds the
1208 name actually used, which will be the DT_SONAME entry if there is
1209 one. */
1210 const char *dt_name;
1211
252b5132
RH
1212 /* Records the result of `get_program_header_size'. */
1213 bfd_size_type program_header_size;
1214
1215 /* Used by find_nearest_line entry point. */
c39a58e6 1216 void *line_info;
252b5132
RH
1217
1218 /* Used by MIPS ELF find_nearest_line entry point. The structure
1219 could be included directly in this one, but there's no point to
1220 wasting the memory just for the infrequently called
1221 find_nearest_line. */
1222 struct mips_elf_find_line *find_line_info;
1223
3e932841 1224 /* A place to stash dwarf1 info for this bfd. */
252b5132
RH
1225 struct dwarf1_debug *dwarf1_find_line_info;
1226
3e932841 1227 /* A place to stash dwarf2 info for this bfd. */
c39a58e6 1228 void *dwarf2_find_line_info;
252b5132
RH
1229
1230 /* An array of stub sections indexed by symbol number, used by the
1231 MIPS ELF linker. FIXME: We should figure out some way to only
1232 include this field for a MIPS ELF target. */
1233 asection **local_stubs;
1234
65765700
JJ
1235 /* Used to determine if PT_GNU_EH_FRAME segment header should be
1236 created. */
126495ed
AM
1237 asection *eh_frame_hdr;
1238
4a43e768
AM
1239 Elf_Internal_Shdr **group_sect_ptr;
1240 int num_group;
65765700 1241
252b5132
RH
1242 /* Number of symbol version definitions we are about to emit. */
1243 unsigned int cverdefs;
1244
1245 /* Number of symbol version references we are about to emit. */
1246 unsigned int cverrefs;
1247
9ee5e499
JJ
1248 /* Segment flags for the PT_GNU_STACK segment. */
1249 unsigned int stack_flags;
1250
8c37241b
JJ
1251 /* Should the PT_GNU_RELRO segment be emitted? */
1252 bfd_boolean relro;
1253
252b5132
RH
1254 /* Symbol version definitions in external objects. */
1255 Elf_Internal_Verdef *verdef;
1256
1257 /* Symbol version references to external objects. */
1258 Elf_Internal_Verneed *verref;
1259
b305ef96
UC
1260 /* The Irix 5 support uses two virtual sections, which represent
1261 text/data symbols defined in dynamic objects. */
1262 asymbol *elf_data_symbol;
1263 asymbol *elf_text_symbol;
1264 asection *elf_data_section;
1265 asection *elf_text_section;
4a43e768
AM
1266
1267 /* Whether a dyanmic object was specified normally on the linker
1268 command line, or was specified when --as-needed was in effect,
1269 or was found via a DT_NEEDED entry. */
1270 enum dynamic_lib_link_class dyn_lib_class;
1271
1272 /* This is set to TRUE if the object was created by the backend
1273 linker. */
1274 bfd_boolean linker;
1275
1276 /* Irix 5 often screws up the symbol table, sorting local symbols
1277 after global symbols. This flag is set if the symbol table in
1278 this BFD appears to be screwed up. If it is, we ignore the
1279 sh_info field in the symbol table header, and always read all the
1280 symbols. */
1281 bfd_boolean bad_symtab;
1282
1283 /* Used to determine if the e_flags field has been initialized */
1284 bfd_boolean flags_init;
252b5132
RH
1285};
1286
1287#define elf_tdata(bfd) ((bfd) -> tdata.elf_obj_data)
1288#define elf_elfheader(bfd) (elf_tdata(bfd) -> elf_header)
1289#define elf_elfsections(bfd) (elf_tdata(bfd) -> elf_sect_ptr)
9ad5cbcf 1290#define elf_numsections(bfd) (elf_tdata(bfd) -> num_elf_sections)
252b5132
RH
1291#define elf_shstrtab(bfd) (elf_tdata(bfd) -> strtab_ptr)
1292#define elf_onesymtab(bfd) (elf_tdata(bfd) -> symtab_section)
9ad5cbcf 1293#define elf_symtab_shndx(bfd) (elf_tdata(bfd) -> symtab_shndx_section)
252b5132
RH
1294#define elf_dynsymtab(bfd) (elf_tdata(bfd) -> dynsymtab_section)
1295#define elf_dynversym(bfd) (elf_tdata(bfd) -> dynversym_section)
1296#define elf_dynverdef(bfd) (elf_tdata(bfd) -> dynverdef_section)
1297#define elf_dynverref(bfd) (elf_tdata(bfd) -> dynverref_section)
1298#define elf_num_locals(bfd) (elf_tdata(bfd) -> num_locals)
1299#define elf_num_globals(bfd) (elf_tdata(bfd) -> num_globals)
1300#define elf_section_syms(bfd) (elf_tdata(bfd) -> section_syms)
4e89ac30 1301#define elf_num_section_syms(bfd) (elf_tdata(bfd) -> num_section_syms)
252b5132
RH
1302#define core_prpsinfo(bfd) (elf_tdata(bfd) -> prpsinfo)
1303#define core_prstatus(bfd) (elf_tdata(bfd) -> prstatus)
1304#define elf_gp(bfd) (elf_tdata(bfd) -> gp)
1305#define elf_gp_size(bfd) (elf_tdata(bfd) -> gp_size)
1306#define elf_sym_hashes(bfd) (elf_tdata(bfd) -> sym_hashes)
1307#define elf_local_got_refcounts(bfd) (elf_tdata(bfd) -> local_got.refcounts)
1308#define elf_local_got_offsets(bfd) (elf_tdata(bfd) -> local_got.offsets)
5cab59f6 1309#define elf_local_got_ents(bfd) (elf_tdata(bfd) -> local_got.ents)
252b5132 1310#define elf_dt_name(bfd) (elf_tdata(bfd) -> dt_name)
4a43e768 1311#define elf_dyn_lib_class(bfd) (elf_tdata(bfd) -> dyn_lib_class)
252b5132
RH
1312#define elf_bad_symtab(bfd) (elf_tdata(bfd) -> bad_symtab)
1313#define elf_flags_init(bfd) (elf_tdata(bfd) -> flags_init)
252b5132
RH
1314\f
1315extern void _bfd_elf_swap_verdef_in
c39a58e6 1316 (bfd *, const Elf_External_Verdef *, Elf_Internal_Verdef *);
252b5132 1317extern void _bfd_elf_swap_verdef_out
c39a58e6 1318 (bfd *, const Elf_Internal_Verdef *, Elf_External_Verdef *);
252b5132 1319extern void _bfd_elf_swap_verdaux_in
c39a58e6 1320 (bfd *, const Elf_External_Verdaux *, Elf_Internal_Verdaux *);
252b5132 1321extern void _bfd_elf_swap_verdaux_out
c39a58e6 1322 (bfd *, const Elf_Internal_Verdaux *, Elf_External_Verdaux *);
252b5132 1323extern void _bfd_elf_swap_verneed_in
c39a58e6 1324 (bfd *, const Elf_External_Verneed *, Elf_Internal_Verneed *);
252b5132 1325extern void _bfd_elf_swap_verneed_out
c39a58e6 1326 (bfd *, const Elf_Internal_Verneed *, Elf_External_Verneed *);
252b5132 1327extern void _bfd_elf_swap_vernaux_in
c39a58e6 1328 (bfd *, const Elf_External_Vernaux *, Elf_Internal_Vernaux *);
252b5132 1329extern void _bfd_elf_swap_vernaux_out
c39a58e6 1330 (bfd *, const Elf_Internal_Vernaux *, Elf_External_Vernaux *);
252b5132 1331extern void _bfd_elf_swap_versym_in
c39a58e6 1332 (bfd *, const Elf_External_Versym *, Elf_Internal_Versym *);
252b5132 1333extern void _bfd_elf_swap_versym_out
c39a58e6 1334 (bfd *, const Elf_Internal_Versym *, Elf_External_Versym *);
252b5132 1335
dc810e39 1336extern int _bfd_elf_section_from_bfd_section
c39a58e6 1337 (bfd *, asection *);
252b5132 1338extern char *bfd_elf_string_from_elf_section
c39a58e6 1339 (bfd *, unsigned, unsigned);
dc810e39 1340extern char *bfd_elf_get_str_section
c39a58e6 1341 (bfd *, unsigned);
6cdc0ccc 1342extern Elf_Internal_Sym *bfd_elf_get_elf_syms
c39a58e6
AM
1343 (bfd *, Elf_Internal_Shdr *, size_t, size_t, Elf_Internal_Sym *, void *,
1344 Elf_External_Sym_Shndx *);
5cab59f6 1345extern const char *bfd_elf_local_sym_name
c39a58e6 1346 (bfd *, Elf_Internal_Sym *);
252b5132 1347
b34976b6 1348extern bfd_boolean _bfd_elf_copy_private_bfd_data
c39a58e6 1349 (bfd *, bfd *);
b34976b6 1350extern bfd_boolean _bfd_elf_print_private_bfd_data
c39a58e6 1351 (bfd *, void *);
dc810e39 1352extern void bfd_elf_print_symbol
c39a58e6 1353 (bfd *, void *, asymbol *, bfd_print_symbol_type);
dc810e39
AM
1354
1355#define elf_string_from_elf_strtab(abfd, strindex) \
c39a58e6
AM
1356 bfd_elf_string_from_elf_section (abfd, elf_elfheader(abfd)->e_shstrndx, \
1357 strindex)
252b5132 1358
dc810e39 1359extern void _bfd_elf_sprintf_vma
c39a58e6 1360 (bfd *, char *, bfd_vma);
dc810e39 1361extern void _bfd_elf_fprintf_vma
c39a58e6 1362 (bfd *, void *, bfd_vma);
d69bb69b 1363
ec3391e7
AO
1364extern bfd_byte _bfd_elf_encode_eh_address
1365 (bfd *abfd, struct bfd_link_info *info, asection *osec, bfd_vma offset,
1366 asection *loc_sec, bfd_vma loc_offset, bfd_vma *encoded);
1367extern bfd_boolean _bfd_elf_can_make_relative
1368 (bfd *input_bfd, struct bfd_link_info *info, asection *eh_frame_section);
1369
dc810e39 1370extern enum elf_reloc_type_class _bfd_elf_reloc_type_class
c39a58e6 1371 (const Elf_Internal_Rela *);
f8df10f4 1372extern bfd_vma _bfd_elf_rela_local_sym
8517fae7 1373 (bfd *, Elf_Internal_Sym *, asection **, Elf_Internal_Rela *);
c629eae0 1374extern bfd_vma _bfd_elf_rel_local_sym
c39a58e6 1375 (bfd *, Elf_Internal_Sym *, asection **, bfd_vma);
c629eae0 1376extern bfd_vma _bfd_elf_section_offset
c39a58e6 1377 (bfd *, struct bfd_link_info *, asection *, bfd_vma);
db6751f2 1378
dc810e39 1379extern unsigned long bfd_elf_hash
c39a58e6 1380 (const char *);
252b5132 1381
dc810e39 1382extern bfd_reloc_status_type bfd_elf_generic_reloc
c39a58e6 1383 (bfd *, arelent *, asymbol *, void *, asection *, bfd *, char **);
b34976b6 1384extern bfd_boolean bfd_elf_mkobject
c39a58e6 1385 (bfd *);
b34976b6 1386extern bfd_boolean bfd_elf_mkcorefile
c39a58e6 1387 (bfd *);
dc810e39 1388extern Elf_Internal_Shdr *bfd_elf_find_section
c39a58e6 1389 (bfd *, char *);
b34976b6 1390extern bfd_boolean _bfd_elf_make_section_from_shdr
c39a58e6 1391 (bfd *, Elf_Internal_Shdr *, const char *);
b34976b6 1392extern bfd_boolean _bfd_elf_make_section_from_phdr
c39a58e6 1393 (bfd *, Elf_Internal_Phdr *, int, const char *);
252b5132 1394extern struct bfd_hash_entry *_bfd_elf_link_hash_newfunc
c39a58e6 1395 (struct bfd_hash_entry *, struct bfd_hash_table *, const char *);
252b5132 1396extern struct bfd_link_hash_table *_bfd_elf_link_hash_table_create
c39a58e6 1397 (bfd *);
c61b8717 1398extern void _bfd_elf_link_hash_copy_indirect
9c5bfbb7 1399 (const struct elf_backend_data *, struct elf_link_hash_entry *,
c39a58e6 1400 struct elf_link_hash_entry *);
c61b8717 1401extern void _bfd_elf_link_hash_hide_symbol
c39a58e6 1402 (struct bfd_link_info *, struct elf_link_hash_entry *, bfd_boolean);
b34976b6 1403extern bfd_boolean _bfd_elf_link_hash_table_init
c39a58e6
AM
1404 (struct elf_link_hash_table *, bfd *,
1405 struct bfd_hash_entry *(*)
1406 (struct bfd_hash_entry *, struct bfd_hash_table *, const char *));
b34976b6 1407extern bfd_boolean _bfd_elf_slurp_version_tables
c39a58e6 1408 (bfd *);
b34976b6 1409extern bfd_boolean _bfd_elf_merge_sections
c39a58e6 1410 (bfd *, struct bfd_link_info *);
72adc230
AM
1411extern bfd_boolean bfd_elf_is_group_section
1412 (bfd *, const struct bfd_section *);
b34976b6 1413extern bfd_boolean bfd_elf_discard_group
198beae2 1414 (bfd *, struct bfd_section *);
082b7297
L
1415extern void _bfd_elf_section_already_linked
1416 (bfd *, struct bfd_section *);
1126897b 1417extern void bfd_elf_set_group_contents
c39a58e6 1418 (bfd *, asection *, void *);
2d653fc7 1419extern void _bfd_elf_link_just_syms
c39a58e6 1420 (asection *, struct bfd_link_info *);
80fccad2
BW
1421extern bfd_boolean _bfd_elf_copy_private_header_data
1422 (bfd *, bfd *);
b34976b6 1423extern bfd_boolean _bfd_elf_copy_private_symbol_data
c39a58e6 1424 (bfd *, asymbol *, bfd *, asymbol *);
b34976b6 1425extern bfd_boolean _bfd_elf_copy_private_section_data
c39a58e6 1426 (bfd *, asection *, bfd *, asection *);
b34976b6 1427extern bfd_boolean _bfd_elf_write_object_contents
c39a58e6 1428 (bfd *);
b34976b6 1429extern bfd_boolean _bfd_elf_write_corefile_contents
c39a58e6 1430 (bfd *);
b34976b6 1431extern bfd_boolean _bfd_elf_set_section_contents
0f867abe 1432 (bfd *, sec_ptr, const void *, file_ptr, bfd_size_type);
dc810e39 1433extern long _bfd_elf_get_symtab_upper_bound
c39a58e6 1434 (bfd *);
6cee3f79 1435extern long _bfd_elf_canonicalize_symtab
c39a58e6 1436 (bfd *, asymbol **);
dc810e39 1437extern long _bfd_elf_get_dynamic_symtab_upper_bound
c39a58e6 1438 (bfd *);
dc810e39 1439extern long _bfd_elf_canonicalize_dynamic_symtab
c39a58e6 1440 (bfd *, asymbol **);
4c45e5c9 1441extern long _bfd_elf_get_synthetic_symtab
c9727e01 1442 (bfd *, long, asymbol **, long, asymbol **, asymbol **);
dc810e39 1443extern long _bfd_elf_get_reloc_upper_bound
c39a58e6 1444 (bfd *, sec_ptr);
dc810e39 1445extern long _bfd_elf_canonicalize_reloc
c39a58e6 1446 (bfd *, sec_ptr, arelent **, asymbol **);
dc810e39 1447extern long _bfd_elf_get_dynamic_reloc_upper_bound
c39a58e6 1448 (bfd *);
dc810e39 1449extern long _bfd_elf_canonicalize_dynamic_reloc
c39a58e6 1450 (bfd *, arelent **, asymbol **);
dc810e39 1451extern asymbol *_bfd_elf_make_empty_symbol
c39a58e6 1452 (bfd *);
dc810e39 1453extern void _bfd_elf_get_symbol_info
c39a58e6 1454 (bfd *, asymbol *, symbol_info *);
b34976b6 1455extern bfd_boolean _bfd_elf_is_local_label_name
c39a58e6 1456 (bfd *, const char *);
dc810e39 1457extern alent *_bfd_elf_get_lineno
c39a58e6 1458 (bfd *, asymbol *);
b34976b6 1459extern bfd_boolean _bfd_elf_set_arch_mach
c39a58e6 1460 (bfd *, enum bfd_architecture, unsigned long);
b34976b6 1461extern bfd_boolean _bfd_elf_find_nearest_line
c39a58e6
AM
1462 (bfd *, asection *, asymbol **, bfd_vma, const char **, const char **,
1463 unsigned int *);
252b5132
RH
1464#define _bfd_elf_read_minisymbols _bfd_generic_read_minisymbols
1465#define _bfd_elf_minisymbol_to_symbol _bfd_generic_minisymbol_to_symbol
dc810e39 1466extern int _bfd_elf_sizeof_headers
c39a58e6 1467 (bfd *, bfd_boolean);
b34976b6 1468extern bfd_boolean _bfd_elf_new_section_hook
c39a58e6 1469 (bfd *, asection *);
b34976b6 1470extern bfd_boolean _bfd_elf_init_reloc_shdr
c39a58e6 1471 (bfd *, Elf_Internal_Shdr *, asection *, bfd_boolean);
7dcb9820
AM
1472extern const struct bfd_elf_special_section *_bfd_elf_get_sec_type_attr
1473 (bfd *, const char *);
252b5132
RH
1474
1475/* If the target doesn't have reloc handling written yet: */
dc810e39 1476extern void _bfd_elf_no_info_to_howto
c39a58e6 1477 (bfd *, arelent *, Elf_Internal_Rela *);
dc810e39 1478
b34976b6 1479extern bfd_boolean bfd_section_from_shdr
c39a58e6 1480 (bfd *, unsigned int shindex);
b34976b6 1481extern bfd_boolean bfd_section_from_phdr
c39a58e6 1482 (bfd *, Elf_Internal_Phdr *, int);
dc810e39
AM
1483
1484extern int _bfd_elf_symbol_from_bfd_symbol
c39a58e6 1485 (bfd *, asymbol **);
dc810e39 1486
ec338859 1487extern asection *bfd_section_from_r_symndx
c39a58e6 1488 (bfd *, struct sym_sec_cache *, asection *, unsigned long);
dc810e39 1489extern asection *bfd_section_from_elf_index
c39a58e6 1490 (bfd *, unsigned int);
dc810e39 1491extern struct bfd_strtab_hash *_bfd_elf_stringtab_init
c39a58e6 1492 (void);
2b0f7ef9
JJ
1493
1494extern struct elf_strtab_hash * _bfd_elf_strtab_init
c39a58e6 1495 (void);
2b0f7ef9 1496extern void _bfd_elf_strtab_free
c39a58e6 1497 (struct elf_strtab_hash *);
2b0f7ef9 1498extern bfd_size_type _bfd_elf_strtab_add
c39a58e6 1499 (struct elf_strtab_hash *, const char *, bfd_boolean);
2b0f7ef9 1500extern void _bfd_elf_strtab_addref
c39a58e6 1501 (struct elf_strtab_hash *, bfd_size_type);
2b0f7ef9 1502extern void _bfd_elf_strtab_delref
c39a58e6 1503 (struct elf_strtab_hash *, bfd_size_type);
2b0f7ef9 1504extern void _bfd_elf_strtab_clear_all_refs
c39a58e6 1505 (struct elf_strtab_hash *);
2b0f7ef9 1506extern bfd_size_type _bfd_elf_strtab_size
c39a58e6 1507 (struct elf_strtab_hash *);
2b0f7ef9 1508extern bfd_size_type _bfd_elf_strtab_offset
c39a58e6 1509 (struct elf_strtab_hash *, bfd_size_type);
b34976b6 1510extern bfd_boolean _bfd_elf_strtab_emit
c39a58e6 1511 (bfd *, struct elf_strtab_hash *);
2b0f7ef9 1512extern void _bfd_elf_strtab_finalize
c39a58e6 1513 (struct elf_strtab_hash *);
2b0f7ef9 1514
b34976b6 1515extern bfd_boolean _bfd_elf_discard_section_eh_frame
c39a58e6
AM
1516 (bfd *, struct bfd_link_info *, asection *,
1517 bfd_boolean (*) (bfd_vma, void *), struct elf_reloc_cookie *);
b34976b6 1518extern bfd_boolean _bfd_elf_discard_section_eh_frame_hdr
c39a58e6 1519 (bfd *, struct bfd_link_info *);
65765700 1520extern bfd_vma _bfd_elf_eh_frame_section_offset
c39a58e6 1521 (bfd *, asection *, bfd_vma);
b34976b6 1522extern bfd_boolean _bfd_elf_write_section_eh_frame
c39a58e6 1523 (bfd *, struct bfd_link_info *, asection *, bfd_byte *);
b34976b6 1524extern bfd_boolean _bfd_elf_write_section_eh_frame_hdr
c39a58e6 1525 (bfd *, struct bfd_link_info *);
b34976b6 1526extern bfd_boolean _bfd_elf_maybe_strip_eh_frame_hdr
c39a58e6 1527 (struct bfd_link_info *);
65765700 1528
45d6a902 1529extern bfd_boolean _bfd_elf_merge_symbol
c39a58e6
AM
1530 (bfd *, struct bfd_link_info *, const char *, Elf_Internal_Sym *,
1531 asection **, bfd_vma *, struct elf_link_hash_entry **, bfd_boolean *,
0f8a2703 1532 bfd_boolean *, bfd_boolean *, bfd_boolean *);
45d6a902
AM
1533
1534extern bfd_boolean _bfd_elf_add_default_symbol
c39a58e6
AM
1535 (bfd *, struct bfd_link_info *, struct elf_link_hash_entry *,
1536 const char *, Elf_Internal_Sym *, asection **, bfd_vma *,
0f8a2703 1537 bfd_boolean *, bfd_boolean);
45d6a902
AM
1538
1539extern bfd_boolean _bfd_elf_export_symbol
c39a58e6 1540 (struct elf_link_hash_entry *, void *);
45d6a902
AM
1541
1542extern bfd_boolean _bfd_elf_link_find_version_dependencies
c39a58e6 1543 (struct elf_link_hash_entry *, void *);
45d6a902
AM
1544
1545extern bfd_boolean _bfd_elf_link_assign_sym_version
c39a58e6 1546 (struct elf_link_hash_entry *, void *);
45d6a902 1547
dc810e39 1548extern long _bfd_elf_link_lookup_local_dynindx
c39a58e6 1549 (struct bfd_link_info *, bfd *, long);
b34976b6 1550extern bfd_boolean _bfd_elf_compute_section_file_positions
c39a58e6 1551 (bfd *, struct bfd_link_info *);
dc810e39 1552extern void _bfd_elf_assign_file_positions_for_relocs
c39a58e6 1553 (bfd *);
dc810e39 1554extern file_ptr _bfd_elf_assign_file_position_for_section
c39a58e6 1555 (Elf_Internal_Shdr *, file_ptr, bfd_boolean);
dc810e39 1556
b34976b6 1557extern bfd_boolean _bfd_elf_validate_reloc
c39a58e6 1558 (bfd *, arelent *);
dc810e39 1559
45d6a902 1560extern bfd_boolean _bfd_elf_link_create_dynamic_sections
c39a58e6 1561 (bfd *, struct bfd_link_info *);
aee6f5b4
AO
1562extern bfd_boolean _bfd_elf_link_omit_section_dynsym
1563 (bfd *, struct bfd_link_info *, asection *);
b34976b6 1564extern bfd_boolean _bfd_elf_create_dynamic_sections
c39a58e6 1565 (bfd *, struct bfd_link_info *);
b34976b6 1566extern bfd_boolean _bfd_elf_create_got_section
c39a58e6 1567 (bfd *, struct bfd_link_info *);
dc810e39 1568extern unsigned long _bfd_elf_link_renumber_dynsyms
c39a58e6 1569 (bfd *, struct bfd_link_info *);
dc810e39 1570
b34976b6 1571extern bfd_boolean _bfd_elfcore_make_pseudosection
c39a58e6 1572 (bfd *, char *, size_t, ufile_ptr);
dc810e39 1573extern char *_bfd_elfcore_strndup
c39a58e6 1574 (bfd *, char *, size_t);
dc810e39 1575
45d6a902 1576extern Elf_Internal_Rela *_bfd_elf_link_read_relocs
c39a58e6 1577 (bfd *, asection *, void *, Elf_Internal_Rela *, bfd_boolean);
45d6a902
AM
1578
1579extern bfd_boolean _bfd_elf_link_size_reloc_section
c39a58e6 1580 (bfd *, Elf_Internal_Shdr *, asection *);
45d6a902
AM
1581
1582extern bfd_boolean _bfd_elf_link_output_relocs
c39a58e6 1583 (bfd *, asection *, Elf_Internal_Shdr *, Elf_Internal_Rela *);
45d6a902
AM
1584
1585extern bfd_boolean _bfd_elf_fix_symbol_flags
c39a58e6 1586 (struct elf_link_hash_entry *, struct elf_info_failed *);
45d6a902
AM
1587
1588extern bfd_boolean _bfd_elf_adjust_dynamic_symbol
c39a58e6 1589 (struct elf_link_hash_entry *, void *);
45d6a902
AM
1590
1591extern bfd_boolean _bfd_elf_link_sec_merge_syms
c39a58e6 1592 (struct elf_link_hash_entry *, void *);
45d6a902 1593
986a241f 1594extern bfd_boolean _bfd_elf_dynamic_symbol_p
c39a58e6 1595 (struct elf_link_hash_entry *, struct bfd_link_info *, bfd_boolean);
f6c52c13
AM
1596
1597extern bfd_boolean _bfd_elf_symbol_refs_local_p
c39a58e6 1598 (struct elf_link_hash_entry *, struct bfd_link_info *, bfd_boolean);
986a241f 1599
3d7f7666
L
1600extern bfd_boolean bfd_elf_match_symbols_in_sections
1601 (asection *sec1, asection *sec2);
1602
1603extern bfd_boolean _bfd_elf_setup_group_pointers
1604 (bfd *);
1605
dc810e39 1606extern const bfd_target *bfd_elf32_object_p
c39a58e6 1607 (bfd *);
dc810e39 1608extern const bfd_target *bfd_elf32_core_file_p
c39a58e6 1609 (bfd *);
dc810e39 1610extern char *bfd_elf32_core_file_failing_command
c39a58e6 1611 (bfd *);
dc810e39 1612extern int bfd_elf32_core_file_failing_signal
c39a58e6 1613 (bfd *);
b34976b6 1614extern bfd_boolean bfd_elf32_core_file_matches_executable_p
c39a58e6 1615 (bfd *, bfd *);
252b5132 1616
252b5132 1617extern void bfd_elf32_swap_symbol_in
c39a58e6 1618 (bfd *, const void *, const void *, Elf_Internal_Sym *);
252b5132 1619extern void bfd_elf32_swap_symbol_out
c39a58e6 1620 (bfd *, const Elf_Internal_Sym *, void *, void *);
252b5132 1621extern void bfd_elf32_swap_reloc_in
c39a58e6 1622 (bfd *, const bfd_byte *, Elf_Internal_Rela *);
252b5132 1623extern void bfd_elf32_swap_reloc_out
c39a58e6 1624 (bfd *, const Elf_Internal_Rela *, bfd_byte *);
252b5132 1625extern void bfd_elf32_swap_reloca_in
c39a58e6 1626 (bfd *, const bfd_byte *, Elf_Internal_Rela *);
252b5132 1627extern void bfd_elf32_swap_reloca_out
c39a58e6 1628 (bfd *, const Elf_Internal_Rela *, bfd_byte *);
252b5132 1629extern void bfd_elf32_swap_phdr_in
c39a58e6 1630 (bfd *, const Elf32_External_Phdr *, Elf_Internal_Phdr *);
252b5132 1631extern void bfd_elf32_swap_phdr_out
c39a58e6 1632 (bfd *, const Elf_Internal_Phdr *, Elf32_External_Phdr *);
252b5132 1633extern void bfd_elf32_swap_dyn_in
c39a58e6 1634 (bfd *, const void *, Elf_Internal_Dyn *);
252b5132 1635extern void bfd_elf32_swap_dyn_out
c39a58e6 1636 (bfd *, const Elf_Internal_Dyn *, void *);
252b5132 1637extern long bfd_elf32_slurp_symbol_table
c39a58e6 1638 (bfd *, asymbol **, bfd_boolean);
b34976b6 1639extern bfd_boolean bfd_elf32_write_shdrs_and_ehdr
c39a58e6 1640 (bfd *);
252b5132 1641extern int bfd_elf32_write_out_phdrs
c39a58e6 1642 (bfd *, const Elf_Internal_Phdr *, unsigned int);
b9f66672 1643extern void bfd_elf32_write_relocs
c39a58e6 1644 (bfd *, asection *, void *);
b34976b6 1645extern bfd_boolean bfd_elf32_slurp_reloc_table
c39a58e6 1646 (bfd *, asection *, asymbol **, bfd_boolean);
252b5132 1647
dc810e39 1648extern const bfd_target *bfd_elf64_object_p
c39a58e6 1649 (bfd *);
dc810e39 1650extern const bfd_target *bfd_elf64_core_file_p
c39a58e6 1651 (bfd *);
dc810e39 1652extern char *bfd_elf64_core_file_failing_command
c39a58e6 1653 (bfd *);
dc810e39 1654extern int bfd_elf64_core_file_failing_signal
c39a58e6 1655 (bfd *);
b34976b6 1656extern bfd_boolean bfd_elf64_core_file_matches_executable_p
c39a58e6 1657 (bfd *, bfd *);
252b5132
RH
1658
1659extern void bfd_elf64_swap_symbol_in
c39a58e6 1660 (bfd *, const void *, const void *, Elf_Internal_Sym *);
252b5132 1661extern void bfd_elf64_swap_symbol_out
c39a58e6 1662 (bfd *, const Elf_Internal_Sym *, void *, void *);
252b5132 1663extern void bfd_elf64_swap_reloc_in
c39a58e6 1664 (bfd *, const bfd_byte *, Elf_Internal_Rela *);
252b5132 1665extern void bfd_elf64_swap_reloc_out
c39a58e6 1666 (bfd *, const Elf_Internal_Rela *, bfd_byte *);
252b5132 1667extern void bfd_elf64_swap_reloca_in
c39a58e6 1668 (bfd *, const bfd_byte *, Elf_Internal_Rela *);
252b5132 1669extern void bfd_elf64_swap_reloca_out
c39a58e6 1670 (bfd *, const Elf_Internal_Rela *, bfd_byte *);
252b5132 1671extern void bfd_elf64_swap_phdr_in
c39a58e6 1672 (bfd *, const Elf64_External_Phdr *, Elf_Internal_Phdr *);
252b5132 1673extern void bfd_elf64_swap_phdr_out
c39a58e6 1674 (bfd *, const Elf_Internal_Phdr *, Elf64_External_Phdr *);
252b5132 1675extern void bfd_elf64_swap_dyn_in
c39a58e6 1676 (bfd *, const void *, Elf_Internal_Dyn *);
252b5132 1677extern void bfd_elf64_swap_dyn_out
c39a58e6 1678 (bfd *, const Elf_Internal_Dyn *, void *);
252b5132 1679extern long bfd_elf64_slurp_symbol_table
c39a58e6 1680 (bfd *, asymbol **, bfd_boolean);
b34976b6 1681extern bfd_boolean bfd_elf64_write_shdrs_and_ehdr
c39a58e6 1682 (bfd *);
252b5132 1683extern int bfd_elf64_write_out_phdrs
c39a58e6 1684 (bfd *, const Elf_Internal_Phdr *, unsigned int);
b9f66672 1685extern void bfd_elf64_write_relocs
c39a58e6 1686 (bfd *, asection *, void *);
b34976b6 1687extern bfd_boolean bfd_elf64_slurp_reloc_table
c39a58e6 1688 (bfd *, asection *, asymbol **, bfd_boolean);
5a580b3a 1689
8387904d
AM
1690extern struct elf_link_hash_entry *_bfd_elf_archive_symbol_lookup
1691 (bfd *, struct bfd_link_info *, const char *);
4ad4eba5
AM
1692extern bfd_boolean bfd_elf_link_add_symbols
1693 (bfd *, struct bfd_link_info *);
5a580b3a 1694extern bfd_boolean _bfd_elf_add_dynamic_entry
c39a58e6 1695 (struct bfd_link_info *, bfd_vma, bfd_vma);
252b5132 1696
c152c796
AM
1697extern bfd_boolean bfd_elf_link_record_dynamic_symbol
1698 (struct bfd_link_info *, struct elf_link_hash_entry *);
30b30c21 1699
c152c796 1700extern int bfd_elf_link_record_local_dynamic_symbol
c39a58e6 1701 (struct bfd_link_info *, bfd *, long);
252b5132 1702
b34976b6 1703extern bfd_boolean _bfd_elf_close_and_cleanup
c39a58e6 1704 (bfd *);
252b5132 1705extern bfd_reloc_status_type _bfd_elf_rel_vtable_reloc_fn
fc0a2244 1706 (bfd *, arelent *, struct bfd_symbol *, void *,
c39a58e6 1707 asection *, bfd *, char **);
252b5132 1708
c152c796 1709extern bfd_boolean bfd_elf_final_link
c39a58e6 1710 (bfd *, struct bfd_link_info *);
c152c796
AM
1711
1712extern bfd_boolean bfd_elf_gc_sections
c39a58e6 1713 (bfd *, struct bfd_link_info *);
c152c796
AM
1714
1715extern bfd_boolean bfd_elf_gc_record_vtinherit
c39a58e6 1716 (bfd *, asection *, struct elf_link_hash_entry *, bfd_vma);
c152c796
AM
1717
1718extern bfd_boolean bfd_elf_gc_record_vtentry
c39a58e6 1719 (bfd *, asection *, struct elf_link_hash_entry *, bfd_vma);
252b5132 1720
ccfa59ea
AM
1721extern bfd_boolean _bfd_elf_gc_mark
1722 (struct bfd_link_info *, asection *,
1723 asection * (*) (asection *, struct bfd_link_info *, Elf_Internal_Rela *,
1724 struct elf_link_hash_entry *, Elf_Internal_Sym *));
1725
c152c796 1726extern bfd_boolean bfd_elf_gc_common_finalize_got_offsets
c39a58e6 1727 (bfd *, struct bfd_link_info *);
c152c796
AM
1728
1729extern bfd_boolean bfd_elf_gc_common_final_link
c39a58e6 1730 (bfd *, struct bfd_link_info *);
252b5132 1731
c152c796 1732extern bfd_boolean bfd_elf_reloc_symbol_deleted_p
c39a58e6 1733 (bfd_vma, void *);
73d074b4 1734
229fcec5
MM
1735extern struct elf_segment_map *
1736_bfd_elf_make_dynamic_segment
1737 (bfd *, asection *);
1738
7c76fa91 1739/* Exported interface for writing elf corefile notes. */
d4c88bbb 1740extern char *elfcore_write_note
c39a58e6 1741 (bfd *, char *, int *, const char *, int, const void *, int);
d4c88bbb 1742extern char *elfcore_write_prpsinfo
c39a58e6 1743 (bfd *, char *, int *, const char *, const char *);
d4c88bbb 1744extern char *elfcore_write_prstatus
c39a58e6 1745 (bfd *, char *, int *, long, int, const void *);
d4c88bbb 1746extern char * elfcore_write_pstatus
c39a58e6 1747 (bfd *, char *, int *, long, int, const void *);
d4c88bbb 1748extern char *elfcore_write_prfpreg
c39a58e6 1749 (bfd *, char *, int *, const void *, int);
d4c88bbb 1750extern char *elfcore_write_prxfpreg
c39a58e6 1751 (bfd *, char *, int *, const void *, int);
d4c88bbb 1752extern char *elfcore_write_lwpstatus
c39a58e6 1753 (bfd *, char *, int *, long, int, const void *);
7c76fa91 1754
8d6337fe 1755extern bfd *_bfd_elf32_bfd_from_remote_memory
c39a58e6
AM
1756 (bfd *templ, bfd_vma ehdr_vma, bfd_vma *loadbasep,
1757 int (*target_read_memory) (bfd_vma, char *, int));
8d6337fe 1758extern bfd *_bfd_elf64_bfd_from_remote_memory
c39a58e6
AM
1759 (bfd *templ, bfd_vma ehdr_vma, bfd_vma *loadbasep,
1760 int (*target_read_memory) (bfd_vma, char *, int));
8d6337fe 1761
d4845d57
JR
1762/* SH ELF specific routine. */
1763
b34976b6 1764extern bfd_boolean _sh_elf_set_mach_from_flags
c39a58e6 1765 (bfd *);
d4845d57 1766
c152c796
AM
1767/* This is the condition under which finish_dynamic_symbol will be called.
1768 If our finish_dynamic_symbol isn't called, we'll need to do something
1769 about initializing any .plt and .got entries in relocate_section. */
1770#define WILL_CALL_FINISH_DYNAMIC_SYMBOL(DYN, SHARED, H) \
1771 ((DYN) \
f5385ebf
AM
1772 && ((SHARED) || !(H)->forced_local) \
1773 && ((H)->dynindx != -1 || (H)->forced_local))
c152c796 1774
560e09e9
NC
1775/* This macro is to avoid lots of duplicated code in the body
1776 of xxx_relocate_section() in the various elfxx-xxxx.c files. */
b2a8e766
AM
1777#define RELOC_FOR_GLOBAL_SYMBOL(info, input_bfd, input_section, rel, \
1778 r_symndx, symtab_hdr, sym_hashes, \
1779 h, sec, relocation, \
1780 unresolved_reloc, warned) \
1781 do \
1782 { \
1783 /* It seems this can happen with erroneous or unsupported \
1784 input (mixing a.out and elf in an archive, for example.) */ \
1785 if (sym_hashes == NULL) \
1786 return FALSE; \
1787 \
1788 h = sym_hashes[r_symndx - symtab_hdr->sh_info]; \
1789 \
1790 while (h->root.type == bfd_link_hash_indirect \
1791 || h->root.type == bfd_link_hash_warning) \
1792 h = (struct elf_link_hash_entry *) h->root.u.i.link; \
1793 \
1794 warned = FALSE; \
1795 unresolved_reloc = FALSE; \
1796 relocation = 0; \
1797 if (h->root.type == bfd_link_hash_defined \
1798 || h->root.type == bfd_link_hash_defweak) \
1799 { \
1800 sec = h->root.u.def.section; \
1801 if (sec == NULL \
1802 || sec->output_section == NULL) \
1803 /* Set a flag that will be cleared later if we find a \
1804 relocation value for this symbol. output_section \
1805 is typically NULL for symbols satisfied by a shared \
1806 library. */ \
1807 unresolved_reloc = TRUE; \
1808 else \
1809 relocation = (h->root.u.def.value \
1810 + sec->output_section->vma \
1811 + sec->output_offset); \
1812 } \
1813 else if (h->root.type == bfd_link_hash_undefweak) \
1814 ; \
1815 else if (info->unresolved_syms_in_objects == RM_IGNORE \
1816 && ELF_ST_VISIBILITY (h->other) == STV_DEFAULT) \
1817 ; \
1818 else \
1819 { \
5a580b3a
AM
1820 bfd_boolean err; \
1821 err = (info->unresolved_syms_in_objects == RM_GENERATE_ERROR \
1822 || ELF_ST_VISIBILITY (h->other) != STV_DEFAULT); \
1823 if (!info->callbacks->undefined_symbol (info, \
1824 h->root.root.string, \
1825 input_bfd, \
1826 input_section, \
1827 rel->r_offset, err)) \
b2a8e766
AM
1828 return FALSE; \
1829 warned = TRUE; \
1830 } \
1831 } \
560e09e9
NC
1832 while (0)
1833
252b5132 1834#endif /* _LIBELF_H_ */
This page took 0.430815 seconds and 4 git commands to generate.