merge from gcc
[deliverable/binutils-gdb.git] / bfd / libbfd-in.h
CommitLineData
252b5132
RH
1/* libbfd.h -- Declarations used by bfd library *implementation*.
2 (This include file is not for users of the library.)
7c192733
AC
3
4 Copyright 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
72f6ea61 5 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007
f075ee0c 6 Free Software Foundation, Inc.
7c192733 7
252b5132
RH
8 Written by Cygnus Support.
9
cd123cb7
NC
10 This file is part of BFD, the Binary File Descriptor library.
11
12 This program is free software; you can redistribute it and/or modify
13 it under the terms of the GNU General Public License as published by
14 the Free Software Foundation; either version 3 of the License, or
15 (at your option) any later version.
16
17 This program is distributed in the hope that it will be useful,
18 but WITHOUT ANY WARRANTY; without even the implied warranty of
19 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 GNU General Public License for more details.
21
22 You should have received a copy of the GNU General Public License
23 along with this program; if not, write to the Free Software
24 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
25 MA 02110-1301, USA. */
252b5132 26
109f7096
BE
27#include "hashtab.h"
28
252b5132
RH
29/* Align an address upward to a boundary, expressed as a number of bytes.
30 E.g. align to an 8-byte boundary with argument of 8. Take care never
31 to wrap around if the address is within boundary-1 of the end of the
32 address space. */
dc810e39
AM
33#define BFD_ALIGN(this, boundary) \
34 ((((bfd_vma) (this) + (boundary) - 1) >= (bfd_vma) (this)) \
35 ? (((bfd_vma) (this) + ((boundary) - 1)) & ~ (bfd_vma) ((boundary)-1)) \
252b5132
RH
36 : ~ (bfd_vma) 0)
37
38/* If you want to read and write large blocks, you might want to do it
39 in quanta of this amount */
40#define DEFAULT_BUFFERSIZE 8192
41
42/* Set a tdata field. Can't use the other macros for this, since they
43 do casts, and casting to the left of assignment isn't portable. */
c58b9523 44#define set_tdata(bfd, v) ((bfd)->tdata.any = (v))
252b5132
RH
45
46/* If BFD_IN_MEMORY is set for a BFD, then the iostream fields points
47 to an instance of this structure. */
48
49struct bfd_in_memory
50{
51 /* Size of buffer. */
52 bfd_size_type size;
53 /* Buffer holding contents of BFD. */
54 bfd_byte *buffer;
55};
56
66eb6687
AM
57struct section_hash_entry
58{
59 struct bfd_hash_entry root;
60 asection section;
61};
62
252b5132
RH
63/* tdata for an archive. For an input archive, cache
64 needs to be free()'d. For an output archive, symdefs do. */
65
66struct artdata {
67 file_ptr first_file_filepos;
68 /* Speed up searching the armap */
109f7096 69 htab_t cache;
52b219b5 70 bfd *archive_head; /* Only interesting in output routines */
252b5132 71 carsym *symdefs; /* the symdef entries */
52b219b5 72 symindex symdef_count; /* how many there are */
252b5132 73 char *extended_names; /* clever intel extension */
9e492e05 74 bfd_size_type extended_names_size; /* Size of extended names */
252b5132
RH
75 /* when more compilers are standard C, this can be a time_t */
76 long armap_timestamp; /* Timestamp value written into armap.
77 This is used for BSD archives to check
78 that the timestamp is recent enough
79 for the BSD linker to not complain,
80 just before we finish writing an
81 archive. */
82 file_ptr armap_datepos; /* Position within archive to seek to
83 rewrite the date field. */
c58b9523 84 void *tdata; /* Backend specific information. */
252b5132
RH
85};
86
87#define bfd_ardata(bfd) ((bfd)->tdata.aout_ar_data)
88
89/* Goes in bfd's arelt_data slot */
90struct areltdata {
52b219b5
AM
91 char * arch_header; /* it's actually a string */
92 unsigned int parsed_size; /* octets of filesize not including ar_hdr */
93 char *filename; /* null-terminated */
252b5132
RH
94};
95
96#define arelt_size(bfd) (((struct areltdata *)((bfd)->arelt_data))->parsed_size)
97
c58b9523
AM
98extern void *bfd_malloc
99 (bfd_size_type);
100extern void *bfd_realloc
101 (void *, bfd_size_type);
515ef31d
NC
102extern void *bfd_realloc_or_free
103 (void *, bfd_size_type);
c58b9523
AM
104extern void *bfd_zmalloc
105 (bfd_size_type);
d0fb9a8d
JJ
106extern void *bfd_malloc2
107 (bfd_size_type, bfd_size_type);
108extern void *bfd_realloc2
109 (void *, bfd_size_type, bfd_size_type);
110extern void *bfd_zmalloc2
111 (bfd_size_type, bfd_size_type);
252b5132 112
185d09ad 113extern void _bfd_default_error_handler (const char *s, ...);
252b5132
RH
114extern bfd_error_handler_type _bfd_error_handler;
115
116/* These routines allocate and free things on the BFD's objalloc. */
117
c58b9523
AM
118extern void *bfd_alloc
119 (bfd *, bfd_size_type);
120extern void *bfd_zalloc
121 (bfd *, bfd_size_type);
d0fb9a8d
JJ
122extern void *bfd_alloc2
123 (bfd *, bfd_size_type, bfd_size_type);
124extern void *bfd_zalloc2
125 (bfd *, bfd_size_type, bfd_size_type);
b34976b6 126extern void bfd_release
c58b9523 127 (bfd *, void *);
b34976b6
AM
128
129bfd * _bfd_create_empty_archive_element_shell
c58b9523 130 (bfd *obfd);
b34976b6 131bfd * _bfd_look_for_bfd_in_cache
c58b9523 132 (bfd *, file_ptr);
b34976b6 133bfd_boolean _bfd_add_bfd_to_archive_cache
c58b9523 134 (bfd *, file_ptr, bfd *);
b34976b6 135bfd_boolean _bfd_generic_mkarchive
c58b9523 136 (bfd *abfd);
b34976b6 137const bfd_target *bfd_generic_archive_p
c58b9523 138 (bfd *abfd);
b34976b6 139bfd_boolean bfd_slurp_armap
c58b9523 140 (bfd *abfd);
b34976b6 141bfd_boolean bfd_slurp_bsd_armap_f2
c58b9523 142 (bfd *abfd);
252b5132
RH
143#define bfd_slurp_bsd_armap bfd_slurp_armap
144#define bfd_slurp_coff_armap bfd_slurp_armap
b34976b6 145bfd_boolean _bfd_slurp_extended_name_table
c58b9523 146 (bfd *abfd);
b34976b6 147extern bfd_boolean _bfd_construct_extended_name_table
c58b9523 148 (bfd *, bfd_boolean, char **, bfd_size_type *);
b34976b6 149bfd_boolean _bfd_write_archive_contents
c58b9523 150 (bfd *abfd);
b34976b6 151bfd_boolean _bfd_compute_and_write_armap
c58b9523 152 (bfd *, unsigned int elength);
b34976b6 153bfd *_bfd_get_elt_at_filepos
c58b9523 154 (bfd *archive, file_ptr filepos);
b34976b6 155extern bfd *_bfd_generic_get_elt_at_index
c58b9523 156 (bfd *, symindex);
b34976b6 157bfd * _bfd_new_bfd
c58b9523 158 (void);
b34976b6 159void _bfd_delete_bfd
c58b9523 160 (bfd *);
b25e3d87
L
161bfd_boolean _bfd_free_cached_info
162 (bfd *);
b34976b6
AM
163
164bfd_boolean bfd_false
c58b9523 165 (bfd *ignore);
b34976b6 166bfd_boolean bfd_true
c58b9523
AM
167 (bfd *ignore);
168void *bfd_nullvoidptr
169 (bfd *ignore);
b34976b6 170int bfd_0
c58b9523 171 (bfd *ignore);
b34976b6 172unsigned int bfd_0u
c58b9523 173 (bfd *ignore);
b34976b6 174long bfd_0l
c58b9523 175 (bfd *ignore);
b34976b6 176long _bfd_n1
c58b9523 177 (bfd *ignore);
b34976b6 178void bfd_void
c58b9523 179 (bfd *ignore);
b34976b6
AM
180
181bfd *_bfd_new_bfd_contained_in
c58b9523 182 (bfd *);
b34976b6 183const bfd_target *_bfd_dummy_target
c58b9523 184 (bfd *abfd);
b34976b6
AM
185
186void bfd_dont_truncate_arname
c58b9523 187 (bfd *abfd, const char *filename, char *hdr);
b34976b6 188void bfd_bsd_truncate_arname
c58b9523 189 (bfd *abfd, const char *filename, char *hdr);
b34976b6 190void bfd_gnu_truncate_arname
c58b9523 191 (bfd *abfd, const char *filename, char *hdr);
b34976b6
AM
192
193bfd_boolean bsd_write_armap
c58b9523
AM
194 (bfd *arch, unsigned int elength, struct orl *map, unsigned int orl_count,
195 int stridx);
b34976b6
AM
196
197bfd_boolean coff_write_armap
c58b9523
AM
198 (bfd *arch, unsigned int elength, struct orl *map, unsigned int orl_count,
199 int stridx);
b34976b6 200
c58b9523
AM
201extern void *_bfd_generic_read_ar_hdr
202 (bfd *);
390c0e42
JJ
203extern void _bfd_ar_spacepad
204 (char *, size_t, const char *, long);
b34976b6 205
c58b9523
AM
206extern void *_bfd_generic_read_ar_hdr_mag
207 (bfd *, const char *);
b34976b6
AM
208
209bfd * bfd_generic_openr_next_archived_file
c58b9523 210 (bfd *archive, bfd *last_file);
b34976b6
AM
211
212int bfd_generic_stat_arch_elt
c58b9523 213 (bfd *, struct stat *);
252b5132
RH
214
215#define _bfd_read_ar_hdr(abfd) \
216 BFD_SEND (abfd, _bfd_read_ar_hdr_fn, (abfd))
217\f
218/* Generic routines to use for BFD_JUMP_TABLE_GENERIC. Use
219 BFD_JUMP_TABLE_GENERIC (_bfd_generic). */
220
221#define _bfd_generic_close_and_cleanup bfd_true
222#define _bfd_generic_bfd_free_cached_info bfd_true
f592407e
AM
223extern bfd_boolean _bfd_generic_new_section_hook
224 (bfd *, asection *);
b34976b6 225extern bfd_boolean _bfd_generic_get_section_contents
c58b9523 226 (bfd *, asection *, void *, file_ptr, bfd_size_type);
b34976b6 227extern bfd_boolean _bfd_generic_get_section_contents_in_window
c58b9523 228 (bfd *, asection *, bfd_window *, file_ptr, bfd_size_type);
252b5132
RH
229
230/* Generic routines to use for BFD_JUMP_TABLE_COPY. Use
231 BFD_JUMP_TABLE_COPY (_bfd_generic). */
232
233#define _bfd_generic_bfd_copy_private_bfd_data \
c58b9523 234 ((bfd_boolean (*) (bfd *, bfd *)) bfd_true)
252b5132 235#define _bfd_generic_bfd_merge_private_bfd_data \
c58b9523 236 ((bfd_boolean (*) (bfd *, bfd *)) bfd_true)
252b5132 237#define _bfd_generic_bfd_set_private_flags \
c58b9523 238 ((bfd_boolean (*) (bfd *, flagword)) bfd_true)
252b5132 239#define _bfd_generic_bfd_copy_private_section_data \
c58b9523 240 ((bfd_boolean (*) (bfd *, asection *, bfd *, asection *)) bfd_true)
252b5132 241#define _bfd_generic_bfd_copy_private_symbol_data \
c58b9523 242 ((bfd_boolean (*) (bfd *, asymbol *, bfd *, asymbol *)) bfd_true)
80fccad2
BW
243#define _bfd_generic_bfd_copy_private_header_data \
244 ((bfd_boolean (*) (bfd *, bfd *)) bfd_true)
252b5132 245#define _bfd_generic_bfd_print_private_bfd_data \
c58b9523 246 ((bfd_boolean (*) (bfd *, void *)) bfd_true)
252b5132 247
ccd2ec6a
L
248extern bfd_boolean _bfd_generic_init_private_section_data
249 (bfd *, asection *, bfd *, asection *, struct bfd_link_info *);
250
252b5132
RH
251/* Routines to use for BFD_JUMP_TABLE_CORE when there is no core file
252 support. Use BFD_JUMP_TABLE_CORE (_bfd_nocore). */
253
b34976b6 254extern char *_bfd_nocore_core_file_failing_command
c58b9523 255 (bfd *);
b34976b6 256extern int _bfd_nocore_core_file_failing_signal
c58b9523 257 (bfd *);
b34976b6 258extern bfd_boolean _bfd_nocore_core_file_matches_executable_p
c58b9523 259 (bfd *, bfd *);
252b5132
RH
260
261/* Routines to use for BFD_JUMP_TABLE_ARCHIVE when there is no archive
262 file support. Use BFD_JUMP_TABLE_ARCHIVE (_bfd_noarchive). */
263
264#define _bfd_noarchive_slurp_armap bfd_false
265#define _bfd_noarchive_slurp_extended_name_table bfd_false
266#define _bfd_noarchive_construct_extended_name_table \
c58b9523 267 ((bfd_boolean (*) (bfd *, char **, bfd_size_type *, const char **)) \
252b5132
RH
268 bfd_false)
269#define _bfd_noarchive_truncate_arname \
c58b9523 270 ((void (*) (bfd *, const char *, char *)) bfd_void)
252b5132 271#define _bfd_noarchive_write_armap \
c58b9523 272 ((bfd_boolean (*) (bfd *, unsigned int, struct orl *, unsigned int, int)) \
252b5132
RH
273 bfd_false)
274#define _bfd_noarchive_read_ar_hdr bfd_nullvoidptr
275#define _bfd_noarchive_openr_next_archived_file \
c58b9523 276 ((bfd *(*) (bfd *, bfd *)) bfd_nullvoidptr)
252b5132 277#define _bfd_noarchive_get_elt_at_index \
c58b9523 278 ((bfd *(*) (bfd *, symindex)) bfd_nullvoidptr)
252b5132
RH
279#define _bfd_noarchive_generic_stat_arch_elt bfd_generic_stat_arch_elt
280#define _bfd_noarchive_update_armap_timestamp bfd_false
281
282/* Routines to use for BFD_JUMP_TABLE_ARCHIVE to get BSD style
283 archives. Use BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_bsd). */
284
285#define _bfd_archive_bsd_slurp_armap bfd_slurp_bsd_armap
286#define _bfd_archive_bsd_slurp_extended_name_table \
287 _bfd_slurp_extended_name_table
b34976b6 288extern bfd_boolean _bfd_archive_bsd_construct_extended_name_table
c58b9523 289 (bfd *, char **, bfd_size_type *, const char **);
252b5132
RH
290#define _bfd_archive_bsd_truncate_arname bfd_bsd_truncate_arname
291#define _bfd_archive_bsd_write_armap bsd_write_armap
292#define _bfd_archive_bsd_read_ar_hdr _bfd_generic_read_ar_hdr
293#define _bfd_archive_bsd_openr_next_archived_file \
294 bfd_generic_openr_next_archived_file
295#define _bfd_archive_bsd_get_elt_at_index _bfd_generic_get_elt_at_index
296#define _bfd_archive_bsd_generic_stat_arch_elt \
297 bfd_generic_stat_arch_elt
b34976b6 298extern bfd_boolean _bfd_archive_bsd_update_armap_timestamp
c58b9523 299 (bfd *);
252b5132
RH
300
301/* Routines to use for BFD_JUMP_TABLE_ARCHIVE to get COFF style
302 archives. Use BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff). */
303
304#define _bfd_archive_coff_slurp_armap bfd_slurp_coff_armap
305#define _bfd_archive_coff_slurp_extended_name_table \
306 _bfd_slurp_extended_name_table
b34976b6 307extern bfd_boolean _bfd_archive_coff_construct_extended_name_table
c58b9523 308 (bfd *, char **, bfd_size_type *, const char **);
252b5132
RH
309#define _bfd_archive_coff_truncate_arname bfd_dont_truncate_arname
310#define _bfd_archive_coff_write_armap coff_write_armap
311#define _bfd_archive_coff_read_ar_hdr _bfd_generic_read_ar_hdr
312#define _bfd_archive_coff_openr_next_archived_file \
313 bfd_generic_openr_next_archived_file
314#define _bfd_archive_coff_get_elt_at_index _bfd_generic_get_elt_at_index
315#define _bfd_archive_coff_generic_stat_arch_elt \
316 bfd_generic_stat_arch_elt
317#define _bfd_archive_coff_update_armap_timestamp bfd_true
318
319/* Routines to use for BFD_JUMP_TABLE_SYMBOLS where there is no symbol
320 support. Use BFD_JUMP_TABLE_SYMBOLS (_bfd_nosymbols). */
321
322#define _bfd_nosymbols_get_symtab_upper_bound _bfd_n1
6cee3f79 323#define _bfd_nosymbols_canonicalize_symtab \
c58b9523 324 ((long (*) (bfd *, asymbol **)) _bfd_n1)
3f3c5c34 325#define _bfd_nosymbols_make_empty_symbol _bfd_generic_make_empty_symbol
252b5132 326#define _bfd_nosymbols_print_symbol \
c58b9523 327 ((void (*) (bfd *, void *, asymbol *, bfd_print_symbol_type)) bfd_void)
252b5132 328#define _bfd_nosymbols_get_symbol_info \
c58b9523 329 ((void (*) (bfd *, asymbol *, symbol_info *)) bfd_void)
252b5132 330#define _bfd_nosymbols_bfd_is_local_label_name \
c58b9523 331 ((bfd_boolean (*) (bfd *, const char *)) bfd_false)
3c9458e9
NC
332#define _bfd_nosymbols_bfd_is_target_special_symbol \
333 ((bfd_boolean (*) (bfd *, asymbol *)) bfd_false)
252b5132 334#define _bfd_nosymbols_get_lineno \
c58b9523 335 ((alent *(*) (bfd *, asymbol *)) bfd_nullvoidptr)
252b5132 336#define _bfd_nosymbols_find_nearest_line \
c58b9523
AM
337 ((bfd_boolean (*) (bfd *, asection *, asymbol **, bfd_vma, const char **, \
338 const char **, unsigned int *)) \
252b5132 339 bfd_false)
4ab527b0
FF
340#define _bfd_nosymbols_find_inliner_info \
341 ((bfd_boolean (*) (bfd *, const char **, const char **, unsigned int *)) \
342 bfd_false)
252b5132 343#define _bfd_nosymbols_bfd_make_debug_symbol \
c58b9523 344 ((asymbol *(*) (bfd *, void *, unsigned long)) bfd_nullvoidptr)
252b5132 345#define _bfd_nosymbols_read_minisymbols \
c58b9523 346 ((long (*) (bfd *, bfd_boolean, void **, unsigned int *)) _bfd_n1)
252b5132 347#define _bfd_nosymbols_minisymbol_to_symbol \
c58b9523 348 ((asymbol *(*) (bfd *, bfd_boolean, const void *, asymbol *)) \
252b5132
RH
349 bfd_nullvoidptr)
350
351/* Routines to use for BFD_JUMP_TABLE_RELOCS when there is no reloc
352 support. Use BFD_JUMP_TABLE_RELOCS (_bfd_norelocs). */
353
72f6ea61
AM
354extern long _bfd_norelocs_get_reloc_upper_bound (bfd *, asection *);
355extern long _bfd_norelocs_canonicalize_reloc (bfd *, asection *,
356 arelent **, asymbol **);
252b5132 357#define _bfd_norelocs_bfd_reloc_type_lookup \
c58b9523 358 ((reloc_howto_type *(*) (bfd *, bfd_reloc_code_real_type)) bfd_nullvoidptr)
157090f7
AM
359#define _bfd_norelocs_bfd_reloc_name_lookup \
360 ((reloc_howto_type *(*) (bfd *, const char *)) bfd_nullvoidptr)
252b5132
RH
361
362/* Routines to use for BFD_JUMP_TABLE_WRITE for targets which may not
363 be written. Use BFD_JUMP_TABLE_WRITE (_bfd_nowrite). */
364
365#define _bfd_nowrite_set_arch_mach \
c58b9523 366 ((bfd_boolean (*) (bfd *, enum bfd_architecture, unsigned long)) \
252b5132
RH
367 bfd_false)
368#define _bfd_nowrite_set_section_contents \
0f867abe 369 ((bfd_boolean (*) (bfd *, asection *, const void *, file_ptr, bfd_size_type)) \
252b5132
RH
370 bfd_false)
371
372/* Generic routines to use for BFD_JUMP_TABLE_WRITE. Use
373 BFD_JUMP_TABLE_WRITE (_bfd_generic). */
374
375#define _bfd_generic_set_arch_mach bfd_default_set_arch_mach
b34976b6 376extern bfd_boolean _bfd_generic_set_section_contents
0f867abe 377 (bfd *, asection *, const void *, file_ptr, bfd_size_type);
252b5132
RH
378
379/* Routines to use for BFD_JUMP_TABLE_LINK for targets which do not
380 support linking. Use BFD_JUMP_TABLE_LINK (_bfd_nolink). */
381
a6b96beb
AM
382#define _bfd_nolink_sizeof_headers \
383 ((int (*) (bfd *, struct bfd_link_info *)) bfd_0)
252b5132 384#define _bfd_nolink_bfd_get_relocated_section_contents \
c58b9523
AM
385 ((bfd_byte *(*) (bfd *, struct bfd_link_info *, struct bfd_link_order *, \
386 bfd_byte *, bfd_boolean, asymbol **)) \
252b5132
RH
387 bfd_nullvoidptr)
388#define _bfd_nolink_bfd_relax_section \
b34976b6 389 ((bfd_boolean (*) \
c58b9523 390 (bfd *, asection *, struct bfd_link_info *, bfd_boolean *)) \
252b5132
RH
391 bfd_false)
392#define _bfd_nolink_bfd_gc_sections \
c58b9523 393 ((bfd_boolean (*) (bfd *, struct bfd_link_info *)) \
252b5132 394 bfd_false)
8550eb6e 395#define _bfd_nolink_bfd_merge_sections \
c58b9523 396 ((bfd_boolean (*) (bfd *, struct bfd_link_info *)) \
8550eb6e 397 bfd_false)
72adc230
AM
398#define _bfd_nolink_bfd_is_group_section \
399 ((bfd_boolean (*) (bfd *, const struct bfd_section *)) \
400 bfd_false)
e61463e1 401#define _bfd_nolink_bfd_discard_group \
198beae2 402 ((bfd_boolean (*) (bfd *, struct bfd_section *)) \
e61463e1 403 bfd_false)
252b5132 404#define _bfd_nolink_bfd_link_hash_table_create \
c58b9523 405 ((struct bfd_link_hash_table *(*) (bfd *)) bfd_nullvoidptr)
e2d34d7d 406#define _bfd_nolink_bfd_link_hash_table_free \
c58b9523 407 ((void (*) (struct bfd_link_hash_table *)) bfd_void)
252b5132 408#define _bfd_nolink_bfd_link_add_symbols \
c58b9523 409 ((bfd_boolean (*) (bfd *, struct bfd_link_info *)) bfd_false)
2d653fc7 410#define _bfd_nolink_bfd_link_just_syms \
c58b9523 411 ((void (*) (asection *, struct bfd_link_info *)) bfd_void)
252b5132 412#define _bfd_nolink_bfd_final_link \
c58b9523 413 ((bfd_boolean (*) (bfd *, struct bfd_link_info *)) bfd_false)
252b5132 414#define _bfd_nolink_bfd_link_split_section \
198beae2 415 ((bfd_boolean (*) (bfd *, struct bfd_section *)) bfd_false)
082b7297 416#define _bfd_nolink_section_already_linked \
c0f00686 417 ((void (*) (bfd *, struct bfd_section *, struct bfd_link_info *)) bfd_void)
252b5132
RH
418
419/* Routines to use for BFD_JUMP_TABLE_DYNAMIC for targets which do not
420 have dynamic symbols or relocs. Use BFD_JUMP_TABLE_DYNAMIC
421 (_bfd_nodynamic). */
422
423#define _bfd_nodynamic_get_dynamic_symtab_upper_bound _bfd_n1
424#define _bfd_nodynamic_canonicalize_dynamic_symtab \
c58b9523 425 ((long (*) (bfd *, asymbol **)) _bfd_n1)
4c45e5c9 426#define _bfd_nodynamic_get_synthetic_symtab \
c9727e01 427 ((long (*) (bfd *, long, asymbol **, long, asymbol **, asymbol **)) _bfd_n1)
252b5132
RH
428#define _bfd_nodynamic_get_dynamic_reloc_upper_bound _bfd_n1
429#define _bfd_nodynamic_canonicalize_dynamic_reloc \
c58b9523 430 ((long (*) (bfd *, arelent **, asymbol **)) _bfd_n1)
252b5132
RH
431\f
432/* Generic routine to determine of the given symbol is a local
433 label. */
b34976b6 434extern bfd_boolean bfd_generic_is_local_label_name
c58b9523 435 (bfd *, const char *);
252b5132
RH
436
437/* Generic minisymbol routines. */
438extern long _bfd_generic_read_minisymbols
c58b9523 439 (bfd *, bfd_boolean, void **, unsigned int *);
252b5132 440extern asymbol *_bfd_generic_minisymbol_to_symbol
c58b9523 441 (bfd *, bfd_boolean, const void *, asymbol *);
252b5132
RH
442
443/* Find the nearest line using .stab/.stabstr sections. */
b34976b6 444extern bfd_boolean _bfd_stab_section_find_nearest_line
c58b9523
AM
445 (bfd *, asymbol **, asection *, bfd_vma, bfd_boolean *,
446 const char **, const char **, unsigned int *, void **);
252b5132 447
2db3311b 448/* Find the nearest line using DWARF 1 debugging information. */
b34976b6 449extern bfd_boolean _bfd_dwarf1_find_nearest_line
c58b9523
AM
450 (bfd *, asection *, asymbol **, bfd_vma, const char **,
451 const char **, unsigned int *);
252b5132
RH
452
453/* Find the nearest line using DWARF 2 debugging information. */
b34976b6 454extern bfd_boolean _bfd_dwarf2_find_nearest_line
c58b9523
AM
455 (bfd *, asection *, asymbol **, bfd_vma, const char **, const char **,
456 unsigned int *, unsigned int, void **);
252b5132 457
5420f73d
L
458/* Find the line using DWARF 2 debugging information. */
459extern bfd_boolean _bfd_dwarf2_find_line
460 (bfd *, asymbol **, asymbol *, const char **,
461 unsigned int *, unsigned int, void **);
462
463bfd_boolean _bfd_generic_find_line
464 (bfd *, asymbol **, asymbol *, const char **, unsigned int *);
465
4ab527b0
FF
466/* Find inliner info after calling bfd_find_nearest_line. */
467extern bfd_boolean _bfd_dwarf2_find_inliner_info
468 (bfd *, const char **, const char **, unsigned int *, void **);
469
73e87d70
AM
470/* Create a new section entry. */
471extern struct bfd_hash_entry *bfd_section_hash_newfunc
c58b9523 472 (struct bfd_hash_entry *, struct bfd_hash_table *, const char *);
73e87d70 473
252b5132
RH
474/* A routine to create entries for a bfd_link_hash_table. */
475extern struct bfd_hash_entry *_bfd_link_hash_newfunc
c58b9523
AM
476 (struct bfd_hash_entry *entry, struct bfd_hash_table *table,
477 const char *string);
252b5132
RH
478
479/* Initialize a bfd_link_hash_table. */
b34976b6 480extern bfd_boolean _bfd_link_hash_table_init
c58b9523
AM
481 (struct bfd_link_hash_table *, bfd *,
482 struct bfd_hash_entry *(*) (struct bfd_hash_entry *,
483 struct bfd_hash_table *,
66eb6687
AM
484 const char *),
485 unsigned int);
252b5132
RH
486
487/* Generic link hash table creation routine. */
488extern struct bfd_link_hash_table *_bfd_generic_link_hash_table_create
c58b9523 489 (bfd *);
252b5132 490
e2d34d7d
DJ
491/* Generic link hash table destruction routine. */
492extern void _bfd_generic_link_hash_table_free
c58b9523 493 (struct bfd_link_hash_table *);
e2d34d7d 494
252b5132 495/* Generic add symbol routine. */
b34976b6 496extern bfd_boolean _bfd_generic_link_add_symbols
c58b9523 497 (bfd *, struct bfd_link_info *);
252b5132
RH
498
499/* Generic add symbol routine. This version is used by targets for
500 which the linker must collect constructors and destructors by name,
501 as the collect2 program does. */
b34976b6 502extern bfd_boolean _bfd_generic_link_add_symbols_collect
c58b9523 503 (bfd *, struct bfd_link_info *);
252b5132
RH
504
505/* Generic archive add symbol routine. */
b34976b6 506extern bfd_boolean _bfd_generic_link_add_archive_symbols
c58b9523
AM
507 (bfd *, struct bfd_link_info *,
508 bfd_boolean (*) (bfd *, struct bfd_link_info *, bfd_boolean *));
252b5132 509
252b5132
RH
510/* Forward declaration to avoid prototype errors. */
511typedef struct bfd_link_hash_entry _bfd_link_hash_entry;
512
513/* Generic routine to add a single symbol. */
b34976b6 514extern bfd_boolean _bfd_generic_link_add_one_symbol
c58b9523
AM
515 (struct bfd_link_info *, bfd *, const char *name, flagword,
516 asection *, bfd_vma, const char *, bfd_boolean copy,
517 bfd_boolean constructor, struct bfd_link_hash_entry **);
252b5132 518
2d653fc7
AM
519/* Generic routine to mark section as supplying symbols only. */
520extern void _bfd_generic_link_just_syms
c58b9523 521 (asection *, struct bfd_link_info *);
2d653fc7 522
252b5132 523/* Generic link routine. */
b34976b6 524extern bfd_boolean _bfd_generic_final_link
c58b9523 525 (bfd *, struct bfd_link_info *);
252b5132 526
b34976b6 527extern bfd_boolean _bfd_generic_link_split_section
198beae2 528 (bfd *, struct bfd_section *);
252b5132 529
082b7297 530extern void _bfd_generic_section_already_linked
c0f00686 531 (bfd *, struct bfd_section *, struct bfd_link_info *);
082b7297 532
252b5132 533/* Generic reloc_link_order processing routine. */
b34976b6 534extern bfd_boolean _bfd_generic_reloc_link_order
c58b9523 535 (bfd *, struct bfd_link_info *, asection *, struct bfd_link_order *);
252b5132
RH
536
537/* Default link order processing routine. */
b34976b6 538extern bfd_boolean _bfd_default_link_order
c58b9523 539 (bfd *, struct bfd_link_info *, asection *, struct bfd_link_order *);
252b5132
RH
540
541/* Count the number of reloc entries in a link order list. */
542extern unsigned int _bfd_count_link_order_relocs
c58b9523 543 (struct bfd_link_order *);
252b5132
RH
544
545/* Final link relocation routine. */
546extern bfd_reloc_status_type _bfd_final_link_relocate
c58b9523
AM
547 (reloc_howto_type *, bfd *, asection *, bfd_byte *,
548 bfd_vma, bfd_vma, bfd_vma);
252b5132
RH
549
550/* Relocate a particular location by a howto and a value. */
551extern bfd_reloc_status_type _bfd_relocate_contents
c58b9523 552 (reloc_howto_type *, bfd *, bfd_vma, bfd_byte *);
252b5132 553
b1e24c02
DJ
554/* Clear a given location using a given howto. */
555extern void _bfd_clear_contents (reloc_howto_type *howto, bfd *input_bfd,
556 bfd_byte *location);
557
252b5132
RH
558/* Link stabs in sections in the first pass. */
559
b34976b6 560extern bfd_boolean _bfd_link_section_stabs
3722b82f
AM
561 (bfd *, struct stab_info *, asection *, asection *, void **,
562 bfd_size_type *);
252b5132 563
73d074b4 564/* Eliminate stabs for discarded functions and symbols. */
b34976b6 565extern bfd_boolean _bfd_discard_section_stabs
c58b9523 566 (bfd *, asection *, void *, bfd_boolean (*) (bfd_vma, void *), void *);
73d074b4 567
252b5132
RH
568/* Write out the .stab section when linking stabs in sections. */
569
b34976b6 570extern bfd_boolean _bfd_write_section_stabs
3722b82f 571 (bfd *, struct stab_info *, asection *, void **, bfd_byte *);
252b5132
RH
572
573/* Write out the .stabstr string table when linking stabs in sections. */
574
b34976b6 575extern bfd_boolean _bfd_write_stab_strings
3722b82f 576 (bfd *, struct stab_info *);
252b5132
RH
577
578/* Find an offset within a .stab section when linking stabs in
579 sections. */
580
581extern bfd_vma _bfd_stab_section_offset
eea6121a 582 (asection *, void *, bfd_vma);
252b5132 583
57ceae94 584/* Register a SEC_MERGE section as a candidate for merging. */
f5fa8ca2 585
57ceae94 586extern bfd_boolean _bfd_add_merge_section
c58b9523 587 (bfd *, void **, asection *, void **);
f5fa8ca2 588
8550eb6e
JJ
589/* Attempt to merge SEC_MERGE sections. */
590
b34976b6 591extern bfd_boolean _bfd_merge_sections
57ceae94 592 (bfd *, struct bfd_link_info *, void *, void (*) (bfd *, asection *));
8550eb6e 593
f5fa8ca2
JJ
594/* Write out a merged section. */
595
b34976b6 596extern bfd_boolean _bfd_write_merged_section
c58b9523 597 (bfd *, asection *, void *);
f5fa8ca2
JJ
598
599/* Find an offset within a modified SEC_MERGE section. */
600
601extern bfd_vma _bfd_merged_section_offset
753731ee 602 (bfd *, asection **, void *, bfd_vma);
f5fa8ca2 603
252b5132 604/* Create a string table. */
b34976b6 605extern struct bfd_strtab_hash *_bfd_stringtab_init
c58b9523 606 (void);
252b5132
RH
607
608/* Create an XCOFF .debug section style string table. */
b34976b6 609extern struct bfd_strtab_hash *_bfd_xcoff_stringtab_init
c58b9523 610 (void);
252b5132
RH
611
612/* Free a string table. */
b34976b6 613extern void _bfd_stringtab_free
c58b9523 614 (struct bfd_strtab_hash *);
252b5132
RH
615
616/* Get the size of a string table. */
b34976b6 617extern bfd_size_type _bfd_stringtab_size
c58b9523 618 (struct bfd_strtab_hash *);
252b5132
RH
619
620/* Add a string to a string table. */
621extern bfd_size_type _bfd_stringtab_add
c58b9523 622 (struct bfd_strtab_hash *, const char *, bfd_boolean hash, bfd_boolean copy);
252b5132
RH
623
624/* Write out a string table. */
b34976b6 625extern bfd_boolean _bfd_stringtab_emit
c58b9523 626 (bfd *, struct bfd_strtab_hash *);
875f7f69
JR
627
628/* Check that endianness of input and output file match. */
b34976b6 629extern bfd_boolean _bfd_generic_verify_endian_match
c58b9523 630 (bfd *, bfd *);
252b5132
RH
631\f
632/* Macros to tell if bfds are read or write enabled.
633
634 Note that bfds open for read may be scribbled into if the fd passed
635 to bfd_fdopenr is actually open both for read and write
636 simultaneously. However an output bfd will never be open for
637 read. Therefore sometimes you want to check bfd_read_p or
638 !bfd_read_p, and only sometimes bfd_write_p.
639*/
640
c58b9523
AM
641#define bfd_read_p(abfd) \
642 ((abfd)->direction == read_direction || (abfd)->direction == both_direction)
643#define bfd_write_p(abfd) \
644 ((abfd)->direction == write_direction || (abfd)->direction == both_direction)
252b5132 645
b34976b6 646void bfd_assert
c58b9523 647 (const char*,int);
252b5132
RH
648
649#define BFD_ASSERT(x) \
f12123c0 650 do { if (!(x)) bfd_assert(__FILE__,__LINE__); } while (0)
252b5132
RH
651
652#define BFD_FAIL() \
f12123c0 653 do { bfd_assert(__FILE__,__LINE__); } while (0)
252b5132 654
b34976b6 655extern void _bfd_abort
c58b9523 656 (const char *, int, const char *) ATTRIBUTE_NORETURN;
c0bed66d 657
a1934524
AM
658/* if gcc >= 2.6, we can give a function name, too */
659#if __GNUC__ < 2 || (__GNUC__ == 2 && __GNUC_MINOR__ < 6)
c0bed66d
ILT
660#define __PRETTY_FUNCTION__ ((char *) NULL)
661#endif
662
663#undef abort
664#define abort() _bfd_abort (__FILE__, __LINE__, __PRETTY_FUNCTION__)
665
7c192733
AC
666/* Manipulate a system FILE but using BFD's "file_ptr", rather than
667 the system "off_t" or "off64_t", as the offset. */
668extern file_ptr real_ftell (FILE *file);
669extern int real_fseek (FILE *file, file_ptr offset, int whence);
2e6f4fae 670extern FILE *real_fopen (const char *filename, const char *modes);
7c192733 671
252b5132
RH
672/* List of supported target vectors, and the default vector (if
673 bfd_default_vector[0] is NULL, there is no default). */
7340082d 674extern const bfd_target * const *bfd_target_vector;
252b5132
RH
675extern const bfd_target *bfd_default_vector[];
676
08f74004
AM
677/* List of associated target vectors. */
678extern const bfd_target * const *bfd_associated_vector;
679
252b5132
RH
680/* Functions shared by the ECOFF and MIPS ELF backends, which have no
681 other common header files. */
682
683#if defined(__STDC__) || defined(ALMOST_STDC)
684struct ecoff_find_line;
685#endif
686
b34976b6 687extern bfd_boolean _bfd_ecoff_locate_line
c58b9523
AM
688 (bfd *, asection *, bfd_vma, struct ecoff_debug_info * const,
689 const struct ecoff_debug_swap * const, struct ecoff_find_line *,
690 const char **, const char **, unsigned int *);
b34976b6 691extern bfd_boolean _bfd_ecoff_get_accumulated_pdr
c58b9523 692 (void *, bfd_byte *);
b34976b6 693extern bfd_boolean _bfd_ecoff_get_accumulated_sym
c58b9523 694 (void *, bfd_byte *);
b34976b6 695extern bfd_boolean _bfd_ecoff_get_accumulated_ss
c58b9523 696 (void *, bfd_byte *);
b34976b6
AM
697
698extern bfd_vma _bfd_get_gp_value
c58b9523 699 (bfd *);
b34976b6 700extern void _bfd_set_gp_value
c58b9523 701 (bfd *, bfd_vma);
252b5132
RH
702
703/* Function shared by the COFF and ELF SH backends, which have no
704 other common header files. */
705
c58b9523 706#ifndef _bfd_sh_align_load_span
b34976b6 707extern bfd_boolean _bfd_sh_align_load_span
c58b9523
AM
708 (bfd *, asection *, bfd_byte *,
709 bfd_boolean (*) (bfd *, asection *, void *, bfd_byte *, bfd_vma),
710 void *, bfd_vma **, bfd_vma *, bfd_vma, bfd_vma, bfd_boolean *);
711#endif
082b7297
L
712
713/* This is the shape of the elements inside the already_linked hash
714 table. It maps a name onto a list of already_linked elements with
715 the same name. */
716
717struct bfd_section_already_linked_hash_entry
718{
719 struct bfd_hash_entry root;
720 struct bfd_section_already_linked *entry;
721};
722
723struct bfd_section_already_linked
724{
725 struct bfd_section_already_linked *next;
726 asection *sec;
727};
728
729extern struct bfd_section_already_linked_hash_entry *
730 bfd_section_already_linked_table_lookup (const char *);
a6626e8c 731extern bfd_boolean bfd_section_already_linked_table_insert
082b7297 732 (struct bfd_section_already_linked_hash_entry *, asection *);
3d7f7666
L
733extern void bfd_section_already_linked_table_traverse
734 (bfd_boolean (*) (struct bfd_section_already_linked_hash_entry *,
735 void *), void *);
736
f075ee0c
AM
737extern bfd_vma read_unsigned_leb128 (bfd *, bfd_byte *, unsigned int *);
738extern bfd_signed_vma read_signed_leb128 (bfd *, bfd_byte *, unsigned int *);
c0c28ab8 739
This page took 0.492361 seconds and 4 git commands to generate.